From 4d25e4ece0b72d240bb2565f8abb7389e650990a Mon Sep 17 00:00:00 2001 From: Benjamin Chausse Date: Sat, 23 Nov 2024 21:05:11 -0500 Subject: Preview + Unit-tests for color conversions --- internal/switcher/switcher.go | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) (limited to 'internal/switcher') diff --git a/internal/switcher/switcher.go b/internal/switcher/switcher.go index d542df1..0680996 100644 --- a/internal/switcher/switcher.go +++ b/internal/switcher/switcher.go @@ -5,19 +5,23 @@ import ( "github.com/charmbracelet/bubbles/key" tea "github.com/charmbracelet/bubbletea" + "github.com/charmbracelet/bubbletea-app-template/internal/colors" "github.com/charmbracelet/bubbletea-app-template/internal/picker" + "github.com/charmbracelet/bubbletea-app-template/internal/preview" "github.com/charmbracelet/bubbletea-app-template/internal/quit" ) type Model struct { active int pickers []picker.Model + preview preview.Model } func New(pickers []picker.Model) Model { return Model{ active: 0, pickers: pickers, + preview: *preview.New(colors.Hex(pickers[0].GetColor())), } } @@ -53,7 +57,7 @@ func (m Model) View() string { v += fmt.Sprintf(" %s |", p.Title()) } } - return fmt.Sprintf("%s\n%s", v, m.pickers[m.active].View()) + return fmt.Sprintf("%s\n%s\n%s", v, m.pickers[m.active].View(), m.preview.View()) } func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) { @@ -74,9 +78,14 @@ func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) { return quit.Model{}, tea.Quit // return m, tea.Quit default: + // Update the picker newActive, cmd := m.pickers[m.active].Update(msg) m.pickers[m.active] = newActive.(picker.Model) cmds = append(cmds, cmd) + // Update the preview + newPreview := preview.New(colors.Hex(m.pickers[m.active].GetColor())) + m.preview = *newPreview + return m, tea.Batch(cmds...) } } @@ -85,5 +94,8 @@ func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) { m.pickers[i] = newActive.(picker.Model) cmds = append(cmds, cmd) } + // Update the preview + newPreview := preview.New(colors.Hex(m.pickers[m.active].GetColor())) + m.preview = *newPreview return m, tea.Batch(cmds...) } -- cgit v1.2.3