@frontify/fondue-components 19.2.0 → 19.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (173) hide show
  1. package/dist/fondue-components.js +10 -8
  2. package/dist/fondue-components.js.map +1 -1
  3. package/dist/fondue-components10.js +3 -3
  4. package/dist/fondue-components10.js.map +1 -1
  5. package/dist/fondue-components11.js +3 -3
  6. package/dist/fondue-components11.js.map +1 -1
  7. package/dist/fondue-components12.js +2 -2
  8. package/dist/fondue-components12.js.map +1 -1
  9. package/dist/fondue-components13.js +3 -3
  10. package/dist/fondue-components13.js.map +1 -1
  11. package/dist/fondue-components14.js +2 -2
  12. package/dist/fondue-components14.js.map +1 -1
  13. package/dist/fondue-components15.js +2 -2
  14. package/dist/fondue-components15.js.map +1 -1
  15. package/dist/fondue-components16.js +1 -1
  16. package/dist/fondue-components16.js.map +1 -1
  17. package/dist/fondue-components17.js +1 -1
  18. package/dist/fondue-components17.js.map +1 -1
  19. package/dist/fondue-components18.js +1 -1
  20. package/dist/fondue-components18.js.map +1 -1
  21. package/dist/fondue-components19.js +1 -1
  22. package/dist/fondue-components19.js.map +1 -1
  23. package/dist/fondue-components20.js +2 -2
  24. package/dist/fondue-components20.js.map +1 -1
  25. package/dist/fondue-components21.js +2 -2
  26. package/dist/fondue-components21.js.map +1 -1
  27. package/dist/fondue-components22.js +8 -8
  28. package/dist/fondue-components22.js.map +1 -1
  29. package/dist/fondue-components23.js +1 -1
  30. package/dist/fondue-components23.js.map +1 -1
  31. package/dist/fondue-components24.js +2 -2
  32. package/dist/fondue-components24.js.map +1 -1
  33. package/dist/fondue-components25.js +63 -62
  34. package/dist/fondue-components25.js.map +1 -1
  35. package/dist/fondue-components26.js +77 -70
  36. package/dist/fondue-components26.js.map +1 -1
  37. package/dist/fondue-components27.js +2 -2
  38. package/dist/fondue-components27.js.map +1 -1
  39. package/dist/fondue-components28.js +3 -12
  40. package/dist/fondue-components28.js.map +1 -1
  41. package/dist/fondue-components29.js +101 -10
  42. package/dist/fondue-components29.js.map +1 -1
  43. package/dist/fondue-components3.js +93 -73
  44. package/dist/fondue-components3.js.map +1 -1
  45. package/dist/fondue-components30.js +12 -55
  46. package/dist/fondue-components30.js.map +1 -1
  47. package/dist/fondue-components31.js +55 -14
  48. package/dist/fondue-components31.js.map +1 -1
  49. package/dist/fondue-components32.js +20 -7
  50. package/dist/fondue-components32.js.map +1 -1
  51. package/dist/fondue-components33.js +7 -6
  52. package/dist/fondue-components33.js.map +1 -1
  53. package/dist/fondue-components34.js +7 -32
  54. package/dist/fondue-components34.js.map +1 -1
  55. package/dist/fondue-components35.js +32 -5
  56. package/dist/fondue-components35.js.map +1 -1
  57. package/dist/fondue-components36.js +5 -12
  58. package/dist/fondue-components36.js.map +1 -1
  59. package/dist/fondue-components37.js +10 -153
  60. package/dist/fondue-components37.js.map +1 -1
  61. package/dist/fondue-components38.js +59 -22
  62. package/dist/fondue-components38.js.map +1 -1
  63. package/dist/fondue-components39.js +17 -17
  64. package/dist/fondue-components39.js.map +1 -1
  65. package/dist/fondue-components4.js +33 -32
  66. package/dist/fondue-components4.js.map +1 -1
  67. package/dist/fondue-components40.js +112 -15
  68. package/dist/fondue-components40.js.map +1 -1
  69. package/dist/fondue-components41.js +19 -30
  70. package/dist/fondue-components41.js.map +1 -1
  71. package/dist/fondue-components42.js +32 -62
  72. package/dist/fondue-components42.js.map +1 -1
  73. package/dist/fondue-components43.js +53 -121
  74. package/dist/fondue-components43.js.map +1 -1
  75. package/dist/fondue-components44.js +129 -20
  76. package/dist/fondue-components44.js.map +1 -1
  77. package/dist/fondue-components45.js +21 -45
  78. package/dist/fondue-components45.js.map +1 -1
  79. package/dist/fondue-components46.js +45 -8
  80. package/dist/fondue-components46.js.map +1 -1
  81. package/dist/fondue-components47.js +8 -13
  82. package/dist/fondue-components47.js.map +1 -1
  83. package/dist/fondue-components48.js +13 -15
  84. package/dist/fondue-components48.js.map +1 -1
  85. package/dist/fondue-components49.js +14 -4
  86. package/dist/fondue-components49.js.map +1 -1
  87. package/dist/fondue-components5.js +2 -2
  88. package/dist/fondue-components5.js.map +1 -1
  89. package/dist/fondue-components50.js +5 -60
  90. package/dist/fondue-components50.js.map +1 -1
  91. package/dist/fondue-components51.js +59 -17
  92. package/dist/fondue-components51.js.map +1 -1
  93. package/dist/fondue-components52.js +18 -19
  94. package/dist/fondue-components52.js.map +1 -1
  95. package/dist/fondue-components53.js +18 -4
  96. package/dist/fondue-components53.js.map +1 -1
  97. package/dist/fondue-components54.js +3 -13
  98. package/dist/fondue-components54.js.map +1 -1
  99. package/dist/fondue-components55.js +13 -3
  100. package/dist/fondue-components55.js.map +1 -1
  101. package/dist/fondue-components56.js +3 -17
  102. package/dist/fondue-components56.js.map +1 -1
  103. package/dist/fondue-components57.js +19 -35
  104. package/dist/fondue-components57.js.map +1 -1
  105. package/dist/fondue-components58.js +35 -5
  106. package/dist/fondue-components58.js.map +1 -1
  107. package/dist/fondue-components59.js +4 -12
  108. package/dist/fondue-components59.js.map +1 -1
  109. package/dist/fondue-components6.js +4 -4
  110. package/dist/fondue-components6.js.map +1 -1
  111. package/dist/fondue-components60.js +12 -4
  112. package/dist/fondue-components60.js.map +1 -1
  113. package/dist/fondue-components61.js +4 -24
  114. package/dist/fondue-components61.js.map +1 -1
  115. package/dist/fondue-components62.js +24 -16
  116. package/dist/fondue-components62.js.map +1 -1
  117. package/dist/fondue-components63.js +16 -150
  118. package/dist/fondue-components63.js.map +1 -1
  119. package/dist/fondue-components64.js +151 -19
  120. package/dist/fondue-components64.js.map +1 -1
  121. package/dist/fondue-components65.js +19 -77
  122. package/dist/fondue-components65.js.map +1 -1
  123. package/dist/fondue-components66.js +77 -8
  124. package/dist/fondue-components66.js.map +1 -1
  125. package/dist/fondue-components67.js +8 -35
  126. package/dist/fondue-components67.js.map +1 -1
  127. package/dist/fondue-components68.js +34 -70
  128. package/dist/fondue-components68.js.map +1 -1
  129. package/dist/fondue-components69.js +70 -10
  130. package/dist/fondue-components69.js.map +1 -1
  131. package/dist/fondue-components7.js +36 -30
  132. package/dist/fondue-components7.js.map +1 -1
  133. package/dist/fondue-components70.js +8 -10
  134. package/dist/fondue-components70.js.map +1 -1
  135. package/dist/fondue-components71.js +12 -12
  136. package/dist/fondue-components71.js.map +1 -1
  137. package/dist/fondue-components72.js +12 -20
  138. package/dist/fondue-components72.js.map +1 -1
  139. package/dist/fondue-components73.js +21 -29
  140. package/dist/fondue-components73.js.map +1 -1
  141. package/dist/fondue-components74.js +33 -55
  142. package/dist/fondue-components74.js.map +1 -1
  143. package/dist/fondue-components75.js +55 -14
  144. package/dist/fondue-components75.js.map +1 -1
  145. package/dist/fondue-components76.js +14 -25
  146. package/dist/fondue-components76.js.map +1 -1
  147. package/dist/fondue-components77.js +24 -13
  148. package/dist/fondue-components77.js.map +1 -1
  149. package/dist/fondue-components78.js +14 -6
  150. package/dist/fondue-components78.js.map +1 -1
  151. package/dist/fondue-components79.js +21 -5
  152. package/dist/fondue-components79.js.map +1 -1
  153. package/dist/fondue-components8.js +5 -5
  154. package/dist/fondue-components8.js.map +1 -1
  155. package/dist/fondue-components80.js +6 -4
  156. package/dist/fondue-components80.js.map +1 -1
  157. package/dist/fondue-components81.js +6 -4
  158. package/dist/fondue-components81.js.map +1 -1
  159. package/dist/fondue-components82.js +5 -2
  160. package/dist/fondue-components82.js.map +1 -1
  161. package/dist/fondue-components83.js +4 -16
  162. package/dist/fondue-components83.js.map +1 -1
  163. package/dist/fondue-components84.js +2 -40
  164. package/dist/fondue-components84.js.map +1 -1
  165. package/dist/fondue-components85.js +43 -0
  166. package/dist/fondue-components85.js.map +1 -0
  167. package/dist/fondue-components86.js +20 -0
  168. package/dist/fondue-components86.js.map +1 -0
  169. package/dist/fondue-components9.js +37 -32
  170. package/dist/fondue-components9.js.map +1 -1
  171. package/dist/index.d.ts +125 -50
  172. package/dist/style.css +1 -1
  173. package/package.json +60 -60
