222 lines
5.5 KiB
Go
222 lines
5.5 KiB
Go
package gui
|
|
|
|
import (
|
|
"log"
|
|
"fmt"
|
|
"strconv"
|
|
|
|
"github.com/andlabs/ui"
|
|
_ "github.com/andlabs/ui/winmanifest"
|
|
)
|
|
|
|
func MessageWindow(gw *GuiWindow, msg1 string, msg2 string) {
|
|
ui.MsgBox(gw.UiWindow, msg1, msg2)
|
|
}
|
|
|
|
func ErrorWindow(gw *GuiWindow, msg1 string, msg2 string) {
|
|
ui.MsgBoxError(gw.UiWindow, msg1, msg2)
|
|
}
|
|
|
|
func DeleteWindow(name string) {
|
|
log.Println("gui.DeleteWindow() START name =", name)
|
|
window := Data.WindowMap[name]
|
|
if window == nil {
|
|
log.Println("gui.DeleteWindow() NO WINDOW WITH name =", name)
|
|
return
|
|
}
|
|
|
|
log.Println("gui.DumpBoxes() MAP: ", name)
|
|
log.Println("gui.DumpBoxes()\tWindow.name =", window.Name)
|
|
if window.TabNumber == nil {
|
|
log.Println("gui.DumpBoxes() \tWindows.TabNumber = nil")
|
|
}
|
|
tab := *window.TabNumber
|
|
log.Println("gui.DumpBoxes() \tWindows.TabNumber =", tab)
|
|
log.Println("gui.DumpBoxes() \tSHOULD DELETE TAB", tab, "HERE")
|
|
log.Println("gui.DeleteWindow() \tSHOULD DELETE TAB", tab, "HERE")
|
|
log.Println("gui.DumpBoxes() \tUiTab =", window.UiTab)
|
|
tabnum := window.UiTab.NumPages()
|
|
log.Println("gui.DumpBoxes() \tUiTab.NumPages() =", tabnum)
|
|
if (tabnum > 0) {
|
|
window.UiTab.Delete(tab)
|
|
}
|
|
delete(Data.WindowMap, name)
|
|
|
|
// renumber tabs here
|
|
for name, window := range Data.WindowMap {
|
|
log.Println("gui.DumpBoxes() MAP: ", name)
|
|
if window.TabNumber == nil {
|
|
log.Println("gui.DumpBoxes() \tWindows.TabNumber = nil")
|
|
} else {
|
|
log.Println("gui.DumpBoxes() \tWindows.TabNumber =", *window.TabNumber)
|
|
if tab < *window.TabNumber {
|
|
log.Println("gui.DumpBoxes() \tSubtracting 1 from TabNumber")
|
|
*window.TabNumber -= 1
|
|
log.Println("gui.DumpBoxes() \tWindows.TabNumber is now =", *window.TabNumber)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/*
|
|
generic function to create a newnode structure on the tree of nodes
|
|
|
|
If the parent is null, it tries to find out where it should go otherwise
|
|
it creates a new window or new tab depending on the toolkit or OS
|
|
*/
|
|
func makeNode(parent *Node, title string, x int, y int) *Node {
|
|
var node Node
|
|
node.Name = title
|
|
node.Width = x
|
|
node.Height = y
|
|
|
|
id := Config.prefix + strconv.Itoa(Config.counter)
|
|
Config.counter += 1
|
|
node.id = id
|
|
|
|
// panic("gui.makeNode() START")
|
|
if (parent == nil) {
|
|
if (Data.NodeMap[title] != nil) {
|
|
log.Println("Duplicate window name =", title)
|
|
// TODO: just change the 'title' to something unique
|
|
panic(fmt.Sprintf("Duplicate window name = %s\n", title))
|
|
return nil
|
|
}
|
|
// panic("gui.makeNode() before NodeMap()")
|
|
Data.NodeMap[title] = &node
|
|
Data.NodeArray = append(Data.NodeArray, &node)
|
|
Data.NodeSlice = append(Data.NodeSlice, &node)
|
|
// panic("gui.makeNode() after NodeMap()")
|
|
return &node
|
|
} else {
|
|
// panic("gui.makeNode() before Append()")
|
|
parent.Append(&node)
|
|
// panic("gui.makeNode() after Append()")
|
|
}
|
|
node.parent = parent
|
|
return &node
|
|
}
|
|
|
|
func (parent *Node) makeNode(title string, x int, y int) *Node {
|
|
var node Node
|
|
node.Name = title
|
|
node.Width = x
|
|
node.Height = y
|
|
|
|
id := Config.prefix + strconv.Itoa(Config.counter)
|
|
Config.counter += 1
|
|
node.id = id
|
|
|
|
parent.Append(&node)
|
|
node.parent = parent
|
|
return &node
|
|
}
|
|
|
|
func (n *Node) AddNode(title string) *Node {
|
|
var node Node
|
|
node.Name = title
|
|
node.Width = n.Width
|
|
node.Height = n.Height
|
|
|
|
id := Config.prefix + strconv.Itoa(Config.counter)
|
|
Config.counter += 1
|
|
node.id = id
|
|
|
|
n.Append(&node)
|
|
node.parent = n
|
|
return &node
|
|
}
|
|
|
|
func (n *Node) uiNewWindow(title string, x int, y int) {
|
|
w := ui.NewWindow(title, x, y, false)
|
|
w.SetBorderless(false)
|
|
f := Config.Exit
|
|
w.OnClosing(func(*ui.Window) bool {
|
|
if (Config.Debug) {
|
|
log.Println("ui.Window().OnClosing()")
|
|
}
|
|
if (f != nil) {
|
|
f(n)
|
|
}
|
|
return true
|
|
})
|
|
w.SetMargined(true)
|
|
w.Show()
|
|
n.uiWindow = w
|
|
// w.node = &node
|
|
return
|
|
}
|
|
|
|
func mapWindow(parent *Node, window *ui.Window, title string, x int, y int) *Node {
|
|
log.Println("gui.WindowMap START title =", title)
|
|
if Data.WindowMap[title] != nil {
|
|
log.Println("Data.WindowMap[title] already exists title =", title)
|
|
title = title + Config.prefix + strconv.Itoa(Config.counter)
|
|
Config.counter += 1
|
|
}
|
|
if Data.WindowMap[title] != nil {
|
|
log.Println("Data.WindowMap[title] already exists title =", title)
|
|
panic("Data.WindowMap[newGuiWindow.Name] already exists")
|
|
return nil
|
|
}
|
|
|
|
var newGuiWindow GuiWindow
|
|
newGuiWindow.Width = x
|
|
newGuiWindow.Height = y
|
|
newGuiWindow.Name = title
|
|
newGuiWindow.UiWindow = window
|
|
|
|
newGuiWindow.BoxMap = make(map[string]*GuiBox)
|
|
newGuiWindow.EntryMap = make(map[string]*GuiEntry)
|
|
|
|
Data.WindowMap[newGuiWindow.Name] = &newGuiWindow
|
|
|
|
var box GuiBox
|
|
box.Window = &newGuiWindow
|
|
box.Name = title
|
|
|
|
node := makeNode(parent, title, x, y)
|
|
node.box = &box
|
|
node.uiWindow = window
|
|
box.node = node
|
|
|
|
newGuiWindow.BoxMap["jcarrInitTest"] = &box
|
|
|
|
return node
|
|
}
|
|
|
|
// This routine creates a blank window with a Title and size (W x H)
|
|
//
|
|
// This routine can not have any arguements due to the nature of how
|
|
// it can be passed via the 'andlabs/ui' queue which, because it is
|
|
// cross platform, must pass UI changes into the OS threads (that is
|
|
// my guess).
|
|
func NewWindow() *Node {
|
|
title := Config.Title
|
|
w := Config.Width
|
|
h := Config.Height
|
|
|
|
var n *Node
|
|
n = mapWindow(nil, nil, title, w, h)
|
|
box := n.box
|
|
log.Println("gui.NewWindow() title = box.Name =", box.Name)
|
|
|
|
n.uiNewWindow(box.Name, w, h)
|
|
window := n.uiWindow
|
|
|
|
f := Config.Exit
|
|
ui.OnShouldQuit(func() bool {
|
|
log.Println("createWindow().Destroy() on node.Name =", n.Name)
|
|
if (f != nil) {
|
|
f(n)
|
|
}
|
|
return true
|
|
})
|
|
|
|
box.Window.UiWindow = window
|
|
if(n.uiWindow == nil) {
|
|
panic("node.uiWindow == nil. This should never happen")
|
|
}
|
|
return n
|
|
}
|