aerc/widgets/account.go

116 lines
2.6 KiB
Go
Raw Normal View History

package widgets
import (
2019-01-13 19:03:28 +01:00
"log"
"time"
"github.com/gdamore/tcell"
2019-01-13 19:03:28 +01:00
"git.sr.ht/~sircmpwn/aerc2/config"
"git.sr.ht/~sircmpwn/aerc2/lib/ui"
2019-01-13 19:03:28 +01:00
"git.sr.ht/~sircmpwn/aerc2/worker"
"git.sr.ht/~sircmpwn/aerc2/worker/types"
)
type AccountView struct {
conf *config.AccountConfig
grid *ui.Grid
2019-01-13 19:03:28 +01:00
logger *log.Logger
onInvalidate func(d ui.Drawable)
status *StatusLine
2019-01-13 19:03:28 +01:00
worker *types.Worker
}
func NewAccountView(conf *config.AccountConfig,
logger *log.Logger, statusbar ui.Drawable) *AccountView {
2019-01-13 19:03:28 +01:00
status := NewStatusLine()
grid := ui.NewGrid().Rows([]ui.GridSpec{
{ui.SIZE_WEIGHT, 1},
{ui.SIZE_EXACT, 1},
}).Columns([]ui.GridSpec{
{ui.SIZE_EXACT, 20},
{ui.SIZE_WEIGHT, 1},
})
grid.AddChild(ui.NewBordered(
ui.NewFill('s'), ui.BORDER_RIGHT)).Span(2, 1)
grid.AddChild(ui.NewFill('.')).At(0, 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
}
2019-01-13 19:03:28 +01:00
acct := &AccountView{
conf: conf,
grid: grid,
logger: logger,
status: status,
2019-01-13 19:03:28 +01:00
worker: worker,
}
logger.Printf("My grid is %p; status %p", grid, status)
2019-01-13 19:03:28 +01:00
go worker.Backend.Run()
go func() {
for {
msg := <-worker.Messages
msg = worker.ProcessMessage(msg)
// TODO: dispatch to appropriate handlers
}
}()
worker.PostAction(&types.Configure{Config: conf}, nil)
worker.PostAction(&types.Connect{}, acct.connected)
go func() {
time.Sleep(10 * time.Second)
status.Set("Test")
}()
return acct
2019-01-13 19:03:28 +01:00
}
func (acct *AccountView) connected(msg types.WorkerMessage) {
switch msg := msg.(type) {
case *types.Done:
acct.status.Set("Connected.")
2019-01-13 19:03:28 +01:00
acct.logger.Println("Connected.")
acct.worker.PostAction(&types.ListDirectories{}, nil)
case *types.CertificateApprovalRequest:
// TODO: Ask the user
acct.logger.Println("Approved unknown certificate.")
acct.status.Push("Approved unknown certificate.", 5*time.Second)
2019-01-13 19:03:28 +01:00
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)
2019-01-13 19:03:28 +01:00
}
}
func (acct *AccountView) OnInvalidate(onInvalidate func(d ui.Drawable)) {
acct.grid.OnInvalidate(func(_ ui.Drawable) {
onInvalidate(acct)
})
}
func (acct *AccountView) Invalidate() {
acct.grid.Invalidate()
}
func (acct *AccountView) Draw(ctx *ui.Context) {
acct.grid.Draw(ctx)
}