From f7f8ec295f568313312bc4243150cb472cfe8a12 Mon Sep 17 00:00:00 2001 From: nsfisis Date: Fri, 10 Mar 2023 00:15:37 +0900 Subject: refactor: move common stuff to internal/term package --- internal/term/screen.go | 70 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 70 insertions(+) create mode 100644 internal/term/screen.go (limited to 'internal/term/screen.go') diff --git a/internal/term/screen.go b/internal/term/screen.go new file mode 100644 index 0000000..14bfcfb --- /dev/null +++ b/internal/term/screen.go @@ -0,0 +1,70 @@ +package term + +import ( + "github.com/gdamore/tcell/v2" +) + +type Screen struct { + scr tcell.Screen + onResize func() bool + QuitC chan struct{} +} + +func NewScreen() (*Screen, error) { + scr, err := tcell.NewScreen() + if err != nil{ + return nil, err + } + err = scr.Init() + if err != nil{ + return nil, err + } + return &Screen{ + scr: scr, + QuitC: make(chan struct{}), + }, nil +} + +func (scr *Screen) Close() { + scr.scr.Fini() +} + +func (scr *Screen) Size() (int, int) { + return scr.scr.Size() +} + +func (scr *Screen) Clear(style Style) { + scr.scr.SetStyle(tcell.Style(style)) + scr.scr.Clear() +} + +func (scr *Screen) OnResize(handler func() bool) { + scr.onResize = handler +} + +func (scr *Screen) Show() { + scr.scr.Show() +} + +func (scr *Screen) DoEventLoop() { + for { + scr.scr.Show() + + ev := scr.scr.PollEvent() + switch ev := ev.(type) { + case *tcell.EventResize: + if scr.onResize != nil { + if quit := scr.onResize(); quit { + return + } + } + scr.scr.Sync() + case *tcell.EventKey: + if ev.Key() == tcell.KeyEscape || ev.Key() == tcell.KeyCtrlC || ev.Rune() == 'q' { + close(scr.QuitC) + return + } + scr.scr.Sync() + } + } +} -- cgit v1.2.3-70-g09d2