mirror of
https://github.com/Maks1mS/bubbles.git
synced 2025-01-25 21:31:04 +03:00
Fix spinner frame skipping and remove custom message functionality
This commit is contained in:
parent
2525319d72
commit
35c3cd626d
@ -17,7 +17,7 @@ const (
|
|||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
defaultFPS = 9
|
defaultFPS = time.Second / 10
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -38,7 +38,7 @@ type Model struct {
|
|||||||
Type Spinner
|
Type Spinner
|
||||||
|
|
||||||
// FPS is the speed at which the ticker should tick
|
// FPS is the speed at which the ticker should tick
|
||||||
FPS int
|
FPS time.Duration
|
||||||
|
|
||||||
// ForegroundColor sets the background color of the spinner. It can be a
|
// ForegroundColor sets the background color of the spinner. It can be a
|
||||||
// hex code or one of the 256 ANSI colors. If the terminal emulator can't
|
// hex code or one of the 256 ANSI colors. If the terminal emulator can't
|
||||||
@ -52,12 +52,6 @@ type Model struct {
|
|||||||
// (per github.com/muesli/termenv).
|
// (per github.com/muesli/termenv).
|
||||||
BackgroundColor string
|
BackgroundColor string
|
||||||
|
|
||||||
// CustomMsgFunc can be used to a custom message on tick. This can be
|
|
||||||
// useful when you have spinners in different parts of your application and
|
|
||||||
// want to differentiate between the messages for clarity and simplicity.
|
|
||||||
// If nil, this setting is ignored.
|
|
||||||
CustomMsgFunc func() tea.Msg
|
|
||||||
|
|
||||||
frame int
|
frame int
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -76,14 +70,14 @@ type TickMsg struct{}
|
|||||||
// every time it's called, regardless the message passed, so be sure the logic
|
// every time it's called, regardless the message passed, so be sure the logic
|
||||||
// is setup so as not to call this Update needlessly.
|
// is setup so as not to call this Update needlessly.
|
||||||
func Update(msg tea.Msg, m Model) (Model, tea.Cmd) {
|
func Update(msg tea.Msg, m Model) (Model, tea.Cmd) {
|
||||||
|
if _, ok := msg.(TickMsg); ok {
|
||||||
m.frame++
|
m.frame++
|
||||||
if m.frame >= len(spinners[m.Type]) {
|
if m.frame >= len(spinners[m.Type]) {
|
||||||
m.frame = 0
|
m.frame = 0
|
||||||
}
|
}
|
||||||
if m.CustomMsgFunc != nil {
|
|
||||||
return m, Tick(m)
|
return m, Tick(m)
|
||||||
}
|
}
|
||||||
return m, Tick(m)
|
return m, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// View renders the model's view.
|
// View renders the model's view.
|
||||||
@ -107,12 +101,8 @@ func View(model Model) string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Tick is the command used to advance the spinner one frame.
|
// Tick is the command used to advance the spinner one frame.
|
||||||
func Tick(model Model) tea.Cmd {
|
func Tick(m Model) tea.Cmd {
|
||||||
return func() tea.Msg {
|
return tea.Tick(m.FPS, func(time.Time) tea.Msg {
|
||||||
time.Sleep(time.Second / time.Duration(model.FPS))
|
|
||||||
if model.CustomMsgFunc != nil {
|
|
||||||
return model.CustomMsgFunc()
|
|
||||||
}
|
|
||||||
return TickMsg{}
|
return TickMsg{}
|
||||||
}
|
})
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user