aerc/lib/ui/ui.go
Markus Ongyerth 80e891a802 switch to tcell from termbox
This is a simple mostly straight forward switch to tcell in favor of
termbox.
It uses the tcell native api (not the compat layer) but does not make
use of most features.

Further changes should include moving to tcell's views.TextArea and the
general built in widget behaviour instead of the current ad hoc
implementation.

Regression: Cursor isn't shown in ex-line
2018-06-01 16:04:43 -07:00

84 lines
1.6 KiB
Go

package ui
import (
"github.com/gdamore/tcell"
"git.sr.ht/~sircmpwn/aerc2/config"
)
type UI struct {
Exit bool
Content DrawableInteractive
ctx *Context
screen tcell.Screen
tcEvents chan tcell.Event
invalidations chan interface{}
}
func Initialize(conf *config.AercConfig,
content DrawableInteractive) (*UI, error) {
screen, err := tcell.NewScreen()
if err != nil {
return nil, err
}
if err = screen.Init(); err != nil {
return nil, err
}
screen.Clear()
screen.HideCursor()
width, height := screen.Size()
state := UI{
Content: content,
ctx: NewContext(width, height, screen),
screen: screen,
tcEvents: make(chan tcell.Event, 10),
invalidations: make(chan interface{}),
}
//tb.SetOutputMode(tb.Output256)
go (func() {
for !state.Exit {
state.tcEvents <- screen.PollEvent()
}
})()
go (func() { state.invalidations <- nil })()
content.OnInvalidate(func(_ Drawable) {
go (func() { state.invalidations <- nil })()
})
return &state, nil
}
func (state *UI) Close() {
state.screen.Fini()
}
func (state *UI) Tick() bool {
select {
case event := <-state.tcEvents:
switch event := event.(type) {
case *tcell.EventKey:
// TODO: temporary
if event.Key() == tcell.KeyEsc {
state.Exit = true
}
case *tcell.EventResize:
state.screen.Clear()
width, height := event.Size()
state.ctx = NewContext(width, height, state.screen)
state.Content.Invalidate()
}
state.Content.Event(event)
case <-state.invalidations:
state.Content.Draw(state.ctx)
state.screen.Show()
default:
return false
}
return true
}