summaryrefslogtreecommitdiff
path: root/internal
diff options
context:
space:
mode:
Diffstat (limited to 'internal')
-rw-r--r--internal/switcher/switcher.go21
-rw-r--r--internal/userinput/userinput.go78
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
+}