From 9c780011ffde9172b22804969d2514e67625207d Mon Sep 17 00:00:00 2001 From: Christian Rocha Date: Mon, 26 Oct 2020 21:14:48 -0400 Subject: [PATCH] Underpinnings for always-on and always-hidden cursor modes --- textinput/textinput.go | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/textinput/textinput.go b/textinput/textinput.go index 4bd1c0c..b244db7 100644 --- a/textinput/textinput.go +++ b/textinput/textinput.go @@ -156,7 +156,9 @@ func (m Model) Value() string { func (m *Model) SetCursor(pos int) bool { m.pos = clamp(pos, 0, len(m.value)) m.handleOverflow() - m.blink = false + + // Show the cursor unless it's been explicitly hidden + m.blink = m.cursorMode == cursorHide if m.cursorMode == cursorBlink { return true @@ -184,7 +186,7 @@ func (m Model) Focused() bool { // Focus sets the focus state on the model. func (m *Model) Focus() { m.focus = true - m.blink = false + m.blink = m.cursorMode == cursorHide // show the cursor unless we've explicitly hidden it } // Blur removes the focus state on the model. @@ -532,8 +534,11 @@ func (m Model) Update(msg tea.Msg) (Model, tea.Cmd) { } case blinkMsg: - m.blink = !m.blink - cmd := m.blinkCmd() + var cmd tea.Cmd + if m.cursorMode == cursorBlink { + m.blink = !m.blink + cmd = m.blinkCmd() + } return m, cmd case blinkCanceled: // no-op