forked from VladimirMarkelov/clui
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconsts.go
347 lines (317 loc) · 10.6 KB
/
consts.go
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
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
package clui
import (
term "github.com/nsf/termbox-go"
)
const (
// Fixed means 'never change size of the object when its parent resizes'
Fixed int = 0
// AutoSize is used only in constructors. It means that the constructor
// should either calculate the size of an object, e.g. for Label it is its text
// length, or use default intial values
AutoSize int = -1
// KeepSize is used as a placeholder when you want to change only one
// value and keep other ones untouched. Used in SetSize and SetConstraints
// methods only
// Example: control.SetConstraint(10, KeepValue) changes only minimal width
// of the control and do not change the current minimal control height
KeepValue int = -1
)
// Predefined types
type (
// BorderStyle is a kind of frame: none, single, and double
BorderStyle int
// ViewButton is a set of buttons displayed in a view title
ViewButton int
// HitResult is a type of a view area that is under mouse cursor.
// Used in mouse click events
HitResult int
// Align is text align: left, right and center
Align int
// EventType is a type of event fired by an object
EventType int
// Direction indicates the direction in which a control must draw its
// content. At that moment it can be applied to Label (text output
// direction and to ProgressBar (direction of bar filling)
Direction int
// PackType sets how to pack controls inside its parent. Can be Vertical or
// Horizontal
PackType int
// SelectDialogType sets the way of choosing an item from a list for
// SelectionDialog control: a list-based selections, or radio group one
SelectDialogType uint
// TableAction is a type of user-generated event for TableView
TableAction int
// SortOrder is a way of sorting rows in TableView
SortOrder int
DragType int
)
const (
DragNone DragType = iota
DragMove
DragResizeLeft
DragResizeRight
DragResizeBottom
DragResizeBottomLeft
DragResizeBottomRight
DragResizeTopLeft
DragResizeTopRight
)
// Event is structure used by Views and controls to communicate with Composer
// and vice versa
type Event struct {
// Event type - the first events are mapped to termbox Event and then a few
// own events added to the end
Type EventType
// Mod - is a key modifier. Only Alt modifier is supported
Mod term.Modifier
// Msg is a text part of the event. Used by few events: e.g, ListBox click
// sends a value of clicked item
Msg string
// X and Y are multi-purpose fields: mouse coordinated for click event,
// X is used to indicate on/off for events like Activate
// Y is used for vertical-based events like ListBox item selection - id of the item
X, Y int
// Err is error got from termbox library
Err error
// Key is a pressed key
Key term.Key
// Ch is a printable representation of pressed key combinaton
Ch rune
// For resize event - new terminal size
Width int
Height int
Target Control
}
// BorderStyle constants
const (
BorderNone BorderStyle = iota
BorderThin
BorderThick
)
// Color predefined values
const (
ColorDefault = term.ColorDefault
ColorBlack = term.ColorBlack
ColorRed = term.ColorRed
ColorGreen = term.ColorGreen
ColorYellow = term.ColorYellow
ColorBlue = term.ColorBlue
ColorMagenta = term.ColorMagenta
ColorCyan = term.ColorCyan
ColorWhite = term.ColorWhite
ColorBlackBold = term.ColorBlack | term.AttrBold
ColorRedBold = term.ColorRed | term.AttrBold
ColorGreenBold = term.ColorGreen | term.AttrBold
ColorYellowBold = term.ColorYellow | term.AttrBold
ColorBlueBold = term.ColorBlue | term.AttrBold
ColorMagentaBold = term.ColorMagenta | term.AttrBold
ColorCyanBold = term.ColorCyan | term.AttrBold
ColorWhiteBold = term.ColorWhite | term.AttrBold
)
// HitResult constants
const (
HitOutside HitResult = iota
HitInside
HitBorder
HitTop
HitBottom
HitRight
HitLeft
HitTopLeft
HitTopRight
HitBottomRight
HitBottomLeft
HitButtonClose
HitButtonBottom
HitButtonMaximize
)
// VeiwButton values - list of buttons available for using in View title
const (
// ButtonDefault - no button
ButtonDefault ViewButton = 0
// ButtonClose - button to close View
ButtonClose = 1 << 0
// ButtonBottom - move Window to bottom of the View stack
ButtonBottom = 1 << 1
// ButtonMaximaize - maximize and restore View
ButtonMaximize = 1 << 2
)
// Alignment constants
const (
AlignLeft Align = iota
AlignRight
AlignCenter
)
// Output direction
// Used for Label text output direction and for Radio items distribution,
// and for container controls
const (
Horizontal = iota
Vertical
)
// Available object identifiers that can be used in themes
const (
ObjSingleBorder = "SingleBorder"
ObjDoubleBorder = "DoubleBorder"
ObjEdit = "Edit"
ObjScrollBar = "ScrollBar"
ObjViewButtons = "ViewButtons"
ObjCheckBox = "CheckBox"
ObjRadio = "Radio"
ObjProgressBar = "ProgressBar"
ObjBarChart = "BarChart"
ObjSparkChart = "SparkChart"
ObjTableView = "TableView"
)
// Available color identifiers that can be used in themes
const (
// Window back and fore colors (inner area & border)
ColorViewBack = "ViewBack"
ColorViewText = "ViewText"
// general colors
ColorBack = "Back"
ColorText = "Text"
ColorDisabledText = "GrayText"
ColorDisabledBack = "GrayBack"
// editable & listbox-like controls
ColorEditBack = "EditBack"
ColorEditText = "EditText"
ColorEditActiveBack = "EditActiveBack"
ColorEditActiveText = "EditActiveText"
ColorSelectionText = "SelectionText"
ColorSelectionBack = "SelectionBack"
// button control
ColorButtonBack = "ButtonBack"
ColorButtonText = "ButtonText"
ColorButtonActiveBack = "ButtonActiveBack"
ColorButtonActiveText = "ButtonActiveText"
ColorButtonShadow = "ButtonShadowBack"
ColorButtonDisabledBack = "ButtonDisabledBack"
ColorButtonDisabledText = "ButtonDisabledText"
// scroll control
ColorScrollText = "ScrollText"
ColorScrollBack = "ScrollBack"
ColorThumbText = "ThumbText"
ColorThumbBack = "ThumbBack"
// window-like controls (button, radiogroup...)
ColorControlText = "ControlText"
ColorControlBack = "ControlBack"
ColorControlActiveBack = "ControlActiveBack"
ColorControlActiveText = "ControlActiveText"
ColorControlDisabledBack = "ControlDisabledBack"
ColorControlDisabledText = "ControlDisabledText"
ColorControlShadow = "ControlShadowBack"
// progressbar colors
ColorProgressBack = "ProgressBack"
ColorProgressText = "ProgressText"
ColorProgressActiveBack = "ProgressActiveBack"
ColorProgressActiveText = "ProgressActiveText"
ColorProgressTitleText = "ProgressTitle"
// barchart colors
ColorBarChartBack = "BarChartBack"
ColorBarChartText = "BarChartText"
// sparkchart colors
ColorSparkChartBack = "SparkChartBack"
ColorSparkChartText = "SparkChartText"
ColorSparkChartBarBack = "SparkChartBarBack"
ColorSparkChartBarText = "SparkChartBarText"
ColorSparkChartMaxBack = "SparkChartMaxBack"
ColorSparkChartMaxText = "SparkChartMaxText"
// tableview colors
ColorTableText = "TableText"
ColorTableBack = "TableBack"
ColorTableSelectedText = "TableSelectedText"
ColorTableSelectedBack = "TableSelectedBack"
ColorTableActiveCellText = "TableActiveCellText"
ColorTableActiveCellBack = "TableActiveCellBack"
ColorTableLineText = "TableLineText"
ColorTableHeaderText = "TableHeaderText"
ColorTableHeaderBack = "TableHeaderBack"
)
// EventType is event that window or control may process
// Note: Do not change events from EventKey to EventNone - they correspond to the same named events in termbox library
const (
// a key pressed
EventKey EventType = iota
// an object or console size changed. X and Y are new width and height
EventResize
// Mouse button clicked. X and Y are coordinates of mouse click
EventMouse
// Something bad happened
EventError
EventInterrupt
EventRaw
EventNone
// Asks an object to redraw. A library can ask a control to redraw and control can send the event to its parent to ask for total repaint, e.g, button sends redraw event after to its parent it depressed after a while to imitate real button
EventRedraw = iota + 100
// an object that receives the event should close and destroys itself
EventClose
// Notify an object when it is activated or deactivated. X determines whether the object is activated or deactivated(0 - deactivated, 1 - activated)
EventActivate
// An object changes its position. X and Y are new coordinates of the object
EventMove
/*
control events
*/
// Content of a control changed. E.g, EditField text changed, selected item of ListBox changed etc
// X defines how the content was changed: 0 - by pressing any key, 1 - by clicking mouse. This is used by compound controls, e.g, child ListBox of ComboBox should change its parent EditField text when a user selects a new item an ListBox with arrow keys and the ListBox should be closed if a user clicks on ListBox item
EventChanged
// Button event - button was clicked
EventClick
// dialog closed
EventDialogClose
// Close application
EventQuit
// Close top window - or application is there is only one window
EventCloseWindow
// Make a control (Target field of Event structure) to recalculate and reposition all its children
EventLayout
)
// ConfirmationDialog and SelectDialog exit codes
const (
// DialogClosed - a user clicked close button on the dialog title
DialogClosed = -1
// DialogAlive - a user does not close the dialog yet, exit code is unavailable
DialogAlive = 0
// DialogButton1 - a user clicked the first button in the dialog (by default, it is 'Yes' or 'OK')
DialogButton1 = 1
// DialogButton2 - a user clicked the second button in the dialog
DialogButton2 = 2
// DialogButton3 - a user clicked the third button in the dialog
DialogButton3 = 3
)
// Predefined sets of the buttons for ConfirmationDialog and SelectDialog
var (
ButtonsOK = []string{"OK"}
ButtonsYesNo = []string{"Yes", "No"}
ButtonsYesNoCancel = []string{"Yes", "No", "Cancel"}
)
// SelectDialogType constants
const (
// SelectDialogList - all items are displayed in a ListBox
SelectDialogList SelectDialogType = iota
// SelectDialogRadio - all items are displayed in a RadioGroup
SelectDialogRadio
// SelectDialogEdit - Creates an editbox for user input
SelectDialogEdit
)
// TableAction constants
const (
// A user pressed F2 or Enter key in TableView
TableActionEdit TableAction = iota
// A user pressed Insert key in TableView
TableActionNew
// A user pressed Delete key in TableView
TableActionDelete
// A user clicked on a column header in TableView
TableActionSort
)
// SortOrder constants
const (
// Do not sort
SortNone SortOrder = iota
// Sort ascending
SortAsc
// Sort descending
SortDesc
)