From 26e4f7f11a8c10c48af66ce4f2d4c50d5a2dc760 Mon Sep 17 00:00:00 2001 From: Benjamin Chausse Date: Sun, 24 Nov 2024 18:19:04 -0500 Subject: feat: Notice messages when performing actions (#11) * Update releaser CI/CD version * feat: Notice messages when performing actions * Showcase notices in demo.gif --- internal/switcher/switcher.go | 26 +++++++++++++++++++++----- 1 file changed, 21 insertions(+), 5 deletions(-) (limited to 'internal/switcher') diff --git a/internal/switcher/switcher.go b/internal/switcher/switcher.go index 589b029..fce242c 100644 --- a/internal/switcher/switcher.go +++ b/internal/switcher/switcher.go @@ -5,6 +5,7 @@ import ( "log/slog" "github.com/ChausseBenjamin/termpicker/internal/colors" + "github.com/ChausseBenjamin/termpicker/internal/notices" "github.com/ChausseBenjamin/termpicker/internal/picker" "github.com/ChausseBenjamin/termpicker/internal/preview" "github.com/ChausseBenjamin/termpicker/internal/quit" @@ -21,6 +22,7 @@ type Model struct { preview preview.Model help help.Model fullHelp bool // When false, only show help for the switcher (not children) + notices notices.Model } func New(pickers []picker.Model) Model { @@ -30,6 +32,7 @@ func New(pickers []picker.Model) Model { preview: *preview.New(colors.Hex(pickers[0].GetColor())), help: help.New(), fullHelp: false, + notices: notices.New(), } } @@ -91,11 +94,12 @@ func (m Model) View() string { helpstr = boxStyle.Render(helpstr) - return fmt.Sprintf("%s\n%s\n%s\n%v", + return fmt.Sprintf("%s\n%s\n%s\n%v\n%v", tabs, pickerView, previewStr, helpstr, + m.notices.View(), ) } @@ -104,6 +108,10 @@ func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) { cmds := []tea.Cmd{} slog.Info("Received tea.Msg", "tea_msg", msg, "type", fmt.Sprintf("%T", msg)) switch msg := msg.(type) { + case notices.NoticeExpiryMsg: + newNotices, cmd := m.notices.Update(msg) + m.notices = newNotices.(notices.Model) + cmds = append(cmds, cmd) case tea.KeyMsg: switch { case key.Matches(msg, keys.next): @@ -117,22 +125,26 @@ func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) { m.pickers[m.active].SetColor(cs) case key.Matches(msg, keys.cpHex): - util.Copy(colors.Hex(m.pickers[m.active].GetColor())) + cmd := m.notices.New(util.Copy(colors.Hex(m.pickers[m.active].GetColor()))) + cmds = append(cmds, cmd) case key.Matches(msg, keys.cpRgb): pc := m.pickers[m.active].GetColor().ToPrecise() rgb := colors.RGB{}.FromPrecise(pc).(colors.RGB) - util.Copy(rgb.String()) + cmd := m.notices.New(util.Copy(rgb.String())) + cmds = append(cmds, cmd) case key.Matches(msg, keys.cpHsl): pc := m.pickers[m.active].GetColor().ToPrecise() hsl := colors.HSL{}.FromPrecise(pc).(colors.HSL) - util.Copy(hsl.String()) + cmd := m.notices.New(util.Copy(hsl.String())) + cmds = append(cmds, cmd) case key.Matches(msg, keys.cpCmyk): pc := m.pickers[m.active].GetColor().ToPrecise() cmyk := colors.CMYK{}.FromPrecise(pc).(colors.CMYK) - util.Copy(cmyk.String()) + cmd := m.notices.New(util.Copy(cmyk.String())) + cmds = append(cmds, cmd) case key.Matches(msg, keys.help): m.fullHelp = !m.fullHelp @@ -149,6 +161,10 @@ func (m Model) Update(msg tea.Msg) (tea.Model, tea.Cmd) { newPreview := preview.New(colors.Hex(m.pickers[m.active].GetColor())) m.preview = *newPreview + newNotices, cmd := m.notices.Update(msg) + m.notices = newNotices.(notices.Model) + cmds = append(cmds, cmd) + return m, tea.Batch(cmds...) } default: -- cgit v1.2.3