package main

import (
	"log"
	"os"
	"time"

	"git.wit.org/wit/gui"
)

// This initializes the first window
//
// BUG: THIS PROGRAM DOESN'T EXIT PROPERLY (NOT REALLY A BUG)
//
// Then starts a goroutine to demonstrate how to
// inject things into the GUI
func main() {
	log.Println("Starting my Control Panel")

//	gui.Init()
//	go gui.Main(helloworld)
	go gui.Main(gui.DebugWindow)
//	go gui.DemoToolkitWindow()

	watchGUI()
}

// This demonstrates how to properly interact with the GUI
// You can not involke the GUI from external goroutines in most cases.
func watchGUI() {
	var i = 1
	for {
		log.Println("Waiting", i, "seconds")
		i += 1
		time.Sleep(1 * time.Second)
		if i == 2 {
			log.Println("Opening a Debug Window via the gui.Queue()")
			gui.Config.Width = 800
			gui.Config.Height = 300
			gui.Config.Exit = myExit
			// gui.DebugWindow()
			time.Sleep(1 * time.Second)
			// gui.DebugTab()
		}
	}
}

// TODO: myExit isn't getting used anymore
func myExit(n *gui.Node) {
	log.Println()
	log.Println("Entered myExit() on node.Name =", n.Name)
	log.Println()
	os.Exit(0)
}