@@ -1,133 +1,65 @@
1
- import { jsxs as n, jsx as e } from "react/jsx-runtime";
2
- import { forwardRef as N, useState as b, useEffect as R } from "react";
3
- import { Select as c } from "./fondue-components22.js";
4
- import { TextInput as r } from "./fondue-components28.js";
5
- import a from "./fondue-components44.js";
6
- import { rgbColorToHex as d, DEFAULT_COLOR as I, DEFAULT_FORMAT as x, isValidHexColor as m, hexColorToRgba as S, getLimitedColorChannelValue as o } from "./fondue-components45.js";
7
- const h = ({
8
- currentColor: t = I,
9
- onColorChange: i = () => {
10
- },
11
- currentFormat: s = x,
12
- setCurrentFormat: v = () => {
13
- },
14
- "data-test-id": f = "color-picker-value-input"
15
- }, g) => {
16
- const [u, p] = b(d(t));
17
- return R(() => {
18
- p(d(t));
19
- }, [t]), /* @__PURE__ */ n("div", { className: a.inputs, "data-test-id": f, ref: g, children: [
20
- /* @__PURE__ */ e("div", { className: a.colorFormatInput, children: /* @__PURE__ */ n(
21
- c,
1
+ import { jsxs as s, jsx as e, Fragment as f } from "react/jsx-runtime";
2
+ import { IconDroplet as h, IconCross as I, IconCaretDown as v } from "@frontify/fondue-icons";
3
+ import { forwardRef as b } from "react";
4
+ import t from "./fondue-components86.js";
5
+ import { getColorWithName as k, colorToCss as y } from "./fondue-components46.js";
6
+ const c = ({
7
+ id: l,
8
+ currentColor: a,
9
+ isOpen: d,
10
+ disabled: i = !1,
11
+ onClear: o,
12
+ onClick: m,
13
+ "data-test-id": n = "color-picker-input",
14
+ ...r
15
+ }, p) => {
16
+ const N = (a == null ? void 0 : a.name) ?? (a ? k(a, "RGBA").name : "");
17
+ return /* @__PURE__ */ s("div", { id: l, className: t.root, ref: p, "data-test-id": n, children: [
18
+ /* @__PURE__ */ s(
19
+ "button",
22
20
  {
23
- "data-test-id": "color-picker-select-format",
24
- "aria-label": "Select a color format",
25
- onSelect: (l) => {
26
- v(l);
27
- },
28
- value: s,
21
+ className: t.button,
22
+ ...r,
23
+ disabled: i,
24
+ onClick: m,
25
+ type: "button",
26
+ "data-color-input-select": !0,
29
27
  children: [
30
- /* @__PURE__ */ e(c.Item, { value: "HEX", children: "HEX" }),
31
- /* @__PURE__ */ e(c.Item, { value: "RGBA", children: "RGBA" })
28
+ (a == null ? void 0 : a.red) !== void 0 ? /* @__PURE__ */ e(
29
+ "div",
30
+ {
31
+ "aria-hidden": !0,
32
+ className: t.colorIndicator,
33
+ style: { "--active-color": y(a) }
34
+ }
35
+ ) : /* @__PURE__ */ s(f, { children: [
36
+ /* @__PURE__ */ e(h, { size: 16 }),
37
+ /* @__PURE__ */ e("span", { children: "Select Color" })
38
+ ] }),
39
+ /* @__PURE__ */ e("span", { className: t.colorName, children: N })
32
40
  ]
33
41
  }
34
- ) }),
35
- s === "HEX" ? /* @__PURE__ */ e(
36
- r.Root,
37
- {
38
- "data-test-id": "color-picker-value-input-hex",
39
- className: a.valueInput,
40
- type: "text",
41
- value: u,
42
- status: m(u) ? "neutral" : "error",
43
- onBlur: (l) => {
44
- m(l.target.value) && i({ ...S(l.target.value), alpha: t.alpha });
45
- },
46
- onChange: (l) => {
47
- p(l.target.value);
48
- },
49
- "aria-label": "Hex color value",
50
- children: /* @__PURE__ */ e(r.Slot, { name: "left", children: /* @__PURE__ */ e("span", { className: a.inputDecorator, children: "#" }) })
51
- }
52
- ) : /* @__PURE__ */ n("div", { className: a.colorChannelInputGroup, children: [
53
- /* @__PURE__ */ e(
54
- r.Root,
55
- {
56
- "data-test-id": "color-picker-value-input-red",
57
- className: a.valueInput,
58
- value: t.red,
59
- type: "number",
60
- onChange: (l) => {
61
- i({
62
- ...t,
63
- red: o(l.target.value)
64
- });
65
- },
66
- "aria-label": "Red Color Channel",
67
- children: /* @__PURE__ */ e(r.Slot, { name: "left", children: /* @__PURE__ */ e("span", { className: a.inputDecorator, children: "R" }) })
68
- }
69
- ),
70
- /* @__PURE__ */ e(
71
- r.Root,
42
+ ),
43
+ /* @__PURE__ */ s("div", { className: t.actions, children: [
44
+ o && /* @__PURE__ */ e(
45
+ "button",
72
46
  {
73
- "data-test-id": "color-picker-value-input-green",
74
- className: a.valueInput,
75
- value: t.green,
76
- type: "number",
77
- onChange: (l) => {
78
- i({
79
- ...t,
80
- green: o(l.target.value)
81
- });
82
- },
83
- "aria-label": "Green Color Channel",
84
- children: /* @__PURE__ */ e(r.Slot, { name: "left", children: /* @__PURE__ */ e("span", { className: a.inputDecorator, children: "G" }) })
47
+ type: "button",
48
+ "aria-label": "Clear color",
49
+ onClick: o,
50
+ className: t.clear,
51
+ disabled: i,
52
+ children: /* @__PURE__ */ e(I, { size: 16 })
85
53
  }
86
54
  ),
87
- /* @__PURE__ */ e(
88
- r.Root,
89
- {
90
- "data-test-id": "color-picker-value-input-blue",
91
- className: a.valueInput,
92
- value: t.blue,
93
- type: "number",
94
- onChange: (l) => {
95
- i({
96
- ...t,
97
- blue: o(l.target.value)
98
- });
99
- },
100
- "aria-label": "Blue Color Channel",
101
- children: /* @__PURE__ */ e(r.Slot, { name: "left", children: /* @__PURE__ */ e("span", { className: a.inputDecorator, children: "B" }) })
102
- }
103
- )
104
- ] }),
105
- /* @__PURE__ */ e("div", { className: a.colorAlphaInput, children: /* @__PURE__ */ n(
106
- r.Root,
107
- {
108
- "data-test-id": "color-picker-value-input-alpha",
109
- className: a.valueInput,
110
- value: t.alpha === void 0 ? 100 : Math.trunc(t.alpha * 100).toString(),
111
- type: "number",
112
- onChange: (l) => {
113
- i({
114
- ...t,
115
- alpha: o(l.target.value, 0, 100) / 100
116
- });
117
- },
118
- "aria-label": "Color Opacity",
119
- children: [
120
- /* @__PURE__ */ e(r.Slot, { name: "left", children: /* @__PURE__ */ e("span", { className: a.inputDecorator, children: "A" }) }),
121
- /* @__PURE__ */ e(r.Slot, { name: "right", children: /* @__PURE__ */ e("span", { className: a.inputDecorator, children: "%" }) })
122
- ]
123
- }
124
- ) })
55
+ /* @__PURE__ */ e("div", { className: t.caret, "data-state": d ? "open" : "closed", children: /* @__PURE__ */ e(v, { size: 16, className: t.caret }) })
56
+ ] })
125
57
  ] });
126
58
  };
127
- h.displayName = "ColorPicker.Values";
128
- const E = N(h);
59
+ c.displayName = "ColorPicker.Input";
60
+ const g = b(c);
129
61
  export {
130
- h as ColorValueInput,
131
- E as ForwardedRefColorValueInput
62
+ c as ColorPickerInput,
63
+ g as ForwardedRefColorPickerInput
132
64
  };
133
65
  //# sourceMappingURL=fondue-components43.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"fondue-components43.js","sources":["../src/components/ColorPicker/ColorValueInput.tsx"],"sourcesContent":["/* (c) Copyright Frontify Ltd., all rights reserved. */\n\nimport { type ForwardedRef, forwardRef, useEffect, useState } from 'react';\n\nimport { Select } from '../Select/Select';\nimport { TextInput } from '../TextInput/TextInput';\n\nimport styles from './styles/customColorPicker.module.scss';\nimport { type RgbaColor } from './types';\nimport {\n DEFAULT_COLOR,\n DEFAULT_FORMAT,\n getLimitedColorChannelValue,\n hexColorToRgba,\n isValidHexColor,\n rgbColorToHex,\n} from './utils';\n\ntype ColorFormat = 'HEX' | 'RGBA';\n\ntype ColorValueInputProps = {\n /**\n * @ignore\n * The active color in the color picker, passed down from the root component\n */\n currentColor?: RgbaColor;\n /**\n * @ignore\n * Event handler called when the color changes, passed down from the root component\n */\n onColorChange?: (color: RgbaColor) => void;\n /**\n * @ignore\n * The format to use for the color input, passed down from the root component\n */\n currentFormat?: ColorFormat;\n /**\n * @ignore\n * The format to use for the color input, passed down from the root component\n */\n setCurrentFormat?: (format: ColorFormat) => void;\n /**\n * The test id of the color picker value input\n */\n 'data-test-id'?: string;\n};\n\nexport const ColorValueInput = (\n {\n currentColor = DEFAULT_COLOR,\n onColorChange = () => {},\n currentFormat = DEFAULT_FORMAT,\n setCurrentFormat = () => {},\n 'data-test-id': dataTestId = 'color-picker-value-input',\n }: ColorValueInputProps,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n) => {\n const [hexColorValue, setHexColorValue] = useState<string>(rgbColorToHex(currentColor));\n\n useEffect(() => {\n setHexColorValue(rgbColorToHex(currentColor));\n }, [currentColor]);\n\n return (\n <div className={styles.inputs} data-test-id={dataTestId} ref={forwardedRef}>\n <div className={styles.colorFormatInput}>\n <Select\n data-test-id=\"color-picker-select-format\"\n aria-label=\"Select a color format\"\n onSelect={(selectedValue) => {\n setCurrentFormat(selectedValue as ColorFormat);\n }}\n value={currentFormat}\n >\n <Select.Item value=\"HEX\">HEX</Select.Item>\n <Select.Item value=\"RGBA\">RGBA</Select.Item>\n </Select>\n </div>\n {currentFormat === 'HEX' ? (\n <TextInput.Root\n data-test-id=\"color-picker-value-input-hex\"\n className={styles.valueInput}\n type=\"text\"\n value={hexColorValue}\n status={isValidHexColor(hexColorValue) ? 'neutral' : 'error'}\n onBlur={(event) => {\n if (isValidHexColor(event.target.value)) {\n onColorChange({ ...hexColorToRgba(event.target.value), alpha: currentColor.alpha });\n }\n }}\n onChange={(event) => {\n setHexColorValue(event.target.value);\n }}\n aria-label=\"Hex color value\"\n >\n <TextInput.Slot name=\"left\">\n <span className={styles.inputDecorator}>#</span>\n </TextInput.Slot>\n </TextInput.Root>\n ) : (\n <div className={styles.colorChannelInputGroup}>\n <TextInput.Root\n data-test-id=\"color-picker-value-input-red\"\n className={styles.valueInput}\n value={currentColor.red}\n type=\"number\"\n onChange={(event) => {\n onColorChange({\n ...currentColor,\n red: getLimitedColorChannelValue(event.target.value),\n });\n }}\n aria-label=\"Red Color Channel\"\n >\n <TextInput.Slot name=\"left\">\n <span className={styles.inputDecorator}>R</span>\n </TextInput.Slot>\n </TextInput.Root>\n <TextInput.Root\n data-test-id=\"color-picker-value-input-green\"\n className={styles.valueInput}\n value={currentColor.green}\n type=\"number\"\n onChange={(event) => {\n onColorChange({\n ...currentColor,\n green: getLimitedColorChannelValue(event.target.value),\n });\n }}\n aria-label=\"Green Color Channel\"\n >\n <TextInput.Slot name=\"left\">\n <span className={styles.inputDecorator}>G</span>\n </TextInput.Slot>\n </TextInput.Root>\n <TextInput.Root\n data-test-id=\"color-picker-value-input-blue\"\n className={styles.valueInput}\n value={currentColor.blue}\n type=\"number\"\n onChange={(event) => {\n onColorChange({\n ...currentColor,\n blue: getLimitedColorChannelValue(event.target.value),\n });\n }}\n aria-label=\"Blue Color Channel\"\n >\n <TextInput.Slot name=\"left\">\n <span className={styles.inputDecorator}>B</span>\n </TextInput.Slot>\n </TextInput.Root>\n </div>\n )}\n <div className={styles.colorAlphaInput}>\n <TextInput.Root\n data-test-id=\"color-picker-value-input-alpha\"\n className={styles.valueInput}\n /* .toString() is a workaround for https://github.com/facebook/react/issues/9402 */\n value={currentColor.alpha === undefined ? 100 : Math.trunc(currentColor.alpha * 100).toString()}\n type=\"number\"\n onChange={(event) => {\n onColorChange({\n ...currentColor,\n alpha: getLimitedColorChannelValue(event.target.value, 0, 100) / 100,\n });\n }}\n aria-label=\"Color Opacity\"\n >\n <TextInput.Slot name=\"left\">\n <span className={styles.inputDecorator}>A</span>\n </TextInput.Slot>\n <TextInput.Slot name=\"right\">\n <span className={styles.inputDecorator}>%</span>\n </TextInput.Slot>\n </TextInput.Root>\n </div>\n </div>\n );\n};\nColorValueInput.displayName = 'ColorPicker.Values';\n\nexport const ForwardedRefColorValueInput = forwardRef<HTMLDivElement, ColorValueInputProps>(ColorValueInput);\n"],"names":["ColorValueInput","currentColor","DEFAULT_COLOR","onColorChange","currentFormat","DEFAULT_FORMAT","setCurrentFormat","dataTestId","forwardedRef","hexColorValue","setHexColorValue","useState","rgbColorToHex","useEffect","jsxs","styles","jsx","Select","selectedValue","TextInput","isValidHexColor","event","hexColorToRgba","getLimitedColorChannelValue","ForwardedRefColorValueInput","forwardRef"],"mappings":"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"}
1
+ {"version":3,"file":"fondue-components43.js","sources":["../src/components/ColorPicker/ColorPickerInput.tsx"],"sourcesContent":["/* (c) Copyright Frontify Ltd., all rights reserved. */\n\nimport { IconCaretDown, IconCross, IconDroplet } from '@frontify/fondue-icons';\nimport { type CSSProperties, type ForwardedRef, forwardRef } from 'react';\n\nimport { type CommonAriaAttrs } from '#/utilities/types';\n\nimport styles from './styles/colorInput.module.scss';\nimport { type RgbaColor } from './types';\nimport { colorToCss, getColorWithName } from './utils';\n\ntype ColorPickerInputProps = {\n id?: string;\n /**\n * The active color in the color picker\n */\n currentColor?: RgbaColor;\n /**\n * The open state of the color picker used to determine arrow state\n */\n isOpen?: boolean;\n /**\n * Whether the color picker input is disabled\n */\n disabled?: boolean;\n /**\n * callback for clearing the color\n */\n onClear?: () => void;\n /**\n * Event handler called when the color picker input is clicked\n */\n onClick?: () => void;\n /**\n * The test id of the color picker input\n */\n 'data-test-id'?: string;\n} & CommonAriaAttrs;\n\nexport const ColorPickerInput = (\n {\n id,\n currentColor,\n isOpen,\n disabled = false,\n onClear,\n onClick,\n 'data-test-id': dataTestId = 'color-picker-input',\n ...props\n }: ColorPickerInputProps,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n) => {\n const colorName = currentColor?.name ?? (currentColor ? getColorWithName(currentColor, 'RGBA').name : '');\n return (\n <div id={id} className={styles.root} ref={forwardedRef} data-test-id={dataTestId}>\n <button\n className={styles.button}\n {...props}\n disabled={disabled}\n onClick={onClick}\n type=\"button\"\n data-color-input-select\n >\n {currentColor?.red !== undefined ? (\n <div\n aria-hidden\n className={styles.colorIndicator}\n style={{ '--active-color': colorToCss(currentColor) } as CSSProperties}\n />\n ) : (\n <>\n <IconDroplet size={16} />\n <span>Select Color</span>\n </>\n )}\n\n <span className={styles.colorName}>{colorName}</span>\n </button>\n <div className={styles.actions}>\n {onClear && (\n <button\n type=\"button\"\n aria-label=\"Clear color\"\n onClick={onClear}\n className={styles.clear}\n disabled={disabled}\n >\n <IconCross size={16} />\n </button>\n )}\n <div className={styles.caret} data-state={isOpen ? 'open' : 'closed'}>\n <IconCaretDown size={16} className={styles.caret} />\n </div>\n </div>\n </div>\n );\n};\nColorPickerInput.displayName = 'ColorPicker.Input';\n\nexport const ForwardedRefColorPickerInput = forwardRef<HTMLDivElement, ColorPickerInputProps>(ColorPickerInput);\n"],"names":["ColorPickerInput","id","currentColor","isOpen","disabled","onClear","onClick","dataTestId","props","forwardedRef","colorName","getColorWithName","jsxs","styles","jsx","colorToCss","Fragment","IconDroplet","IconCross","IconCaretDown","ForwardedRefColorPickerInput","forwardRef"],"mappings":";;;;;AAuCO,MAAMA,IAAmB,CAC5B;AAAA,EACI,IAAAC;AAAA,EACA,cAAAC;AAAA,EACA,QAAAC;AAAA,EACA,UAAAC,IAAW;AAAA,EACX,SAAAC;AAAA,EACA,SAAAC;AAAA,EACA,gBAAgBC,IAAa;AAAA,EAC7B,GAAGC;AACP,GACAC,MACC;AACD,QAAMC,KAAYR,KAAA,gBAAAA,EAAc,UAASA,IAAeS,EAAiBT,GAAc,MAAM,EAAE,OAAO;AACtG,SACI,gBAAAU,EAAC,SAAI,IAAAX,GAAQ,WAAWY,EAAO,MAAM,KAAKJ,GAAc,gBAAcF,GAClE,UAAA;AAAA,IAAA,gBAAAK;AAAA,MAAC;AAAA,MAAA;AAAA,QACG,WAAWC,EAAO;AAAA,QACjB,GAAGL;AAAA,QACJ,UAAAJ;AAAA,QACA,SAAAE;AAAA,QACA,MAAK;AAAA,QACL,2BAAuB;AAAA,QAEtB,UAAA;AAAA,WAAAJ,KAAA,gBAAAA,EAAc,SAAQ,SACnB,gBAAAY;AAAA,YAAC;AAAA,YAAA;AAAA,cACG,eAAW;AAAA,cACX,WAAWD,EAAO;AAAA,cAClB,OAAO,EAAE,kBAAkBE,EAAWb,CAAY,EAAA;AAAA,YAAE;AAAA,UAAA,IAGxD,gBAAAU,EAAAI,GAAA,EACI,UAAA;AAAA,YAAA,gBAAAF,EAACG,GAAA,EAAY,MAAM,GAAA,CAAI;AAAA,YACvB,gBAAAH,EAAC,UAAK,UAAA,eAAA,CAAY;AAAA,UAAA,GACtB;AAAA,UAGJ,gBAAAA,EAAC,QAAA,EAAK,WAAWD,EAAO,WAAY,UAAAH,EAAA,CAAU;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,IAElD,gBAAAE,EAAC,OAAA,EAAI,WAAWC,EAAO,SAClB,UAAA;AAAA,MAAAR,KACG,gBAAAS;AAAA,QAAC;AAAA,QAAA;AAAA,UACG,MAAK;AAAA,UACL,cAAW;AAAA,UACX,SAAST;AAAA,UACT,WAAWQ,EAAO;AAAA,UAClB,UAAAT;AAAA,UAEA,UAAA,gBAAAU,EAACI,GAAA,EAAU,MAAM,GAAA,CAAI;AAAA,QAAA;AAAA,MAAA;AAAA,wBAG5B,OAAA,EAAI,WAAWL,EAAO,OAAO,cAAYV,IAAS,SAAS,UACxD,UAAA,gBAAAW,EAACK,KAAc,MAAM,IAAI,WAAWN,EAAO,OAAO,EAAA,CACtD;AAAA,IAAA,EAAA,CACJ;AAAA,EAAA,GACJ;AAER;AACAb,EAAiB,cAAc;AAExB,MAAMoB,IAA+BC,EAAkDrB,CAAgB;"}
@@ -1,24 +1,133 @@
1
- const o = "_root_riubn_4", n = "_inputs_riubn_12", t = "_colorFormatInput_riubn_23", r = "_colorAlphaInput_riubn_24", u = "_colorChannelInputGroup_riubn_28", p = "_inputDecorator_riubn_39", _ = "_gradientInput_riubn_43", l = "_reactColorful_riubn_46", c = "_valueInput_riubn_50", a = {
2
- root: o,
3
- inputs: n,
4
- colorFormatInput: t,
5
- colorAlphaInput: r,
6
- colorChannelInputGroup: u,
7
- inputDecorator: p,
8
- gradientInput: _,
9
- reactColorful: l,
10
- valueInput: c
1
+ import { jsxs as n, jsx as e } from "react/jsx-runtime";
2
+ import { forwardRef as N, useState as b, useEffect as R } from "react";
3
+ import { Select as c } from "./fondue-components22.js";
4
+ import { TextInput as r } from "./fondue-components28.js";
5
+ import a from "./fondue-components45.js";
6
+ import { rgbColorToHex as d, DEFAULT_COLOR as I, DEFAULT_FORMAT as x, isValidHexColor as m, hexColorToRgba as S, getLimitedColorChannelValue as o } from "./fondue-components46.js";
7
+ const h = ({
8
+ currentColor: t = I,
9
+ onColorChange: i = () => {
10
+ },
11
+ currentFormat: s = x,
12
+ setCurrentFormat: v = () => {
13
+ },
14
+ "data-test-id": f = "color-picker-value-input"
15
+ }, g) => {
16
+ const [u, p] = b(() => d(t));
17
+ return R(() => {
18
+ p(d(t));
19
+ }, [t]), /* @__PURE__ */ n("div", { className: a.inputs, "data-test-id": f, ref: g, children: [
20
+ /* @__PURE__ */ e("div", { className: a.colorFormatInput, children: /* @__PURE__ */ n(
21
+ c,
22
+ {
23
+ "data-test-id": "color-picker-select-format",
24
+ "aria-label": "Select a color format",
25
+ onSelect: (l) => {
26
+ v(l);
27
+ },
28
+ value: s,
29
+ children: [
30
+ /* @__PURE__ */ e(c.Item, { value: "HEX", children: "HEX" }),
31
+ /* @__PURE__ */ e(c.Item, { value: "RGBA", children: "RGBA" })
32
+ ]
33
+ }
34
+ ) }),
35
+ s === "HEX" ? /* @__PURE__ */ e(
36
+ r.Root,
37
+ {
38
+ "data-test-id": "color-picker-value-input-hex",
39
+ className: a.valueInput,
40
+ type: "text",
41
+ value: u,
42
+ status: m(u) ? "neutral" : "error",
43
+ onBlur: (l) => {
44
+ m(l.target.value) && i({ ...S(l.target.value), alpha: t.alpha });
45
+ },
46
+ onChange: (l) => {
47
+ p(l.target.value);
48
+ },
49
+ "aria-label": "Hex color value",
50
+ children: /* @__PURE__ */ e(r.Slot, { name: "left", children: /* @__PURE__ */ e("span", { className: a.inputDecorator, children: "#" }) })
51
+ }
52
+ ) : /* @__PURE__ */ n("div", { className: a.colorChannelInputGroup, children: [
53
+ /* @__PURE__ */ e(
54
+ r.Root,
55
+ {
56
+ "data-test-id": "color-picker-value-input-red",
57
+ className: a.valueInput,
58
+ value: t.red,
59
+ type: "number",
60
+ onChange: (l) => {
61
+ i({
62
+ ...t,
63
+ red: o(l.target.value)
64
+ });
65
+ },
66
+ "aria-label": "Red Color Channel",
67
+ children: /* @__PURE__ */ e(r.Slot, { name: "left", children: /* @__PURE__ */ e("span", { className: a.inputDecorator, children: "R" }) })
68
+ }
69
+ ),
70
+ /* @__PURE__ */ e(
71
+ r.Root,
72
+ {
73
+ "data-test-id": "color-picker-value-input-green",
74
+ className: a.valueInput,
75
+ value: t.green,
76
+ type: "number",
77
+ onChange: (l) => {
78
+ i({
79
+ ...t,
80
+ green: o(l.target.value)
81
+ });
82
+ },
83
+ "aria-label": "Green Color Channel",
84
+ children: /* @__PURE__ */ e(r.Slot, { name: "left", children: /* @__PURE__ */ e("span", { className: a.inputDecorator, children: "G" }) })
85
+ }
86
+ ),
87
+ /* @__PURE__ */ e(
88
+ r.Root,
89
+ {
90
+ "data-test-id": "color-picker-value-input-blue",
91
+ className: a.valueInput,
92
+ value: t.blue,
93
+ type: "number",
94
+ onChange: (l) => {
95
+ i({
96
+ ...t,
97
+ blue: o(l.target.value)
98
+ });
99
+ },
100
+ "aria-label": "Blue Color Channel",
101
+ children: /* @__PURE__ */ e(r.Slot, { name: "left", children: /* @__PURE__ */ e("span", { className: a.inputDecorator, children: "B" }) })
102
+ }
103
+ )
104
+ ] }),
105
+ /* @__PURE__ */ e("div", { className: a.colorAlphaInput, children: /* @__PURE__ */ n(
106
+ r.Root,
107
+ {
108
+ "data-test-id": "color-picker-value-input-alpha",
109
+ className: a.valueInput,
110
+ value: t.alpha === void 0 ? 100 : Math.trunc(t.alpha * 100).toString(),
111
+ type: "number",
112
+ onChange: (l) => {
113
+ i({
114
+ ...t,
115
+ alpha: o(l.target.value, 0, 100) / 100
116
+ });
117
+ },
118
+ "aria-label": "Color Opacity",
119
+ children: [
120
+ /* @__PURE__ */ e(r.Slot, { name: "left", children: /* @__PURE__ */ e("span", { className: a.inputDecorator, children: "A" }) }),
121
+ /* @__PURE__ */ e(r.Slot, { name: "right", children: /* @__PURE__ */ e("span", { className: a.inputDecorator, children: "%" }) })
122
+ ]
123
+ }
124
+ ) })
125
+ ] });
11
126
  };
127
+ h.displayName = "ColorPicker.Values";
128
+ const E = N(h);
12
129
  export {
13
- r as colorAlphaInput,
14
- u as colorChannelInputGroup,
15
- t as colorFormatInput,
16
- a as default,
17
- _ as gradientInput,
18
- p as inputDecorator,
19
- n as inputs,
20
- l as reactColorful,
21
- o as root,
22
- c as valueInput
130
+ h as ColorValueInput,
131
+ E as ForwardedRefColorValueInput
23
132
  };
24
133
  //# sourceMappingURL=fondue-components44.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"fondue-components44.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;"}
1
+ {"version":3,"file":"fondue-components44.js","sources":["../src/components/ColorPicker/ColorValueInput.tsx"],"sourcesContent":["/* (c) Copyright Frontify Ltd., all rights reserved. */\n\nimport { type ForwardedRef, forwardRef, useEffect, useState } from 'react';\n\nimport { Select } from '../Select/Select';\nimport { TextInput } from '../TextInput/TextInput';\n\nimport styles from './styles/customColorPicker.module.scss';\nimport { type RgbaColor } from './types';\nimport {\n DEFAULT_COLOR,\n DEFAULT_FORMAT,\n getLimitedColorChannelValue,\n hexColorToRgba,\n isValidHexColor,\n rgbColorToHex,\n} from './utils';\n\ntype ColorFormat = 'HEX' | 'RGBA';\n\ntype ColorValueInputProps = {\n /**\n * @ignore\n * The active color in the color picker, passed down from the root component\n */\n currentColor?: RgbaColor;\n /**\n * @ignore\n * Event handler called when the color changes, passed down from the root component\n */\n onColorChange?: (color: RgbaColor) => void;\n /**\n * @ignore\n * The format to use for the color input, passed down from the root component\n */\n currentFormat?: ColorFormat;\n /**\n * @ignore\n * The format to use for the color input, passed down from the root component\n */\n setCurrentFormat?: (format: ColorFormat) => void;\n /**\n * The test id of the color picker value input\n */\n 'data-test-id'?: string;\n};\n\nexport const ColorValueInput = (\n {\n currentColor = DEFAULT_COLOR,\n onColorChange = () => {},\n currentFormat = DEFAULT_FORMAT,\n setCurrentFormat = () => {},\n 'data-test-id': dataTestId = 'color-picker-value-input',\n }: ColorValueInputProps,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n) => {\n const [hexColorValue, setHexColorValue] = useState<string>(() => rgbColorToHex(currentColor));\n\n useEffect(() => {\n setHexColorValue(rgbColorToHex(currentColor));\n }, [currentColor]);\n\n return (\n <div className={styles.inputs} data-test-id={dataTestId} ref={forwardedRef}>\n <div className={styles.colorFormatInput}>\n <Select\n data-test-id=\"color-picker-select-format\"\n aria-label=\"Select a color format\"\n onSelect={(selectedValue) => {\n setCurrentFormat(selectedValue as ColorFormat);\n }}\n value={currentFormat}\n >\n <Select.Item value=\"HEX\">HEX</Select.Item>\n <Select.Item value=\"RGBA\">RGBA</Select.Item>\n </Select>\n </div>\n {currentFormat === 'HEX' ? (\n <TextInput.Root\n data-test-id=\"color-picker-value-input-hex\"\n className={styles.valueInput}\n type=\"text\"\n value={hexColorValue}\n status={isValidHexColor(hexColorValue) ? 'neutral' : 'error'}\n onBlur={(event) => {\n if (isValidHexColor(event.target.value)) {\n onColorChange({ ...hexColorToRgba(event.target.value), alpha: currentColor.alpha });\n }\n }}\n onChange={(event) => {\n setHexColorValue(event.target.value);\n }}\n aria-label=\"Hex color value\"\n >\n <TextInput.Slot name=\"left\">\n <span className={styles.inputDecorator}>#</span>\n </TextInput.Slot>\n </TextInput.Root>\n ) : (\n <div className={styles.colorChannelInputGroup}>\n <TextInput.Root\n data-test-id=\"color-picker-value-input-red\"\n className={styles.valueInput}\n value={currentColor.red}\n type=\"number\"\n onChange={(event) => {\n onColorChange({\n ...currentColor,\n red: getLimitedColorChannelValue(event.target.value),\n });\n }}\n aria-label=\"Red Color Channel\"\n >\n <TextInput.Slot name=\"left\">\n <span className={styles.inputDecorator}>R</span>\n </TextInput.Slot>\n </TextInput.Root>\n <TextInput.Root\n data-test-id=\"color-picker-value-input-green\"\n className={styles.valueInput}\n value={currentColor.green}\n type=\"number\"\n onChange={(event) => {\n onColorChange({\n ...currentColor,\n green: getLimitedColorChannelValue(event.target.value),\n });\n }}\n aria-label=\"Green Color Channel\"\n >\n <TextInput.Slot name=\"left\">\n <span className={styles.inputDecorator}>G</span>\n </TextInput.Slot>\n </TextInput.Root>\n <TextInput.Root\n data-test-id=\"color-picker-value-input-blue\"\n className={styles.valueInput}\n value={currentColor.blue}\n type=\"number\"\n onChange={(event) => {\n onColorChange({\n ...currentColor,\n blue: getLimitedColorChannelValue(event.target.value),\n });\n }}\n aria-label=\"Blue Color Channel\"\n >\n <TextInput.Slot name=\"left\">\n <span className={styles.inputDecorator}>B</span>\n </TextInput.Slot>\n </TextInput.Root>\n </div>\n )}\n <div className={styles.colorAlphaInput}>\n <TextInput.Root\n data-test-id=\"color-picker-value-input-alpha\"\n className={styles.valueInput}\n /* .toString() is a workaround for https://github.com/facebook/react/issues/9402 */\n value={currentColor.alpha === undefined ? 100 : Math.trunc(currentColor.alpha * 100).toString()}\n type=\"number\"\n onChange={(event) => {\n onColorChange({\n ...currentColor,\n alpha: getLimitedColorChannelValue(event.target.value, 0, 100) / 100,\n });\n }}\n aria-label=\"Color Opacity\"\n >\n <TextInput.Slot name=\"left\">\n <span className={styles.inputDecorator}>A</span>\n </TextInput.Slot>\n <TextInput.Slot name=\"right\">\n <span className={styles.inputDecorator}>%</span>\n </TextInput.Slot>\n </TextInput.Root>\n </div>\n </div>\n );\n};\nColorValueInput.displayName = 'ColorPicker.Values';\n\nexport const ForwardedRefColorValueInput = forwardRef<HTMLDivElement, ColorValueInputProps>(ColorValueInput);\n"],"names":["ColorValueInput","currentColor","DEFAULT_COLOR","onColorChange","currentFormat","DEFAULT_FORMAT","setCurrentFormat","dataTestId","forwardedRef","hexColorValue","setHexColorValue","useState","rgbColorToHex","useEffect","jsxs","styles","jsx","Select","selectedValue","TextInput","isValidHexColor","event","hexColorToRgba","getLimitedColorChannelValue","ForwardedRefColorValueInput","forwardRef"],"mappings":"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"}
@@ -1,48 +1,24 @@
1
- const s = { red: 255, green: 255, blue: 255, alpha: 1, name: "" }, g = "HEX", $ = (e) => {
2
- if (e)
3
- return `rgba(${e.red}, ${e.green}, ${e.blue}, ${e.alpha ?? 1})`;
4
- }, p = (e) => {
5
- const r = /^([\dA-Fa-f]{3}){1,2}$/;
6
- return e.length > 2 && r.test(e);
7
- }, h = (e) => {
8
- const r = /^([\dA-Fa-f]{3}){1,2}$/, n = e.match(r);
9
- if (!n)
10
- return {
11
- red: 0,
12
- green: 0,
13
- blue: 0,
14
- alpha: 0
15
- };
16
- const t = n[0];
17
- return t.length === 3 ? {
18
- red: parseInt(`${t[0]}${t[0]}`, 16),
19
- green: parseInt(`${t[1]}${t[1]}`, 16),
20
- blue: parseInt(`${t[2]}${t[2]}`, 16),
21
- alpha: 1
22
- } : {
23
- red: parseInt(t.slice(0, 2), 16),
24
- green: parseInt(t.slice(2, 4), 16),
25
- blue: parseInt(t.slice(4, 6), 16),
26
- alpha: 1
27
- };
28
- }, a = (e) => {
29
- const { red: r, green: n, blue: t } = e;
30
- return `${r.toString(16).padStart(2, "0")}${n.toString(16).padStart(2, "0")}${t.toString(16).padStart(2, "0")}`;
31
- }, i = (e, r) => r === "HEX" ? {
32
- ...e,
33
- name: `#${a(e)}`
34
- } : {
35
- ...e,
36
- name: `rgba(${e.red}, ${e.green}, ${e.blue}, ${e.alpha ?? 1})`
37
- }, u = (e, r = 0, n = 255) => e.length === 0 || parseInt(e) < r ? r : parseInt(e) > n ? n : parseInt(e);
1
+ const o = "_root_riubn_4", n = "_inputs_riubn_12", t = "_colorFormatInput_riubn_23", r = "_colorAlphaInput_riubn_24", u = "_colorChannelInputGroup_riubn_28", p = "_inputDecorator_riubn_39", _ = "_gradientInput_riubn_43", l = "_reactColorful_riubn_46", c = "_valueInput_riubn_50", a = {
2
+ root: o,
3
+ inputs: n,
4
+ colorFormatInput: t,
5
+ colorAlphaInput: r,
6
+ colorChannelInputGroup: u,
7
+ inputDecorator: p,
8
+ gradientInput: _,
9
+ reactColorful: l,
10
+ valueInput: c
11
+ };
38
12
  export {
39
- s as DEFAULT_COLOR,
40
- g as DEFAULT_FORMAT,
41
- $ as colorToCss,
42
- i as getColorWithName,
43
- u as getLimitedColorChannelValue,
44
- h as hexColorToRgba,
45
- p as isValidHexColor,
46
- a as rgbColorToHex
13
+ r as colorAlphaInput,
14
+ u as colorChannelInputGroup,
15
+ t as colorFormatInput,
16
+ a as default,
17
+ _ as gradientInput,
18
+ p as inputDecorator,
19
+ n as inputs,
20
+ l as reactColorful,
21
+ o as root,
22
+ c as valueInput
47
23
  };
48
24
  //# sourceMappingURL=fondue-components45.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"fondue-components45.js","sources":["../src/components/ColorPicker/utils.ts"],"sourcesContent":["/* (c) Copyright Frontify Ltd., all rights reserved. */\n\nimport { type ColorFormat, type RgbaColor } from './types';\n\nexport const DEFAULT_COLOR = { red: 255, green: 255, blue: 255, alpha: 1, name: '' };\nexport const DEFAULT_FORMAT = 'HEX';\n\n/**\n * Converts a color object to a CSS color string.\n * @param {RgbaColor} color - The color object to be converted.\n * @returns {string}\n * @example\n * colorToCss({ red: 255, green: 255, blue: 255, alpha: 1 }); // 'rgba(255, 255, 255, 1)'\n * @example\n * colorToCss({ red: 255, green: 87, blue: 51, alpha: 1 }); // 'rgba(255, 87, 51, 1)'\n * @example\n * colorToCss({ red: 0, green: 0, blue: 0, alpha: 0 }); // 'rgba(0, 0, 0, 0)'\n */\nexport const colorToCss = (color?: RgbaColor) => {\n if (!color) {\n return undefined;\n }\n return `rgba(${color.red}, ${color.green}, ${color.blue}, ${color.alpha ?? 1})`;\n};\n\n/**\n * Checks if a string is a valid hexadecimal color code. This function accepts\n * both three-digit and six-digit hex codes without the '#' symbol.\n * @param {string} color - The color code to be checked.\n * @returns {boolean}\n * @example\n * isValidHexColor('FFF'); // true\n * @example\n * isValidHexColor('FF5733'); // true\n * @example\n * isValidHexColor('XYZ'); // false\n */\nexport const isValidHexColor = (color: string): boolean => {\n const hexRegex = /^([\\dA-Fa-f]{3}){1,2}$/;\n return color.length > 2 && hexRegex.test(color);\n};\n\n/**\n * Converts a hexadecimal color code to an RGBA color object. This function accepts\n * both three-digit and six-digit hex codes without the '#' symbol.\n * @param {string} hex - The hex code, either 3 or 6 characters long. Characters should be from the set [0-9A-Fa-f].\n * @returns {RgbaColor}\n * @example\n * hexColorToRgba('FFF'); // { red: 255, green: 255, blue: 255, alpha: 1 }\n * @example\n * hexColorToRgba('FF5733'); // { red: 255, green: 87, blue: 51, alpha: 1 }\n * @example\n * hexColorToRgba('XYZ'); // { red: 0, green: 0, blue: 0, alpha: 0 }\n */\nexport const hexColorToRgba = (hex: string): RgbaColor => {\n const hexRegex = /^([\\dA-Fa-f]{3}){1,2}$/;\n const matches = hex.match(hexRegex);\n if (!matches) {\n return {\n red: 0,\n green: 0,\n blue: 0,\n alpha: 0,\n };\n }\n const hexColor = matches[0];\n if (hexColor.length === 3) {\n return {\n red: parseInt(`${hexColor[0]}${hexColor[0]}`, 16),\n green: parseInt(`${hexColor[1]}${hexColor[1]}`, 16),\n blue: parseInt(`${hexColor[2]}${hexColor[2]}`, 16),\n alpha: 1,\n };\n }\n return {\n red: parseInt(hexColor.slice(0, 2), 16),\n green: parseInt(hexColor.slice(2, 4), 16),\n blue: parseInt(hexColor.slice(4, 6), 16),\n alpha: 1,\n };\n};\n\n/**\n * Converts an RGBA color object to a hexadecimal color code. This function returns a\n * six-digit hex code without the '#' symbol.\n * @param {RgbaColor} rgb - The RGBA color object.\n * @returns {string}\n * @example\n * rgbColorToHex({ red: 255, green: 255, blue: 255, alpha: 1 }); // '#FFFFFF'\n * @example\n * rgbColorToHex({ red: 255, green: 87, blue: 51, alpha: 1 }); // '#FF5733'\n * @example\n * rgbColorToHex({ red: 0, green: 0, blue: 0, alpha: 0 }); // '#000000'\n */\nexport const rgbColorToHex = (rgb: Omit<RgbaColor, 'alpha'>): string => {\n const { red, green, blue } = rgb;\n return `${red.toString(16).padStart(2, '0')}${green.toString(16).padStart(2, '0')}${blue.toString(16).padStart(2, '0')}`;\n};\n\n/**\n * Returns a color object with a name property based on the provided color and format.\n * @param {RgbaColor} color - The RGBA color object.\n * @param {ColorFormat} currentFormat - The current format of the color.\n * @returns {RgbaColor}\n * @example\n * getColorWithName({ red: 255, green: 255, blue: 255, alpha: 1 }, 'HEX'); // { red: 255, green: 255, blue: 255, alpha: 1, name: '#FFFFFF' }\n * @example\n * getColorWithName({ red: 255, green: 255, blue: 255, alpha: 1 }, 'RGBA'); // { red: 255, green: 255, blue: 255, alpha: 1, name: 'rgba(255, 255, 255, 1)' }\n * @example\n * getColorWithName({ red: 255, green: 87, blue: 51, alpha: 1 }, 'RGBA'); // { red: 255, green: 87, blue: 51, alpha: 1, name: 'rgba(255, 87, 51, 1)' }\n */\nexport const getColorWithName = (color: RgbaColor, currentFormat: ColorFormat) => {\n if (currentFormat === 'HEX') {\n return {\n ...color,\n name: `#${rgbColorToHex(color)}`,\n };\n }\n return {\n ...color,\n name: `rgba(${color.red}, ${color.green}, ${color.blue}, ${color.alpha ?? 1})`,\n };\n};\n\n/**\n * Returns a number between a minimum and maximum value, inclusive.\n * @param {string} value - The value to be limited.\n * @param {number} [min=0] - The minimum value (inclusive).\n * @param {number} [max=255] - The maximum value (inclusive).\n * @returns {number}\n * @example\n * getLimitedColorChannelValue('255'); // 255\n * @example\n * getLimitedColorChannelValue('100'); // 100\n * @example\n * getLimitedColorChannelValue('0'); // 0\n * @example\n * getLimitedColorChannelValue('500'); // 255\n * @example\n * getLimitedColorChannelValue('500', 0, 100); // 100\n */\nexport const getLimitedColorChannelValue = (value: string, min: number = 0, max: number = 255): number => {\n if (value.length === 0 || parseInt(value) < min) {\n return min;\n } else if (parseInt(value) > max) {\n return max;\n }\n return parseInt(value);\n};\n"],"names":["DEFAULT_COLOR","DEFAULT_FORMAT","colorToCss","color","isValidHexColor","hexRegex","hexColorToRgba","hex","matches","hexColor","rgbColorToHex","rgb","red","green","blue","getColorWithName","currentFormat","getLimitedColorChannelValue","value","min","max"],"mappings":"AAIa,MAAAA,IAAgB,EAAE,KAAK,KAAK,OAAO,KAAK,MAAM,KAAK,OAAO,GAAG,MAAM,GAAG,GACtEC,IAAiB,OAajBC,IAAa,CAACC,MAAsB;AAC7C,MAAKA;AAGL,WAAO,QAAQA,EAAM,GAAG,KAAKA,EAAM,KAAK,KAAKA,EAAM,IAAI,KAAKA,EAAM,SAAS,CAAC;AAChF,GAcaC,IAAkB,CAACD,MAA2B;AACvD,QAAME,IAAW;AACjB,SAAOF,EAAM,SAAS,KAAKE,EAAS,KAAKF,CAAK;AAClD,GAcaG,IAAiB,CAACC,MAA2B;AACtD,QAAMF,IAAW,0BACXG,IAAUD,EAAI,MAAMF,CAAQ;AAClC,MAAI,CAACG;AACM,WAAA;AAAA,MACH,KAAK;AAAA,MACL,OAAO;AAAA,MACP,MAAM;AAAA,MACN,OAAO;AAAA,IACX;AAEE,QAAAC,IAAWD,EAAQ,CAAC;AACtB,SAAAC,EAAS,WAAW,IACb;AAAA,IACH,KAAK,SAAS,GAAGA,EAAS,CAAC,CAAC,GAAGA,EAAS,CAAC,CAAC,IAAI,EAAE;AAAA,IAChD,OAAO,SAAS,GAAGA,EAAS,CAAC,CAAC,GAAGA,EAAS,CAAC,CAAC,IAAI,EAAE;AAAA,IAClD,MAAM,SAAS,GAAGA,EAAS,CAAC,CAAC,GAAGA,EAAS,CAAC,CAAC,IAAI,EAAE;AAAA,IACjD,OAAO;AAAA,EACX,IAEG;AAAA,IACH,KAAK,SAASA,EAAS,MAAM,GAAG,CAAC,GAAG,EAAE;AAAA,IACtC,OAAO,SAASA,EAAS,MAAM,GAAG,CAAC,GAAG,EAAE;AAAA,IACxC,MAAM,SAASA,EAAS,MAAM,GAAG,CAAC,GAAG,EAAE;AAAA,IACvC,OAAO;AAAA,EACX;AACJ,GAcaC,IAAgB,CAACC,MAA0C;AACpE,QAAM,EAAE,KAAAC,GAAK,OAAAC,GAAO,MAAAC,EAAS,IAAAH;AACtB,SAAA,GAAGC,EAAI,SAAS,EAAE,EAAE,SAAS,GAAG,GAAG,CAAC,GAAGC,EAAM,SAAS,EAAE,EAAE,SAAS,GAAG,GAAG,CAAC,GAAGC,EAAK,SAAS,EAAE,EAAE,SAAS,GAAG,GAAG,CAAC;AAC1H,GAcaC,IAAmB,CAACZ,GAAkBa,MAC3CA,MAAkB,QACX;AAAA,EACH,GAAGb;AAAA,EACH,MAAM,IAAIO,EAAcP,CAAK,CAAC;AAClC,IAEG;AAAA,EACH,GAAGA;AAAA,EACH,MAAM,QAAQA,EAAM,GAAG,KAAKA,EAAM,KAAK,KAAKA,EAAM,IAAI,KAAKA,EAAM,SAAS,CAAC;AAC/E,GAoBSc,IAA8B,CAACC,GAAeC,IAAc,GAAGC,IAAc,QAClFF,EAAM,WAAW,KAAK,SAASA,CAAK,IAAIC,IACjCA,IACA,SAASD,CAAK,IAAIE,IAClBA,IAEJ,SAASF,CAAK;"}
1
+ {"version":3,"file":"fondue-components45.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;"}
@@ -1,11 +1,48 @@
1
- import { useEffect as f } from "react";
2
- import { syncRefs as o } from "./fondue-components47.js";
3
- const m = (s, e) => {
4
- f(() => {
5
- o(s, e);
6
- }, [s]);
7
- };
1
+ const s = { red: 255, green: 255, blue: 255, alpha: 1, name: "" }, g = "HEX", $ = (e) => {
2
+ if (e)
3
+ return `rgba(${e.red}, ${e.green}, ${e.blue}, ${e.alpha ?? 1})`;
4
+ }, p = (e) => {
5
+ const r = /^([\dA-Fa-f]{3}){1,2}$/;
6
+ return e.length > 2 && r.test(e);
7
+ }, h = (e) => {
8
+ const r = /^([\dA-Fa-f]{3}){1,2}$/, n = e.match(r);
9
+ if (!n)
10
+ return {
11
+ red: 0,
12
+ green: 0,
13
+ blue: 0,
14
+ alpha: 0
15
+ };
16
+ const t = n[0];
17
+ return t.length === 3 ? {
18
+ red: parseInt(`${t[0]}${t[0]}`, 16),
19
+ green: parseInt(`${t[1]}${t[1]}`, 16),
20
+ blue: parseInt(`${t[2]}${t[2]}`, 16),
21
+ alpha: 1
22
+ } : {
23
+ red: parseInt(t.slice(0, 2), 16),
24
+ green: parseInt(t.slice(2, 4), 16),
25
+ blue: parseInt(t.slice(4, 6), 16),
26
+ alpha: 1
27
+ };
28
+ }, a = (e) => {
29
+ const { red: r, green: n, blue: t } = e;
30
+ return `${r.toString(16).padStart(2, "0")}${n.toString(16).padStart(2, "0")}${t.toString(16).padStart(2, "0")}`;
31
+ }, i = (e, r) => r === "HEX" ? {
32
+ ...e,
33
+ name: `#${a(e)}`
34
+ } : {
35
+ ...e,
36
+ name: `rgba(${e.red}, ${e.green}, ${e.blue}, ${e.alpha ?? 1})`
37
+ }, u = (e, r = 0, n = 255) => e.length === 0 || parseInt(e) < r ? r : parseInt(e) > n ? n : parseInt(e);
8
38
  export {
9
- m as useSyncRefs
39
+ s as DEFAULT_COLOR,
40
+ g as DEFAULT_FORMAT,
41
+ $ as colorToCss,
42
+ i as getColorWithName,
43
+ u as getLimitedColorChannelValue,
44
+ h as hexColorToRgba,
45
+ p as isValidHexColor,
46
+ a as rgbColorToHex
10
47
  };
11
48
  //# sourceMappingURL=fondue-components46.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"fondue-components46.js","sources":["../src/hooks/useSyncRefs.ts"],"sourcesContent":["/* (c) Copyright Frontify Ltd., all rights reserved. */\n\nimport { type ForwardedRef, useEffect, type RefObject } from 'react';\n\nimport { syncRefs } from '#/utilities/domUtilities';\n\n/**\n * A custom React hook that synchronizes a local ref with a forwarded ref.\n * This is useful when you need to maintain both an internal reference to a DOM element\n * and allow external access through a forwarded ref.\n *\n * @template TElement - The type of the DOM element being referenced. Defaults to HTMLElement.\n * @param {RefObject<TElement>} localRef - The local ref object used internally by the component.\n * @param {ForwardedRef<TElement>} forwardedRef - The ref forwarded from a parent component.\n *\n * @example\n * ```tsx\n * const MyComponent = forwardRef<HTMLDivElement>((props, ref) => {\n * const localRef = useRef<HTMLDivElement>(null);\n * useSyncRefs(localRef, ref);\n *\n * return <div ref={localRef}>Content</div>;\n * });\n * ```\n */\nexport const useSyncRefs = <TElement = HTMLElement>(\n localRef: RefObject<TElement>,\n forwardedRef: ForwardedRef<TElement>,\n) => {\n useEffect(() => {\n syncRefs<TElement>(localRef, forwardedRef);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [localRef]);\n};\n"],"names":["useSyncRefs","localRef","forwardedRef","useEffect","syncRefs"],"mappings":";;AAyBa,MAAAA,IAAc,CACvBC,GACAC,MACC;AACD,EAAAC,EAAU,MAAM;AACZ,IAAAC,EAAmBH,GAAUC,CAAY;AAAA,EAAA,GAE1C,CAACD,CAAQ,CAAC;AACjB;"}
1
+ {"version":3,"file":"fondue-components46.js","sources":["../src/components/ColorPicker/utils.ts"],"sourcesContent":["/* (c) Copyright Frontify Ltd., all rights reserved. */\n\nimport { type ColorFormat, type RgbaColor } from './types';\n\nexport const DEFAULT_COLOR = { red: 255, green: 255, blue: 255, alpha: 1, name: '' };\nexport const DEFAULT_FORMAT = 'HEX';\n\n/**\n * Converts a color object to a CSS color string.\n * @param {RgbaColor} color - The color object to be converted.\n * @returns {string}\n * @example\n * colorToCss({ red: 255, green: 255, blue: 255, alpha: 1 }); // 'rgba(255, 255, 255, 1)'\n * @example\n * colorToCss({ red: 255, green: 87, blue: 51, alpha: 1 }); // 'rgba(255, 87, 51, 1)'\n * @example\n * colorToCss({ red: 0, green: 0, blue: 0, alpha: 0 }); // 'rgba(0, 0, 0, 0)'\n */\nexport const colorToCss = (color?: RgbaColor) => {\n if (!color) {\n return undefined;\n }\n return `rgba(${color.red}, ${color.green}, ${color.blue}, ${color.alpha ?? 1})`;\n};\n\n/**\n * Checks if a string is a valid hexadecimal color code. This function accepts\n * both three-digit and six-digit hex codes without the '#' symbol.\n * @param {string} color - The color code to be checked.\n * @returns {boolean}\n * @example\n * isValidHexColor('FFF'); // true\n * @example\n * isValidHexColor('FF5733'); // true\n * @example\n * isValidHexColor('XYZ'); // false\n */\nexport const isValidHexColor = (color: string): boolean => {\n const hexRegex = /^([\\dA-Fa-f]{3}){1,2}$/;\n return color.length > 2 && hexRegex.test(color);\n};\n\n/**\n * Converts a hexadecimal color code to an RGBA color object. This function accepts\n * both three-digit and six-digit hex codes without the '#' symbol.\n * @param {string} hex - The hex code, either 3 or 6 characters long. Characters should be from the set [0-9A-Fa-f].\n * @returns {RgbaColor}\n * @example\n * hexColorToRgba('FFF'); // { red: 255, green: 255, blue: 255, alpha: 1 }\n * @example\n * hexColorToRgba('FF5733'); // { red: 255, green: 87, blue: 51, alpha: 1 }\n * @example\n * hexColorToRgba('XYZ'); // { red: 0, green: 0, blue: 0, alpha: 0 }\n */\nexport const hexColorToRgba = (hex: string): RgbaColor => {\n const hexRegex = /^([\\dA-Fa-f]{3}){1,2}$/;\n const matches = hex.match(hexRegex);\n if (!matches) {\n return {\n red: 0,\n green: 0,\n blue: 0,\n alpha: 0,\n };\n }\n const hexColor = matches[0];\n if (hexColor.length === 3) {\n return {\n red: parseInt(`${hexColor[0]}${hexColor[0]}`, 16),\n green: parseInt(`${hexColor[1]}${hexColor[1]}`, 16),\n blue: parseInt(`${hexColor[2]}${hexColor[2]}`, 16),\n alpha: 1,\n };\n }\n return {\n red: parseInt(hexColor.slice(0, 2), 16),\n green: parseInt(hexColor.slice(2, 4), 16),\n blue: parseInt(hexColor.slice(4, 6), 16),\n alpha: 1,\n };\n};\n\n/**\n * Converts an RGBA color object to a hexadecimal color code. This function returns a\n * six-digit hex code without the '#' symbol.\n * @param {RgbaColor} rgb - The RGBA color object.\n * @returns {string}\n * @example\n * rgbColorToHex({ red: 255, green: 255, blue: 255, alpha: 1 }); // '#FFFFFF'\n * @example\n * rgbColorToHex({ red: 255, green: 87, blue: 51, alpha: 1 }); // '#FF5733'\n * @example\n * rgbColorToHex({ red: 0, green: 0, blue: 0, alpha: 0 }); // '#000000'\n */\nexport const rgbColorToHex = (rgb: Omit<RgbaColor, 'alpha'>): string => {\n const { red, green, blue } = rgb;\n return `${red.toString(16).padStart(2, '0')}${green.toString(16).padStart(2, '0')}${blue.toString(16).padStart(2, '0')}`;\n};\n\n/**\n * Returns a color object with a name property based on the provided color and format.\n * @param {RgbaColor} color - The RGBA color object.\n * @param {ColorFormat} currentFormat - The current format of the color.\n * @returns {RgbaColor}\n * @example\n * getColorWithName({ red: 255, green: 255, blue: 255, alpha: 1 }, 'HEX'); // { red: 255, green: 255, blue: 255, alpha: 1, name: '#FFFFFF' }\n * @example\n * getColorWithName({ red: 255, green: 255, blue: 255, alpha: 1 }, 'RGBA'); // { red: 255, green: 255, blue: 255, alpha: 1, name: 'rgba(255, 255, 255, 1)' }\n * @example\n * getColorWithName({ red: 255, green: 87, blue: 51, alpha: 1 }, 'RGBA'); // { red: 255, green: 87, blue: 51, alpha: 1, name: 'rgba(255, 87, 51, 1)' }\n */\nexport const getColorWithName = (color: RgbaColor, currentFormat: ColorFormat) => {\n if (currentFormat === 'HEX') {\n return {\n ...color,\n name: `#${rgbColorToHex(color)}`,\n };\n }\n return {\n ...color,\n name: `rgba(${color.red}, ${color.green}, ${color.blue}, ${color.alpha ?? 1})`,\n };\n};\n\n/**\n * Returns a number between a minimum and maximum value, inclusive.\n * @param {string} value - The value to be limited.\n * @param {number} [min=0] - The minimum value (inclusive).\n * @param {number} [max=255] - The maximum value (inclusive).\n * @returns {number}\n * @example\n * getLimitedColorChannelValue('255'); // 255\n * @example\n * getLimitedColorChannelValue('100'); // 100\n * @example\n * getLimitedColorChannelValue('0'); // 0\n * @example\n * getLimitedColorChannelValue('500'); // 255\n * @example\n * getLimitedColorChannelValue('500', 0, 100); // 100\n */\nexport const getLimitedColorChannelValue = (value: string, min: number = 0, max: number = 255): number => {\n if (value.length === 0 || parseInt(value) < min) {\n return min;\n } else if (parseInt(value) > max) {\n return max;\n }\n return parseInt(value);\n};\n"],"names":["DEFAULT_COLOR","DEFAULT_FORMAT","colorToCss","color","isValidHexColor","hexRegex","hexColorToRgba","hex","matches","hexColor","rgbColorToHex","rgb","red","green","blue","getColorWithName","currentFormat","getLimitedColorChannelValue","value","min","max"],"mappings":"AAIO,MAAMA,IAAgB,EAAE,KAAK,KAAK,OAAO,KAAK,MAAM,KAAK,OAAO,GAAG,MAAM,GAAA,GACnEC,IAAiB,OAajBC,IAAa,CAACC,MAAsB;AAC7C,MAAKA;AAGL,WAAO,QAAQA,EAAM,GAAG,KAAKA,EAAM,KAAK,KAAKA,EAAM,IAAI,KAAKA,EAAM,SAAS,CAAC;AAChF,GAcaC,IAAkB,CAACD,MAA2B;AACvD,QAAME,IAAW;AACjB,SAAOF,EAAM,SAAS,KAAKE,EAAS,KAAKF,CAAK;AAClD,GAcaG,IAAiB,CAACC,MAA2B;AACtD,QAAMF,IAAW,0BACXG,IAAUD,EAAI,MAAMF,CAAQ;AAClC,MAAI,CAACG;AACD,WAAO;AAAA,MACH,KAAK;AAAA,MACL,OAAO;AAAA,MACP,MAAM;AAAA,MACN,OAAO;AAAA,IAAA;AAGf,QAAMC,IAAWD,EAAQ,CAAC;AAC1B,SAAIC,EAAS,WAAW,IACb;AAAA,IACH,KAAK,SAAS,GAAGA,EAAS,CAAC,CAAC,GAAGA,EAAS,CAAC,CAAC,IAAI,EAAE;AAAA,IAChD,OAAO,SAAS,GAAGA,EAAS,CAAC,CAAC,GAAGA,EAAS,CAAC,CAAC,IAAI,EAAE;AAAA,IAClD,MAAM,SAAS,GAAGA,EAAS,CAAC,CAAC,GAAGA,EAAS,CAAC,CAAC,IAAI,EAAE;AAAA,IACjD,OAAO;AAAA,EAAA,IAGR;AAAA,IACH,KAAK,SAASA,EAAS,MAAM,GAAG,CAAC,GAAG,EAAE;AAAA,IACtC,OAAO,SAASA,EAAS,MAAM,GAAG,CAAC,GAAG,EAAE;AAAA,IACxC,MAAM,SAASA,EAAS,MAAM,GAAG,CAAC,GAAG,EAAE;AAAA,IACvC,OAAO;AAAA,EAAA;AAEf,GAcaC,IAAgB,CAACC,MAA0C;AACpE,QAAM,EAAE,KAAAC,GAAK,OAAAC,GAAO,MAAAC,EAAA,IAASH;AAC7B,SAAO,GAAGC,EAAI,SAAS,EAAE,EAAE,SAAS,GAAG,GAAG,CAAC,GAAGC,EAAM,SAAS,EAAE,EAAE,SAAS,GAAG,GAAG,CAAC,GAAGC,EAAK,SAAS,EAAE,EAAE,SAAS,GAAG,GAAG,CAAC;AAC1H,GAcaC,IAAmB,CAACZ,GAAkBa,MAC3CA,MAAkB,QACX;AAAA,EACH,GAAGb;AAAA,EACH,MAAM,IAAIO,EAAcP,CAAK,CAAC;AAAA,IAG/B;AAAA,EACH,GAAGA;AAAA,EACH,MAAM,QAAQA,EAAM,GAAG,KAAKA,EAAM,KAAK,KAAKA,EAAM,IAAI,KAAKA,EAAM,SAAS,CAAC;AAAA,GAqBtEc,IAA8B,CAACC,GAAeC,IAAc,GAAGC,IAAc,QAClFF,EAAM,WAAW,KAAK,SAASA,CAAK,IAAIC,IACjCA,IACA,SAASD,CAAK,IAAIE,IAClBA,IAEJ,SAASF,CAAK;"}
@@ -1,16 +1,11 @@
1
- function s(u, t) {
2
- t && (typeof t == "function" ? t(u.current) : t && "current" in t && (t.current = u.current));
3
- }
4
- function i(u) {
5
- u.currentTarget.dataset.autoFocusVisible = "false";
6
- }
7
- function a(u) {
8
- const t = u.relatedTarget;
9
- t != null && t.dataset.autoFocusTrigger && (t.dataset.autoFocusVisible === "true" ? u.target.dataset.showFocusRing = "true" : u.target.dataset.showFocusRing = "false", t.dataset.autoFocusVisible = "true");
10
- }
1
+ import { useEffect as f } from "react";
2
+ import { syncRefs as o } from "./fondue-components48.js";
3
+ const m = (s, e) => {
4
+ f(() => {
5
+ o(s, e);
6
+ }, [s]);
7
+ };
11
8
  export {
12
- i as addAutoFocusAttribute,
13
- a as addShowFocusRing,
14
- s as syncRefs
9
+ m as useSyncRefs
15
10
  };
16
11
  //# sourceMappingURL=fondue-components47.js.map