2017-12-15 22:03:01 +00:00
|
|
|
package tview
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/gdamore/tcell"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Button is labeled box that triggers an action when selected.
|
2018-01-07 15:39:06 +00:00
|
|
|
//
|
|
|
|
// See https://github.com/rivo/tview/wiki/Button for an example.
|
2017-12-15 22:03:01 +00:00
|
|
|
type Button struct {
|
2017-12-16 21:48:26 +00:00
|
|
|
*Box
|
2017-12-15 22:03:01 +00:00
|
|
|
|
|
|
|
// The text to be displayed before the input area.
|
|
|
|
label string
|
|
|
|
|
|
|
|
// The label color.
|
|
|
|
labelColor tcell.Color
|
|
|
|
|
|
|
|
// The label color when the button is in focus.
|
|
|
|
labelColorActivated tcell.Color
|
|
|
|
|
|
|
|
// The background color when the button is in focus.
|
|
|
|
backgroundColorActivated tcell.Color
|
|
|
|
|
|
|
|
// An optional function which is called when the button was selected.
|
|
|
|
selected func()
|
|
|
|
|
|
|
|
// An optional function which is called when the user leaves the button. A
|
|
|
|
// key is provided indicating which key was pressed to leave (tab or backtab).
|
|
|
|
blur func(tcell.Key)
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewButton returns a new input field.
|
|
|
|
func NewButton(label string) *Button {
|
2018-01-10 08:43:32 +00:00
|
|
|
box := NewBox().SetBackgroundColor(Styles.ContrastBackgroundColor)
|
2019-03-19 11:12:40 +00:00
|
|
|
box.SetRect(0, 0, TaggedStringWidth(label)+4, 1)
|
2017-12-15 22:03:01 +00:00
|
|
|
return &Button{
|
2017-12-16 21:48:26 +00:00
|
|
|
Box: box,
|
2017-12-15 22:03:01 +00:00
|
|
|
label: label,
|
2018-01-10 08:43:32 +00:00
|
|
|
labelColor: Styles.PrimaryTextColor,
|
|
|
|
labelColorActivated: Styles.InverseTextColor,
|
|
|
|
backgroundColorActivated: Styles.PrimaryTextColor,
|
2017-12-15 22:03:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetLabel sets the button text.
|
|
|
|
func (b *Button) SetLabel(label string) *Button {
|
|
|
|
b.label = label
|
|
|
|
return b
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetLabel returns the button text.
|
|
|
|
func (b *Button) GetLabel() string {
|
|
|
|
return b.label
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetLabelColor sets the color of the button text.
|
|
|
|
func (b *Button) SetLabelColor(color tcell.Color) *Button {
|
|
|
|
b.labelColor = color
|
|
|
|
return b
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetLabelColorActivated sets the color of the button text when the button is
|
|
|
|
// in focus.
|
|
|
|
func (b *Button) SetLabelColorActivated(color tcell.Color) *Button {
|
|
|
|
b.labelColorActivated = color
|
|
|
|
return b
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetBackgroundColorActivated sets the background color of the button text when
|
|
|
|
// the button is in focus.
|
|
|
|
func (b *Button) SetBackgroundColorActivated(color tcell.Color) *Button {
|
|
|
|
b.backgroundColorActivated = color
|
|
|
|
return b
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetSelectedFunc sets a handler which is called when the button was selected.
|
|
|
|
func (b *Button) SetSelectedFunc(handler func()) *Button {
|
|
|
|
b.selected = handler
|
|
|
|
return b
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetBlurFunc sets a handler which is called when the user leaves the button.
|
|
|
|
// The callback function is provided with the key that was pressed, which is one
|
|
|
|
// of the following:
|
|
|
|
//
|
|
|
|
// - KeyEscape: Leaving the button with no specific direction.
|
|
|
|
// - KeyTab: Move to the next field.
|
|
|
|
// - KeyBacktab: Move to the previous field.
|
|
|
|
func (b *Button) SetBlurFunc(handler func(key tcell.Key)) *Button {
|
|
|
|
b.blur = handler
|
|
|
|
return b
|
|
|
|
}
|
|
|
|
|
|
|
|
// Draw draws this primitive onto the screen.
|
|
|
|
func (b *Button) Draw(screen tcell.Screen) {
|
|
|
|
// Draw the box.
|
2017-12-27 15:04:21 +00:00
|
|
|
borderColor := b.borderColor
|
2017-12-15 22:03:01 +00:00
|
|
|
backgroundColor := b.backgroundColor
|
2017-12-16 21:48:26 +00:00
|
|
|
if b.focus.HasFocus() {
|
2017-12-15 22:03:01 +00:00
|
|
|
b.backgroundColor = b.backgroundColorActivated
|
2017-12-27 15:04:21 +00:00
|
|
|
b.borderColor = b.labelColorActivated
|
|
|
|
defer func() {
|
|
|
|
b.borderColor = borderColor
|
|
|
|
}()
|
2017-12-15 22:03:01 +00:00
|
|
|
}
|
|
|
|
b.Box.Draw(screen)
|
|
|
|
b.backgroundColor = backgroundColor
|
|
|
|
|
|
|
|
// Draw label.
|
2017-12-21 17:08:53 +00:00
|
|
|
x, y, width, height := b.GetInnerRect()
|
2017-12-27 15:04:21 +00:00
|
|
|
if width > 0 && height > 0 {
|
|
|
|
y = y + height/2
|
|
|
|
labelColor := b.labelColor
|
|
|
|
if b.focus.HasFocus() {
|
|
|
|
labelColor = b.labelColorActivated
|
|
|
|
}
|
|
|
|
Print(screen, b.label, x, y, width, AlignCenter, labelColor)
|
2017-12-15 22:03:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// InputHandler returns the handler for this primitive.
|
2017-12-18 19:04:52 +00:00
|
|
|
func (b *Button) InputHandler() func(event *tcell.EventKey, setFocus func(p Primitive)) {
|
2018-03-19 20:25:30 +00:00
|
|
|
return b.WrapInputHandler(func(event *tcell.EventKey, setFocus func(p Primitive)) {
|
2017-12-15 22:03:01 +00:00
|
|
|
// Process key event.
|
|
|
|
switch key := event.Key(); key {
|
|
|
|
case tcell.KeyEnter: // Selected.
|
|
|
|
if b.selected != nil {
|
|
|
|
b.selected()
|
|
|
|
}
|
|
|
|
case tcell.KeyBacktab, tcell.KeyTab, tcell.KeyEscape: // Leave. No action.
|
|
|
|
if b.blur != nil {
|
|
|
|
b.blur(key)
|
|
|
|
}
|
|
|
|
}
|
2018-01-14 20:29:34 +00:00
|
|
|
})
|
2017-12-15 22:03:01 +00:00
|
|
|
}
|
2019-11-04 05:34:46 +00:00
|
|
|
|
2019-11-04 06:30:25 +00:00
|
|
|
// MouseHandler returns the mouse handler for this primitive.
|
2019-11-04 05:34:46 +00:00
|
|
|
func (b *Button) MouseHandler() func(event EventMouse) {
|
|
|
|
return b.WrapMouseHandler(func(event EventMouse) {
|
|
|
|
// Process mouse event.
|
|
|
|
if event.Buttons()&tcell.Button1 != 0 {
|
|
|
|
if b.selected != nil {
|
|
|
|
b.selected()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|