diff --git a/wdgt_alert.go b/wdgt_alert.go index 8ae2124..0f33733 100644 --- a/wdgt_alert.go +++ b/wdgt_alert.go @@ -32,11 +32,10 @@ type Alert struct { id string style tcell.Style - x, y int - w, h int - active bool - visible bool - focusable bool + x, y int + w, h int + active bool + visible bool layout *LinearLayout title string @@ -90,7 +89,6 @@ func (w *Alert) Init(id string, style tcell.Style) { NewKey(BuildEK(tcell.KeyUp), w.SelectNext), NewKey(BuildEK(tcell.KeyEnter), w.Do), ) - w.focusable = true } func (w *Alert) Id() string { return w.id } func (w *Alert) HandleResize(ev *tcell.EventResize) { @@ -131,23 +129,28 @@ func (w *Alert) SetActive(a bool) bool { w.active = a return w.active } -func (w *Alert) Visible() bool { return w.visible } -func (w *Alert) SetVisible(a bool) { w.visible = a } -func (w *Alert) SetX(x int) { w.x = x } -func (w *Alert) SetY(y int) { w.y = y } -func (w *Alert) GetX() int { return w.x } -func (w *Alert) GetY() int { return w.y } -func (w *Alert) GetPos() Coord { return Coord{X: w.x, Y: w.y} } -func (w *Alert) SetPos(c Coord) { w.x, w.y = c.X, c.Y } -func (w *Alert) SetW(x int) { w.w = x } -func (w *Alert) SetH(y int) { w.h = y } -func (w *Alert) GetW() int { return w.w } -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) Focusable() bool { return w.focusable } -func (w *Alert) SetFocusable(b bool) { w.focusable = b } +func (w *Alert) Visible() bool { return w.visible } +func (w *Alert) SetVisible(a bool) { w.visible = a } +func (w *Alert) SetX(x int) { w.x = x } +func (w *Alert) SetY(y int) { w.y = y } +func (w *Alert) GetX() int { return w.x } +func (w *Alert) GetY() int { return w.y } +func (w *Alert) GetPos() Coord { return Coord{X: w.x, Y: w.y} } +func (w *Alert) SetPos(c Coord) { w.x, w.y = c.X, c.Y } +func (w *Alert) SetW(x int) { w.w = x } +func (w *Alert) SetH(y int) { w.h = y } +func (w *Alert) GetW() int { return w.w } +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) 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 { @@ -167,13 +170,11 @@ func (w *Alert) SetMessage(msg string) { w.message.SetText(msg) } func (w *Alert) SetOkPressed(b func() bool) { w.btnOk.SetVisible(b != nil) - w.btnOk.SetFocusable(b != nil) w.btnOk.SetOnPressed(b) } func (w *Alert) SetCancelPressed(b func() bool) { w.btnCancel.SetVisible(b != nil) - w.btnCancel.SetFocusable(b != nil) w.btnCancel.SetOnPressed(b) } diff --git a/wdgt_button.go b/wdgt_button.go index 69ec6fe..bd8ca9f 100644 --- a/wdgt_button.go +++ b/wdgt_button.go @@ -36,10 +36,9 @@ type Button struct { x, y int w, h int - active bool - visible bool - focusable bool - keyMap *KeyMap + active bool + visible bool + keyMap *KeyMap onPressed func() bool logger func(string, ...any) @@ -59,7 +58,6 @@ func (w *Button) Init(id string, style tcell.Style) { w.visible = true w.keyMap = NewKeyMap(NewKey(BuildEK(tcell.KeyEnter), func(ev *tcell.EventKey) bool { return w.onPressed() })) w.onPressed = func() bool { return false } - w.focusable = true } func (w *Button) Id() string { return w.id } func (w *Button) HandleResize(ev *tcell.EventResize) { @@ -125,25 +123,23 @@ func (w *Button) SetActive(a bool) bool { w.active = a return w.active } -func (w *Button) Visible() bool { return w.visible } -func (w *Button) SetVisible(a bool) { w.visible = a } -func (w *Button) SetX(x int) { w.x = x } -func (w *Button) SetY(y int) { w.y = y } -func (w *Button) GetX() int { return w.x } -func (w *Button) GetY() int { return w.y } -func (w *Button) GetPos() Coord { return Coord{X: w.x, Y: w.y} } -func (w *Button) SetPos(c Coord) { w.x, w.y = c.X, c.Y } -func (w *Button) SetW(x int) { w.w = x } -func (w *Button) SetH(y int) { w.h = y } -func (w *Button) GetW() int { return w.w } -func (w *Button) GetH() int { return w.h } -func (w *Button) WantW() int { return 4 + len(w.label) } -func (w *Button) WantH() int { return 3 } -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) MinH() int { return 1 } +func (w *Button) Visible() bool { return w.visible } +func (w *Button) SetVisible(a bool) { w.visible = a } +func (w *Button) SetX(x int) { w.x = x } +func (w *Button) SetY(y int) { w.y = y } +func (w *Button) GetX() int { return w.x } +func (w *Button) GetY() int { return w.y } +func (w *Button) GetPos() Coord { return Coord{X: w.x, Y: w.y} } +func (w *Button) SetPos(c Coord) { w.x, w.y = c.X, c.Y } +func (w *Button) SetW(x int) { w.w = x } +func (w *Button) SetH(y int) { w.h = y } +func (w *Button) GetW() int { return w.w } +func (w *Button) GetH() int { return w.h } +func (w *Button) WantW() int { return 4 + len(w.label) } +func (w *Button) WantH() int { return 3 } +func (w *Button) SetSize(c Coord) { w.w, w.h = c.X, c.Y } +func (w *Button) MinW() int { return len(w.label) + 2 } +func (w *Button) MinH() int { return 1 } func (w *Button) SetLabel(l string) { w.label = l } func (w *Button) SetOnPressed(p func() bool) { w.onPressed = p } diff --git a/wdgt_top_menu_layout.go b/wdgt_top_menu_layout.go index 99a87f3..50fd5f1 100644 --- a/wdgt_top_menu_layout.go +++ b/wdgt_top_menu_layout.go @@ -78,28 +78,6 @@ func (w *TopMenuLayout) Init(id string, s tcell.Style) { ) } -func (w *TopMenuLayout) HideMenu() bool { - if w.menu == nil { - return false - } - w.menu.SetActive(false) - if w.widget != nil { - w.widget.SetActive(true) - } - return true -} - -func (w *TopMenuLayout) ShowMenu() bool { - if w.menu == nil { - return false - } - w.menu.SetActive(true) - if w.widget != nil { - w.widget.SetActive(false) - } - return true -} - func (w *TopMenuLayout) ToggleMenu() bool { if w.menu != nil { w.menu.SetActive(!w.menu.Active()) @@ -111,6 +89,28 @@ func (w *TopMenuLayout) ToggleMenu() bool { 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) HandleResize(ev *tcell.EventResize) { w.w, w.h = ev.Size()