1
0
mirror of https://github.com/mrusme/neonmodem.git synced 2024-12-04 14:46:37 -05:00

Implemented first ToolKit draft

This commit is contained in:
マリウス 2023-01-03 14:53:32 -05:00
parent 2921069bfa
commit be62b30a59
No known key found for this signature in database
GPG Key ID: 272ED814BF63261F
2 changed files with 142 additions and 48 deletions

118
ui/toolkit/toolkit.go Normal file
View File

@ -0,0 +1,118 @@
package toolkit
import (
tea "github.com/charmbracelet/bubbletea"
"github.com/mrusme/gobbs/ui/cmd"
"go.uber.org/zap"
)
type ViewFunc func(m interface{}, cached bool) string
type ToolKit struct {
winID string
logger *zap.SugaredLogger
m interface{}
wh [2]int
focused bool
viewfunc ViewFunc
viewcache string
}
func New(winID string, l *zap.SugaredLogger) *ToolKit {
tk := new(ToolKit)
tk.winID = winID
tk.logger = l
tk.wh = [2]int{0, 0}
tk.focused = false
return tk
}
func (tk *ToolKit) SetViewFunc(fn ViewFunc) {
tk.viewfunc = fn
}
func (tk *ToolKit) CacheView(m interface{}) bool {
if tk.viewfunc != nil {
tk.viewcache = tk.viewfunc(m, false)
return true
}
return false
}
func (tk *ToolKit) GetCachedView() string {
return tk.viewcache
}
func (tk *ToolKit) IsCached() bool {
return tk.viewcache != ""
}
func (tk *ToolKit) View(m interface{}, cached bool) string {
return tk.viewfunc(m, cached)
}
func (tk *ToolKit) Focus(m interface{}) {
tk.focused = true
if tk.viewfunc != nil {
tk.viewcache = tk.viewfunc(m, false)
}
}
func (tk *ToolKit) Blur(m interface{}) {
tk.focused = false
if tk.viewfunc != nil {
tk.viewcache = tk.viewfunc(m, false)
}
}
func (tk *ToolKit) IsFocused() bool {
return tk.focused
}
func (tk *ToolKit) ViewWidth() int {
return tk.wh[0]
}
func (tk *ToolKit) ViewHeight() int {
return tk.wh[1]
}
func (tk *ToolKit) HandleMsg(m interface{}, msg tea.Msg) (bool, []tea.Cmd) {
var cmds []tea.Cmd
switch msg := msg.(type) {
case tea.WindowSizeMsg:
tk.wh[0] = msg.Width
tk.wh[1] = msg.Height
return false, cmds
case cmd.Command:
tk.logger.Debugf("got command: %v\n", msg)
switch msg.Call {
case cmd.WinFocus:
if msg.Target == tk.winID ||
msg.Target == "*" {
tk.logger.Debug("got WinFocus")
tk.Focus(m)
}
tk.logger.Debugf("focused: %v", tk.focused)
return true, nil
case cmd.WinBlur:
if msg.Target == tk.winID ||
msg.Target == "*" {
tk.logger.Debug("got WinBlur")
tk.Blur(m)
}
tk.logger.Debugf("focused: %v", tk.focused)
return true, nil
}
}
return false, cmds
}

View File

