summaryrefslogtreecommitdiff
path: root/windowNew.go
diff options
context:
space:
mode:
authorJeff Carr <[email protected]>2025-01-20 02:14:08 -0600
committerJeff Carr <[email protected]>2025-01-20 02:14:08 -0600
commitd9c4d18b168726f0c44269b40bb699c17278ab17 (patch)
treea0d121651bb0196f558e79a782e84a5701079652 /windowNew.go
parent25b2e50f6b1a15f887416479cd0df583cc6d4e19 (diff)
patch window
Diffstat (limited to 'windowNew.go')
-rw-r--r--windowNew.go112
1 files changed, 112 insertions, 0 deletions
diff --git a/windowNew.go b/windowNew.go
new file mode 100644
index 0000000..e6d0043
--- /dev/null
+++ b/windowNew.go
@@ -0,0 +1,112 @@
+package main
+
+import (
+ "sync"
+
+ "go.wit.com/lib/gadgets"
+ "go.wit.com/lib/protobuf/gitpb"
+ "go.wit.com/log"
+
+ "go.wit.com/gui"
+)
+
+type patchesWindow struct {
+ once sync.Once
+ win *gadgets.BasicWindow
+ box *gui.Node
+
+ // the top box of the repolist window
+ topbox *gui.Node
+}
+
+func (r *patchesWindow) Hidden() bool {
+ return r.win.Hidden()
+}
+
+func (r *patchesWindow) Toggle() {
+ if r.Hidden() {
+ r.Show()
+ } else {
+ r.Show()
+ }
+}
+
+func (r *patchesWindow) Show() {
+ r.win.Show()
+}
+
+func (r *patchesWindow) Hide() {
+ r.win.Hide()
+}
+
+func (r *patchesWindow) Disable() {
+ r.box.Disable()
+}
+
+func (r *patchesWindow) Enable() {
+ r.box.Enable()
+}
+
+// you can only have one of these
+func (r *patchesWindow) initWindow() {
+ // sync.Once()
+ r.win = gadgets.RawBasicWindow("All git repositories in ~/go/src/")
+ r.win.Make()
+
+ r.box = r.win.Box().NewBox("bw vbox", false)
+ // me.reposwin.Draw()
+ r.win.Custom = func() {
+ log.Warn("Repo Window close. Do something here?")
+ }
+
+ r.topbox = r.initGroup()
+}
+
+func (r *patchesWindow) initGroup() *gui.Node {
+ // reposbox.SetExpand(false)
+ group1 := r.box.NewGroup("Filter:")
+
+ hbox := group1.Box()
+ // hbox.Horizontal()
+ hbox.Vertical()
+
+ box2 := hbox.Box().Horizontal()
+ /*
+ */
+
+ dirty := box2.NewCheckbox("dirty")
+ dirty.Custom = func() {
+ log.Info("filter dirty =", dirty.Checked())
+ }
+
+ box2.NewButton("merge user to devel", func() {
+ r.Disable()
+ defer r.Enable()
+ })
+
+ box2.NewButton("test master merge", func() {
+ r.Disable()
+ r.Enable()
+ })
+
+ box2.NewButton("show apps", func() {
+ })
+ box2.NewButton("re-init forge", func() {
+ log.Info("re-scanning now")
+ })
+ box2.NewButton("ConfigSave()", func() {
+ })
+ box2.NewButton("Table()", func() {
+ me.found = new(gitpb.Repos)
+ loop := me.forge.Repos.All()
+ for loop.Scan() {
+ repo := loop.Next()
+ me.found.AppendByGoPath(repo)
+ }
+ me.forge.PrintHumanTable(me.found)
+ })
+ box2.NewButton("Prep for release()", func() {
+ })
+
+ return box2
+}