diff options
author | Reto Brunner <reto@labrat.space> | 2020-08-08 11:38:38 +0200 |
---|---|---|
committer | Reto Brunner <reto@labrat.space> | 2020-08-10 08:00:34 +0200 |
commit | 2d7a8707257eec2b9f0ff41772cfd8dab4f1201e (patch) | |
tree | 257436ae151d923cf80aec0382f16b9fa03bbdae /widgets/aerc.go | |
parent | c3c982c3ec0f9702047e0e09d667bbd70a33103c (diff) | |
download | aerc-2d7a8707257eec2b9f0ff41772cfd8dab4f1201e.tar.gz |
show error if account view creation fails
This can happen for example if aerc is compiled without notmuch support but the notmuch worker is requested. Pushing a status message isn't good enough, as this gets overridden pretty quickly if one has multiple accounts configured. So we show a fullscreen error instead.
Diffstat (limited to 'widgets/aerc.go')
-rw-r--r-- | widgets/aerc.go | 27 |
1 files changed, 24 insertions, 3 deletions
diff --git a/widgets/aerc.go b/widgets/aerc.go index 692e00d..acdd8b4 100644 --- a/widgets/aerc.go +++ b/widgets/aerc.go @@ -84,9 +84,13 @@ func NewAerc(conf *config.AercConfig, logger *log.Logger, conf.Triggers.ExecuteCommand = cmd for i, acct := range conf.Accounts { - view := NewAccountView(aerc, conf, &conf.Accounts[i], logger, aerc) - aerc.accounts[acct.Name] = view - tabs.Add(view, acct.Name) + view, err := NewAccountView(aerc, conf, &conf.Accounts[i], logger, aerc) + if err != nil { + tabs.Add(errorScreen(err.Error(), conf.Ui), acct.Name) + } else { + aerc.accounts[acct.Name] = view + tabs.Add(view, acct.Name) + } } if len(conf.Accounts) == 0 { @@ -609,3 +613,20 @@ func (aerc *Aerc) DecryptKeys(keys []openpgp.Key, symmetric bool) (b []byte, err } return nil, err } + +// errorScreen is a widget that draws an error in the middle of the context +func errorScreen(s string, conf config.UIConfig) ui.Drawable { + errstyle := conf.GetStyle(config.STYLE_ERROR) + text := ui.NewText(s, errstyle).Strategy(ui.TEXT_CENTER) + grid := ui.NewGrid().Rows([]ui.GridSpec{ + {ui.SIZE_WEIGHT, ui.Const(1)}, + {ui.SIZE_EXACT, ui.Const(1)}, + {ui.SIZE_WEIGHT, ui.Const(1)}, + }).Columns([]ui.GridSpec{ + {ui.SIZE_WEIGHT, ui.Const(1)}, + }) + grid.AddChild(ui.NewFill(' ')).At(0, 0) + grid.AddChild(text).At(1, 0) + grid.AddChild(ui.NewFill(' ')).At(2, 0) + return grid +} |