From ea0df7bee433fedae5716906ea56141f92b9ce53 Mon Sep 17 00:00:00 2001 From: Reto Brunner Date: Sun, 26 Jan 2020 12:43:46 +0100 Subject: dirlist: adapt to dynamic UIconfig --- widgets/account.go | 2 +- widgets/dirlist.go | 30 ++++++++++++++++++++---------- 2 files changed, 21 insertions(+), 11 deletions(-) (limited to 'widgets') diff --git a/widgets/account.go b/widgets/account.go index 455c28ec..f8b6581f 100644 --- a/widgets/account.go +++ b/widgets/account.go @@ -65,7 +65,7 @@ func NewAccountView(aerc *Aerc, conf *config.AercConfig, acct *config.AccountCon } } - dirlist := NewDirectoryList(acct, &acctUiConf, logger, worker) + dirlist := NewDirectoryList(conf, acct, logger, worker) if acctUiConf.SidebarWidth > 0 { grid.AddChild(ui.NewBordered(dirlist, ui.BORDER_RIGHT)) } diff --git a/widgets/dirlist.go b/widgets/dirlist.go index edc84c6a..5cdbe06d 100644 --- a/widgets/dirlist.go +++ b/widgets/dirlist.go @@ -18,8 +18,8 @@ import ( type DirectoryList struct { ui.Invalidatable + aercConf *config.AercConfig acctConf *config.AccountConfig - uiConf *config.UIConfig store *lib.DirStore dirs []string logger *log.Logger @@ -29,17 +29,18 @@ type DirectoryList struct { worker *types.Worker } -func NewDirectoryList(acctConf *config.AccountConfig, uiConf *config.UIConfig, +func NewDirectoryList(conf *config.AercConfig, acctConf *config.AccountConfig, logger *log.Logger, worker *types.Worker) *DirectoryList { dirlist := &DirectoryList{ + aercConf: conf, acctConf: acctConf, - uiConf: uiConf, logger: logger, - spinner: NewSpinner(uiConf), store: lib.NewDirStore(), worker: worker, } + uiConf := dirlist.UiConfig() + dirlist.spinner = NewSpinner(&uiConf) dirlist.spinner.OnInvalidate(func(_ ui.Drawable) { dirlist.Invalidate() }) @@ -47,6 +48,13 @@ func NewDirectoryList(acctConf *config.AccountConfig, uiConf *config.UIConfig, return dirlist } +func (dirlist *DirectoryList) UiConfig() config.UIConfig { + return dirlist.aercConf.GetUiConfig(map[config.ContextType]string{ + config.UI_CONTEXT_ACCOUNT: dirlist.acctConf.Name, + config.UI_CONTEXT_FOLDER: dirlist.Selected(), + }) +} + func (dirlist *DirectoryList) List() []string { return dirlist.store.List() } @@ -118,7 +126,7 @@ func (dirlist *DirectoryList) getDirString(name string, width int, recentUnseen formatted = runewidth.FillRight(formatted, width-len(s)) formatted = runewidth.Truncate(formatted, width-len(s), "…") } - for _, char := range dirlist.uiConf.DirListFormat { + for _, char := range dirlist.UiConfig().DirListFormat { switch char { case '%': if percent { @@ -206,7 +214,7 @@ func (dirlist *DirectoryList) Draw(ctx *ui.Context) { if len(dirlist.dirs) == 0 { style := tcell.StyleDefault - ctx.Printf(0, 0, style, dirlist.uiConf.EmptyDirlist) + ctx.Printf(0, 0, style, dirlist.UiConfig().EmptyDirlist) return } @@ -304,8 +312,9 @@ func folderMatches(folder string, pattern string) bool { // will be appended at the end in alphabetical order func (dirlist *DirectoryList) sortDirsByFoldersSortConfig() { sort.Slice(dirlist.dirs, func(i, j int) bool { - iInFoldersSort := findString(dirlist.acctConf.FoldersSort, dirlist.dirs[i]) - jInFoldersSort := findString(dirlist.acctConf.FoldersSort, dirlist.dirs[j]) + foldersSort := dirlist.acctConf.FoldersSort + iInFoldersSort := findString(foldersSort, dirlist.dirs[i]) + jInFoldersSort := findString(foldersSort, dirlist.dirs[j]) if iInFoldersSort >= 0 && jInFoldersSort >= 0 { return iInFoldersSort < jInFoldersSort } @@ -324,12 +333,13 @@ func (dirlist *DirectoryList) sortDirsByFoldersSortConfig() { func (dirlist *DirectoryList) filterDirsByFoldersConfig() { dirlist.dirs = dirlist.store.List() // config option defaults to show all if unset - if len(dirlist.acctConf.Folders) == 0 { + configFolders := dirlist.acctConf.Folders + if len(configFolders) == 0 { return } var filtered []string for _, folder := range dirlist.dirs { - for _, cfgfolder := range dirlist.acctConf.Folders { + for _, cfgfolder := range configFolders { if folderMatches(folder, cfgfolder) { filtered = append(filtered, folder) break -- cgit