222 lines
5.1 KiB
Go
222 lines
5.1 KiB
Go
package main
|
|
|
|
import (
|
|
"strconv"
|
|
"github.com/andlabs/ui"
|
|
|
|
"go.wit.com/log"
|
|
"go.wit.com/gui/widget"
|
|
)
|
|
|
|
func (n *node) ready() bool {
|
|
if n == nil { return false }
|
|
if n.tk == nil { return false }
|
|
return true
|
|
}
|
|
|
|
func (n *node) show(b bool) {
|
|
if n.tk == nil {
|
|
return
|
|
}
|
|
if n.tk.uiControl == nil {
|
|
return
|
|
}
|
|
if (b) {
|
|
n.tk.uiControl.Show()
|
|
} else {
|
|
n.tk.uiControl.Hide()
|
|
}
|
|
}
|
|
|
|
func (n *node) enable(b bool) {
|
|
if n == nil {
|
|
panic("WHAT? enable was passed nil. How does this even happen?")
|
|
}
|
|
if n.tk == nil {
|
|
return
|
|
}
|
|
if n.tk.uiControl == nil {
|
|
return
|
|
}
|
|
if (b) {
|
|
n.tk.uiControl.Enable()
|
|
} else {
|
|
n.tk.uiControl.Disable()
|
|
}
|
|
}
|
|
|
|
func (n *node) pad(b bool) {
|
|
log.Warn("pad() on WidgetId =", n.WidgetId)
|
|
|
|
t := n.tk
|
|
if (t == nil) {
|
|
log.Log(ERROR, "pad() toolkit struct == nil. for", n.WidgetId)
|
|
return
|
|
}
|
|
|
|
switch n.WidgetType {
|
|
case widget.Group:
|
|
t.uiGroup.SetMargined(b)
|
|
case widget.Tab:
|
|
tabSetMargined(t.uiTab, b)
|
|
case widget.Window:
|
|
t.uiWindow.SetMargined(b)
|
|
t.uiWindow.SetBorderless(b)
|
|
case widget.Grid:
|
|
t.uiGrid.SetPadded(b)
|
|
case widget.Box:
|
|
t.uiBox.SetPadded(b)
|
|
default:
|
|
log.Log(ERROR, "TODO: implement pad() for", n.WidgetType, n.progname)
|
|
}
|
|
}
|
|
|
|
func (n *node) move(newParent *node) {
|
|
p := n.parent
|
|
|
|
switch p.WidgetType {
|
|
case widget.Group:
|
|
case widget.Tab:
|
|
// tabSetMargined(tParent.uiTab, true)
|
|
case widget.Window:
|
|
// t.uiWindow.SetBorderless(false)
|
|
case widget.Grid:
|
|
// t.uiGrid.SetPadded(true)
|
|
case widget.Box:
|
|
log.Log(INFO, "TODO: move() where =", p.ParentId)
|
|
log.Log(INFO, "TODO: move() for widget =", n.WidgetId)
|
|
|
|
stretchy = true
|
|
if (p.tk.uiBox != nil) {
|
|
p.tk.uiBox.Append(n.tk.uiControl, stretchy)
|
|
}
|
|
default:
|
|
log.Log(ERROR, "TODO: need to implement move() for type =", n.WidgetType)
|
|
log.Log(ERROR, "TODO: need to implement move() for where =", p.ParentId)
|
|
log.Log(ERROR, "TODO: need to implement move() for widget =", n.WidgetId)
|
|
}
|
|
}
|
|
|
|
func (n *node) Delete() {
|
|
p := n.parent
|
|
log.Log(NOW, "uiDelete()", n.WidgetId, "to", p.WidgetId)
|
|
|
|
switch p.WidgetType {
|
|
case widget.Group:
|
|
// tParent.uiGroup.SetMargined(true)
|
|
case widget.Tab:
|
|
// tabSetMargined(tParent.uiTab, true)
|
|
case widget.Window:
|
|
// t.uiWindow.SetBorderless(false)
|
|
case widget.Grid:
|
|
// t.uiGrid.SetPadded(true)
|
|
case widget.Box:
|
|
log.Log(NOW, "tWidget.boxC =", p.progname)
|
|
log.Log(NOW, "is there a tParent parent? =", p.parent)
|
|
if (p.tk.boxC < 1) {
|
|
log.Log(NOW, "Can not delete from Box. already empty. tWidget.boxC =", p.tk.boxC)
|
|
return
|
|
}
|
|
p.tk.uiBox.Delete(0)
|
|
p.tk.boxC -= 1
|
|
|
|
// this didn't work:
|
|
// tWidget.uiControl.Disable()
|
|
// sleep(.8)
|
|
// tParent.uiBox.Append(tWidget.uiControl, stretchy)
|
|
default:
|
|
log.Log(ERROR, "TODO: need to implement uiDelete() for widget =", n.WidgetId, n.WidgetType)
|
|
log.Log(ERROR, "TODO: need to implement uiDelete() for parent =", p.WidgetId, p.WidgetType)
|
|
}
|
|
}
|
|
|
|
func rawAction(a *widget.Action) {
|
|
log.Log(INFO, "rawAction() START a.ActionType =", a.ActionType, "a.Value", a.Value)
|
|
|
|
if (a.ActionType == widget.InitToolkit) {
|
|
// TODO: make sure to only do this once
|
|
// go uiMain.Do(func() {
|
|
// ui.Main(demoUI)
|
|
// go catchActionChannel()
|
|
// })
|
|
// try doing this on toolkit load in init()
|
|
return
|
|
}
|
|
|
|
log.Log(INFO, "rawAction() START a.WidgetId =", a.WidgetId, "a.ParentId =", a.ParentId)
|
|
switch a.WidgetType {
|
|
case widget.Flag:
|
|
log.Log(ERROR, "rawAction() RE-IMPLEMENT LOG FLAGS")
|
|
return
|
|
}
|
|
|
|
n := me.rootNode.findWidgetId(a.WidgetId)
|
|
|
|
if (a.ActionType == widget.Add) {
|
|
ui.QueueMain(func() {
|
|
add(a)
|
|
})
|
|
// TODO: remove this artificial delay
|
|
// sleep(.001)
|
|
return
|
|
}
|
|
|
|
if (a.ActionType == widget.Dump) {
|
|
log.Log(NOW, "rawAction() Dump =", a.ActionType, a.WidgetType, n.progname)
|
|
me.rootNode.listChildren(true)
|
|
return
|
|
}
|
|
|
|
if (n == nil) {
|
|
me.rootNode.listChildren(true)
|
|
log.Log(NOW, "rawAction() ERROR findWidgetId found nil", a.ActionType, a.WidgetType)
|
|
log.Log(NOW, "rawAction() ERROR findWidgetId found nil for id =", a.WidgetId)
|
|
log.Log(NOW, "rawAction() ERROR findWidgetId found nil", a.ActionType, a.WidgetType)
|
|
log.Log(NOW, "rawAction() ERROR findWidgetId found nil for id =", a.WidgetId)
|
|
return
|
|
panic("findWidgetId found nil for id = " + strconv.Itoa(a.WidgetId))
|
|
}
|
|
|
|
switch a.ActionType {
|
|
case widget.Show:
|
|
n.show(true)
|
|
case widget.Hide:
|
|
n.show(false)
|
|
case widget.Enable:
|
|
n.enable(true)
|
|
case widget.Disable:
|
|
log.Warn("andlabs got disable for", n.WidgetId, n.progname)
|
|
n.enable(false)
|
|
case widget.Get:
|
|
n.setText(a)
|
|
case widget.GetText:
|
|
switch a.WidgetType {
|
|
case widget.Textbox:
|
|
a.Value = n.value
|
|
}
|
|
case widget.Set:
|
|
n.setText(a)
|
|
case widget.SetText:
|
|
n.setText(a)
|
|
case widget.AddText:
|
|
n.addText(a)
|
|
case widget.Margin:
|
|
n.pad(true)
|
|
case widget.Unmargin:
|
|
n.pad(false)
|
|
case widget.Pad:
|
|
n.pad(true)
|
|
case widget.Unpad:
|
|
n.pad(false)
|
|
case widget.Delete:
|
|
n.Delete()
|
|
case widget.Move:
|
|
log.Log(NOW, "rawAction() attempt to move() =", a.ActionType, a.WidgetType)
|
|
newParent := me.rootNode.findWidgetId(a.ParentId)
|
|
n.move(newParent)
|
|
default:
|
|
log.Log(ERROR, "rawAction() Unknown =", a.ActionType, a.WidgetType)
|
|
}
|
|
log.Log(INFO, "rawAction() END =", a.ActionType, a.WidgetType)
|
|
}
|