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:
parent
2921069bfa
commit
be62b30a59
118
ui/toolkit/toolkit.go
Normal file
118
ui/toolkit/toolkit.go
Normal 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
|
||||||
|
}
|
@ -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)
|
||||||
|
Loading…
Reference in New Issue
Block a user