7 Commits

Author SHA1 Message Date
18ead7b486 Some work 2026-02-18 19:12:13 -06:00
4b51c5b00f Show/Hide Menu Functions 2026-02-18 15:56:20 -06:00
46a87f913b Bug Fixes 2026-02-02 13:38:33 -06:00
5581cf14c1 Bug Fixes 2026-02-02 13:35:13 -06:00
16a92c8f99 Changed 'Tabbable/Focusable' logic to use Active 2026-02-02 13:29:51 -06:00
62ef3b5d44 Add 'Has' to layout flags 2026-01-29 06:12:52 -06:00
16f7e7466a Bug Fix 2026-01-23 14:58:18 -06:00
32 changed files with 450 additions and 393 deletions

View File

@@ -75,6 +75,7 @@ const (
LFSizeAll = LayoutFlag(0x11110000) LFSizeAll = LayoutFlag(0x11110000)
) )
func (f LayoutFlag) Has(fl LayoutFlag) bool { return f&fl != 0 }
func (f LayoutFlag) Add(fl LayoutFlag) { f |= fl } func (f LayoutFlag) Add(fl LayoutFlag) { f |= fl }
func (f LayoutFlag) Remove(fl LayoutFlag) { f = f &^ fl } func (f LayoutFlag) Remove(fl LayoutFlag) { f = f &^ fl }
func (f LayoutFlag) ClearAll() { func (f LayoutFlag) ClearAll() {

View File

@@ -94,8 +94,7 @@ func (w *AbsoluteLayout) HandleKey(ev *tcell.EventKey) bool {
continue continue
} }
} else { } else {
if w.widgets[i].Focusable() { if w.widgets[i].SetActive(true) {
w.widgets[i].SetActive(true)
return true return true
} }
} }
@@ -105,8 +104,7 @@ func (w *AbsoluteLayout) HandleKey(ev *tcell.EventKey) bool {
return false return false
} }
for i := 0; i < fndP; i++ { for i := 0; i < fndP; i++ {
if w.widgets[i].Focusable() { if w.widgets[i].SetActive(true) {
w.widgets[i].SetActive(true)
return true return true
} }
} }
@@ -141,7 +139,10 @@ func (w *AbsoluteLayout) Draw(screen tcell.Screen) {
func (w *AbsoluteLayout) SetStyle(s tcell.Style) { w.style = s } func (w *AbsoluteLayout) SetStyle(s tcell.Style) { w.style = s }
func (w *AbsoluteLayout) Active() bool { return w.active } func (w *AbsoluteLayout) Active() bool { return w.active }
func (w *AbsoluteLayout) SetActive(a bool) { w.active = a } func (w *AbsoluteLayout) SetActive(a bool) bool {
w.active = a
return w.Active()
}
func (w *AbsoluteLayout) Visible() bool { return w.visible } func (w *AbsoluteLayout) Visible() bool { return w.visible }
func (w *AbsoluteLayout) SetVisible(a bool) { w.visible = a } func (w *AbsoluteLayout) SetVisible(a bool) { w.visible = a }
func (w *AbsoluteLayout) Focusable() bool { return w.focusable } func (w *AbsoluteLayout) Focusable() bool { return w.focusable }

View File

@@ -36,7 +36,6 @@ type Alert struct {
w, h int w, h int
active bool active bool
visible bool visible bool
focusable bool
layout *LinearLayout layout *LinearLayout
title string title string
@@ -90,7 +89,6 @@ func (w *Alert) Init(id string, style tcell.Style) {
NewKey(BuildEK(tcell.KeyUp), w.SelectNext), NewKey(BuildEK(tcell.KeyUp), w.SelectNext),
NewKey(BuildEK(tcell.KeyEnter), w.Do), NewKey(BuildEK(tcell.KeyEnter), w.Do),
) )
w.focusable = true
} }
func (w *Alert) Id() string { return w.id } func (w *Alert) Id() string { return w.id }
func (w *Alert) HandleResize(ev *tcell.EventResize) { func (w *Alert) HandleResize(ev *tcell.EventResize) {
@@ -127,7 +125,10 @@ func (w *Alert) Draw(screen tcell.Screen) {
func (w *Alert) SetStyle(s tcell.Style) { w.style = s } func (w *Alert) SetStyle(s tcell.Style) { w.style = s }
func (w *Alert) Active() bool { return w.active } func (w *Alert) Active() bool { return w.active }
func (w *Alert) SetActive(a bool) { w.active = a } func (w *Alert) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *Alert) Visible() bool { return w.visible } func (w *Alert) Visible() bool { return w.visible }
func (w *Alert) SetVisible(a bool) { w.visible = a } func (w *Alert) SetVisible(a bool) { w.visible = a }
func (w *Alert) SetX(x int) { w.x = x } func (w *Alert) SetX(x int) { w.x = x }
@@ -141,10 +142,15 @@ func (w *Alert) SetH(y int) { w.h = y }
func (w *Alert) GetW() int { return w.w } func (w *Alert) GetW() int { return w.w }
func (w *Alert) GetH() int { return w.y } func (w *Alert) GetH() int { return w.y }
func (w *Alert) SetSize(c Coord) { w.w, w.h = c.X, c.Y } func (w *Alert) SetSize(c Coord) { w.w, w.h = c.X, c.Y }
func (w *Alert) Focusable() bool { return w.focusable }
func (w *Alert) SetFocusable(b bool) { w.focusable = b }
func (w *Alert) WantW() int { func (w *Alert) WantW() int {
return 4 + wh.Max(w.message.WantW(), (w.btnOk.WantW()+w.btnCancel.WantW())) var okW, cancelW int
if !w.btnOk.Visible() {
okW = w.btnOk.WantW()
}
if !w.btnCancel.Visible() {
cancelW = w.btnCancel.WantW()
}
return 4 + wh.Max(w.message.WantW(), (okW+cancelW))
} }
func (w *Alert) WantH() int { func (w *Alert) WantH() int {
@@ -164,13 +170,11 @@ func (w *Alert) SetMessage(msg string) { w.message.SetText(msg) }
func (w *Alert) SetOkPressed(b func() bool) { func (w *Alert) SetOkPressed(b func() bool) {
w.btnOk.SetVisible(b != nil) w.btnOk.SetVisible(b != nil)
w.btnOk.SetFocusable(b != nil)
w.btnOk.SetOnPressed(b) w.btnOk.SetOnPressed(b)
} }
func (w *Alert) SetCancelPressed(b func() bool) { func (w *Alert) SetCancelPressed(b func() bool) {
w.btnCancel.SetVisible(b != nil) w.btnCancel.SetVisible(b != nil)
w.btnCancel.SetFocusable(b != nil)
w.btnCancel.SetOnPressed(b) w.btnCancel.SetOnPressed(b)
} }

View File

@@ -82,7 +82,10 @@ func (w *ArtWidget) Draw(screen tcell.Screen) {
func (w *ArtWidget) SetStyle(s tcell.Style) { w.style = s } func (w *ArtWidget) SetStyle(s tcell.Style) { w.style = s }
func (w *ArtWidget) Active() bool { return w.active } func (w *ArtWidget) Active() bool { return w.active }
func (w *ArtWidget) SetActive(a bool) { w.active = a } func (w *ArtWidget) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *ArtWidget) Visible() bool { return w.visible } func (w *ArtWidget) Visible() bool { return w.visible }
func (w *ArtWidget) SetVisible(v bool) { w.visible = v } func (w *ArtWidget) SetVisible(v bool) { w.visible = v }
func (w *ArtWidget) Focusable() bool { return w.focusable } func (w *ArtWidget) Focusable() bool { return w.focusable }

View File

@@ -53,7 +53,7 @@ func (w *BlankWidget) Draw(screen tcell.Screen) {}
func (w *BlankWidget) SetStyle(s tcell.Style) {} func (w *BlankWidget) SetStyle(s tcell.Style) {}
func (w *BlankWidget) Active() bool { return false } func (w *BlankWidget) Active() bool { return false }
func (w *BlankWidget) SetActive(a bool) {} func (w *BlankWidget) SetActive(a bool) bool { return false }
func (w *BlankWidget) Visible() bool { return true } func (w *BlankWidget) Visible() bool { return true }
func (w *BlankWidget) SetVisible(v bool) {} func (w *BlankWidget) SetVisible(v bool) {}
func (w *BlankWidget) Focusable() bool { return false } func (w *BlankWidget) Focusable() bool { return false }

View File

@@ -58,7 +58,6 @@ func (w *BorderedWidget) Init(id string, s tcell.Style) {
w.style = s w.style = s
w.widget.SetVisible(true) w.widget.SetVisible(true)
w.border = wh.BRD_CSIMPLE w.border = wh.BRD_CSIMPLE
w.widget.SetFocusable(true)
} }
func (w *BorderedWidget) Id() string { return w.id } func (w *BorderedWidget) Id() string { return w.id }
@@ -93,11 +92,9 @@ func (w *BorderedWidget) Draw(screen tcell.Screen) {
func (w *BorderedWidget) SetStyle(s tcell.Style) { w.style = s } func (w *BorderedWidget) SetStyle(s tcell.Style) { w.style = s }
func (w *BorderedWidget) Active() bool { return w.widget.Active() } func (w *BorderedWidget) Active() bool { return w.widget.Active() }
func (w *BorderedWidget) SetActive(a bool) { w.widget.SetActive(a) } func (w *BorderedWidget) SetActive(a bool) bool { return w.widget.SetActive(a) }
func (w *BorderedWidget) Visible() bool { return w.widget.Visible() } func (w *BorderedWidget) Visible() bool { return w.widget.Visible() }
func (w *BorderedWidget) SetVisible(a bool) { w.SetVisible(a) } func (w *BorderedWidget) SetVisible(a bool) { w.SetVisible(a) }
func (w *BorderedWidget) Focusable() bool { return w.widget.Focusable() }
func (w *BorderedWidget) SetFocusable(b bool) { w.widget.SetFocusable(b) }
func (w *BorderedWidget) SetX(x int) { w.x = x } func (w *BorderedWidget) SetX(x int) { w.x = x }
func (w *BorderedWidget) SetY(y int) { w.y = y } func (w *BorderedWidget) SetY(y int) { w.y = y }
func (w *BorderedWidget) GetX() int { return w.x } func (w *BorderedWidget) GetX() int { return w.x }

View File

@@ -78,7 +78,10 @@ func (w *BufferWidget) Draw(screen tcell.Screen) { w.buffer.Draw(w.x, w.y,
func (w *BufferWidget) SetStyle(s tcell.Style) { w.style = s } func (w *BufferWidget) SetStyle(s tcell.Style) { w.style = s }
func (w *BufferWidget) Active() bool { return w.active } func (w *BufferWidget) Active() bool { return w.active }
func (w *BufferWidget) SetActive(a bool) { w.active = a } func (w *BufferWidget) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *BufferWidget) Visible() bool { return w.visible } func (w *BufferWidget) Visible() bool { return w.visible }
func (w *BufferWidget) SetVisible(a bool) { w.visible = a } func (w *BufferWidget) SetVisible(a bool) { w.visible = a }
func (w *BufferWidget) Focusable() bool { return w.focusable } func (w *BufferWidget) Focusable() bool { return w.focusable }

View File

@@ -38,7 +38,6 @@ type Button struct {
active bool active bool
visible bool visible bool
focusable bool
keyMap *KeyMap keyMap *KeyMap
onPressed func() bool onPressed func() bool
@@ -59,7 +58,6 @@ func (w *Button) Init(id string, style tcell.Style) {
w.visible = true w.visible = true
w.keyMap = NewKeyMap(NewKey(BuildEK(tcell.KeyEnter), func(ev *tcell.EventKey) bool { return w.onPressed() })) w.keyMap = NewKeyMap(NewKey(BuildEK(tcell.KeyEnter), func(ev *tcell.EventKey) bool { return w.onPressed() }))
w.onPressed = func() bool { return false } w.onPressed = func() bool { return false }
w.focusable = true
} }
func (w *Button) Id() string { return w.id } func (w *Button) Id() string { return w.id }
func (w *Button) HandleResize(ev *tcell.EventResize) { func (w *Button) HandleResize(ev *tcell.EventResize) {
@@ -121,7 +119,10 @@ func (w *Button) Draw(screen tcell.Screen) {
func (w *Button) SetStyle(s tcell.Style) { w.style = s } func (w *Button) SetStyle(s tcell.Style) { w.style = s }
func (w *Button) Active() bool { return w.active } func (w *Button) Active() bool { return w.active }
func (w *Button) SetActive(a bool) { w.active = a } func (w *Button) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *Button) Visible() bool { return w.visible } func (w *Button) Visible() bool { return w.visible }
func (w *Button) SetVisible(a bool) { w.visible = a } func (w *Button) SetVisible(a bool) { w.visible = a }
func (w *Button) SetX(x int) { w.x = x } func (w *Button) SetX(x int) { w.x = x }
@@ -137,8 +138,6 @@ func (w *Button) GetH() int { return w.h }
func (w *Button) WantW() int { return 4 + len(w.label) } func (w *Button) WantW() int { return 4 + len(w.label) }
func (w *Button) WantH() int { return 3 } func (w *Button) WantH() int { return 3 }
func (w *Button) SetSize(c Coord) { w.w, w.h = c.X, c.Y } func (w *Button) SetSize(c Coord) { w.w, w.h = c.X, c.Y }
func (w *Button) Focusable() bool { return w.focusable }
func (w *Button) SetFocusable(b bool) { w.focusable = b }
func (w *Button) MinW() int { return len(w.label) + 2 } func (w *Button) MinW() int { return len(w.label) + 2 }
func (w *Button) MinH() int { return 1 } func (w *Button) MinH() int { return 1 }

View File

@@ -160,7 +160,10 @@ func (w *Chat) Draw(screen tcell.Screen) {
func (w *Chat) SetStyle(s tcell.Style) { w.style = s } func (w *Chat) SetStyle(s tcell.Style) { w.style = s }
func (w *Chat) Active() bool { return w.active } func (w *Chat) Active() bool { return w.active }
func (w *Chat) SetActive(a bool) { w.active = a } func (w *Chat) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *Chat) Visible() bool { return w.visible } func (w *Chat) Visible() bool { return w.visible }
func (w *Chat) SetVisible(a bool) { w.visible = a } func (w *Chat) SetVisible(a bool) { w.visible = a }
func (w *Chat) Focusable() bool { return w.focusable } func (w *Chat) Focusable() bool { return w.focusable }

View File

@@ -94,7 +94,10 @@ func (w *Checkbox) Draw(screen tcell.Screen) {
func (w *Checkbox) SetStyle(s tcell.Style) { w.style = s } func (w *Checkbox) SetStyle(s tcell.Style) { w.style = s }
func (w *Checkbox) Active() bool { return w.active } func (w *Checkbox) Active() bool { return w.active }
func (w *Checkbox) SetActive(a bool) { w.active = a } func (w *Checkbox) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *Checkbox) Visible() bool { return w.visible } func (w *Checkbox) Visible() bool { return w.visible }
func (w *Checkbox) SetVisible(a bool) { w.visible = a } func (w *Checkbox) SetVisible(a bool) { w.visible = a }
func (w *Checkbox) SetX(x int) { w.x = x } func (w *Checkbox) SetX(x int) { w.x = x }

View File

@@ -174,7 +174,10 @@ func (w *Cli) Draw(screen tcell.Screen) {
func (w *Cli) SetStyle(s tcell.Style) { w.style = s } func (w *Cli) SetStyle(s tcell.Style) { w.style = s }
func (w *Cli) Active() bool { return w.active } func (w *Cli) Active() bool { return w.active }
func (w *Cli) SetActive(a bool) { w.active = a } func (w *Cli) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *Cli) Visible() bool { return w.visible } func (w *Cli) Visible() bool { return w.visible }
func (w *Cli) SetVisible(a bool) { w.visible = a } func (w *Cli) SetVisible(a bool) { w.visible = a }
func (w *Cli) Focusable() bool { return true } func (w *Cli) Focusable() bool { return true }

View File

@@ -131,12 +131,13 @@ func (w *DatePicker) Draw(screen tcell.Screen) {
func (w *DatePicker) SetStyle(s tcell.Style) { w.style = s } func (w *DatePicker) SetStyle(s tcell.Style) { w.style = s }
func (w *DatePicker) Active() bool { return w.active } func (w *DatePicker) Active() bool { return w.active }
func (w *DatePicker) SetActive(a bool) { func (w *DatePicker) SetActive(a bool) bool {
if !w.active && a { if !w.active && a {
// Wasn't active, but turning on // Wasn't active, but turning on
w.dateFld.SetActive(true) w.dateFld.SetActive(true)
} }
w.active = a w.active = a
return w.active
} }
func (w *DatePicker) Visible() bool { return w.visible } func (w *DatePicker) Visible() bool { return w.visible }
func (w *DatePicker) SetVisible(a bool) { w.visible = a } func (w *DatePicker) SetVisible(a bool) { w.visible = a }

View File

@@ -167,9 +167,9 @@ func (w *DebugWidget) Draw(screen tcell.Screen) {
func (w *DebugWidget) SetStyle(s tcell.Style) { w.style = s } func (w *DebugWidget) SetStyle(s tcell.Style) { w.style = s }
func (w *DebugWidget) Active() bool { return w.active } func (w *DebugWidget) Active() bool { return w.active }
func (w *DebugWidget) SetActive(a bool) { func (w *DebugWidget) SetActive(a bool) bool {
w.active = a w.active = a
w.widget.SetActive(a) return w.widget.SetActive(a)
} }
func (w *DebugWidget) Visible() bool { return w.visible } func (w *DebugWidget) Visible() bool { return w.visible }
func (w *DebugWidget) SetVisible(a bool) { w.visible = a } func (w *DebugWidget) SetVisible(a bool) { w.visible = a }

View File

@@ -157,7 +157,10 @@ func (w *Field) Draw(screen tcell.Screen) {
func (w *Field) SetStyle(s tcell.Style) { w.style = s } func (w *Field) SetStyle(s tcell.Style) { w.style = s }
func (w *Field) Active() bool { return w.active } func (w *Field) Active() bool { return w.active }
func (w *Field) SetActive(a bool) { w.active = a } func (w *Field) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *Field) Visible() bool { return w.visible } func (w *Field) Visible() bool { return w.visible }
func (w *Field) SetVisible(a bool) { w.visible = a } func (w *Field) SetVisible(a bool) { w.visible = a }
func (w *Field) SetX(x int) { w.x = x } func (w *Field) SetX(x int) { w.x = x }

View File

@@ -123,7 +123,10 @@ func (w *FilePicker) Draw(screen tcell.Screen) {
func (w *FilePicker) SetStyle(s tcell.Style) { w.style = s } func (w *FilePicker) SetStyle(s tcell.Style) { w.style = s }
func (w *FilePicker) Active() bool { return w.active } func (w *FilePicker) Active() bool { return w.active }
func (w *FilePicker) SetActive(a bool) { w.active = a } func (w *FilePicker) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *FilePicker) Visible() bool { return w.visible } func (w *FilePicker) Visible() bool { return w.visible }
func (w *FilePicker) SetVisible(a bool) { w.visible = a } func (w *FilePicker) SetVisible(a bool) { w.visible = a }
func (w *FilePicker) SetX(x int) { w.x = x } func (w *FilePicker) SetX(x int) { w.x = x }

View File

@@ -148,9 +148,10 @@ func (w *Form) Draw(screen tcell.Screen) {
func (w *Form) SetStyle(s tcell.Style) { w.style = s } func (w *Form) SetStyle(s tcell.Style) { w.style = s }
func (w *Form) Active() bool { return w.active } func (w *Form) Active() bool { return w.active }
func (w *Form) SetActive(a bool) { func (w *Form) SetActive(a bool) bool {
w.active = a w.active = a
w.updateWidgets() w.updateWidgets()
return w.active
} }
func (w *Form) Visible() bool { return w.visible } func (w *Form) Visible() bool { return w.visible }
func (w *Form) SetVisible(a bool) { w.visible = a } func (w *Form) SetVisible(a bool) { w.visible = a }

View File

@@ -52,7 +52,6 @@ type LinearLayout struct {
active bool active bool
visible bool visible bool
focusable bool
disableTab bool disableTab bool
insetBorder bool insetBorder bool
@@ -80,7 +79,6 @@ func (w *LinearLayout) Init(id string, s tcell.Style) {
w.id = id w.id = id
w.style = s w.style = s
w.visible = true w.visible = true
w.focusable = true
w.defFlags = LayoutFlag(LFAlignHCenter | LFAlignVCenter) w.defFlags = LayoutFlag(LFAlignHCenter | LFAlignVCenter)
w.layoutFlags = make(map[Widget]LayoutFlag) w.layoutFlags = make(map[Widget]LayoutFlag)
w.layoutWeights = make(map[Widget]int) w.layoutWeights = make(map[Widget]int)
@@ -89,8 +87,7 @@ func (w *LinearLayout) Init(id string, s tcell.Style) {
if active == nil && len(w.widgets) > 0 { if active == nil && len(w.widgets) > 0 {
// No widget is active, but we do have some // No widget is active, but we do have some
for i := range w.widgets { for i := range w.widgets {
if w.widgets[i].Focusable() { if w.widgets[i].SetActive(true) {
w.widgets[i].SetActive(true)
return true return true
} }
} }
@@ -103,8 +100,7 @@ func (w *LinearLayout) Init(id string, s tcell.Style) {
if active == nil && len(w.widgets) > 0 { if active == nil && len(w.widgets) > 0 {
// No widget is active, but we do have some // No widget is active, but we do have some
for i := len(w.widgets) - 1; i >= 0; i-- { for i := len(w.widgets) - 1; i >= 0; i-- {
if w.widgets[i].Focusable() { if w.widgets[i].SetActive(true) {
w.widgets[i].SetActive(true)
return true return true
} }
} }
@@ -162,7 +158,7 @@ func (w *LinearLayout) Draw(screen tcell.Screen) {
func (w *LinearLayout) SetStyle(s tcell.Style) { w.style = s } func (w *LinearLayout) SetStyle(s tcell.Style) { w.style = s }
func (w *LinearLayout) Active() bool { return w.active } func (w *LinearLayout) Active() bool { return w.active }
func (w *LinearLayout) SetActive(a bool) { func (w *LinearLayout) SetActive(a bool) bool {
w.active = a w.active = a
if w.active { if w.active {
act := w.findActiveOrFirst() act := w.findActiveOrFirst()
@@ -170,11 +166,10 @@ func (w *LinearLayout) SetActive(a bool) {
act.SetActive(true) act.SetActive(true)
} }
} }
return w.active
} }
func (w *LinearLayout) Visible() bool { return w.visible } func (w *LinearLayout) Visible() bool { return w.visible }
func (w *LinearLayout) SetVisible(a bool) { w.visible = a } func (w *LinearLayout) SetVisible(a bool) { w.visible = a }
func (w *LinearLayout) Focusable() bool { return w.focusable }
func (w *LinearLayout) SetFocusable(b bool) { w.focusable = b }
func (w *LinearLayout) SetX(x int) { w.x = x } func (w *LinearLayout) SetX(x int) { w.x = x }
func (w *LinearLayout) SetY(y int) { w.y = y } func (w *LinearLayout) SetY(y int) { w.y = y }
func (w *LinearLayout) GetX() int { return w.x } func (w *LinearLayout) GetX() int { return w.x }
@@ -290,8 +285,7 @@ func (w *LinearLayout) ActivateWidget(n Widget) {
func (w *LinearLayout) ActivateNext() bool { func (w *LinearLayout) ActivateNext() bool {
var found bool var found bool
for i := range w.widgets { for i := range w.widgets {
if found && w.widgets[i].Focusable() { if found && w.widgets[i].SetActive(true) {
w.widgets[i].SetActive(true)
return true return true
} else if w.widgets[i].Active() { } else if w.widgets[i].Active() {
found = true found = true
@@ -304,8 +298,7 @@ func (w *LinearLayout) ActivateNext() bool {
func (w *LinearLayout) ActivatePrev() bool { func (w *LinearLayout) ActivatePrev() bool {
var found bool var found bool
for i := len(w.widgets) - 1; i >= 0; i-- { for i := len(w.widgets) - 1; i >= 0; i-- {
if found && w.widgets[i].Focusable() { if found && w.widgets[i].SetActive(true) {
w.widgets[i].SetActive(true)
return true return true
} else if w.widgets[i].Active() { } else if w.widgets[i].Active() {
found = true found = true

View File

@@ -227,7 +227,10 @@ func (w *Menu) drawVMenu(screen tcell.Screen) {
func (w *Menu) SetStyle(s tcell.Style) { w.style = s } func (w *Menu) SetStyle(s tcell.Style) { w.style = s }
func (w *Menu) Active() bool { return w.active } func (w *Menu) Active() bool { return w.active }
func (w *Menu) SetActive(a bool) { w.active = a } func (w *Menu) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *Menu) Visible() bool { return w.visible } func (w *Menu) Visible() bool { return w.visible }
func (w *Menu) SetVisible(a bool) { w.visible = a } func (w *Menu) SetVisible(a bool) { w.visible = a }
func (w *Menu) SetX(x int) { w.x = x } func (w *Menu) SetX(x int) { w.x = x }

View File

@@ -199,11 +199,12 @@ func (w *MenuItem) Draw(screen tcell.Screen) {
func (w *MenuItem) SetStyle(s tcell.Style) { w.style = s } func (w *MenuItem) SetStyle(s tcell.Style) { w.style = s }
func (w *MenuItem) Active() bool { return w.active } func (w *MenuItem) Active() bool { return w.active }
func (w *MenuItem) SetActive(a bool) { func (w *MenuItem) SetActive(a bool) bool {
w.active = a w.active = a
if !w.manualExpand { if !w.manualExpand {
w.expanded = a w.expanded = a
} }
return w.active
} }
func (w *MenuItem) Visible() bool { return w.visible } func (w *MenuItem) Visible() bool { return w.visible }
func (w *MenuItem) SetVisible(a bool) { w.visible = a } func (w *MenuItem) SetVisible(a bool) { w.visible = a }

View File

@@ -116,7 +116,10 @@ func (w *Prompt) Draw(screen tcell.Screen) {
func (w *Prompt) SetStyle(s tcell.Style) { w.style = s } func (w *Prompt) SetStyle(s tcell.Style) { w.style = s }
func (w *Prompt) Active() bool { return w.active } func (w *Prompt) Active() bool { return w.active }
func (w *Prompt) SetActive(a bool) { w.active = a } func (w *Prompt) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *Prompt) Visible() bool { return w.visible } func (w *Prompt) Visible() bool { return w.visible }
func (w *Prompt) SetVisible(a bool) { w.visible = a } func (w *Prompt) SetVisible(a bool) { w.visible = a }
func (w *Prompt) SetX(x int) { w.x = x } func (w *Prompt) SetX(x int) { w.x = x }

View File

@@ -114,7 +114,10 @@ func (w *RelativeLayout) Draw(screen tcell.Screen) {
func (w *RelativeLayout) SetStyle(s tcell.Style) { w.style = s } func (w *RelativeLayout) SetStyle(s tcell.Style) { w.style = s }
func (w *RelativeLayout) Active() bool { return w.active } func (w *RelativeLayout) Active() bool { return w.active }
func (w *RelativeLayout) SetActive(a bool) { w.active = a } func (w *RelativeLayout) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *RelativeLayout) Visible() bool { return w.visible } func (w *RelativeLayout) Visible() bool { return w.visible }
func (w *RelativeLayout) SetVisible(a bool) { w.visible = a } func (w *RelativeLayout) SetVisible(a bool) { w.visible = a }
func (w *RelativeLayout) Focusable() bool { return w.focusable } func (w *RelativeLayout) Focusable() bool { return w.focusable }

View File

@@ -259,9 +259,10 @@ func (w *Searcher) buildBuffer() {
func (w *Searcher) SetStyle(s tcell.Style) { w.style = s } func (w *Searcher) SetStyle(s tcell.Style) { w.style = s }
func (w *Searcher) Active() bool { return w.active } func (w *Searcher) Active() bool { return w.active }
func (w *Searcher) SetActive(a bool) { func (w *Searcher) SetActive(a bool) bool {
w.active = a w.active = a
w.search.SetActive(a) w.search.SetActive(a)
return w.active
} }
func (w *Searcher) Visible() bool { return w.visible } func (w *Searcher) Visible() bool { return w.visible }
func (w *Searcher) SetVisible(a bool) { w.visible = a } func (w *Searcher) SetVisible(a bool) { w.visible = a }

View File

@@ -48,11 +48,11 @@ func (w *ShrinkWrap) Draw(screen tcell.Screen) { w.widget.Draw(screen)
func (w *ShrinkWrap) SetStyle(s tcell.Style) { w.widget.SetStyle(s) } func (w *ShrinkWrap) SetStyle(s tcell.Style) { w.widget.SetStyle(s) }
func (w *ShrinkWrap) Active() bool { return w.widget.Active() } func (w *ShrinkWrap) Active() bool { return w.widget.Active() }
func (w *ShrinkWrap) SetActive(a bool) { w.widget.SetActive(a) } func (w *ShrinkWrap) SetActive(a bool) bool {
return w.widget.SetActive(a)
}
func (w *ShrinkWrap) Visible() bool { return w.widget.Visible() } func (w *ShrinkWrap) Visible() bool { return w.widget.Visible() }
func (w *ShrinkWrap) SetVisible(v bool) { w.widget.SetVisible(v) } func (w *ShrinkWrap) SetVisible(v bool) { w.widget.SetVisible(v) }
func (w *ShrinkWrap) Focusable() bool { return w.widget.Focusable() }
func (w *ShrinkWrap) SetFocusable(t bool) { w.widget.SetFocusable(t) }
func (w *ShrinkWrap) SetX(x int) { w.widget.SetX(x) } func (w *ShrinkWrap) SetX(x int) { w.widget.SetX(x) }
func (w *ShrinkWrap) SetY(y int) { w.widget.SetY(y) } func (w *ShrinkWrap) SetY(y int) { w.widget.SetY(y) }
func (w *ShrinkWrap) GetX() int { return w.widget.GetX() } func (w *ShrinkWrap) GetX() int { return w.widget.GetX() }

View File

@@ -187,7 +187,10 @@ func (w *SimpleList) Draw(screen tcell.Screen) {
func (w *SimpleList) SetStyle(s tcell.Style) { w.style = s } func (w *SimpleList) SetStyle(s tcell.Style) { w.style = s }
func (w *SimpleList) Active() bool { return w.active } func (w *SimpleList) Active() bool { return w.active }
func (w *SimpleList) SetActive(a bool) { w.active = a } func (w *SimpleList) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *SimpleList) Visible() bool { return w.visible } func (w *SimpleList) Visible() bool { return w.visible }
func (w *SimpleList) SetVisible(a bool) { w.visible = a } func (w *SimpleList) SetVisible(a bool) { w.visible = a }
func (w *SimpleList) SetX(x int) { w.x = x } func (w *SimpleList) SetX(x int) { w.x = x }
@@ -228,7 +231,7 @@ func (w *SimpleList) MinW() int {
func (w *SimpleList) MinH() int { return 4 } func (w *SimpleList) MinH() int { return 4 }
func (w *SimpleList) getItemAt(idx int) { func (w *SimpleList) getItemAt(idx int) {
for idx >= len(w.List) { for idx >= len(w.list) {
idx-- idx--
} }

View File

@@ -86,9 +86,9 @@ func (w *SimpleListWithHelp) Draw(screen tcell.Screen) {
func (w *SimpleListWithHelp) SetStyle(s tcell.Style) { w.style = s } func (w *SimpleListWithHelp) SetStyle(s tcell.Style) { w.style = s }
func (w *SimpleListWithHelp) Active() bool { return w.list.Active() } func (w *SimpleListWithHelp) Active() bool { return w.list.Active() }
func (w *SimpleListWithHelp) SetActive(a bool) { func (w *SimpleListWithHelp) SetActive(a bool) bool {
w.list.SetActive(a)
w.help.SetVisible(a) w.help.SetVisible(a)
return w.list.SetActive(a)
} }
func (w *SimpleListWithHelp) Visible() bool { return w.visible } func (w *SimpleListWithHelp) Visible() bool { return w.visible }
func (w *SimpleListWithHelp) SetVisible(a bool) { w.visible = a } func (w *SimpleListWithHelp) SetVisible(a bool) { w.visible = a }

View File

@@ -80,7 +80,7 @@ func (w *Spinner) Draw(screen tcell.Screen) {
func (w *Spinner) SetStyle(s tcell.Style) { w.style = s } func (w *Spinner) SetStyle(s tcell.Style) { w.style = s }
func (w *Spinner) Active() bool { return false } func (w *Spinner) Active() bool { return false }
func (w *Spinner) SetActive(a bool) {} func (w *Spinner) SetActive(a bool) bool { return false }
func (w *Spinner) Visible() bool { return w.visible } func (w *Spinner) Visible() bool { return w.visible }
func (w *Spinner) SetVisible(v bool) { w.visible = v } func (w *Spinner) SetVisible(v bool) { w.visible = v }
func (w *Spinner) Focusable() bool { return false } func (w *Spinner) Focusable() bool { return false }

View File

@@ -79,8 +79,7 @@ func (w *ScrollingWidgetList) Init(id string, s tcell.Style) {
if active == nil && len(w.widgets) > 0 { if active == nil && len(w.widgets) > 0 {
// No widget is active, but we do have some // No widget is active, but we do have some
for i := range w.widgets { for i := range w.widgets {
if w.widgets[i].Focusable() { if w.widgets[i].SetActive(true) {
w.widgets[i].SetActive(true)
return true return true
} }
} }
@@ -93,8 +92,7 @@ func (w *ScrollingWidgetList) Init(id string, s tcell.Style) {
if active == nil && len(w.widgets) > 0 { if active == nil && len(w.widgets) > 0 {
// No widget is active, but we do have some // No widget is active, but we do have some
for i := len(w.widgets) - 1; i >= 0; i-- { for i := len(w.widgets) - 1; i >= 0; i-- {
if w.widgets[i].Focusable() { if w.widgets[i].SetActive(true) {
w.widgets[i].SetActive(true)
return true return true
} }
} }
@@ -155,7 +153,7 @@ func (w *ScrollingWidgetList) Draw(screen tcell.Screen) {
func (w *ScrollingWidgetList) SetStyle(s tcell.Style) { w.style = s } func (w *ScrollingWidgetList) SetStyle(s tcell.Style) { w.style = s }
func (w *ScrollingWidgetList) Active() bool { return w.active } func (w *ScrollingWidgetList) Active() bool { return w.active }
func (w *ScrollingWidgetList) SetActive(a bool) { func (w *ScrollingWidgetList) SetActive(a bool) bool {
w.active = a w.active = a
if w.active { if w.active {
act := w.findActiveOrFirst() act := w.findActiveOrFirst()
@@ -163,11 +161,10 @@ func (w *ScrollingWidgetList) SetActive(a bool) {
act.SetActive(true) act.SetActive(true)
} }
} }
return w.active
} }
func (w *ScrollingWidgetList) Visible() bool { return w.visible } func (w *ScrollingWidgetList) Visible() bool { return w.visible }
func (w *ScrollingWidgetList) SetVisible(a bool) { w.visible = a } func (w *ScrollingWidgetList) SetVisible(a bool) { w.visible = a }
func (w *ScrollingWidgetList) Focusable() bool { return w.focusable }
func (w *ScrollingWidgetList) SetFocusable(b bool) { w.focusable = b }
func (w *ScrollingWidgetList) SetX(x int) { w.x = x } func (w *ScrollingWidgetList) SetX(x int) { w.x = x }
func (w *ScrollingWidgetList) SetY(y int) { w.y = y } func (w *ScrollingWidgetList) SetY(y int) { w.y = y }
func (w *ScrollingWidgetList) GetX() int { return w.x } func (w *ScrollingWidgetList) GetX() int { return w.x }
@@ -283,8 +280,7 @@ func (w *ScrollingWidgetList) ActivateWidget(n Widget) {
func (w *ScrollingWidgetList) ActivateNext() bool { func (w *ScrollingWidgetList) ActivateNext() bool {
var found bool var found bool
for i := range w.widgets { for i := range w.widgets {
if found && w.widgets[i].Focusable() { if found && w.widgets[i].SetActive(true) {
w.widgets[i].SetActive(true)
return true return true
} else if w.widgets[i].Active() { } else if w.widgets[i].Active() {
found = true found = true
@@ -297,8 +293,7 @@ func (w *ScrollingWidgetList) ActivateNext() bool {
func (w *ScrollingWidgetList) ActivatePrev() bool { func (w *ScrollingWidgetList) ActivatePrev() bool {
var found bool var found bool
for i := len(w.widgets) - 1; i >= 0; i-- { for i := len(w.widgets) - 1; i >= 0; i-- {
if found && w.widgets[i].Focusable() { if found && w.widgets[i].SetActive(true) {
w.widgets[i].SetActive(true)
return true return true
} else if w.widgets[i].Active() { } else if w.widgets[i].Active() {
found = true found = true

View File

@@ -151,7 +151,10 @@ func (w *Table) Draw(screen tcell.Screen) {
func (w *Table) SetStyle(s tcell.Style) { w.style = s } func (w *Table) SetStyle(s tcell.Style) { w.style = s }
func (w *Table) Active() bool { return w.active } func (w *Table) Active() bool { return w.active }
func (w *Table) SetActive(a bool) { w.active = a } func (w *Table) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *Table) Visible() bool { return w.visible } func (w *Table) Visible() bool { return w.visible }
func (w *Table) SetVisible(a bool) { w.visible = a } func (w *Table) SetVisible(a bool) { w.visible = a }
func (w *Table) SetX(x int) { w.x = x } func (w *Table) SetX(x int) { w.x = x }

View File

@@ -84,7 +84,10 @@ func (w *Text) Draw(screen tcell.Screen) {
func (w *Text) SetStyle(s tcell.Style) { w.style = s } func (w *Text) SetStyle(s tcell.Style) { w.style = s }
func (w *Text) Active() bool { return w.active } func (w *Text) Active() bool { return w.active }
func (w *Text) SetActive(a bool) { w.active = a } func (w *Text) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *Text) Visible() bool { return w.visible } func (w *Text) Visible() bool { return w.visible }
func (w *Text) SetVisible(a bool) { w.visible = a } func (w *Text) SetVisible(a bool) { w.visible = a }
func (w *Text) SetX(x int) { w.x = x } func (w *Text) SetX(x int) { w.x = x }

View File

@@ -183,7 +183,10 @@ func (w *TimeField) Draw(screen tcell.Screen) {
func (w *TimeField) SetStyle(s tcell.Style) { w.style = s } func (w *TimeField) SetStyle(s tcell.Style) { w.style = s }
func (w *TimeField) Active() bool { return w.active } func (w *TimeField) Active() bool { return w.active }
func (w *TimeField) SetActive(a bool) { w.active = a } func (w *TimeField) SetActive(a bool) bool {
w.active = a
return w.active
}
func (w *TimeField) Visible() bool { return w.visible } func (w *TimeField) Visible() bool { return w.visible }
func (w *TimeField) SetVisible(a bool) { w.visible = a } func (w *TimeField) SetVisible(a bool) { w.visible = a }
func (w *TimeField) SetX(x int) { w.x = x } func (w *TimeField) SetX(x int) { w.x = x }

View File

@@ -89,6 +89,28 @@ func (w *TopMenuLayout) ToggleMenu() bool {
return false return false
} }
func (w *TopMenuLayout) ShowMenu() bool {
if w.menu != nil {
w.menu.SetActive(true)
if w.widget != nil {
w.widget.SetActive(false)
}
return true
}
return false
}
func (w *TopMenuLayout) HideMenu() bool {
if w.menu != nil {
w.menu.SetActive(false)
if w.widget != nil {
w.widget.SetActive(true)
}
return true
}
return false
}
func (w *TopMenuLayout) Id() string { return w.id } func (w *TopMenuLayout) Id() string { return w.id }
func (w *TopMenuLayout) HandleResize(ev *tcell.EventResize) { func (w *TopMenuLayout) HandleResize(ev *tcell.EventResize) {
w.w, w.h = ev.Size() w.w, w.h = ev.Size()
@@ -160,11 +182,12 @@ func (w *TopMenuLayout) Draw(screen tcell.Screen) {
func (w *TopMenuLayout) SetStyle(s tcell.Style) { w.style = s } func (w *TopMenuLayout) SetStyle(s tcell.Style) { w.style = s }
func (w *TopMenuLayout) Active() bool { return w.active } func (w *TopMenuLayout) Active() bool { return w.active }
func (w *TopMenuLayout) SetActive(a bool) { func (w *TopMenuLayout) SetActive(a bool) bool {
w.active = a w.active = a
if w.widget != nil { if w.widget != nil {
w.widget.SetActive(a) w.widget.SetActive(a)
} }
return w.active
} }
func (w *TopMenuLayout) Visible() bool { return w.visible } func (w *TopMenuLayout) Visible() bool { return w.visible }
func (w *TopMenuLayout) SetVisible(a bool) { w.visible = a } func (w *TopMenuLayout) SetVisible(a bool) { w.visible = a }

View File

@@ -40,11 +40,9 @@ type Widget interface {
Draw(tcell.Screen) Draw(tcell.Screen)
SetStyle(tcell.Style) SetStyle(tcell.Style)
Active() bool Active() bool
SetActive(bool) SetActive(bool) bool
Visible() bool Visible() bool
SetVisible(bool) SetVisible(bool)
Focusable() bool
SetFocusable(bool)
SetX(int) SetX(int)
SetY(int) SetY(int)
GetX() int GetX() int