diff options
Diffstat (limited to 'internal')
-rw-r--r-- | internal/switcher/switcher.go | 21 | ||||
-rw-r--r-- | internal/userinput/userinput.go | 78 |
2 files changed, 99 insertions, 0 deletions
diff --git a/internal/switcher/switcher.go b/internal/switcher/switcher.go index fce242c..ec5c47a 100644 --- a/internal/switcher/switcher.go +++ b/internal/switcher/switcher.go @@ -51,8 +51,29 @@ func (m *Model) Prev() int { return m.active } +func (m *Model) SetActive(i int) { + m.active = m.fixSel(i) +} + +func (m *Model) UpdatePicker(i int, c colors.ColorSpace) { + m.pickers[i].SetColor(c) +} + +func (m *Model) NewNotice(msg string) tea.Cmd { + return m.notices.New(msg) +} + func (m Model) Init() tea.Cmd { cmds := []tea.Cmd{} + + // Make a backup of notices received before the program starts + // then reinitialize them with a proper expiration time. + noticeBackup := m.notices.Notices + m.notices = notices.New() + for _, v := range noticeBackup { + cmds = append(cmds, m.NewNotice(v)) + } + for _, p := range m.pickers { cmds = append(cmds, p.Init()) } diff --git a/internal/userinput/userinput.go b/internal/userinput/userinput.go new file mode 100644 index 0000000..8f1ecdc --- /dev/null +++ b/internal/userinput/userinput.go @@ -0,0 +1,78 @@ +package userinput + +import ( + "errors" + "fmt" + "strings" + + "github.com/ChausseBenjamin/termpicker/internal/colors" +) + +var ( + errUnknownColorFormat = errors.New("Unrecognized color format") + errHexParsing = errors.New("Failed to parse hex color") + errRGBParsing = errors.New("Failed to parse RGB color") + errHSLParsing = errors.New("Failed to parse HSL color") + errCMYKParsing = errors.New("Failed to parse CMYK color") +) + +func sanitize(s string) string { + s = strings.ReplaceAll(s, "\"", "") + s = strings.ReplaceAll(s, "%", "") + s = strings.ReplaceAll(s, "°", "") + s = strings.TrimSpace(s) + s = strings.ToLower(s) + return s +} + +func ParseColor(s string) (colors.ColorSpace, error) { + s = sanitize(s) + switch { + case strings.Contains(s, "#"): + return parseHex(s) + case strings.Contains(s, "rgb"): + return parseRGB(s) + case strings.Contains(s, "hsl"): + return parseHSL(s) + case strings.Contains(s, "cmyk"): + return parseCMYK(s) + default: + return nil, errUnknownColorFormat + } +} + +func parseRGB(s string) (colors.ColorSpace, error) { + var r, g, b int + _, err := fmt.Sscanf(s, "rgb(%d,%d,%d)", &r, &g, &b) + if err != nil { + return nil, errors.Join(errRGBParsing, err) + } + return colors.RGB{R: r, G: g, B: b}, nil +} + +func parseHex(s string) (colors.ColorSpace, error) { + var r, g, b int + _, err := fmt.Sscanf(s, "#%02x%02x%02x", &r, &g, &b) + if err != nil { + return nil, errors.Join(errHexParsing, err) + } + return colors.RGB{R: r, G: g, B: b}, nil +} + +func parseCMYK(s string) (colors.ColorSpace, error) { + var c, m, y, k int + _, err := fmt.Sscanf(s, "cmyk(%d,%d,%d,%d)", &c, &m, &y, &k) + if err != nil { + return nil, errors.Join(errCMYKParsing, err) + } + return colors.CMYK{C: c, M: m, Y: y, K: k}, nil +} + +func parseHSL(str string) (colors.ColorSpace, error) { + var h, s, l int + _, err := fmt.Sscanf(str, "hsl(%d,%d,%d)", &h, &s, &l) + if err != nil { + return nil, errors.Join(errHSLParsing, err) + } + return colors.HSL{H: h, S: s, L: l}, nil +} |