summaryrefslogtreecommitdiff
path: root/window.go
diff options
context:
space:
mode:
authorJeff Carr <[email protected]>2019-06-03 19:07:39 -0700
committerJeff Carr <[email protected]>2019-06-03 19:07:39 -0700
commit5c6b5571dec0276a6ad985f8823e7ae77893938d (patch)
tree65b77db845d05774e0533dbcac474cefdb08e70b /window.go
parent70779ab33b662d3e7849133f57521c2ce217bf96 (diff)
fixed a commit
Diffstat (limited to 'window.go')
-rw-r--r--window.go82
1 files changed, 82 insertions, 0 deletions
diff --git a/window.go b/window.go
new file mode 100644
index 0000000..0100778
--- /dev/null
+++ b/window.go
@@ -0,0 +1,82 @@
+package gui
+
+import "log"
+import "time"
+// import "regexp"
+
+import "github.com/andlabs/ui"
+import _ "github.com/andlabs/ui/winmanifest"
+
+func InitGuiWindow(action string, gw *GuiWindow) *GuiWindow {
+ log.Println("InitGuiWindow() START")
+ var newGuiWindow GuiWindow
+ newGuiWindow.Width = Config.Width
+ newGuiWindow.Height = Config.Height
+ newGuiWindow.MakeWindow = gw.MakeWindow
+ newGuiWindow.UiWindow = gw.UiWindow
+ newGuiWindow.UiTab = gw.UiTab
+ newGuiWindow.BoxMap = make(map[string]*GuiBox)
+ newGuiWindow.EntryMap = make(map[string]*GuiEntry)
+ newGuiWindow.EntryMap["test"] = nil
+ Data.Windows = append(Data.Windows, &newGuiWindow)
+
+ if (Data.buttonMap == nil) {
+ GuiInit()
+ }
+ log.Println("InitGuiWindow() END *GuiWindow =", &newGuiWindow)
+ return &newGuiWindow
+}
+
+
+func StartNewWindow(bg bool, action string, callback func(*GuiWindow) *GuiBox) {
+ log.Println("StartNewWindow() Create a new window")
+ var junk GuiWindow
+ junk.MakeWindow = callback
+// junk.Action = action
+ window := InitGuiWindow(action, &junk)
+ if (bg) {
+ log.Println("StartNewWindow() START NEW GOROUTINE for ui.Main()")
+ go ui.Main(func() {
+ log.Println("gui.StartNewWindow() inside ui.Main()")
+ go InitTabWindow(window)
+ })
+ time.Sleep(2000 * time.Millisecond) // this might make it more stable on windows?
+ } else {
+ log.Println("StartNewWindow() WAITING for ui.Main()")
+ ui.Main(func() {
+ log.Println("gui.StartNewWindow() inside ui.Main()")
+ InitTabWindow(window)
+ })
+ }
+}
+
+func InitTabWindow(gw *GuiWindow) {
+ log.Println("InitTabWindow() START. THIS WINDOW IS NOT YET SHOWN")
+
+ gw.UiWindow = ui.NewWindow("InitTabWindow()", int(gw.Width), int(gw.Height), true)
+ gw.UiWindow.SetBorderless(false)
+
+ gw.UiWindow.OnClosing(func(*ui.Window) bool {
+ log.Println("InitTabWindow() OnClosing() THIS WINDOW IS CLOSING gw=", gw)
+ ui.Quit()
+ return true
+ })
+
+ gw.UiTab = ui.NewTab()
+ gw.UiWindow.SetChild(gw.UiTab)
+ gw.UiWindow.SetMargined(true)
+
+
+ box := gw.MakeWindow(gw)
+ log.Println("InitTabWindow() END box =", box)
+ log.Println("InitTabWindow() END gw =", gw)
+ gw.UiWindow.Show()
+}
+
+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)
+}