summaryrefslogtreecommitdiff
path: root/redo/controls.go
diff options
context:
space:
mode:
Diffstat (limited to 'redo/controls.go')
-rw-r--r--redo/controls.go100
1 files changed, 0 insertions, 100 deletions
diff --git a/redo/controls.go b/redo/controls.go
deleted file mode 100644
index cda67db..0000000
--- a/redo/controls.go
+++ /dev/null
@@ -1,100 +0,0 @@
-// 7 july 2014
-
-package ui
-
-// Control represents a control.
-// All Controls have event handlers that take a single argument (the Doer active during the event) and return nothing.
-type Control interface {
- setParent(p *controlParent) // controlParent defined per-platform
- // TODO enable/disable (public)
- // TODO show/hide (public)
- containerShow() // for Windows, where all controls need ot belong to an overlapped window, not to a container control; these respect programmer settings
- containerHide()
- controlSizing
-}
-
-// Button is a clickable button that performs some task.
-type Button interface {
- Control
-
- // OnClicked sets the event handler for when the Button is clicked.
- OnClicked(func())
-
- // Text and SetText get and set the Button's label text.
- Text() string
- SetText(text string)
-}
-
-// NewButton creates a new Button with the given label text.
-func NewButton(text string) Button {
- return newButton(text)
-}
-
-// Checkbox is a clickable box that indicates some Boolean value.
-type Checkbox interface {
- Control
-
- // OnClicked sets the event handler for when the Checkbox is clicked (to change its toggle state).
- // TODO change to OnToggled() or OnChecked()?
- OnClicked(func())
-
- // Text and SetText get and set the Checkbox's label text.
- Text() string
- SetText(text string)
-
- // Checked and SetChecked get and set the Checkbox's check state.
- Checked() bool
- SetChecked(checked bool)
-}
-
-// NewCheckbox creates a new Checkbox with the given label text.
-// The Checkbox will be initially unchecked.
-func NewCheckbox(text string) Checkbox {
- return newCheckbox(text)
-}
-
-// TextField is a Control in which the user can enter a single line of text.
-type TextField interface {
- Control
-
- // TODO figure out what events are appropriate
-
- // Text and SetText are Requests that get and set the TextField's text.
- Text() string
- SetText(text string)
-}
-
-// NewTextField creates a new TextField.
-func NewTextField() TextField {
- return newTextField()
-}
-
-// NewPasswordField creates a new TextField for entering passwords; that is, it hides the text being entered.
-func NewPasswordField() TextField {
- return newPasswordField()
-}
-
-
-// Label is a Control that shows a static line of text.
-// Label shows one line of text; any text that does not fit is truncated.
-// A Label can either have smart vertical alignment relative to the control to its right or just be vertically aligned to the top (standalone).
-type Label interface {
- Control
-
- // Text and SetText get and set the Label's text.
- Text() string
- SetText(text string)
-}
-
-// NewLabel creates a new Label with the given text.
-// The Label will smartly vertically position itself relative to the control to its immediate right.
-// TODO Grids on GTK+ will not respect this unless SetFilling()
-func NewLabel(text string) Label {
- return newLabel(text)
-}
-
-// NewStandaloneLabel creates a new Label with the given text.
-// The Label will be vertically positioned at the top of its allocated space.
-func NewStandaloneLabel(text string) Label {
- return newStandaloneLabel(text)
-}