Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 18ead7b486 |
@@ -32,11 +32,10 @@ type Alert struct {
|
|||||||
id string
|
id string
|
||||||
style tcell.Style
|
style tcell.Style
|
||||||
|
|
||||||
x, y int
|
x, y int
|
||||||
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) {
|
||||||
@@ -131,23 +129,28 @@ func (w *Alert) SetActive(a bool) bool {
|
|||||||
w.active = a
|
w.active = a
|
||||||
return w.active
|
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 }
|
||||||
func (w *Alert) SetY(y int) { w.y = y }
|
func (w *Alert) SetY(y int) { w.y = y }
|
||||||
func (w *Alert) GetX() int { return w.x }
|
func (w *Alert) GetX() int { return w.x }
|
||||||
func (w *Alert) GetY() int { return w.y }
|
func (w *Alert) GetY() int { return w.y }
|
||||||
func (w *Alert) GetPos() Coord { return Coord{X: w.x, Y: 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) SetPos(c Coord) { w.x, w.y = c.X, c.Y }
|
||||||
func (w *Alert) SetW(x int) { w.w = x }
|
func (w *Alert) SetW(x int) { w.w = x }
|
||||||
func (w *Alert) SetH(y int) { w.h = y }
|
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 {
|
||||||
@@ -167,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)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -36,10 +36,9 @@ type Button struct {
|
|||||||
x, y int
|
x, y int
|
||||||
w, h int
|
w, h int
|
||||||
|
|
||||||
active bool
|
active bool
|
||||||
visible bool
|
visible bool
|
||||||
focusable bool
|
keyMap *KeyMap
|
||||||
keyMap *KeyMap
|
|
||||||
|
|
||||||
onPressed func() bool
|
onPressed func() bool
|
||||||
logger func(string, ...any)
|
logger func(string, ...any)
|
||||||
@@ -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) {
|
||||||
@@ -125,25 +123,23 @@ func (w *Button) SetActive(a bool) bool {
|
|||||||
w.active = a
|
w.active = a
|
||||||
return w.active
|
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 }
|
||||||
func (w *Button) SetY(y int) { w.y = y }
|
func (w *Button) SetY(y int) { w.y = y }
|
||||||
func (w *Button) GetX() int { return w.x }
|
func (w *Button) GetX() int { return w.x }
|
||||||
func (w *Button) GetY() int { return w.y }
|
func (w *Button) GetY() int { return w.y }
|
||||||
func (w *Button) GetPos() Coord { return Coord{X: w.x, Y: 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) SetPos(c Coord) { w.x, w.y = c.X, c.Y }
|
||||||
func (w *Button) SetW(x int) { w.w = x }
|
func (w *Button) SetW(x int) { w.w = x }
|
||||||
func (w *Button) SetH(y int) { w.h = y }
|
func (w *Button) SetH(y int) { w.h = y }
|
||||||
func (w *Button) GetW() int { return w.w }
|
func (w *Button) GetW() int { return w.w }
|
||||||
func (w *Button) GetH() int { return w.h }
|
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) MinW() int { return len(w.label) + 2 }
|
||||||
func (w *Button) SetFocusable(b bool) { w.focusable = b }
|
func (w *Button) MinH() int { return 1 }
|
||||||
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) SetLabel(l string) { w.label = l }
|
||||||
func (w *Button) SetOnPressed(p func() bool) { w.onPressed = p }
|
func (w *Button) SetOnPressed(p func() bool) { w.onPressed = p }
|
||||||
|
|||||||
@@ -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 {
|
func (w *TopMenuLayout) ToggleMenu() bool {
|
||||||
if w.menu != nil {
|
if w.menu != nil {
|
||||||
w.menu.SetActive(!w.menu.Active())
|
w.menu.SetActive(!w.menu.Active())
|
||||||
@@ -111,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()
|
||||||
|
|||||||
Reference in New Issue
Block a user