From e4104a867401e383ef2b45f4c449b8b3fa25e69b Mon Sep 17 00:00:00 2001 From: Paul Spooren Date: Thu, 29 Aug 2019 15:30:35 -1000 Subject: [PATCH] Allow custom spinner via config file Allows to set `ui.spinner=` to a string which is then split by `ui.spinner-delimiter=` (Default: comma) instead of having a hard coded animation. This implementation doesn't use INIs capabilities to split strings as it trims whitespaces breaking the default animation. Signed-off-by: Paul Spooren --- config/config.go | 5 +++++ doc/aerc-config.5.scd | 15 +++++++++++++++ widgets/dirlist.go | 2 +- widgets/msglist.go | 2 +- widgets/spinner.go | 29 ++++++++++------------------- 5 files changed, 32 insertions(+), 21 deletions(-) diff --git a/config/config.go b/config/config.go index 5736678..06caec1 100644 --- a/config/config.go +++ b/config/config.go @@ -33,6 +33,8 @@ type UIConfig struct { EmptyDirlist string `ini:"empty-dirlist"` MouseEnabled bool `ini:"mouse-enabled"` NewMessageBell bool `ini:"new-message-bell"` + Spinner string `ini:"spinner"` + SpinnerDelimiter string `ini:"spinner-delimiter"` } const ( @@ -347,6 +349,9 @@ func LoadConfigFromFile(root *string, sharedir string) (*AercConfig, error) { EmptyDirlist: "(no folders)", MouseEnabled: false, NewMessageBell: true, + Spinner: + "[..] , [..] , [..] , [..] , [..], [..] , [..] , [..] ", + SpinnerDelimiter: ",", }, Viewer: ViewerConfig{ diff --git a/doc/aerc-config.5.scd b/doc/aerc-config.5.scd index f0b9b7a..9257bde 100644 --- a/doc/aerc-config.5.scd +++ b/doc/aerc-config.5.scd @@ -110,6 +110,21 @@ These options are configured in the *[ui]* section of aerc.conf. Default: true +*spinner* + Animation shown while loading, split by spinner-delimiter (below) + + Examples: + - spinner = "\-\_-,\_-\_" + - spinner = '. , .' + - spinner = "\,|,/,-" + + Default: "[..] , [..] , [..] , [..] , [..], [..] , [..] , [..] " + +*spinner-delimiter* + Spinner delimiter to split string into a animation + + Default: "," + ## VIEWER These options are configured in the *[viewer]* section of aerc.conf. diff --git a/widgets/dirlist.go b/widgets/dirlist.go index 6214c8e..33119dd 100644 --- a/widgets/dirlist.go +++ b/widgets/dirlist.go @@ -33,7 +33,7 @@ func NewDirectoryList(acctConf *config.AccountConfig, uiConf *config.UIConfig, acctConf: acctConf, uiConf: uiConf, logger: logger, - spinner: NewSpinner(), + spinner: NewSpinner(uiConf), store: lib.NewDirStore(), worker: worker, } diff --git a/widgets/msglist.go b/widgets/msglist.go index df83dbd..a316cf5 100644 --- a/widgets/msglist.go +++ b/widgets/msglist.go @@ -59,7 +59,7 @@ func NewMessageList(conf *config.AercConfig, logger *log.Logger) *MessageList { ml := &MessageList{ conf: conf, logger: logger, - spinner: NewSpinner(), + spinner: NewSpinner(&conf.Ui), isInitalizing: true, } ml.spinner.OnInvalidate(func(_ ui.Drawable) { diff --git a/widgets/spinner.go b/widgets/spinner.go index 56f75cd..be95d39 100644 --- a/widgets/spinner.go +++ b/widgets/spinner.go @@ -3,35 +3,26 @@ package widgets import ( "sync/atomic" "time" + "strings" "github.com/gdamore/tcell" + "git.sr.ht/~sircmpwn/aerc/config" "git.sr.ht/~sircmpwn/aerc/lib/ui" ) -var ( - frames = []string{ - "[..] ", - " [..] ", - " [..] ", - " [..] ", - " [..]", - " [..] ", - " [..] ", - " [..] ", - } -) - type Spinner struct { ui.Invalidatable frame int64 // access via atomic + frames []string stop chan struct{} } -func NewSpinner() *Spinner { +func NewSpinner(uiConf *config.UIConfig) *Spinner { spinner := Spinner{ - stop: make(chan struct{}), - frame: -1, + stop: make(chan struct{}), + frame: -1, + frames: strings.Split(uiConf.Spinner, uiConf.SpinnerDelimiter), } return &spinner } @@ -77,11 +68,11 @@ func (s *Spinner) Draw(ctx *ui.Context) { s.Start() } - cur := int(atomic.LoadInt64(&s.frame) % int64(len(frames))) + cur := int(atomic.LoadInt64(&s.frame) % int64(len(s.frames))) ctx.Fill(0, 0, ctx.Width(), ctx.Height(), ' ', tcell.StyleDefault) - col := ctx.Width()/2 - len(frames[0])/2 + 1 - ctx.Printf(col, 0, tcell.StyleDefault, "%s", frames[cur]) + col := ctx.Width()/2 - len(s.frames[0])/2 + 1 + ctx.Printf(col, 0, tcell.StyleDefault, "%s", s.frames[cur]) } func (s *Spinner) Invalidate() {