gocui/eventMouseMove.go

153 lines
4.1 KiB
Go
Raw Normal View History

2025-02-01 16:44:43 -06:00
// 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"
2025-02-01 17:03:14 -06:00
"go.wit.com/widget"
2025-02-01 16:44:43 -06:00
)
// 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) {
2025-02-03 01:11:01 -06:00
w, h := g.MousePosition()
2025-02-01 16:44:43 -06:00
if me.supermouse {
for _, tk := range findByXY(w, h) {
2025-02-03 01:11:01 -06:00
s := fmt.Sprintf("SM (%3d,%3d)", w, h)
tk.dumpWidget(s)
2025-02-01 16:44:43 -06:00
}
}
2025-02-01 17:17:32 -06:00
// toggle off all highlight vies except for whatever is under the mouse
for _, view := range g.Views() {
view.Highlight = false
}
if v, err := g.ViewByPosition(w, h); err == nil {
v.Highlight = true
}
// create the 'msg' view if it does not yet exist // TODO: put this somewhere more correct
if widgetView, _ := g.View("msg"); widgetView == nil {
if createStdout(g) {
return
}
return
}
2025-02-06 05:52:00 -06:00
if me.globalMouseDown && me.dropdown.active {
log.Info("can't drag while dropdown is active", w, h)
return
}
if me.globalMouseDown {
// log.Info("msgMouseDown == true")
2025-02-01 17:17:32 -06:00
// plugin will segfault if you don't keep this inside a check for msgMouseDown
// don't move this code out of here
var found bool = false
if me.currentDrag != nil {
2025-02-06 23:35:15 -06:00
// me.currentDrag.dumpWidget(fmt.Sprintf("MM (%3d,%3d)", w, h))
me.currentDrag.moveNew()
2025-02-02 23:36:33 -06:00
return
}
// new function that is smarter
if tk := findWindowUnderMouse(); tk != nil {
me.currentDrag = tk
return
}
// first look for windows
2025-02-03 10:21:43 -06:00
for _, tk := range findByXY(w, h) {
if tk.node.WidgetType == widget.Window {
me.currentDrag = tk
2025-02-03 10:21:43 -06:00
return
}
}
// now look for the STDOUT window
2025-02-02 23:36:33 -06:00
for _, tk := range findByXY(w, h) {
if tk.node.WidgetType == widget.Flag {
me.currentDrag = tk
2025-02-04 11:12:13 -06:00
// tk.moveNew()
2025-02-02 23:36:33 -06:00
return
}
}
2025-02-01 17:03:14 -06:00
for _, tk := range findByXY(w, h) {
2025-02-01 17:17:32 -06:00
if tk.node.WidgetType == widget.Stdout {
me.currentDrag = tk
2025-02-04 11:12:13 -06:00
// tk.moveNew()
2025-02-01 17:17:32 -06:00
return
2025-02-01 17:03:14 -06:00
}
/*
if tk.node.WidgetType == widget.Label {
me.currentDrag = tk
// tk.moveNew()
return
}
*/
found = true
}
if !found {
log.Info(fmt.Sprintf("findByXY() empty. nothing to move at (%d,%d)", w, h))
2025-02-01 17:03:14 -06:00
}
}
2025-02-01 16:44:43 -06:00
}
2025-02-01 17:17:32 -06:00
// this is how the window gets dragged around
2025-02-04 11:12:13 -06:00
func (tk *guiWidget) moveNew() {
w, h := me.baseGui.MousePosition()
2025-02-03 10:21:43 -06:00
if tk.node.WidgetType == widget.Window {
2025-02-06 14:46:32 -06:00
tk.window.wasDragged = true
2025-02-05 15:04:40 -06:00
tk.redrawWindow(w-tk.dragW, h-tk.dragH) // TODO: fix these hard coded things with offsets
2025-02-06 02:15:21 -06:00
setThingsOnTop() // sets help, Stdout, etc on the top after windows have been redrawn
2025-02-03 10:21:43 -06:00
return
}
2025-02-02 23:36:33 -06:00
if tk.node.WidgetType == widget.Flag {
2025-02-04 11:12:13 -06:00
me.baseGui.SetView(tk.cuiName, w-3, h-3, w+20, h+20, 0)
2025-02-04 15:48:14 -06:00
// tk.verifyRect()
s := fmt.Sprintf("move(%dx%d) %s ###", w, h, tk.cuiName)
tk.dumpWidget(s)
return
2025-02-02 23:36:33 -06:00
} else {
2025-02-06 04:15:36 -06:00
if me.stdout.resize {
newW := w - me.stdout.lastW
newH := h - me.stdout.lastH
me.stdout.w = newW
me.stdout.h = newH
log.Info("Resize true", w, h, newW, newH)
// me.stdout.lastW = w - me.stdout.mouseOffsetW
// me.stdout.lastH = h - me.stdout.mouseOffsetH
tk.relocateStdout(me.stdout.lastW, me.stdout.lastH)
} else {
// log.Info("Resize false", w, h)
me.stdout.lastW = w - me.stdout.mouseOffsetW
me.stdout.lastH = h - me.stdout.mouseOffsetH
tk.relocateStdout(me.stdout.lastW, me.stdout.lastH)
}
}
// always place the help menu on top
2025-02-06 02:15:21 -06:00
setThingsOnTop() // sets help, Stdout, etc on the top after windows have been redrawn
2025-02-01 16:44:43 -06:00
}
2025-02-01 17:03:14 -06:00
func createStdout(g *gocui.Gui) bool {
2025-02-01 19:42:04 -06:00
makeOutputWidget(g, "this is a create before a mouse click")
2025-02-06 02:49:21 -06:00
if me.stdout.tk != nil {
2025-02-01 19:42:04 -06:00
msg := fmt.Sprintf("test out gocuiEvent() %d\n", me.ecount)
// me.logStdout.v.Write([]byte(msg))
2025-02-06 02:49:21 -06:00
me.stdout.tk.Write([]byte(msg))
2025-02-01 19:42:04 -06:00
log.Log(NOW, "logStdout test out")
2025-02-01 16:44:43 -06:00
}
2025-02-01 19:42:04 -06:00
return true
2025-02-01 16:44:43 -06:00
}