summaryrefslogtreecommitdiff
path: root/eventMouseClick.go
blob: aa8be6ed42c810ace0437f964cbcf5805a698801 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
// Copyright 2017-2025 WIT.COM Inc. All rights reserved.
// Use of this source code is governed by the GPL 3.0

package main

import (
	"github.com/awesome-gocui/gocui"
	"go.wit.com/log"
	"go.wit.com/widget"
)

// this whole things was impossible to make but it got me where I am now
// the debugging is way way better now with it being visible in the Stdout window
// so now it's possible to redo all this and make it better
func (tk *guiWidget) doWidgetClick(w int, h int) {
	switch tk.node.WidgetType {
	case widget.Window:
		// if there is a current window, hide it
		if me.currentWindow != nil {
			me.currentWindow.setColor(&colorWindow)
			// me.currentWindow.hideWidgets()
			me.currentWindow.isCurrent = false
		}

		// now set this window as the current window
		me.currentWindow = tk
		me.currentWindow.isCurrent = true
		tk.active = false

		tk.redrawWindow(w-2, h-2) // TODO: fix these hard coded things with offsets
		return
	case widget.Group:
		/*
			if tk.active {
				tk.active = false
				tk.placeWidgets(tk.startW, tk.startH)
				tk.showWidgets()
			} else {
				tk.active = true
				for _, child := range tk.children {
					child.hideWidgets()
				}
			}
		*/
	case widget.Checkbox:
		if tk.node.State.Checked {
			log.Log(WARN, "checkbox is being set to false")
			tk.node.State.Checked = false
			tk.setCheckbox()
		} else {
			log.Log(WARN, "checkbox is being set to true")
			tk.node.State.Checked = true
			tk.setCheckbox()
		}
		me.myTree.SendUserEvent(tk.node)
	case widget.Grid:
		/*
			newR := tk.realGocuiSize()
			tk.placeGrid(newR.w0, newR.h0)
			tk.showWidgets()
		*/
	case widget.Box:
		/*
			if tk.node.State.Direction == widget.Horizontal {
				log.Log(GOCUI, "BOX IS HORIZONTAL", tk.String())
			} else {
				log.Log(GOCUI, "BOX IS VERTICAL", tk.String())
			}
			tk.placeWidgets(tk.startW, tk.startH)
			tk.toggleTree()
		*/
	case widget.Button:
		me.myTree.SendFromUser(tk.node)
	case widget.Combobox:
		tk.showDropdown()
	case widget.Dropdown:
		tk.showDropdown()
	case widget.Stdout:
		/*
			log.Log(GOCUI, "stdout widget found!")
			tk.dumpWidget("stdout click")
		*/
	case widget.Flag:
		tk.dropdownClicked(w, h)
	default:
		tk.dumpWidget("undef click()")
	}
}

// sends the mouse click to a widget underneath
func click(g *gocui.Gui, v *gocui.View) error {
	mouseW, mouseH := me.baseGui.MousePosition()

	w := mouseW
	h := mouseH

	// Flag widgets (dropdown menus, etc) are the highest priority. ALWAYS SEND MOUSE CLICKS THERE FIRST
	for _, tk := range findByXY(w, h) {
		if tk.node.WidgetType == widget.Flag {
			tk.doWidgetClick(w, h)
			return nil
		}
	}

	// Button widgets
	for _, tk := range findByXY(w, h) {
		if tk.node.WidgetType == widget.Button {
			tk.doWidgetClick(w, h)
			return nil
		}
	}

	for _, tk := range findByXY(w, h) {
		// will show you everything found on a mouse click. great for debugging!
		// tk.dumpWidget("click()")
		if tk.node.WidgetType == widget.Stdout {
			// don't send clicks to the stdout debugging window
			continue
		}
		tk.doWidgetClick(w, h)
		return nil
	}

	log.Log(GOCUI, "click() nothing was at:", v.Name(), mouseW, mouseH)
	return nil
	/*
		// not sure what SetCurrentView() does right now. it was here before
		// SetCurrentView dies if it's sent an non-existent view
		if _, err := g.SetCurrentView(v.Name()); err != nil {
			log.Log(GOCUI, "click() END v.Name =", v.Name(), "err =", err)
			// return err // return causes gocui.MainLoop() to exit. Do we ever want that to happen here?
			return nil
		}
	*/
}