summary refs log tree commit diff stats
diff options
context:
space:
mode:
-rw-r--r--widgets/account.go44
-rw-r--r--widgets/aerc.go15
2 files changed, 44 insertions, 15 deletions
diff --git a/widgets/account.go b/widgets/account.go
index 1f0cc6a..dd7b068 100644
--- a/widgets/account.go
+++ b/widgets/account.go
@@ -2,6 +2,9 @@ package widgets
 
 import (
 	"log"
+	"time"
+
+	"github.com/gdamore/tcell"
 
 	"git.sr.ht/~sircmpwn/aerc2/config"
 	"git.sr.ht/~sircmpwn/aerc2/lib/ui"
@@ -14,16 +17,14 @@ type AccountView struct {
 	grid         *ui.Grid
 	logger       *log.Logger
 	onInvalidate func(d ui.Drawable)
+	status       *StatusLine
 	worker       *types.Worker
 }
 
 func NewAccountView(conf *config.AccountConfig,
-	logger *log.Logger, statusbar ui.Drawable) (*AccountView, error) {
+	logger *log.Logger, statusbar ui.Drawable) *AccountView {
 
-	worker, err := worker.NewWorker(conf.Source, logger)
-	if err != nil {
-		return nil, err
-	}
+	status := NewStatusLine()
 
 	grid := ui.NewGrid().Rows([]ui.GridSpec{
 		{ui.SIZE_WEIGHT, 1},
@@ -35,14 +36,28 @@ func NewAccountView(conf *config.AccountConfig,
 	grid.AddChild(ui.NewBordered(
 		ui.NewFill('s'), ui.BORDER_RIGHT)).Span(2, 1)
 	grid.AddChild(ui.NewFill('.')).At(0, 1)
-	grid.AddChild(statusbar).At(1, 1)
+	grid.AddChild(status).At(1, 1)
+
+	worker, err := worker.NewWorker(conf.Source, logger)
+	if err != nil {
+		acct := &AccountView{
+			conf:   conf,
+			grid:   grid,
+			logger: logger,
+			status: status,
+		}
+		// TODO: Update status line with error
+		return acct
+	}
 
 	acct := &AccountView{
 		conf:   conf,
 		grid:   grid,
 		logger: logger,
+		status: status,
 		worker: worker,
 	}
+	logger.Printf("My grid is %p; status %p", grid, status)
 
 	go worker.Backend.Run()
 	go func() {
@@ -56,28 +71,39 @@ func NewAccountView(conf *config.AccountConfig,
 	worker.PostAction(&types.Configure{Config: conf}, nil)
 	worker.PostAction(&types.Connect{}, acct.connected)
 
-	return acct, nil
+	go func() {
+		time.Sleep(10 * time.Second)
+		status.Set("Test")
+	}()
+
+	return acct
 }
 
 func (acct *AccountView) connected(msg types.WorkerMessage) {
 	switch msg := msg.(type) {
 	case *types.Done:
+		acct.status.Set("Connected.")
 		acct.logger.Println("Connected.")
 		acct.worker.PostAction(&types.ListDirectories{}, nil)
 	case *types.CertificateApprovalRequest:
 		// TODO: Ask the user
-		acct.logger.Println("Approving certificate")
+		acct.logger.Println("Approved unknown certificate.")
+		acct.status.Push("Approved unknown certificate.", 5*time.Second)
 		acct.worker.PostAction(&types.ApproveCertificate{
 			Message:  types.RespondTo(msg),
 			Approved: true,
 		}, acct.connected)
 	default:
 		acct.logger.Println("Connection failed.")
+		acct.status.Set("Connection failed.").
+			Color(tcell.ColorRed, tcell.ColorDefault)
 	}
 }
 
 func (acct *AccountView) OnInvalidate(onInvalidate func(d ui.Drawable)) {
-	acct.grid.OnInvalidate(onInvalidate)
+	acct.grid.OnInvalidate(func(_ ui.Drawable) {
+		onInvalidate(acct)
+	})
 }
 
 func (acct *AccountView) Invalidate() {
diff --git a/widgets/aerc.go b/widgets/aerc.go
index 4351f3b..58e8972 100644
--- a/widgets/aerc.go
+++ b/widgets/aerc.go
@@ -12,6 +12,7 @@ import (
 )
 
 type Aerc struct {
+	accounts    map[string]*AccountView
 	grid        *libui.Grid
 	tabs        *libui.Tabs
 	statusbar   *libui.Stack
@@ -41,16 +42,16 @@ func NewAerc(conf *config.AercConfig, logger *log.Logger) *Aerc {
 	mainGrid.AddChild(tabs.TabStrip).At(0, 1)
 	mainGrid.AddChild(tabs.TabContent).At(1, 0).Span(1, 2)
 
+	accts := make(map[string]*AccountView)
+
 	for _, acct := range conf.Accounts {
-		view, err := NewAccountView(&acct, logger, statusbar)
-		if err != nil {
-			// TODO: something useful (update statusline?)
-			panic(err)
-		}
+		view := NewAccountView(&acct, logger, statusbar)
+		accts[acct.Name] = view
 		tabs.Add(view, acct.Name)
 	}
 
 	return &Aerc{
+		accounts:   accts,
 		grid:       mainGrid,
 		statusbar:  statusbar,
 		statusline: statusline,
@@ -59,7 +60,9 @@ func NewAerc(conf *config.AercConfig, logger *log.Logger) *Aerc {
 }
 
 func (aerc *Aerc) OnInvalidate(onInvalidate func(d libui.Drawable)) {
-	aerc.grid.OnInvalidate(onInvalidate)
+	aerc.grid.OnInvalidate(func(_ libui.Drawable) {
+		onInvalidate(aerc)
+	})
 }
 
 func (aerc *Aerc) Invalidate() {