forked from Mirrors/bubbletea
Blink cursor
This commit is contained in:
parent
923390de7a
commit
4b64a7cbde
|
@ -25,8 +25,16 @@ func main() {
|
|||
},
|
||||
update,
|
||||
view,
|
||||
nil,
|
||||
//[]tea.Sub{input.Blink},
|
||||
[]tea.Sub{
|
||||
// Just hand off the subscription to the input component
|
||||
func(m tea.Model) tea.Msg {
|
||||
if m, ok := m.(model); ok {
|
||||
return input.Blink(m.input)
|
||||
}
|
||||
// TODO: return error
|
||||
return nil
|
||||
},
|
||||
},
|
||||
)
|
||||
|
||||
if err := p.Start(); err != nil {
|
||||
|
@ -36,7 +44,6 @@ func main() {
|
|||
|
||||
func update(msg tea.Msg, mdl tea.Model) (tea.Model, tea.Cmd) {
|
||||
var cmd tea.Cmd
|
||||
|
||||
m, _ := mdl.(model)
|
||||
|
||||
switch msg := msg.(type) {
|
||||
|
@ -47,17 +54,14 @@ func update(msg tea.Msg, mdl tea.Model) (tea.Model, tea.Cmd) {
|
|||
case "esc":
|
||||
return m, tea.Quit
|
||||
}
|
||||
|
||||
case input.CursorBlinkMsg:
|
||||
return input.Update(msg, m.input)
|
||||
}
|
||||
|
||||
m.input, cmd = input.Update(msg, m.input)
|
||||
return m, cmd
|
||||
}
|
||||
|
||||
func view(mdl tea.Model) string {
|
||||
m, _ := mdl.(model)
|
||||
func view(m tea.Model) string {
|
||||
if m, ok := m.(model); ok {
|
||||
help := "(esc to exit)"
|
||||
|
||||
return fmt.Sprintf(
|
||||
|
@ -65,4 +69,7 @@ func view(mdl tea.Model) string {
|
|||
input.View(m.input),
|
||||
help,
|
||||
)
|
||||
}
|
||||
// TODO: return error
|
||||
return ""
|
||||
}
|
||||
|
|
|
@ -27,9 +27,7 @@ func DefaultModel() Model {
|
|||
}
|
||||
}
|
||||
|
||||
func Update(msg tea.Msg, model tea.Model) (Model, tea.Cmd) {
|
||||
m, _ := model.(Model)
|
||||
|
||||
func Update(msg tea.Msg, m Model) (Model, tea.Cmd) {
|
||||
switch msg := msg.(type) {
|
||||
|
||||
case tea.KeyMsg:
|
||||
|
@ -52,15 +50,14 @@ func Update(msg tea.Msg, model tea.Model) (Model, tea.Cmd) {
|
|||
func View(model tea.Model) string {
|
||||
m, _ := model.(Model)
|
||||
cursor := m.Cursor
|
||||
//if m.Blink {
|
||||
//cursor = m.HiddenCursor
|
||||
//}
|
||||
if m.Blink {
|
||||
cursor = m.HiddenCursor
|
||||
}
|
||||
return m.Prompt + m.Value + cursor
|
||||
}
|
||||
|
||||
func Blink(model tea.Model) tea.Msg {
|
||||
//m, _ := model.(Model)
|
||||
//time.Sleep(m.BlinkSpeed)
|
||||
time.Sleep(time.Second)
|
||||
m, _ := model.(Model)
|
||||
time.Sleep(m.BlinkSpeed)
|
||||
return CursorBlinkMsg{}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue