mirror of
https://github.com/mrusme/neonmodem.git
synced 2025-02-02 15:07:59 -05:00
Implemented draft Dialog in TK
This commit is contained in:
parent
be62b30a59
commit
8e57103040
43
ui/toolkit/dialog.go
Normal file
43
ui/toolkit/dialog.go
Normal file
@ -0,0 +1,43 @@
|
||||
package toolkit
|
||||
|
||||
import (
|
||||
"strings"
|
||||
|
||||
"github.com/charmbracelet/lipgloss"
|
||||
)
|
||||
|
||||
func (tk *ToolKit) Dialog(title string, content string) string {
|
||||
var view strings.Builder = strings.Builder{}
|
||||
|
||||
var style lipgloss.Style
|
||||
if tk.IsFocused() {
|
||||
style = tk.theme.DialogBox.Titlebar.Focused
|
||||
} else {
|
||||
style = tk.theme.DialogBox.Titlebar.Blurred
|
||||
}
|
||||
titlebar := style.Align(lipgloss.Center).
|
||||
Width(tk.ViewWidth()).
|
||||
Render(title)
|
||||
|
||||
bottombar := tk.theme.DialogBox.Bottombar.
|
||||
Width(tk.ViewWidth()).
|
||||
Render("[#]r reply · esc close") // TODO
|
||||
|
||||
ui := lipgloss.JoinVertical(
|
||||
lipgloss.Center,
|
||||
titlebar,
|
||||
content,
|
||||
bottombar,
|
||||
)
|
||||
|
||||
var tmp string
|
||||
if tk.IsFocused() {
|
||||
tmp = tk.theme.DialogBox.Window.Focused.Render(ui)
|
||||
} else {
|
||||
tmp = tk.theme.DialogBox.Window.Blurred.Render(ui)
|
||||
}
|
||||
|
||||
view.WriteString(tmp)
|
||||
|
||||
return view.String()
|
||||
}
|
@ -3,6 +3,7 @@ package toolkit
|
||||
import (
|
||||
tea "github.com/charmbracelet/bubbletea"
|
||||
"github.com/mrusme/gobbs/ui/cmd"
|
||||
"github.com/mrusme/gobbs/ui/theme"
|
||||
"go.uber.org/zap"
|
||||
)
|
||||
|
||||
@ -10,6 +11,7 @@ type ViewFunc func(m interface{}, cached bool) string
|
||||
|
||||
type ToolKit struct {
|
||||
winID string
|
||||
theme *theme.Theme
|
||||
logger *zap.SugaredLogger
|
||||
|
||||
m interface{}
|
||||
@ -20,9 +22,10 @@ type ToolKit struct {
|
||||
viewcache string
|
||||
}
|
||||
|
||||
func New(winID string, l *zap.SugaredLogger) *ToolKit {
|
||||
func New(winID string, t *theme.Theme, l *zap.SugaredLogger) *ToolKit {
|
||||
tk := new(ToolKit)
|
||||
tk.winID = winID
|
||||
tk.theme = t
|
||||
tk.logger = l
|
||||
|
||||
tk.wh = [2]int{0, 0}
|
||||
|
@ -65,8 +65,12 @@ func (m Model) Init() tea.Cmd {
|
||||
|
||||
func NewModel(c *ctx.Ctx) Model {
|
||||
m := Model{
|
||||
ctx: c,
|
||||
tk: toolkit.New(WIN_ID, c.Logger),
|
||||
ctx: c,
|
||||
tk: toolkit.New(
|
||||
WIN_ID,
|
||||
c.Theme,
|
||||
c.Logger,
|
||||
),
|
||||
keymap: DefaultKeyMap,
|
||||
|
||||
buffer: "",
|
||||
@ -222,7 +226,6 @@ func (m Model) View() string {
|
||||
|
||||
func buildView(mi interface{}, cached bool) string {
|
||||
var m *Model = mi.(*Model)
|
||||
var view strings.Builder = strings.Builder{}
|
||||
|
||||
if cached && !m.tk.IsFocused() && m.tk.IsCached() {
|
||||
m.ctx.Logger.Debugln("Cached View()")
|
||||
@ -232,37 +235,10 @@ func buildView(mi interface{}, cached bool) string {
|
||||
m.ctx.Logger.Debugln("View()")
|
||||
m.ctx.Logger.Debugf("IsFocused: %v\n", m.tk.IsFocused())
|
||||
|
||||
var style lipgloss.Style
|
||||
if m.tk.IsFocused() {
|
||||
style = m.ctx.Theme.DialogBox.Titlebar.Focused
|
||||
} else {
|
||||
style = m.ctx.Theme.DialogBox.Titlebar.Blurred
|
||||
}
|
||||
titlebar := style.Align(lipgloss.Center).
|
||||
Width(m.tk.ViewWidth()).
|
||||
Render("Post")
|
||||
|
||||
bottombar := m.ctx.Theme.DialogBox.Bottombar.
|
||||
Width(m.tk.ViewWidth()).
|
||||
Render("[#]r reply · esc close")
|
||||
|
||||
ui := lipgloss.JoinVertical(
|
||||
lipgloss.Center,
|
||||
titlebar,
|
||||
return m.tk.Dialog(
|
||||
"Post",
|
||||
viewportStyle.Render(m.viewport.View()),
|
||||
bottombar,
|
||||
)
|
||||
|
||||
var tmp string
|
||||
if m.tk.IsFocused() {
|
||||
tmp = m.ctx.Theme.DialogBox.Window.Focused.Render(ui)
|
||||
} else {
|
||||
tmp = m.ctx.Theme.DialogBox.Window.Blurred.Render(ui)
|
||||
}
|
||||
|
||||
view.WriteString(tmp)
|
||||
|
||||
return view.String()
|
||||
}
|
||||
|
||||
func (m *Model) renderViewport(p *post.Post) string {
|
||||
|
Loading…
x
Reference in New Issue
Block a user