2024-01-01 16:11:54 -06:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2024-01-11 17:19:47 -06:00
|
|
|
"go.wit.com/gui/widget"
|
2024-01-17 21:31:49 -06:00
|
|
|
"go.wit.com/gui/toolkits/tree"
|
2024-01-11 17:19:47 -06:00
|
|
|
|
2024-01-15 16:11:40 -06:00
|
|
|
"go.wit.com/dev/andlabs/ui"
|
|
|
|
_ "go.wit.com/dev/andlabs/ui/winmanifest"
|
2024-01-01 16:11:54 -06:00
|
|
|
)
|
|
|
|
|
|
|
|
// make new Box here
|
2024-01-17 21:31:49 -06:00
|
|
|
func newBox(n *tree.Node) {
|
|
|
|
if notNew(n) { return }
|
2024-01-01 16:11:54 -06:00
|
|
|
newt := new(guiWidget)
|
|
|
|
var box *ui.Box
|
|
|
|
|
2024-01-17 21:31:49 -06:00
|
|
|
if n.State.Direction == widget.Horizontal {
|
2024-01-01 16:11:54 -06:00
|
|
|
box = ui.NewHorizontalBox()
|
|
|
|
} else {
|
|
|
|
box = ui.NewVerticalBox()
|
|
|
|
}
|
2024-01-15 16:11:40 -06:00
|
|
|
box.SetPadded(true)
|
2024-01-01 16:11:54 -06:00
|
|
|
|
|
|
|
newt.uiBox = box
|
|
|
|
newt.uiControl = box
|
|
|
|
newt.boxC = 0
|
2024-01-17 21:31:49 -06:00
|
|
|
n.TK = newt
|
|
|
|
place(n.Parent, n)
|
2024-01-01 16:11:54 -06:00
|
|
|
}
|
2024-01-10 15:35:42 -06:00
|
|
|
|
|
|
|
/*
|
|
|
|
rawBox -- hack to arbitrarily add a box in andlabs to work
|
|
|
|
around the problem that a "group" can not have one entry in it
|
|
|
|
TODO: fix this so that a box is "added on demand" that is,
|
|
|
|
if "go.wit.com/gui/gui" sends you a 2nd thing to add to a group,
|
|
|
|
automatically add a box then. The problem with this, is the macos, windows and linux gtk
|
|
|
|
will panic on a move when an chind object is disasociated from the group
|
|
|
|
I haven't had time to try to debug this, so, instead, it's just probably better to always
|
|
|
|
add a box here. There doesn't seem to be any real issue with forcing a box to be inserted
|
|
|
|
into the toolkits that is "outside" the binary tree of widgets. This only means, that on
|
|
|
|
a destroy of the tree, this box must be checked
|
|
|
|
|
|
|
|
even that is a probably not senario however since clicking on the close box in the toolkit
|
|
|
|
has the operating system destroy everything in the window. it may or may not be possible
|
|
|
|
to control that behavior. at this time, it's "undetermined" and the best course of action
|
|
|
|
is to detect the window is destroyed and then remove all the toolkit information
|
|
|
|
from all the nodes in the binary tree
|
|
|
|
|
|
|
|
TODO: handle user killing/closing a window using the OS
|
|
|
|
*/
|
2024-01-17 21:31:49 -06:00
|
|
|
// func (n *node) rawBox() *ui.Box {
|
|
|
|
func rawBox(n *tree.Node) *ui.Box {
|
2024-01-10 15:35:42 -06:00
|
|
|
var box *ui.Box
|
|
|
|
|
2024-01-17 21:31:49 -06:00
|
|
|
if n.State.Direction == widget.Horizontal {
|
2024-01-10 15:35:42 -06:00
|
|
|
box = ui.NewHorizontalBox()
|
|
|
|
} else {
|
|
|
|
box = ui.NewVerticalBox()
|
|
|
|
}
|
|
|
|
box.SetPadded(true)
|
|
|
|
|
|
|
|
return box
|
|
|
|
}
|