summaryrefslogtreecommitdiff
path: root/internal/slider/slider.go
diff options
context:
space:
mode:
authorBenjamin Chausse <benjamin@chausse.xyz>2024-11-24 02:59:00 -0500
committerBenjamin Chausse <benjamin@chausse.xyz>2024-11-24 02:59:00 -0500
commitac024fff3ce70b435a39de83f7aa3339668fdc6b (patch)
tree2e68d5d6c3517770fc8bae1da3e70f53a241e7e3 /internal/slider/slider.go
parent56ceae9524f40ac89cd68796d1f8e6cd0560c80a (diff)
Instant slider animation
Diffstat (limited to 'internal/slider/slider.go')
-rw-r--r--internal/slider/slider.go18
1 files changed, 15 insertions, 3 deletions
diff --git a/internal/slider/slider.go b/internal/slider/slider.go
index 884d141..bfbc069 100644
--- a/internal/slider/slider.go
+++ b/internal/slider/slider.go
@@ -35,11 +35,20 @@ func New(label byte, maxVal int, opts ...progress.Option) Model {
func (m Model) Title() string { return fmt.Sprintf("%c", m.label) }
func (m Model) Init() tea.Cmd {
- return m.progress.Init()
+ // Triggering a frame message Update here will force the progress bar to
+ // render immediately. This is necessary because progress bars only render
+ // when their state changes. Without this, there is a disrepancy between
+ // the initial state of the progress bar and the initial state of the slider.
+
+ // There's no sugar-coating it: This is a hack. But it works...
+ _, cmd := m.Update(progress.FrameMsg{})
+ return cmd
}
func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
+ cmds := []tea.Cmd{}
keys := newKeybinds()
+
switch msg := msg.(type) {
case tea.KeyMsg:
switch {
@@ -54,12 +63,15 @@ func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
}
return m, m.progress.SetPercent(m.Pcnt())
case progress.FrameMsg:
+ if m.progress.Percent() != m.Pcnt() {
+ cmds = append(cmds, m.progress.SetPercent(m.Pcnt()))
+ }
progressModel, cmd := m.progress.Update(msg)
m.progress = progressModel.(progress.Model)
- return m, cmd
+ cmds = append(cmds, cmd)
default:
- return m, nil
}
+ return m, tea.Batch(cmds...)
}
func (m Model) ViewValue(current int) string {