summaryrefslogtreecommitdiff
path: root/eventMouseMove.go
diff options
context:
space:
mode:
Diffstat (limited to 'eventMouseMove.go')
-rw-r--r--eventMouseMove.go80
1 files changed, 80 insertions, 0 deletions
diff --git a/eventMouseMove.go b/eventMouseMove.go
new file mode 100644
index 0000000..3972cb2
--- /dev/null
+++ b/eventMouseMove.go
@@ -0,0 +1,80 @@
+// Copyright 2017-2025 WIT.COM Inc. All rights reserved.
+// Use of this source code is governed by the GPL 3.0
+
+// 2025 note by jcarr:
+// this is one of the coolest things ever worked with.
+// Personally, I've been working on making a gocui GO plugin
+// so I can use it as a generalized console GUI toolkit.
+//
+// Well done everyone that has contributed to this gocui project !!!
+// I am in your debt. Happy hacking & peace.
+
+package main
+
+import (
+ "fmt"
+
+ "github.com/awesome-gocui/gocui"
+ log "go.wit.com/log"
+)
+
+// this function uses the mouse position to highlight & unhighlight things
+// this is run every time the user moves the mouse over the terminal window
+func mouseMove(g *gocui.Gui) {
+ mx, my := g.MousePosition()
+
+ w := mx
+ h := my
+
+ if me.supermouse {
+ for _, tk := range findByXY(w, h) {
+ tk.dumpWidget("mouseMove()")
+ }
+ }
+
+ if mouseMoveOld(g) {
+ return
+ }
+
+ for _, view := range g.Views() {
+ view.Highlight = false
+ }
+ if v, err := g.ViewByPosition(mx, my); err == nil {
+ v.Highlight = true
+ }
+}
+
+/*
+func dragOutputWindow() {
+ log.Log(GOCUI, "todo: make dragOutputWindow")
+}
+*/
+
+func mouseMoveOld(g *gocui.Gui) bool {
+ me.ecount += 1
+ maxX, maxY := g.Size()
+ mx, my := g.MousePosition()
+ log.Log(NOW, "handleEvent() START", maxX, maxY, mx, my, msgMouseDown)
+ if _, err := g.View("msg"); msgMouseDown && err == nil {
+ moveMsg(g)
+ return true
+ }
+ if widgetView, _ := g.View("msg"); widgetView == nil {
+ log.Log(NOW, "handleEvent() create output widget now", maxX, maxY, mx, my)
+ makeOutputWidget(g, "this is a create before a mouse click")
+ if me.logStdout != nil {
+ // setOutput(me.logStdout)
+ // me.logStdout.Write("test out")
+ w := me.logStdout.TK.(*guiWidget)
+ msg := fmt.Sprintf("test out gocuiEvent() %d\n", me.ecount)
+ w.Write([]byte(msg))
+ // log.CaptureMode(w)
+ log.Log(NOW, "logStdout test out")
+ }
+ return true
+ } else {
+ log.Log(NOW, "output widget already exists", maxX, maxY, mx, my)
+ }
+ log.Log(NOW, "handleEvent() END ", maxX, maxY, mx, my, msgMouseDown)
+ return false
+}