@ -15,6 +15,7 @@ import (
"github.com/mrusme/gobbs/models/reply" "github.com/mrusme/gobbs/models/reply"
"github.com/mrusme/gobbs/ui/cmd" "github.com/mrusme/gobbs/ui/cmd"
"github.com/mrusme/gobbs/ui/ctx" "github.com/mrusme/gobbs/ui/ctx"
"github.com/mrusme/gobbs/ui/toolkit"
"github.com/mrusme/gobbs/ui/windows/postcreate" "github.com/mrusme/gobbs/ui/windows/postcreate"
) )
@ -43,9 +44,8 @@ var DefaultKeyMap = KeyMap{
type Model struct { type Model struct {
ctx *ctx.Ctx ctx *ctx.Ctx
tk *toolkit.ToolKit
keymap KeyMap keymap KeyMap
wh [2]int
focused bool
viewport viewport.Model viewport viewport.Model
a *aggregator.Aggregator a *aggregator.Aggregator
@ -57,8 +57,6 @@ type Model struct {
activePost *post.Post activePost *post.Post
allReplies []*reply.Reply allReplies []*reply.Reply
activeReply *reply.Reply activeReply *reply.Reply
viewcache string
} }
func (m Model) Init() tea.Cmd { func (m Model) Init() tea.Cmd {
@ -68,15 +66,14 @@ func (m Model) Init() tea.Cmd {
func NewModel(c *ctx.Ctx) Model { func NewModel(c *ctx.Ctx) Model {
m := Model{ m := Model{
ctx: c, ctx: c,
tk: toolkit.New(WIN_ID, c.Logger),
keymap: DefaultKeyMap, keymap: DefaultKeyMap,
wh: [2]int{0, 0},
buffer: "", buffer: "",
replyIDs: []string{}, replyIDs: []string{},
viewcache: "",
} }
m.tk.SetViewFunc(buildView)
m.a, _ = aggregator.New(m.ctx) m.a, _ = aggregator.New(m.ctx)
return m return m
@ -85,6 +82,11 @@ func NewModel(c *ctx.Ctx) Model {
func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) { func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
var cmds []tea.Cmd var cmds []tea.Cmd
ret, cmds := m.tk.HandleMsg(&m, msg)
if ret {
return m, tea.Batch(cmds...)
}
switch msg := msg.(type) { switch msg := msg.(type) {
case tea.KeyMsg: case tea.KeyMsg:
switch { switch {
@ -93,7 +95,8 @@ func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
var replyToIdx int = 0 var replyToIdx int = 0
var err error var err error
m.viewcache = m.buildView(false) // m.viewcache = m.buildView(false)
m.tk.CacheView(&m)
if m.buffer != "" { if m.buffer != "" {
replyToIdx, err = strconv.Atoi(m.buffer) replyToIdx, err = strconv.Atoi(m.buffer)
@ -142,11 +145,9 @@ func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
} }
case tea.WindowSizeMsg: case tea.WindowSizeMsg:
m.wh[0] = msg.Width m.ctx.Logger.Debugf("received WindowSizeMsg: %vx%v\n", m.tk.ViewWidth(), m.tk.ViewHeight())
m.wh[1] = msg.Height viewportWidth := m.tk.ViewWidth() - 2
m.ctx.Logger.Debugf("received WindowSizeMsg: %v\n", m.wh) viewportHeight := m.tk.ViewHeight() - 5
viewportWidth := m.wh[0] - 2
viewportHeight := m.wh[1] - 5
viewportStyle.Width(viewportWidth) viewportStyle.Width(viewportWidth)
viewportStyle.Height(viewportHeight) viewportStyle.Height(viewportHeight)
@ -168,22 +169,6 @@ func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
return m, m.loadPost(m.activePost) return m, m.loadPost(m.activePost)
} }
return m, nil return m, nil
case cmd.WinFocus:
if msg.Target == WIN_ID ||
msg.Target == "*" {
m.ctx.Logger.Debug("got WinFocus")
m.Focus()
}
m.ctx.Logger.Debugf("focused: %v", m.focused)
return m, nil
case cmd.WinBlur:
if msg.Target == WIN_ID ||
msg.Target == "*" {
m.ctx.Logger.Debug("got WinBlur")
m.Blur()
}
m.ctx.Logger.Debugf("focused: %v", m.focused)
return m, nil
case cmd.WinFreshData: case cmd.WinFreshData:
if msg.Target == WIN_ID || if msg.Target == WIN_ID ||
msg.Target == "*" { msg.Target == "*" {
@ -231,43 +216,34 @@ func (m *Model) loadPost(p *post.Post) tea.Cmd {
} }
} }
func (m *Model) Focus() {
m.focused = true
m.viewcache = m.buildView(false)
}
func (m *Model) Blur() {
m.focused = false
m.viewcache = m.buildView(false)
}
func (m Model) View() string { func (m Model) View() string {
return m.buildView(true) return m.tk.View(&m, true)
} }
func (m Model) buildView(cached bool) string { func buildView(mi interface{}, cached bool) string {
var m *Model = mi.(*Model)
var view strings.Builder = strings.Builder{} var view strings.Builder = strings.Builder{}
if cached && m.focused == false && m.viewcache != "" { if cached && !m.tk.IsFocused() && m.tk.IsCached() {
m.ctx.Logger.Debugln("Cached View()") m.ctx.Logger.Debugln("Cached View()")
return m.viewcache return m.tk.GetCachedView()
} }
m.ctx.Logger.Debugln("View()") m.ctx.Logger.Debugln("View()")
m.ctx.Logger.Debug(m.focused) m.ctx.Logger.Debugf("IsFocused: %v\n", m.tk.IsFocused())
var style lipgloss.Style var style lipgloss.Style
if m.focused { if m.tk.IsFocused() {
style = m.ctx.Theme.DialogBox.Titlebar.Focused style = m.ctx.Theme.DialogBox.Titlebar.Focused
} else { } else {
style = m.ctx.Theme.DialogBox.Titlebar.Blurred style = m.ctx.Theme.DialogBox.Titlebar.Blurred
} }
titlebar := style.Align(lipgloss.Center). titlebar := style.Align(lipgloss.Center).
Width(m.wh[0]). Width(m.tk.ViewWidth()).
Render("Post") Render("Post")
bottombar := m.ctx.Theme.DialogBox.Bottombar. bottombar := m.ctx.Theme.DialogBox.Bottombar.
Width(m.wh[0]). Width(m.tk.ViewWidth()).
Render("[#]r reply · esc close") Render("[#]r reply · esc close")
ui := lipgloss.JoinVertical( ui := lipgloss.JoinVertical(
@ -278,7 +254,7 @@ func (m Model) buildView(cached bool) string {
) )
var tmp string var tmp string
if m.focused { if m.tk.IsFocused() {
tmp = m.ctx.Theme.DialogBox.Window.Focused.Render(ui) tmp = m.ctx.Theme.DialogBox.Window.Focused.Render(ui)
} else { } else {
tmp = m.ctx.Theme.DialogBox.Window.Blurred.Render(ui) tmp = m.ctx.Theme.DialogBox.Window.Blurred.Render(ui)