Skip to content

Commit

Permalink
Wait for natural end for progress bar
Browse files Browse the repository at this point in the history
  • Loading branch information
cardil committed Mar 22, 2024
1 parent 0ff3298 commit 0ef424a
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 4 deletions.
6 changes: 3 additions & 3 deletions pkg/output/tui/progress.go
Expand Up @@ -175,8 +175,7 @@ func (b bubbleProgressHandler) speedChange() (tea.Model, tea.Cmd) {
}

func (b bubbleProgressHandler) percentChange(event percentChange) (tea.Model, tea.Cmd) {
var cmds []tea.Cmd

cmds := make([]tea.Cmd, 0, 1)
cmds = append(cmds, b.prog.SetPercent(float64(event)))

if event >= 1.0 {
Expand Down Expand Up @@ -252,8 +251,9 @@ func (b *BubbleProgress) stop() {
if b.tea == nil {
return
}
b.tea.Quit()

<-b.quitChan

b.tea = nil
b.quitChan = nil
}
Expand Down
5 changes: 4 additions & 1 deletion pkg/output/tui/spinner.go
Expand Up @@ -36,7 +36,6 @@ func (w *widgets) NewSpinner(message string) Spinner {
return &BubbleSpinner{
InputOutput: output.PrinterFrom(w.ctx),
Message: Message{Text: message},
quitChan: make(chan struct{}),
}
}

Expand Down Expand Up @@ -79,6 +78,7 @@ func (b *BubbleSpinner) start() {
tea.WithInput(b.InOrStdin()),
tea.WithOutput(out),
)
b.quitChan = make(chan struct{})
go func() {
t := b.tea
_, _ = t.Run()
Expand All @@ -93,9 +93,12 @@ func (b *BubbleSpinner) stop() {
if b.tea == nil {
return
}

b.tea.Quit()
<-b.quitChan

b.tea = nil
b.quitChan = nil
endMsg := fmt.Sprintf("%s %s\n",
b.Message.Text, spinnerStyle().Render("Done"))
_, _ = b.OutOrStdout().Write([]byte(endMsg))
Expand Down

0 comments on commit 0ef424a

Please sign in to comment.