1
0
mirror of https://github.com/mrusme/neonmodem.git synced 2024-06-16 06:25:23 +00:00
neonmodem/ui/ui.go

153 lines
3.2 KiB
Go
Raw Normal View History

2022-12-29 03:22:36 +00:00
package ui
import (
// "fmt"
"strings"
"github.com/mrusme/gobbs/ui/cmd"
2022-12-29 03:22:36 +00:00
"github.com/mrusme/gobbs/ui/ctx"
"github.com/mrusme/gobbs/ui/header"
2022-12-29 03:27:46 +00:00
"github.com/mrusme/gobbs/ui/views/posts"
"github.com/mrusme/gobbs/ui/windowmanager"
"github.com/mrusme/gobbs/ui/windows/postdialog"
2022-12-29 03:22:36 +00:00
"github.com/mrusme/gobbs/ui/views"
"github.com/charmbracelet/bubbles/key"
tea "github.com/charmbracelet/bubbletea"
)
type KeyMap struct {
Up key.Binding
Down key.Binding
Close key.Binding
2022-12-29 03:22:36 +00:00
}
var DefaultKeyMap = KeyMap{
// Up: key.NewBinding(
// key.WithKeys("k", "up"),
// key.WithHelp("↑/k", "move up"),
// ),
// Down: key.NewBinding(
// key.WithKeys("j", "down"),
// key.WithHelp("↓/j", "move down"),
// ),
Close: key.NewBinding(
key.WithKeys("q", "esc"),
key.WithHelp("q/esc", "close"),
),
2022-12-29 03:22:36 +00:00
}
type Model struct {
keymap KeyMap
header header.Model
views []views.View
currentView int
wm *windowmanager.WM
ctx *ctx.Ctx
2022-12-29 03:22:36 +00:00
}
func NewModel(c *ctx.Ctx) Model {
m := Model{
keymap: DefaultKeyMap,
currentView: 0,
wm: windowmanager.New(),
ctx: c,
2022-12-29 03:22:36 +00:00
}
m.header = header.NewModel(m.ctx)
2023-01-01 00:06:39 +00:00
m.views = append(m.views, posts.NewModel(m.ctx))
2022-12-29 03:22:36 +00:00
return m
}
func (m Model) Init() tea.Cmd {
return tea.Batch(
tea.EnterAltScreen,
cmd.New(cmd.ViewFocus, "*").Tea(),
cmd.New(cmd.ViewRefreshData, "*").Tea(),
)
2022-12-29 03:22:36 +00:00
}
func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
cmds := make([]tea.Cmd, 0)
switch msg := msg.(type) {
2023-01-02 19:24:07 +00:00
2022-12-29 03:22:36 +00:00
case tea.KeyMsg:
switch {
case key.Matches(msg, m.keymap.Close):
m.ctx.Logger.Debug("close received")
if !m.wm.CloseFocused() {
m.ctx.Logger.Debug("CloseFocused() was false, quitting")
return m, tea.Quit
}
return m, nil
2022-12-29 03:22:36 +00:00
}
case tea.WindowSizeMsg:
m.setSizes(msg.Width, msg.Height)
for i := range m.views {
v, cmd := m.views[i].Update(msg)
m.views[i] = v
cmds = append(cmds, cmd)
}
ccmds := m.wm.UpdateAll(tea.WindowSizeMsg{
Width: m.ctx.Content[0],
Height: m.ctx.Content[1],
})
cmds = append(cmds, ccmds...)
case cmd.Command:
var ccmds []tea.Cmd
switch msg.Call {
case cmd.WinOpen:
m.ctx.Logger.Debugln("received WinOpen")
ccmds = m.wm.Open(
msg.Target,
postdialog.NewModel(m.ctx),
[4]int{3, 2, 10, 6},
2023-01-02 19:24:07 +00:00
msg.GetArgs()...,
)
m.ctx.Logger.Debugf("got back ccmds: %v\n", ccmds)
default:
m.ctx.Logger.Debugf("updating all with cmd: %v\n", msg)
ccmds = m.wm.UpdateAll(msg)
}
cmds = append(cmds, ccmds...)
2023-01-02 19:24:07 +00:00
default:
m.ctx.Logger.Debugf("updating all with default: %v\n", msg)
cmds = append(cmds, m.wm.UpdateAll(msg)...)
2022-12-29 03:22:36 +00:00
}
v, vcmd := m.views[m.currentView].Update(msg)
m.views[m.currentView] = v
cmds = append(cmds, vcmd)
2022-12-29 03:22:36 +00:00
header, hcmd := m.header.Update(msg)
m.header = header
cmds = append(cmds, hcmd)
2022-12-29 03:22:36 +00:00
return m, tea.Batch(cmds...)
}
func (m Model) View() string {
s := strings.Builder{}
2023-01-01 06:59:10 +00:00
s.WriteString(m.header.View() + "\n")
s.WriteString(m.views[m.currentView].View())
return m.wm.View(s.String())
2022-12-29 03:22:36 +00:00
}
func (m Model) setSizes(winWidth int, winHeight int) {
(*m.ctx).Screen[0] = winWidth
(*m.ctx).Screen[1] = winHeight
m.ctx.Content[0] = m.ctx.Screen[0]
m.ctx.Content[1] = m.ctx.Screen[1] - 5
}