new-gui/window.go

51 lines
1.5 KiB
Go

package gui
import (
"git.wit.org/wit/gui/toolkit"
)
//import toolkit "git.wit.org/wit/gui/toolkit/andlabs"
// 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 {
var newNode *Node
var custom func()
// If the user didn't set a custom Exit() use the standard exit() function
// This makes sure the GUI properly closes everything (GTK, QT, console ui, etc exit)
if (Config.Exit != nil) {
log(debugGui, "setting a custom exit")
custom = func() {
log(debugChange, "Running a custom exit()", Config.Exit)
log(debugChange, "Running a custom exit() Config.Title =", Config.Title)
log(debugChange, "Running a custom exit() Config.Width =", Config.Width)
Config.Exit(newNode)
}
} else {
log(debugGui, "setting the standard exit")
custom = func () {
log(debugChange, "Running StandardExit()")
StandardExit()
}
}
// Windows are created off of the master node of the Binary Tree
newNode = Config.rootNode.New(Config.Title, toolkit.Window, custom)
log(logInfo, "NewWindow()", Config.Title)
var a toolkit.Action
a.ActionType = toolkit.Add
a.Width = Config.Width
a.Height = Config.Height
a.Name = Config.Title
a.Text = Config.Title
newaction(&a, newNode, Config.rootNode)
return newNode
}