@storybook/addon-docs 9.2.0-alpha.3 → 10.0.0-beta.1

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 (63) hide show
  1. package/README.md +5 -3
  2. package/dist/_browser-chunks/Color-LWAWP22K.js +1566 -0
  3. package/dist/_browser-chunks/DocsRenderer-HT7GNKAR.js +9 -0
  4. package/dist/_browser-chunks/chunk-67KILNXL.js +6831 -0
  5. package/dist/_browser-chunks/chunk-74ZUTOZN.js +65 -0
  6. package/dist/_browser-chunks/chunk-MM7DTO55.js +44 -0
  7. package/dist/_browser-chunks/chunk-RX6225WF.js +46 -0
  8. package/dist/_browser-chunks/chunk-TQ5Q4DDG.js +846 -0
  9. package/dist/_browser-chunks/chunk-UZFOWTVP.js +974 -0
  10. package/dist/_node-chunks/chunk-6DADMWJS.js +248 -0
  11. package/dist/_node-chunks/chunk-LNIOBV3K.js +231 -0
  12. package/dist/_node-chunks/chunk-QLR5HOHE.js +48 -0
  13. package/dist/_node-chunks/chunk-YXBYQIGE.js +35424 -0
  14. package/dist/_node-chunks/mdx-plugin-NOHB7LLV.js +1653 -0
  15. package/dist/_node-chunks/rehype-external-links-D74PKVP3.js +168 -0
  16. package/dist/_node-chunks/rehype-slug-KQZG2QNC.js +127 -0
  17. package/dist/angular/index.d.ts +3 -0
  18. package/dist/angular/index.js +11 -0
  19. package/dist/blocks.d.ts +86 -42
  20. package/dist/blocks.js +8123 -201
  21. package/dist/ember/index.d.ts +3 -0
  22. package/dist/ember/index.js +11 -0
  23. package/dist/index.d.ts +42 -5
  24. package/dist/index.js +17 -15
  25. package/dist/manager.js +85 -154
  26. package/dist/mdx-loader.js +38 -71
  27. package/dist/mdx-react-shim.js +2 -0
  28. package/dist/preset.js +310 -72
  29. package/dist/preview.js +8 -13
  30. package/dist/web-components/index.d.ts +2 -0
  31. package/dist/web-components/index.js +0 -0
  32. package/manager.js +1 -1
  33. package/package.json +45 -89
  34. package/preset.js +1 -1
  35. package/preview.js +1 -1
  36. package/angular/README.md +0 -256
  37. package/angular/index.d.ts +0 -1
  38. package/angular/index.js +0 -4
  39. package/common/README.md +0 -98
  40. package/dist/Color-AVL7NMMY.mjs +0 -10
  41. package/dist/DocsContainer-fccc2203.d.ts +0 -51
  42. package/dist/DocsRenderer-3PZUHFFL.mjs +0 -2
  43. package/dist/DocsRenderer-ULRJ3H2C.mjs +0 -8
  44. package/dist/blocks.mjs +0 -213
  45. package/dist/chunk-2UFMRE4V.mjs +0 -5
  46. package/dist/chunk-CEH6MNVV.mjs +0 -3
  47. package/dist/chunk-GWJYCGSQ.mjs +0 -7
  48. package/dist/chunk-QUZPS4B6.mjs +0 -3
  49. package/dist/chunk-SPFYY5GD.mjs +0 -3
  50. package/dist/index.mjs +0 -8
  51. package/dist/preview.mjs +0 -5
  52. package/dist/shims/mdx-react-shim.js +0 -12
  53. package/dist/shims/mdx-react-shim.mjs +0 -1
  54. package/ember/README.md +0 -153
  55. package/ember/index.d.ts +0 -1
  56. package/ember/index.js +0 -3
  57. package/react/README.md +0 -149
  58. package/svelte/HOC.svelte +0 -7
  59. package/vue/README.md +0 -152
  60. package/vue3/README.md +0 -152
  61. package/web-components/README.md +0 -131
  62. package/web-components/index.js +0 -1
  63. /package/dist/{shims/mdx-react-shim.d.ts → mdx-react-shim.d.ts} +0 -0
@@ -0,0 +1,1566 @@
1
+ import {
2
+ debounce,
3
+ getControlId
4
+ } from "./chunk-67KILNXL.js";
5
+ import {
6
+ __commonJS,
7
+ __name,
8
+ __toESM
9
+ } from "./chunk-MM7DTO55.js";
10
+
11
+ // ../../node_modules/color-name/index.js
12
+ var require_color_name = __commonJS({
13
+ "../../node_modules/color-name/index.js"(exports, module) {
14
+ "use strict";
15
+ module.exports = {
16
+ "aliceblue": [240, 248, 255],
17
+ "antiquewhite": [250, 235, 215],
18
+ "aqua": [0, 255, 255],
19
+ "aquamarine": [127, 255, 212],
20
+ "azure": [240, 255, 255],
21
+ "beige": [245, 245, 220],
22
+ "bisque": [255, 228, 196],
23
+ "black": [0, 0, 0],
24
+ "blanchedalmond": [255, 235, 205],
25
+ "blue": [0, 0, 255],
26
+ "blueviolet": [138, 43, 226],
27
+ "brown": [165, 42, 42],
28
+ "burlywood": [222, 184, 135],
29
+ "cadetblue": [95, 158, 160],
30
+ "chartreuse": [127, 255, 0],
31
+ "chocolate": [210, 105, 30],
32
+ "coral": [255, 127, 80],
33
+ "cornflowerblue": [100, 149, 237],
34
+ "cornsilk": [255, 248, 220],
35
+ "crimson": [220, 20, 60],
36
+ "cyan": [0, 255, 255],
37
+ "darkblue": [0, 0, 139],
38
+ "darkcyan": [0, 139, 139],
39
+ "darkgoldenrod": [184, 134, 11],
40
+ "darkgray": [169, 169, 169],
41
+ "darkgreen": [0, 100, 0],
42
+ "darkgrey": [169, 169, 169],
43
+ "darkkhaki": [189, 183, 107],
44
+ "darkmagenta": [139, 0, 139],
45
+ "darkolivegreen": [85, 107, 47],
46
+ "darkorange": [255, 140, 0],
47
+ "darkorchid": [153, 50, 204],
48
+ "darkred": [139, 0, 0],
49
+ "darksalmon": [233, 150, 122],
50
+ "darkseagreen": [143, 188, 143],
51
+ "darkslateblue": [72, 61, 139],
52
+ "darkslategray": [47, 79, 79],
53
+ "darkslategrey": [47, 79, 79],
54
+ "darkturquoise": [0, 206, 209],
55
+ "darkviolet": [148, 0, 211],
56
+ "deeppink": [255, 20, 147],
57
+ "deepskyblue": [0, 191, 255],
58
+ "dimgray": [105, 105, 105],
59
+ "dimgrey": [105, 105, 105],
60
+ "dodgerblue": [30, 144, 255],
61
+ "firebrick": [178, 34, 34],
62
+ "floralwhite": [255, 250, 240],
63
+ "forestgreen": [34, 139, 34],
64
+ "fuchsia": [255, 0, 255],
65
+ "gainsboro": [220, 220, 220],
66
+ "ghostwhite": [248, 248, 255],
67
+ "gold": [255, 215, 0],
68
+ "goldenrod": [218, 165, 32],
69
+ "gray": [128, 128, 128],
70
+ "green": [0, 128, 0],
71
+ "greenyellow": [173, 255, 47],
72
+ "grey": [128, 128, 128],
73
+ "honeydew": [240, 255, 240],
74
+ "hotpink": [255, 105, 180],
75
+ "indianred": [205, 92, 92],
76
+ "indigo": [75, 0, 130],
77
+ "ivory": [255, 255, 240],
78
+ "khaki": [240, 230, 140],
79
+ "lavender": [230, 230, 250],
80
+ "lavenderblush": [255, 240, 245],
81
+ "lawngreen": [124, 252, 0],
82
+ "lemonchiffon": [255, 250, 205],
83
+ "lightblue": [173, 216, 230],
84
+ "lightcoral": [240, 128, 128],
85
+ "lightcyan": [224, 255, 255],
86
+ "lightgoldenrodyellow": [250, 250, 210],
87
+ "lightgray": [211, 211, 211],
88
+ "lightgreen": [144, 238, 144],
89
+ "lightgrey": [211, 211, 211],
90
+ "lightpink": [255, 182, 193],
91
+ "lightsalmon": [255, 160, 122],
92
+ "lightseagreen": [32, 178, 170],
93
+ "lightskyblue": [135, 206, 250],
94
+ "lightslategray": [119, 136, 153],
95
+ "lightslategrey": [119, 136, 153],
96
+ "lightsteelblue": [176, 196, 222],
97
+ "lightyellow": [255, 255, 224],
98
+ "lime": [0, 255, 0],
99
+ "limegreen": [50, 205, 50],
100
+ "linen": [250, 240, 230],
101
+ "magenta": [255, 0, 255],
102
+ "maroon": [128, 0, 0],
103
+ "mediumaquamarine": [102, 205, 170],
104
+ "mediumblue": [0, 0, 205],
105
+ "mediumorchid": [186, 85, 211],
106
+ "mediumpurple": [147, 112, 219],
107
+ "mediumseagreen": [60, 179, 113],
108
+ "mediumslateblue": [123, 104, 238],
109
+ "mediumspringgreen": [0, 250, 154],
110
+ "mediumturquoise": [72, 209, 204],
111
+ "mediumvioletred": [199, 21, 133],
112
+ "midnightblue": [25, 25, 112],
113
+ "mintcream": [245, 255, 250],
114
+ "mistyrose": [255, 228, 225],
115
+ "moccasin": [255, 228, 181],
116
+ "navajowhite": [255, 222, 173],
117
+ "navy": [0, 0, 128],
118
+ "oldlace": [253, 245, 230],
119
+ "olive": [128, 128, 0],
120
+ "olivedrab": [107, 142, 35],
121
+ "orange": [255, 165, 0],
122
+ "orangered": [255, 69, 0],
123
+ "orchid": [218, 112, 214],
124
+ "palegoldenrod": [238, 232, 170],
125
+ "palegreen": [152, 251, 152],
126
+ "paleturquoise": [175, 238, 238],
127
+ "palevioletred": [219, 112, 147],
128
+ "papayawhip": [255, 239, 213],
129
+ "peachpuff": [255, 218, 185],
130
+ "peru": [205, 133, 63],
131
+ "pink": [255, 192, 203],
132
+ "plum": [221, 160, 221],
133
+ "powderblue": [176, 224, 230],
134
+ "purple": [128, 0, 128],
135
+ "rebeccapurple": [102, 51, 153],
136
+ "red": [255, 0, 0],
137
+ "rosybrown": [188, 143, 143],
138
+ "royalblue": [65, 105, 225],
139
+ "saddlebrown": [139, 69, 19],
140
+ "salmon": [250, 128, 114],
141
+ "sandybrown": [244, 164, 96],
142
+ "seagreen": [46, 139, 87],
143
+ "seashell": [255, 245, 238],
144
+ "sienna": [160, 82, 45],
145
+ "silver": [192, 192, 192],
146
+ "skyblue": [135, 206, 235],
147
+ "slateblue": [106, 90, 205],
148
+ "slategray": [112, 128, 144],
149
+ "slategrey": [112, 128, 144],
150
+ "snow": [255, 250, 250],
151
+ "springgreen": [0, 255, 127],
152
+ "steelblue": [70, 130, 180],
153
+ "tan": [210, 180, 140],
154
+ "teal": [0, 128, 128],
155
+ "thistle": [216, 191, 216],
156
+ "tomato": [255, 99, 71],
157
+ "turquoise": [64, 224, 208],
158
+ "violet": [238, 130, 238],
159
+ "wheat": [245, 222, 179],
160
+ "white": [255, 255, 255],
161
+ "whitesmoke": [245, 245, 245],
162
+ "yellow": [255, 255, 0],
163
+ "yellowgreen": [154, 205, 50]
164
+ };
165
+ }
166
+ });
167
+
168
+ // ../../node_modules/color-convert/conversions.js
169
+ var require_conversions = __commonJS({
170
+ "../../node_modules/color-convert/conversions.js"(exports, module) {
171
+ var cssKeywords = require_color_name();
172
+ var reverseKeywords = {};
173
+ for (const key of Object.keys(cssKeywords)) {
174
+ reverseKeywords[cssKeywords[key]] = key;
175
+ }
176
+ var convert2 = {
177
+ rgb: { channels: 3, labels: "rgb" },
178
+ hsl: { channels: 3, labels: "hsl" },
179
+ hsv: { channels: 3, labels: "hsv" },
180
+ hwb: { channels: 3, labels: "hwb" },
181
+ cmyk: { channels: 4, labels: "cmyk" },
182
+ xyz: { channels: 3, labels: "xyz" },
183
+ lab: { channels: 3, labels: "lab" },
184
+ lch: { channels: 3, labels: "lch" },
185
+ hex: { channels: 1, labels: ["hex"] },
186
+ keyword: { channels: 1, labels: ["keyword"] },
187
+ ansi16: { channels: 1, labels: ["ansi16"] },
188
+ ansi256: { channels: 1, labels: ["ansi256"] },
189
+ hcg: { channels: 3, labels: ["h", "c", "g"] },
190
+ apple: { channels: 3, labels: ["r16", "g16", "b16"] },
191
+ gray: { channels: 1, labels: ["gray"] }
192
+ };
193
+ module.exports = convert2;
194
+ for (const model of Object.keys(convert2)) {
195
+ if (!("channels" in convert2[model])) {
196
+ throw new Error("missing channels property: " + model);
197
+ }
198
+ if (!("labels" in convert2[model])) {
199
+ throw new Error("missing channel labels property: " + model);
200
+ }
201
+ if (convert2[model].labels.length !== convert2[model].channels) {
202
+ throw new Error("channel and label counts mismatch: " + model);
203
+ }
204
+ const { channels, labels } = convert2[model];
205
+ delete convert2[model].channels;
206
+ delete convert2[model].labels;
207
+ Object.defineProperty(convert2[model], "channels", { value: channels });
208
+ Object.defineProperty(convert2[model], "labels", { value: labels });
209
+ }
210
+ convert2.rgb.hsl = function(rgb) {
211
+ const r2 = rgb[0] / 255;
212
+ const g2 = rgb[1] / 255;
213
+ const b2 = rgb[2] / 255;
214
+ const min = Math.min(r2, g2, b2);
215
+ const max = Math.max(r2, g2, b2);
216
+ const delta = max - min;
217
+ let h2;
218
+ let s2;
219
+ if (max === min) {
220
+ h2 = 0;
221
+ } else if (r2 === max) {
222
+ h2 = (g2 - b2) / delta;
223
+ } else if (g2 === max) {
224
+ h2 = 2 + (b2 - r2) / delta;
225
+ } else if (b2 === max) {
226
+ h2 = 4 + (r2 - g2) / delta;
227
+ }
228
+ h2 = Math.min(h2 * 60, 360);
229
+ if (h2 < 0) {
230
+ h2 += 360;
231
+ }
232
+ const l2 = (min + max) / 2;
233
+ if (max === min) {
234
+ s2 = 0;
235
+ } else if (l2 <= 0.5) {
236
+ s2 = delta / (max + min);
237
+ } else {
238
+ s2 = delta / (2 - max - min);
239
+ }
240
+ return [h2, s2 * 100, l2 * 100];
241
+ };
242
+ convert2.rgb.hsv = function(rgb) {
243
+ let rdif;
244
+ let gdif;
245
+ let bdif;
246
+ let h2;
247
+ let s2;
248
+ const r2 = rgb[0] / 255;
249
+ const g2 = rgb[1] / 255;
250
+ const b2 = rgb[2] / 255;
251
+ const v2 = Math.max(r2, g2, b2);
252
+ const diff = v2 - Math.min(r2, g2, b2);
253
+ const diffc = /* @__PURE__ */ __name(function(c2) {
254
+ return (v2 - c2) / 6 / diff + 1 / 2;
255
+ }, "diffc");
256
+ if (diff === 0) {
257
+ h2 = 0;
258
+ s2 = 0;
259
+ } else {
260
+ s2 = diff / v2;
261
+ rdif = diffc(r2);
262
+ gdif = diffc(g2);
263
+ bdif = diffc(b2);
264
+ if (r2 === v2) {
265
+ h2 = bdif - gdif;
266
+ } else if (g2 === v2) {
267
+ h2 = 1 / 3 + rdif - bdif;
268
+ } else if (b2 === v2) {
269
+ h2 = 2 / 3 + gdif - rdif;
270
+ }
271
+ if (h2 < 0) {
272
+ h2 += 1;
273
+ } else if (h2 > 1) {
274
+ h2 -= 1;
275
+ }
276
+ }
277
+ return [
278
+ h2 * 360,
279
+ s2 * 100,
280
+ v2 * 100
281
+ ];
282
+ };
283
+ convert2.rgb.hwb = function(rgb) {
284
+ const r2 = rgb[0];
285
+ const g2 = rgb[1];
286
+ let b2 = rgb[2];
287
+ const h2 = convert2.rgb.hsl(rgb)[0];
288
+ const w2 = 1 / 255 * Math.min(r2, Math.min(g2, b2));
289
+ b2 = 1 - 1 / 255 * Math.max(r2, Math.max(g2, b2));
290
+ return [h2, w2 * 100, b2 * 100];
291
+ };
292
+ convert2.rgb.cmyk = function(rgb) {
293
+ const r2 = rgb[0] / 255;
294
+ const g2 = rgb[1] / 255;
295
+ const b2 = rgb[2] / 255;
296
+ const k2 = Math.min(1 - r2, 1 - g2, 1 - b2);
297
+ const c2 = (1 - r2 - k2) / (1 - k2) || 0;
298
+ const m2 = (1 - g2 - k2) / (1 - k2) || 0;
299
+ const y2 = (1 - b2 - k2) / (1 - k2) || 0;
300
+ return [c2 * 100, m2 * 100, y2 * 100, k2 * 100];
301
+ };
302
+ function comparativeDistance(x2, y2) {
303
+ return (x2[0] - y2[0]) ** 2 + (x2[1] - y2[1]) ** 2 + (x2[2] - y2[2]) ** 2;
304
+ }
305
+ __name(comparativeDistance, "comparativeDistance");
306
+ convert2.rgb.keyword = function(rgb) {
307
+ const reversed = reverseKeywords[rgb];
308
+ if (reversed) {
309
+ return reversed;
310
+ }
311
+ let currentClosestDistance = Infinity;
312
+ let currentClosestKeyword;
313
+ for (const keyword of Object.keys(cssKeywords)) {
314
+ const value = cssKeywords[keyword];
315
+ const distance = comparativeDistance(rgb, value);
316
+ if (distance < currentClosestDistance) {
317
+ currentClosestDistance = distance;
318
+ currentClosestKeyword = keyword;
319
+ }
320
+ }
321
+ return currentClosestKeyword;
322
+ };
323
+ convert2.keyword.rgb = function(keyword) {
324
+ return cssKeywords[keyword];
325
+ };
326
+ convert2.rgb.xyz = function(rgb) {
327
+ let r2 = rgb[0] / 255;
328
+ let g2 = rgb[1] / 255;
329
+ let b2 = rgb[2] / 255;
330
+ r2 = r2 > 0.04045 ? ((r2 + 0.055) / 1.055) ** 2.4 : r2 / 12.92;
331
+ g2 = g2 > 0.04045 ? ((g2 + 0.055) / 1.055) ** 2.4 : g2 / 12.92;
332
+ b2 = b2 > 0.04045 ? ((b2 + 0.055) / 1.055) ** 2.4 : b2 / 12.92;
333
+ const x2 = r2 * 0.4124 + g2 * 0.3576 + b2 * 0.1805;
334
+ const y2 = r2 * 0.2126 + g2 * 0.7152 + b2 * 0.0722;
335
+ const z2 = r2 * 0.0193 + g2 * 0.1192 + b2 * 0.9505;
336
+ return [x2 * 100, y2 * 100, z2 * 100];
337
+ };
338
+ convert2.rgb.lab = function(rgb) {
339
+ const xyz = convert2.rgb.xyz(rgb);
340
+ let x2 = xyz[0];
341
+ let y2 = xyz[1];
342
+ let z2 = xyz[2];
343
+ x2 /= 95.047;
344
+ y2 /= 100;
345
+ z2 /= 108.883;
346
+ x2 = x2 > 8856e-6 ? x2 ** (1 / 3) : 7.787 * x2 + 16 / 116;
347
+ y2 = y2 > 8856e-6 ? y2 ** (1 / 3) : 7.787 * y2 + 16 / 116;
348
+ z2 = z2 > 8856e-6 ? z2 ** (1 / 3) : 7.787 * z2 + 16 / 116;
349
+ const l2 = 116 * y2 - 16;
350
+ const a2 = 500 * (x2 - y2);
351
+ const b2 = 200 * (y2 - z2);
352
+ return [l2, a2, b2];
353
+ };
354
+ convert2.hsl.rgb = function(hsl) {
355
+ const h2 = hsl[0] / 360;
356
+ const s2 = hsl[1] / 100;
357
+ const l2 = hsl[2] / 100;
358
+ let t2;
359
+ let t3;
360
+ let val;
361
+ if (s2 === 0) {
362
+ val = l2 * 255;
363
+ return [val, val, val];
364
+ }
365
+ if (l2 < 0.5) {
366
+ t2 = l2 * (1 + s2);
367
+ } else {
368
+ t2 = l2 + s2 - l2 * s2;
369
+ }
370
+ const t1 = 2 * l2 - t2;
371
+ const rgb = [0, 0, 0];
372
+ for (let i2 = 0; i2 < 3; i2++) {
373
+ t3 = h2 + 1 / 3 * -(i2 - 1);
374
+ if (t3 < 0) {
375
+ t3++;
376
+ }
377
+ if (t3 > 1) {
378
+ t3--;
379
+ }
380
+ if (6 * t3 < 1) {
381
+ val = t1 + (t2 - t1) * 6 * t3;
382
+ } else if (2 * t3 < 1) {
383
+ val = t2;
384
+ } else if (3 * t3 < 2) {
385
+ val = t1 + (t2 - t1) * (2 / 3 - t3) * 6;
386
+ } else {
387
+ val = t1;
388
+ }
389
+ rgb[i2] = val * 255;
390
+ }
391
+ return rgb;
392
+ };
393
+ convert2.hsl.hsv = function(hsl) {
394
+ const h2 = hsl[0];
395
+ let s2 = hsl[1] / 100;
396
+ let l2 = hsl[2] / 100;
397
+ let smin = s2;
398
+ const lmin = Math.max(l2, 0.01);
399
+ l2 *= 2;
400
+ s2 *= l2 <= 1 ? l2 : 2 - l2;
401
+ smin *= lmin <= 1 ? lmin : 2 - lmin;
402
+ const v2 = (l2 + s2) / 2;
403
+ const sv = l2 === 0 ? 2 * smin / (lmin + smin) : 2 * s2 / (l2 + s2);
404
+ return [h2, sv * 100, v2 * 100];
405
+ };
406
+ convert2.hsv.rgb = function(hsv) {
407
+ const h2 = hsv[0] / 60;
408
+ const s2 = hsv[1] / 100;
409
+ let v2 = hsv[2] / 100;
410
+ const hi = Math.floor(h2) % 6;
411
+ const f2 = h2 - Math.floor(h2);
412
+ const p2 = 255 * v2 * (1 - s2);
413
+ const q2 = 255 * v2 * (1 - s2 * f2);
414
+ const t2 = 255 * v2 * (1 - s2 * (1 - f2));
415
+ v2 *= 255;
416
+ switch (hi) {
417
+ case 0:
418
+ return [v2, t2, p2];
419
+ case 1:
420
+ return [q2, v2, p2];
421
+ case 2:
422
+ return [p2, v2, t2];
423
+ case 3:
424
+ return [p2, q2, v2];
425
+ case 4:
426
+ return [t2, p2, v2];
427
+ case 5:
428
+ return [v2, p2, q2];
429
+ }
430
+ };
431
+ convert2.hsv.hsl = function(hsv) {
432
+ const h2 = hsv[0];
433
+ const s2 = hsv[1] / 100;
434
+ const v2 = hsv[2] / 100;
435
+ const vmin = Math.max(v2, 0.01);
436
+ let sl;
437
+ let l2;
438
+ l2 = (2 - s2) * v2;
439
+ const lmin = (2 - s2) * vmin;
440
+ sl = s2 * vmin;
441
+ sl /= lmin <= 1 ? lmin : 2 - lmin;
442
+ sl = sl || 0;
443
+ l2 /= 2;
444
+ return [h2, sl * 100, l2 * 100];
445
+ };
446
+ convert2.hwb.rgb = function(hwb) {
447
+ const h2 = hwb[0] / 360;
448
+ let wh = hwb[1] / 100;
449
+ let bl = hwb[2] / 100;
450
+ const ratio = wh + bl;
451
+ let f2;
452
+ if (ratio > 1) {
453
+ wh /= ratio;
454
+ bl /= ratio;
455
+ }
456
+ const i2 = Math.floor(6 * h2);
457
+ const v2 = 1 - bl;
458
+ f2 = 6 * h2 - i2;
459
+ if ((i2 & 1) !== 0) {
460
+ f2 = 1 - f2;
461
+ }
462
+ const n2 = wh + f2 * (v2 - wh);
463
+ let r2;
464
+ let g2;
465
+ let b2;
466
+ switch (i2) {
467
+ default:
468
+ case 6:
469
+ case 0:
470
+ r2 = v2;
471
+ g2 = n2;
472
+ b2 = wh;
473
+ break;
474
+ case 1:
475
+ r2 = n2;
476
+ g2 = v2;
477
+ b2 = wh;
478
+ break;
479
+ case 2:
480
+ r2 = wh;
481
+ g2 = v2;
482
+ b2 = n2;
483
+ break;
484
+ case 3:
485
+ r2 = wh;
486
+ g2 = n2;
487
+ b2 = v2;
488
+ break;
489
+ case 4:
490
+ r2 = n2;
491
+ g2 = wh;
492
+ b2 = v2;
493
+ break;
494
+ case 5:
495
+ r2 = v2;
496
+ g2 = wh;
497
+ b2 = n2;
498
+ break;
499
+ }
500
+ return [r2 * 255, g2 * 255, b2 * 255];
501
+ };
502
+ convert2.cmyk.rgb = function(cmyk) {
503
+ const c2 = cmyk[0] / 100;
504
+ const m2 = cmyk[1] / 100;
505
+ const y2 = cmyk[2] / 100;
506
+ const k2 = cmyk[3] / 100;
507
+ const r2 = 1 - Math.min(1, c2 * (1 - k2) + k2);
508
+ const g2 = 1 - Math.min(1, m2 * (1 - k2) + k2);
509
+ const b2 = 1 - Math.min(1, y2 * (1 - k2) + k2);
510
+ return [r2 * 255, g2 * 255, b2 * 255];
511
+ };
512
+ convert2.xyz.rgb = function(xyz) {
513
+ const x2 = xyz[0] / 100;
514
+ const y2 = xyz[1] / 100;
515
+ const z2 = xyz[2] / 100;
516
+ let r2;
517
+ let g2;
518
+ let b2;
519
+ r2 = x2 * 3.2406 + y2 * -1.5372 + z2 * -0.4986;
520
+ g2 = x2 * -0.9689 + y2 * 1.8758 + z2 * 0.0415;
521
+ b2 = x2 * 0.0557 + y2 * -0.204 + z2 * 1.057;
522
+ r2 = r2 > 31308e-7 ? 1.055 * r2 ** (1 / 2.4) - 0.055 : r2 * 12.92;
523
+ g2 = g2 > 31308e-7 ? 1.055 * g2 ** (1 / 2.4) - 0.055 : g2 * 12.92;
524
+ b2 = b2 > 31308e-7 ? 1.055 * b2 ** (1 / 2.4) - 0.055 : b2 * 12.92;
525
+ r2 = Math.min(Math.max(0, r2), 1);
526
+ g2 = Math.min(Math.max(0, g2), 1);
527
+ b2 = Math.min(Math.max(0, b2), 1);
528
+ return [r2 * 255, g2 * 255, b2 * 255];
529
+ };
530
+ convert2.xyz.lab = function(xyz) {
531
+ let x2 = xyz[0];
532
+ let y2 = xyz[1];
533
+ let z2 = xyz[2];
534
+ x2 /= 95.047;
535
+ y2 /= 100;
536
+ z2 /= 108.883;
537
+ x2 = x2 > 8856e-6 ? x2 ** (1 / 3) : 7.787 * x2 + 16 / 116;
538
+ y2 = y2 > 8856e-6 ? y2 ** (1 / 3) : 7.787 * y2 + 16 / 116;
539
+ z2 = z2 > 8856e-6 ? z2 ** (1 / 3) : 7.787 * z2 + 16 / 116;
540
+ const l2 = 116 * y2 - 16;
541
+ const a2 = 500 * (x2 - y2);
542
+ const b2 = 200 * (y2 - z2);
543
+ return [l2, a2, b2];
544
+ };
545
+ convert2.lab.xyz = function(lab) {
546
+ const l2 = lab[0];
547
+ const a2 = lab[1];
548
+ const b2 = lab[2];
549
+ let x2;
550
+ let y2;
551
+ let z2;
552
+ y2 = (l2 + 16) / 116;
553
+ x2 = a2 / 500 + y2;
554
+ z2 = y2 - b2 / 200;
555
+ const y22 = y2 ** 3;
556
+ const x22 = x2 ** 3;
557
+ const z22 = z2 ** 3;
558
+ y2 = y22 > 8856e-6 ? y22 : (y2 - 16 / 116) / 7.787;
559
+ x2 = x22 > 8856e-6 ? x22 : (x2 - 16 / 116) / 7.787;
560
+ z2 = z22 > 8856e-6 ? z22 : (z2 - 16 / 116) / 7.787;
561
+ x2 *= 95.047;
562
+ y2 *= 100;
563
+ z2 *= 108.883;
564
+ return [x2, y2, z2];
565
+ };
566
+ convert2.lab.lch = function(lab) {
567
+ const l2 = lab[0];
568
+ const a2 = lab[1];
569
+ const b2 = lab[2];
570
+ let h2;
571
+ const hr = Math.atan2(b2, a2);
572
+ h2 = hr * 360 / 2 / Math.PI;
573
+ if (h2 < 0) {
574
+ h2 += 360;
575
+ }
576
+ const c2 = Math.sqrt(a2 * a2 + b2 * b2);
577
+ return [l2, c2, h2];
578
+ };
579
+ convert2.lch.lab = function(lch) {
580
+ const l2 = lch[0];
581
+ const c2 = lch[1];
582
+ const h2 = lch[2];
583
+ const hr = h2 / 360 * 2 * Math.PI;
584
+ const a2 = c2 * Math.cos(hr);
585
+ const b2 = c2 * Math.sin(hr);
586
+ return [l2, a2, b2];
587
+ };
588
+ convert2.rgb.ansi16 = function(args, saturation = null) {
589
+ const [r2, g2, b2] = args;
590
+ let value = saturation === null ? convert2.rgb.hsv(args)[2] : saturation;
591
+ value = Math.round(value / 50);
592
+ if (value === 0) {
593
+ return 30;
594
+ }
595
+ let ansi = 30 + (Math.round(b2 / 255) << 2 | Math.round(g2 / 255) << 1 | Math.round(r2 / 255));
596
+ if (value === 2) {
597
+ ansi += 60;
598
+ }
599
+ return ansi;
600
+ };
601
+ convert2.hsv.ansi16 = function(args) {
602
+ return convert2.rgb.ansi16(convert2.hsv.rgb(args), args[2]);
603
+ };
604
+ convert2.rgb.ansi256 = function(args) {
605
+ const r2 = args[0];
606
+ const g2 = args[1];
607
+ const b2 = args[2];
608
+ if (r2 === g2 && g2 === b2) {
609
+ if (r2 < 8) {
610
+ return 16;
611
+ }
612
+ if (r2 > 248) {
613
+ return 231;
614
+ }
615
+ return Math.round((r2 - 8) / 247 * 24) + 232;
616
+ }
617
+ const ansi = 16 + 36 * Math.round(r2 / 255 * 5) + 6 * Math.round(g2 / 255 * 5) + Math.round(b2 / 255 * 5);
618
+ return ansi;
619
+ };
620
+ convert2.ansi16.rgb = function(args) {
621
+ let color = args % 10;
622
+ if (color === 0 || color === 7) {
623
+ if (args > 50) {
624
+ color += 3.5;
625
+ }
626
+ color = color / 10.5 * 255;
627
+ return [color, color, color];
628
+ }
629
+ const mult = (~~(args > 50) + 1) * 0.5;
630
+ const r2 = (color & 1) * mult * 255;
631
+ const g2 = (color >> 1 & 1) * mult * 255;
632
+ const b2 = (color >> 2 & 1) * mult * 255;
633
+ return [r2, g2, b2];
634
+ };
635
+ convert2.ansi256.rgb = function(args) {
636
+ if (args >= 232) {
637
+ const c2 = (args - 232) * 10 + 8;
638
+ return [c2, c2, c2];
639
+ }
640
+ args -= 16;
641
+ let rem;
642
+ const r2 = Math.floor(args / 36) / 5 * 255;
643
+ const g2 = Math.floor((rem = args % 36) / 6) / 5 * 255;
644
+ const b2 = rem % 6 / 5 * 255;
645
+ return [r2, g2, b2];
646
+ };
647
+ convert2.rgb.hex = function(args) {
648
+ const integer = ((Math.round(args[0]) & 255) << 16) + ((Math.round(args[1]) & 255) << 8) + (Math.round(args[2]) & 255);
649
+ const string = integer.toString(16).toUpperCase();
650
+ return "000000".substring(string.length) + string;
651
+ };
652
+ convert2.hex.rgb = function(args) {
653
+ const match = args.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);
654
+ if (!match) {
655
+ return [0, 0, 0];
656
+ }
657
+ let colorString = match[0];
658
+ if (match[0].length === 3) {
659
+ colorString = colorString.split("").map((char) => {
660
+ return char + char;
661
+ }).join("");
662
+ }
663
+ const integer = parseInt(colorString, 16);
664
+ const r2 = integer >> 16 & 255;
665
+ const g2 = integer >> 8 & 255;
666
+ const b2 = integer & 255;
667
+ return [r2, g2, b2];
668
+ };
669
+ convert2.rgb.hcg = function(rgb) {
670
+ const r2 = rgb[0] / 255;
671
+ const g2 = rgb[1] / 255;
672
+ const b2 = rgb[2] / 255;
673
+ const max = Math.max(Math.max(r2, g2), b2);
674
+ const min = Math.min(Math.min(r2, g2), b2);
675
+ const chroma = max - min;
676
+ let grayscale;
677
+ let hue;
678
+ if (chroma < 1) {
679
+ grayscale = min / (1 - chroma);
680
+ } else {
681
+ grayscale = 0;
682
+ }
683
+ if (chroma <= 0) {
684
+ hue = 0;
685
+ } else if (max === r2) {
686
+ hue = (g2 - b2) / chroma % 6;
687
+ } else if (max === g2) {
688
+ hue = 2 + (b2 - r2) / chroma;
689
+ } else {
690
+ hue = 4 + (r2 - g2) / chroma;
691
+ }
692
+ hue /= 6;
693
+ hue %= 1;
694
+ return [hue * 360, chroma * 100, grayscale * 100];
695
+ };
696
+ convert2.hsl.hcg = function(hsl) {
697
+ const s2 = hsl[1] / 100;
698
+ const l2 = hsl[2] / 100;
699
+ const c2 = l2 < 0.5 ? 2 * s2 * l2 : 2 * s2 * (1 - l2);
700
+ let f2 = 0;
701
+ if (c2 < 1) {
702
+ f2 = (l2 - 0.5 * c2) / (1 - c2);
703
+ }
704
+ return [hsl[0], c2 * 100, f2 * 100];
705
+ };
706
+ convert2.hsv.hcg = function(hsv) {
707
+ const s2 = hsv[1] / 100;
708
+ const v2 = hsv[2] / 100;
709
+ const c2 = s2 * v2;
710
+ let f2 = 0;
711
+ if (c2 < 1) {
712
+ f2 = (v2 - c2) / (1 - c2);
713
+ }
714
+ return [hsv[0], c2 * 100, f2 * 100];
715
+ };
716
+ convert2.hcg.rgb = function(hcg) {
717
+ const h2 = hcg[0] / 360;
718
+ const c2 = hcg[1] / 100;
719
+ const g2 = hcg[2] / 100;
720
+ if (c2 === 0) {
721
+ return [g2 * 255, g2 * 255, g2 * 255];
722
+ }
723
+ const pure = [0, 0, 0];
724
+ const hi = h2 % 1 * 6;
725
+ const v2 = hi % 1;
726
+ const w2 = 1 - v2;
727
+ let mg = 0;
728
+ switch (Math.floor(hi)) {
729
+ case 0:
730
+ pure[0] = 1;
731
+ pure[1] = v2;
732
+ pure[2] = 0;
733
+ break;
734
+ case 1:
735
+ pure[0] = w2;
736
+ pure[1] = 1;
737
+ pure[2] = 0;
738
+ break;
739
+ case 2:
740
+ pure[0] = 0;
741
+ pure[1] = 1;
742
+ pure[2] = v2;
743
+ break;
744
+ case 3:
745
+ pure[0] = 0;
746
+ pure[1] = w2;
747
+ pure[2] = 1;
748
+ break;
749
+ case 4:
750
+ pure[0] = v2;
751
+ pure[1] = 0;
752
+ pure[2] = 1;
753
+ break;
754
+ default:
755
+ pure[0] = 1;
756
+ pure[1] = 0;
757
+ pure[2] = w2;
758
+ }
759
+ mg = (1 - c2) * g2;
760
+ return [
761
+ (c2 * pure[0] + mg) * 255,
762
+ (c2 * pure[1] + mg) * 255,
763
+ (c2 * pure[2] + mg) * 255
764
+ ];
765
+ };
766
+ convert2.hcg.hsv = function(hcg) {
767
+ const c2 = hcg[1] / 100;
768
+ const g2 = hcg[2] / 100;
769
+ const v2 = c2 + g2 * (1 - c2);
770
+ let f2 = 0;
771
+ if (v2 > 0) {
772
+ f2 = c2 / v2;
773
+ }
774
+ return [hcg[0], f2 * 100, v2 * 100];
775
+ };
776
+ convert2.hcg.hsl = function(hcg) {
777
+ const c2 = hcg[1] / 100;
778
+ const g2 = hcg[2] / 100;
779
+ const l2 = g2 * (1 - c2) + 0.5 * c2;
780
+ let s2 = 0;
781
+ if (l2 > 0 && l2 < 0.5) {
782
+ s2 = c2 / (2 * l2);
783
+ } else if (l2 >= 0.5 && l2 < 1) {
784
+ s2 = c2 / (2 * (1 - l2));
785
+ }
786
+ return [hcg[0], s2 * 100, l2 * 100];
787
+ };
788
+ convert2.hcg.hwb = function(hcg) {
789
+ const c2 = hcg[1] / 100;
790
+ const g2 = hcg[2] / 100;
791
+ const v2 = c2 + g2 * (1 - c2);
792
+ return [hcg[0], (v2 - c2) * 100, (1 - v2) * 100];
793
+ };
794
+ convert2.hwb.hcg = function(hwb) {
795
+ const w2 = hwb[1] / 100;
796
+ const b2 = hwb[2] / 100;
797
+ const v2 = 1 - b2;
798
+ const c2 = v2 - w2;
799
+ let g2 = 0;
800
+ if (c2 < 1) {
801
+ g2 = (v2 - c2) / (1 - c2);
802
+ }
803
+ return [hwb[0], c2 * 100, g2 * 100];
804
+ };
805
+ convert2.apple.rgb = function(apple) {
806
+ return [apple[0] / 65535 * 255, apple[1] / 65535 * 255, apple[2] / 65535 * 255];
807
+ };
808
+ convert2.rgb.apple = function(rgb) {
809
+ return [rgb[0] / 255 * 65535, rgb[1] / 255 * 65535, rgb[2] / 255 * 65535];
810
+ };
811
+ convert2.gray.rgb = function(args) {
812
+ return [args[0] / 100 * 255, args[0] / 100 * 255, args[0] / 100 * 255];
813
+ };
814
+ convert2.gray.hsl = function(args) {
815
+ return [0, 0, args[0]];
816
+ };
817
+ convert2.gray.hsv = convert2.gray.hsl;
818
+ convert2.gray.hwb = function(gray) {
819
+ return [0, 100, gray[0]];
820
+ };
821
+ convert2.gray.cmyk = function(gray) {
822
+ return [0, 0, 0, gray[0]];
823
+ };
824
+ convert2.gray.lab = function(gray) {
825
+ return [gray[0], 0, 0];
826
+ };
827
+ convert2.gray.hex = function(gray) {
828
+ const val = Math.round(gray[0] / 100 * 255) & 255;
829
+ const integer = (val << 16) + (val << 8) + val;
830
+ const string = integer.toString(16).toUpperCase();
831
+ return "000000".substring(string.length) + string;
832
+ };
833
+ convert2.rgb.gray = function(rgb) {
834
+ const val = (rgb[0] + rgb[1] + rgb[2]) / 3;
835
+ return [val / 255 * 100];
836
+ };
837
+ }
838
+ });
839
+
840
+ // ../../node_modules/color-convert/route.js
841
+ var require_route = __commonJS({
842
+ "../../node_modules/color-convert/route.js"(exports, module) {
843
+ var conversions = require_conversions();
844
+ function buildGraph() {
845
+ const graph = {};
846
+ const models = Object.keys(conversions);
847
+ for (let len = models.length, i2 = 0; i2 < len; i2++) {
848
+ graph[models[i2]] = {
849
+ // http://jsperf.com/1-vs-infinity
850
+ // micro-opt, but this is simple.
851
+ distance: -1,
852
+ parent: null
853
+ };
854
+ }
855
+ return graph;
856
+ }
857
+ __name(buildGraph, "buildGraph");
858
+ function deriveBFS(fromModel) {
859
+ const graph = buildGraph();
860
+ const queue = [fromModel];
861
+ graph[fromModel].distance = 0;
862
+ while (queue.length) {
863
+ const current = queue.pop();
864
+ const adjacents = Object.keys(conversions[current]);
865
+ for (let len = adjacents.length, i2 = 0; i2 < len; i2++) {
866
+ const adjacent = adjacents[i2];
867
+ const node = graph[adjacent];
868
+ if (node.distance === -1) {
869
+ node.distance = graph[current].distance + 1;
870
+ node.parent = current;
871
+ queue.unshift(adjacent);
872
+ }
873
+ }
874
+ }
875
+ return graph;
876
+ }
877
+ __name(deriveBFS, "deriveBFS");
878
+ function link(from, to) {
879
+ return function(args) {
880
+ return to(from(args));
881
+ };
882
+ }
883
+ __name(link, "link");
884
+ function wrapConversion(toModel, graph) {
885
+ const path = [graph[toModel].parent, toModel];
886
+ let fn = conversions[graph[toModel].parent][toModel];
887
+ let cur = graph[toModel].parent;
888
+ while (graph[cur].parent) {
889
+ path.unshift(graph[cur].parent);
890
+ fn = link(conversions[graph[cur].parent][cur], fn);
891
+ cur = graph[cur].parent;
892
+ }
893
+ fn.conversion = path;
894
+ return fn;
895
+ }
896
+ __name(wrapConversion, "wrapConversion");
897
+ module.exports = function(fromModel) {
898
+ const graph = deriveBFS(fromModel);
899
+ const conversion = {};
900
+ const models = Object.keys(graph);
901
+ for (let len = models.length, i2 = 0; i2 < len; i2++) {
902
+ const toModel = models[i2];
903
+ const node = graph[toModel];
904
+ if (node.parent === null) {
905
+ continue;
906
+ }
907
+ conversion[toModel] = wrapConversion(toModel, graph);
908
+ }
909
+ return conversion;
910
+ };
911
+ }
912
+ });
913
+
914
+ // ../../node_modules/color-convert/index.js
915
+ var require_color_convert = __commonJS({
916
+ "../../node_modules/color-convert/index.js"(exports, module) {
917
+ var conversions = require_conversions();
918
+ var route = require_route();
919
+ var convert2 = {};
920
+ var models = Object.keys(conversions);
921
+ function wrapRaw(fn) {
922
+ const wrappedFn = /* @__PURE__ */ __name(function(...args) {
923
+ const arg0 = args[0];
924
+ if (arg0 === void 0 || arg0 === null) {
925
+ return arg0;
926
+ }
927
+ if (arg0.length > 1) {
928
+ args = arg0;
929
+ }
930
+ return fn(args);
931
+ }, "wrappedFn");
932
+ if ("conversion" in fn) {
933
+ wrappedFn.conversion = fn.conversion;
934
+ }
935
+ return wrappedFn;
936
+ }
937
+ __name(wrapRaw, "wrapRaw");
938
+ function wrapRounded(fn) {
939
+ const wrappedFn = /* @__PURE__ */ __name(function(...args) {
940
+ const arg0 = args[0];
941
+ if (arg0 === void 0 || arg0 === null) {
942
+ return arg0;
943
+ }
944
+ if (arg0.length > 1) {
945
+ args = arg0;
946
+ }
947
+ const result = fn(args);
948
+ if (typeof result === "object") {
949
+ for (let len = result.length, i2 = 0; i2 < len; i2++) {
950
+ result[i2] = Math.round(result[i2]);
951
+ }
952
+ }
953
+ return result;
954
+ }, "wrappedFn");
955
+ if ("conversion" in fn) {
956
+ wrappedFn.conversion = fn.conversion;
957
+ }
958
+ return wrappedFn;
959
+ }
960
+ __name(wrapRounded, "wrapRounded");
961
+ models.forEach((fromModel) => {
962
+ convert2[fromModel] = {};
963
+ Object.defineProperty(convert2[fromModel], "channels", { value: conversions[fromModel].channels });
964
+ Object.defineProperty(convert2[fromModel], "labels", { value: conversions[fromModel].labels });
965
+ const routes = route(fromModel);
966
+ const routeModels = Object.keys(routes);
967
+ routeModels.forEach((toModel) => {
968
+ const fn = routes[toModel];
969
+ convert2[fromModel][toModel] = wrapRounded(fn);
970
+ convert2[fromModel][toModel].raw = wrapRaw(fn);
971
+ });
972
+ });
973
+ module.exports = convert2;
974
+ }
975
+ });
976
+
977
+ // src/blocks/controls/Color.tsx
978
+ var import_color_convert = __toESM(require_color_convert(), 1);
979
+ import React, { useCallback, useEffect, useMemo, useState } from "react";
980
+ import { Form, TooltipNote, WithTooltip } from "storybook/internal/components";
981
+ import { MarkupIcon } from "@storybook/icons";
982
+
983
+ // ../../node_modules/react-colorful/dist/index.mjs
984
+ import e, { useRef as r, useMemo as t, useEffect as n, useState as o, useCallback as a, useLayoutEffect as l } from "react";
985
+ function u() {
986
+ return (u = Object.assign || function(e2) {
987
+ for (var r2 = 1; r2 < arguments.length; r2++) {
988
+ var t2 = arguments[r2];
989
+ for (var n2 in t2) Object.prototype.hasOwnProperty.call(t2, n2) && (e2[n2] = t2[n2]);
990
+ }
991
+ return e2;
992
+ }).apply(this, arguments);
993
+ }
994
+ __name(u, "u");
995
+ function c(e2, r2) {
996
+ if (null == e2) return {};
997
+ var t2, n2, o2 = {}, a2 = Object.keys(e2);
998
+ for (n2 = 0; n2 < a2.length; n2++) r2.indexOf(t2 = a2[n2]) >= 0 || (o2[t2] = e2[t2]);
999
+ return o2;
1000
+ }
1001
+ __name(c, "c");
1002
+ function i(e2) {
1003
+ var t2 = r(e2), n2 = r(function(e3) {
1004
+ t2.current && t2.current(e3);
1005
+ });
1006
+ return t2.current = e2, n2.current;
1007
+ }
1008
+ __name(i, "i");
1009
+ var s = /* @__PURE__ */ __name(function(e2, r2, t2) {
1010
+ return void 0 === r2 && (r2 = 0), void 0 === t2 && (t2 = 1), e2 > t2 ? t2 : e2 < r2 ? r2 : e2;
1011
+ }, "s");
1012
+ var f = /* @__PURE__ */ __name(function(e2) {
1013
+ return "touches" in e2;
1014
+ }, "f");
1015
+ var v = /* @__PURE__ */ __name(function(e2) {
1016
+ return e2 && e2.ownerDocument.defaultView || self;
1017
+ }, "v");
1018
+ var d = /* @__PURE__ */ __name(function(e2, r2, t2) {
1019
+ var n2 = e2.getBoundingClientRect(), o2 = f(r2) ? function(e3, r3) {
1020
+ for (var t3 = 0; t3 < e3.length; t3++) if (e3[t3].identifier === r3) return e3[t3];
1021
+ return e3[0];
1022
+ }(r2.touches, t2) : r2;
1023
+ return { left: s((o2.pageX - (n2.left + v(e2).pageXOffset)) / n2.width), top: s((o2.pageY - (n2.top + v(e2).pageYOffset)) / n2.height) };
1024
+ }, "d");
1025
+ var h = /* @__PURE__ */ __name(function(e2) {
1026
+ !f(e2) && e2.preventDefault();
1027
+ }, "h");
1028
+ var m = e.memo(function(o2) {
1029
+ var a2 = o2.onMove, l2 = o2.onKey, s2 = c(o2, ["onMove", "onKey"]), m2 = r(null), g2 = i(a2), p2 = i(l2), b2 = r(null), _2 = r(false), x2 = t(function() {
1030
+ var e2 = /* @__PURE__ */ __name(function(e3) {
1031
+ h(e3), (f(e3) ? e3.touches.length > 0 : e3.buttons > 0) && m2.current ? g2(d(m2.current, e3, b2.current)) : t2(false);
1032
+ }, "e"), r2 = /* @__PURE__ */ __name(function() {
1033
+ return t2(false);
1034
+ }, "r");
1035
+ function t2(t3) {
1036
+ var n2 = _2.current, o3 = v(m2.current), a3 = t3 ? o3.addEventListener : o3.removeEventListener;
1037
+ a3(n2 ? "touchmove" : "mousemove", e2), a3(n2 ? "touchend" : "mouseup", r2);
1038
+ }
1039
+ __name(t2, "t");
1040
+ return [function(e3) {
1041
+ var r3 = e3.nativeEvent, n2 = m2.current;
1042
+ if (n2 && (h(r3), !function(e4, r4) {
1043
+ return r4 && !f(e4);
1044
+ }(r3, _2.current) && n2)) {
1045
+ if (f(r3)) {
1046
+ _2.current = true;
1047
+ var o3 = r3.changedTouches || [];
1048
+ o3.length && (b2.current = o3[0].identifier);
1049
+ }
1050
+ n2.focus(), g2(d(n2, r3, b2.current)), t2(true);
1051
+ }
1052
+ }, function(e3) {
1053
+ var r3 = e3.which || e3.keyCode;
1054
+ r3 < 37 || r3 > 40 || (e3.preventDefault(), p2({ left: 39 === r3 ? 0.05 : 37 === r3 ? -0.05 : 0, top: 40 === r3 ? 0.05 : 38 === r3 ? -0.05 : 0 }));
1055
+ }, t2];
1056
+ }, [p2, g2]), C2 = x2[0], E2 = x2[1], H2 = x2[2];
1057
+ return n(function() {
1058
+ return H2;
1059
+ }, [H2]), e.createElement("div", u({}, s2, { onTouchStart: C2, onMouseDown: C2, className: "react-colorful__interactive", ref: m2, onKeyDown: E2, tabIndex: 0, role: "slider" }));
1060
+ });
1061
+ var g = /* @__PURE__ */ __name(function(e2) {
1062
+ return e2.filter(Boolean).join(" ");
1063
+ }, "g");
1064
+ var p = /* @__PURE__ */ __name(function(r2) {
1065
+ var t2 = r2.color, n2 = r2.left, o2 = r2.top, a2 = void 0 === o2 ? 0.5 : o2, l2 = g(["react-colorful__pointer", r2.className]);
1066
+ return e.createElement("div", { className: l2, style: { top: 100 * a2 + "%", left: 100 * n2 + "%" } }, e.createElement("div", { className: "react-colorful__pointer-fill", style: { backgroundColor: t2 } }));
1067
+ }, "p");
1068
+ var b = /* @__PURE__ */ __name(function(e2, r2, t2) {
1069
+ return void 0 === r2 && (r2 = 0), void 0 === t2 && (t2 = Math.pow(10, r2)), Math.round(t2 * e2) / t2;
1070
+ }, "b");
1071
+ var _ = { grad: 0.9, turn: 360, rad: 360 / (2 * Math.PI) };
1072
+ var x = /* @__PURE__ */ __name(function(e2) {
1073
+ return L(C(e2));
1074
+ }, "x");
1075
+ var C = /* @__PURE__ */ __name(function(e2) {
1076
+ return "#" === e2[0] && (e2 = e2.substring(1)), e2.length < 6 ? { r: parseInt(e2[0] + e2[0], 16), g: parseInt(e2[1] + e2[1], 16), b: parseInt(e2[2] + e2[2], 16), a: 4 === e2.length ? b(parseInt(e2[3] + e2[3], 16) / 255, 2) : 1 } : { r: parseInt(e2.substring(0, 2), 16), g: parseInt(e2.substring(2, 4), 16), b: parseInt(e2.substring(4, 6), 16), a: 8 === e2.length ? b(parseInt(e2.substring(6, 8), 16) / 255, 2) : 1 };
1077
+ }, "C");
1078
+ var E = /* @__PURE__ */ __name(function(e2, r2) {
1079
+ return void 0 === r2 && (r2 = "deg"), Number(e2) * (_[r2] || 1);
1080
+ }, "E");
1081
+ var H = /* @__PURE__ */ __name(function(e2) {
1082
+ var r2 = /hsla?\(?\s*(-?\d*\.?\d+)(deg|rad|grad|turn)?[,\s]+(-?\d*\.?\d+)%?[,\s]+(-?\d*\.?\d+)%?,?\s*[/\s]*(-?\d*\.?\d+)?(%)?\s*\)?/i.exec(e2);
1083
+ return r2 ? N({ h: E(r2[1], r2[2]), s: Number(r2[3]), l: Number(r2[4]), a: void 0 === r2[5] ? 1 : Number(r2[5]) / (r2[6] ? 100 : 1) }) : { h: 0, s: 0, v: 0, a: 1 };
1084
+ }, "H");
1085
+ var N = /* @__PURE__ */ __name(function(e2) {
1086
+ var r2 = e2.s, t2 = e2.l;
1087
+ return { h: e2.h, s: (r2 *= (t2 < 50 ? t2 : 100 - t2) / 100) > 0 ? 2 * r2 / (t2 + r2) * 100 : 0, v: t2 + r2, a: e2.a };
1088
+ }, "N");
1089
+ var w = /* @__PURE__ */ __name(function(e2) {
1090
+ return K(I(e2));
1091
+ }, "w");
1092
+ var y = /* @__PURE__ */ __name(function(e2) {
1093
+ var r2 = e2.s, t2 = e2.v, n2 = e2.a, o2 = (200 - r2) * t2 / 100;
1094
+ return { h: b(e2.h), s: b(o2 > 0 && o2 < 200 ? r2 * t2 / 100 / (o2 <= 100 ? o2 : 200 - o2) * 100 : 0), l: b(o2 / 2), a: b(n2, 2) };
1095
+ }, "y");
1096
+ var q = /* @__PURE__ */ __name(function(e2) {
1097
+ var r2 = y(e2);
1098
+ return "hsl(" + r2.h + ", " + r2.s + "%, " + r2.l + "%)";
1099
+ }, "q");
1100
+ var k = /* @__PURE__ */ __name(function(e2) {
1101
+ var r2 = y(e2);
1102
+ return "hsla(" + r2.h + ", " + r2.s + "%, " + r2.l + "%, " + r2.a + ")";
1103
+ }, "k");
1104
+ var I = /* @__PURE__ */ __name(function(e2) {
1105
+ var r2 = e2.h, t2 = e2.s, n2 = e2.v, o2 = e2.a;
1106
+ r2 = r2 / 360 * 6, t2 /= 100, n2 /= 100;
1107
+ var a2 = Math.floor(r2), l2 = n2 * (1 - t2), u2 = n2 * (1 - (r2 - a2) * t2), c2 = n2 * (1 - (1 - r2 + a2) * t2), i2 = a2 % 6;
1108
+ return { r: b(255 * [n2, u2, l2, l2, c2, n2][i2]), g: b(255 * [c2, n2, n2, u2, l2, l2][i2]), b: b(255 * [l2, l2, c2, n2, n2, u2][i2]), a: b(o2, 2) };
1109
+ }, "I");
1110
+ var z = /* @__PURE__ */ __name(function(e2) {
1111
+ var r2 = /rgba?\(?\s*(-?\d*\.?\d+)(%)?[,\s]+(-?\d*\.?\d+)(%)?[,\s]+(-?\d*\.?\d+)(%)?,?\s*[/\s]*(-?\d*\.?\d+)?(%)?\s*\)?/i.exec(e2);
1112
+ return r2 ? L({ r: Number(r2[1]) / (r2[2] ? 100 / 255 : 1), g: Number(r2[3]) / (r2[4] ? 100 / 255 : 1), b: Number(r2[5]) / (r2[6] ? 100 / 255 : 1), a: void 0 === r2[7] ? 1 : Number(r2[7]) / (r2[8] ? 100 : 1) }) : { h: 0, s: 0, v: 0, a: 1 };
1113
+ }, "z");
1114
+ var D = /* @__PURE__ */ __name(function(e2) {
1115
+ var r2 = e2.toString(16);
1116
+ return r2.length < 2 ? "0" + r2 : r2;
1117
+ }, "D");
1118
+ var K = /* @__PURE__ */ __name(function(e2) {
1119
+ var r2 = e2.r, t2 = e2.g, n2 = e2.b, o2 = e2.a, a2 = o2 < 1 ? D(b(255 * o2)) : "";
1120
+ return "#" + D(r2) + D(t2) + D(n2) + a2;
1121
+ }, "K");
1122
+ var L = /* @__PURE__ */ __name(function(e2) {
1123
+ var r2 = e2.r, t2 = e2.g, n2 = e2.b, o2 = e2.a, a2 = Math.max(r2, t2, n2), l2 = a2 - Math.min(r2, t2, n2), u2 = l2 ? a2 === r2 ? (t2 - n2) / l2 : a2 === t2 ? 2 + (n2 - r2) / l2 : 4 + (r2 - t2) / l2 : 0;
1124
+ return { h: b(60 * (u2 < 0 ? u2 + 6 : u2)), s: b(a2 ? l2 / a2 * 100 : 0), v: b(a2 / 255 * 100), a: o2 };
1125
+ }, "L");
1126
+ var S = e.memo(function(r2) {
1127
+ var t2 = r2.hue, n2 = r2.onChange, o2 = g(["react-colorful__hue", r2.className]);
1128
+ return e.createElement("div", { className: o2 }, e.createElement(m, { onMove: /* @__PURE__ */ __name(function(e2) {
1129
+ n2({ h: 360 * e2.left });
1130
+ }, "onMove"), onKey: /* @__PURE__ */ __name(function(e2) {
1131
+ n2({ h: s(t2 + 360 * e2.left, 0, 360) });
1132
+ }, "onKey"), "aria-label": "Hue", "aria-valuenow": b(t2), "aria-valuemax": "360", "aria-valuemin": "0" }, e.createElement(p, { className: "react-colorful__hue-pointer", left: t2 / 360, color: q({ h: t2, s: 100, v: 100, a: 1 }) })));
1133
+ });
1134
+ var T = e.memo(function(r2) {
1135
+ var t2 = r2.hsva, n2 = r2.onChange, o2 = { backgroundColor: q({ h: t2.h, s: 100, v: 100, a: 1 }) };
1136
+ return e.createElement("div", { className: "react-colorful__saturation", style: o2 }, e.createElement(m, { onMove: /* @__PURE__ */ __name(function(e2) {
1137
+ n2({ s: 100 * e2.left, v: 100 - 100 * e2.top });
1138
+ }, "onMove"), onKey: /* @__PURE__ */ __name(function(e2) {
1139
+ n2({ s: s(t2.s + 100 * e2.left, 0, 100), v: s(t2.v - 100 * e2.top, 0, 100) });
1140
+ }, "onKey"), "aria-label": "Color", "aria-valuetext": "Saturation " + b(t2.s) + "%, Brightness " + b(t2.v) + "%" }, e.createElement(p, { className: "react-colorful__saturation-pointer", top: 1 - t2.v / 100, left: t2.s / 100, color: q(t2) })));
1141
+ });
1142
+ var F = /* @__PURE__ */ __name(function(e2, r2) {
1143
+ if (e2 === r2) return true;
1144
+ for (var t2 in e2) if (e2[t2] !== r2[t2]) return false;
1145
+ return true;
1146
+ }, "F");
1147
+ var P = /* @__PURE__ */ __name(function(e2, r2) {
1148
+ return e2.replace(/\s/g, "") === r2.replace(/\s/g, "");
1149
+ }, "P");
1150
+ var X = /* @__PURE__ */ __name(function(e2, r2) {
1151
+ return e2.toLowerCase() === r2.toLowerCase() || F(C(e2), C(r2));
1152
+ }, "X");
1153
+ function Y(e2, t2, l2) {
1154
+ var u2 = i(l2), c2 = o(function() {
1155
+ return e2.toHsva(t2);
1156
+ }), s2 = c2[0], f2 = c2[1], v2 = r({ color: t2, hsva: s2 });
1157
+ n(function() {
1158
+ if (!e2.equal(t2, v2.current.color)) {
1159
+ var r2 = e2.toHsva(t2);
1160
+ v2.current = { hsva: r2, color: t2 }, f2(r2);
1161
+ }
1162
+ }, [t2, e2]), n(function() {
1163
+ var r2;
1164
+ F(s2, v2.current.hsva) || e2.equal(r2 = e2.fromHsva(s2), v2.current.color) || (v2.current = { hsva: s2, color: r2 }, u2(r2));
1165
+ }, [s2, e2, u2]);
1166
+ var d2 = a(function(e3) {
1167
+ f2(function(r2) {
1168
+ return Object.assign({}, r2, e3);
1169
+ });
1170
+ }, []);
1171
+ return [s2, d2];
1172
+ }
1173
+ __name(Y, "Y");
1174
+ var R;
1175
+ var V = "undefined" != typeof window ? l : n;
1176
+ var $ = /* @__PURE__ */ __name(function() {
1177
+ return R || ("undefined" != typeof __webpack_nonce__ ? __webpack_nonce__ : void 0);
1178
+ }, "$");
1179
+ var J = /* @__PURE__ */ new Map();
1180
+ var Q = /* @__PURE__ */ __name(function(e2) {
1181
+ V(function() {
1182
+ var r2 = e2.current ? e2.current.ownerDocument : document;
1183
+ if (void 0 !== r2 && !J.has(r2)) {
1184
+ var t2 = r2.createElement("style");
1185
+ t2.innerHTML = `.react-colorful{position:relative;display:flex;flex-direction:column;width:200px;height:200px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:default}.react-colorful__saturation{position:relative;flex-grow:1;border-color:transparent;border-bottom:12px solid #000;border-radius:8px 8px 0 0;background-image:linear-gradient(0deg,#000,transparent),linear-gradient(90deg,#fff,hsla(0,0%,100%,0))}.react-colorful__alpha-gradient,.react-colorful__pointer-fill{content:"";position:absolute;left:0;top:0;right:0;bottom:0;pointer-events:none;border-radius:inherit}.react-colorful__alpha-gradient,.react-colorful__saturation{box-shadow:inset 0 0 0 1px rgba(0,0,0,.05)}.react-colorful__alpha,.react-colorful__hue{position:relative;height:24px}.react-colorful__hue{background:linear-gradient(90deg,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red)}.react-colorful__last-control{border-radius:0 0 8px 8px}.react-colorful__interactive{position:absolute;left:0;top:0;right:0;bottom:0;border-radius:inherit;outline:none;touch-action:none}.react-colorful__pointer{position:absolute;z-index:1;box-sizing:border-box;width:28px;height:28px;transform:translate(-50%,-50%);background-color:#fff;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.2)}.react-colorful__interactive:focus .react-colorful__pointer{transform:translate(-50%,-50%) scale(1.1)}.react-colorful__alpha,.react-colorful__alpha-pointer{background-color:#fff;background-image:url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill-opacity=".05"><path d="M8 0h8v8H8zM0 8h8v8H0z"/></svg>')}.react-colorful__saturation-pointer{z-index:3}.react-colorful__hue-pointer{z-index:2}`, J.set(r2, t2);
1186
+ var n2 = $();
1187
+ n2 && t2.setAttribute("nonce", n2), r2.head.appendChild(t2);
1188
+ }
1189
+ }, []);
1190
+ }, "Q");
1191
+ var U = /* @__PURE__ */ __name(function(t2) {
1192
+ var n2 = t2.className, o2 = t2.colorModel, a2 = t2.color, l2 = void 0 === a2 ? o2.defaultColor : a2, i2 = t2.onChange, s2 = c(t2, ["className", "colorModel", "color", "onChange"]), f2 = r(null);
1193
+ Q(f2);
1194
+ var v2 = Y(o2, l2, i2), d2 = v2[0], h2 = v2[1], m2 = g(["react-colorful", n2]);
1195
+ return e.createElement("div", u({}, s2, { ref: f2, className: m2 }), e.createElement(T, { hsva: d2, onChange: h2 }), e.createElement(S, { hue: d2.h, onChange: h2, className: "react-colorful__last-control" }));
1196
+ }, "U");
1197
+ var W = { defaultColor: "000", toHsva: x, fromHsva: /* @__PURE__ */ __name(function(e2) {
1198
+ return w({ h: e2.h, s: e2.s, v: e2.v, a: 1 });
1199
+ }, "fromHsva"), equal: X };
1200
+ var Z = /* @__PURE__ */ __name(function(r2) {
1201
+ return e.createElement(U, u({}, r2, { colorModel: W }));
1202
+ }, "Z");
1203
+ var ee = /* @__PURE__ */ __name(function(r2) {
1204
+ var t2 = r2.className, n2 = r2.hsva, o2 = r2.onChange, a2 = { backgroundImage: "linear-gradient(90deg, " + k(Object.assign({}, n2, { a: 0 })) + ", " + k(Object.assign({}, n2, { a: 1 })) + ")" }, l2 = g(["react-colorful__alpha", t2]), u2 = b(100 * n2.a);
1205
+ return e.createElement("div", { className: l2 }, e.createElement("div", { className: "react-colorful__alpha-gradient", style: a2 }), e.createElement(m, { onMove: /* @__PURE__ */ __name(function(e2) {
1206
+ o2({ a: e2.left });
1207
+ }, "onMove"), onKey: /* @__PURE__ */ __name(function(e2) {
1208
+ o2({ a: s(n2.a + e2.left) });
1209
+ }, "onKey"), "aria-label": "Alpha", "aria-valuetext": u2 + "%", "aria-valuenow": u2, "aria-valuemin": "0", "aria-valuemax": "100" }, e.createElement(p, { className: "react-colorful__alpha-pointer", left: n2.a, color: k(n2) })));
1210
+ }, "ee");
1211
+ var re = /* @__PURE__ */ __name(function(t2) {
1212
+ var n2 = t2.className, o2 = t2.colorModel, a2 = t2.color, l2 = void 0 === a2 ? o2.defaultColor : a2, i2 = t2.onChange, s2 = c(t2, ["className", "colorModel", "color", "onChange"]), f2 = r(null);
1213
+ Q(f2);
1214
+ var v2 = Y(o2, l2, i2), d2 = v2[0], h2 = v2[1], m2 = g(["react-colorful", n2]);
1215
+ return e.createElement("div", u({}, s2, { ref: f2, className: m2 }), e.createElement(T, { hsva: d2, onChange: h2 }), e.createElement(S, { hue: d2.h, onChange: h2 }), e.createElement(ee, { hsva: d2, onChange: h2, className: "react-colorful__last-control" }));
1216
+ }, "re");
1217
+ var le = { defaultColor: "hsla(0, 0%, 0%, 1)", toHsva: H, fromHsva: k, equal: P };
1218
+ var ue = /* @__PURE__ */ __name(function(r2) {
1219
+ return e.createElement(re, u({}, r2, { colorModel: le }));
1220
+ }, "ue");
1221
+ var Ee = { defaultColor: "rgba(0, 0, 0, 1)", toHsva: z, fromHsva: /* @__PURE__ */ __name(function(e2) {
1222
+ var r2 = I(e2);
1223
+ return "rgba(" + r2.r + ", " + r2.g + ", " + r2.b + ", " + r2.a + ")";
1224
+ }, "fromHsva"), equal: P };
1225
+ var He = /* @__PURE__ */ __name(function(r2) {
1226
+ return e.createElement(re, u({}, r2, { colorModel: Ee }));
1227
+ }, "He");
1228
+
1229
+ // src/blocks/controls/Color.tsx
1230
+ import { styled } from "storybook/theming";
1231
+ var Wrapper = styled.div({
1232
+ position: "relative",
1233
+ maxWidth: 250,
1234
+ '&[aria-readonly="true"]': {
1235
+ opacity: 0.5
1236
+ }
1237
+ });
1238
+ var PickerTooltip = styled(WithTooltip)({
1239
+ position: "absolute",
1240
+ zIndex: 1,
1241
+ top: 4,
1242
+ left: 4,
1243
+ "[aria-readonly=true] &": {
1244
+ cursor: "not-allowed"
1245
+ }
1246
+ });
1247
+ var TooltipContent = styled.div({
1248
+ width: 200,
1249
+ margin: 5,
1250
+ ".react-colorful__saturation": {
1251
+ borderRadius: "4px 4px 0 0"
1252
+ },
1253
+ ".react-colorful__hue": {
1254
+ boxShadow: "inset 0 0 0 1px rgb(0 0 0 / 5%)"
1255
+ },
1256
+ ".react-colorful__last-control": {
1257
+ borderRadius: "0 0 4px 4px"
1258
+ }
1259
+ });
1260
+ var Note = styled(TooltipNote)(({ theme }) => ({
1261
+ fontFamily: theme.typography.fonts.base
1262
+ }));
1263
+ var Swatches = styled.div({
1264
+ display: "grid",
1265
+ gridTemplateColumns: "repeat(9, 16px)",
1266
+ gap: 6,
1267
+ padding: 3,
1268
+ marginTop: 5,
1269
+ width: 200
1270
+ });
1271
+ var SwatchColor = styled.div(({ theme, active }) => ({
1272
+ width: 16,
1273
+ height: 16,
1274
+ boxShadow: active ? `${theme.appBorderColor} 0 0 0 1px inset, ${theme.textMutedColor}50 0 0 0 4px` : `${theme.appBorderColor} 0 0 0 1px inset`,
1275
+ borderRadius: theme.appBorderRadius
1276
+ }));
1277
+ var swatchBackground = `url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill-opacity=".05"><path d="M8 0h8v8H8zM0 8h8v8H0z"/></svg>')`;
1278
+ var Swatch = /* @__PURE__ */ __name(({ value, style, ...props }) => {
1279
+ const backgroundImage = `linear-gradient(${value}, ${value}), ${swatchBackground}, linear-gradient(#fff, #fff)`;
1280
+ return React.createElement(SwatchColor, { ...props, style: { ...style, backgroundImage } });
1281
+ }, "Swatch");
1282
+ var Input = styled(Form.Input)(({ theme, readOnly }) => ({
1283
+ width: "100%",
1284
+ paddingLeft: 30,
1285
+ paddingRight: 30,
1286
+ boxSizing: "border-box",
1287
+ fontFamily: theme.typography.fonts.base
1288
+ }));
1289
+ var ToggleIcon = styled(MarkupIcon)(({ theme }) => ({
1290
+ position: "absolute",
1291
+ zIndex: 1,
1292
+ top: 6,
1293
+ right: 7,
1294
+ width: 20,
1295
+ height: 20,
1296
+ padding: 4,
1297
+ boxSizing: "border-box",
1298
+ cursor: "pointer",
1299
+ color: theme.input.color
1300
+ }));
1301
+ var ColorSpace = /* @__PURE__ */ ((ColorSpace2) => {
1302
+ ColorSpace2["RGB"] = "rgb";
1303
+ ColorSpace2["HSL"] = "hsl";
1304
+ ColorSpace2["HEX"] = "hex";
1305
+ return ColorSpace2;
1306
+ })(ColorSpace || {});
1307
+ var COLOR_SPACES = Object.values(ColorSpace);
1308
+ var COLOR_REGEXP = /\(([0-9]+),\s*([0-9]+)%?,\s*([0-9]+)%?,?\s*([0-9.]+)?\)/;
1309
+ var RGB_REGEXP = /^\s*rgba?\(([0-9]+),\s*([0-9]+),\s*([0-9]+),?\s*([0-9.]+)?\)\s*$/i;
1310
+ var HSL_REGEXP = /^\s*hsla?\(([0-9]+),\s*([0-9]+)%,\s*([0-9]+)%,?\s*([0-9.]+)?\)\s*$/i;
1311
+ var HEX_REGEXP = /^\s*#?([0-9a-f]{3}|[0-9a-f]{6})\s*$/i;
1312
+ var SHORTHEX_REGEXP = /^\s*#?([0-9a-f]{3})\s*$/i;
1313
+ var ColorPicker = {
1314
+ ["hex" /* HEX */]: Z,
1315
+ ["rgb" /* RGB */]: He,
1316
+ ["hsl" /* HSL */]: ue
1317
+ };
1318
+ var fallbackColor = {
1319
+ ["hex" /* HEX */]: "transparent",
1320
+ ["rgb" /* RGB */]: "rgba(0, 0, 0, 0)",
1321
+ ["hsl" /* HSL */]: "hsla(0, 0%, 0%, 0)"
1322
+ };
1323
+ var stringToArgs = /* @__PURE__ */ __name((value) => {
1324
+ const match = value?.match(COLOR_REGEXP);
1325
+ if (!match) {
1326
+ return [0, 0, 0, 1];
1327
+ }
1328
+ const [, x2, y2, z2, a2 = 1] = match;
1329
+ return [x2, y2, z2, a2].map(Number);
1330
+ }, "stringToArgs");
1331
+ var parseRgb = /* @__PURE__ */ __name((value) => {
1332
+ const [r2, g2, b2, a2] = stringToArgs(value);
1333
+ const [h2, s2, l2] = import_color_convert.default.rgb.hsl([r2, g2, b2]) || [0, 0, 0];
1334
+ return {
1335
+ valid: true,
1336
+ value,
1337
+ keyword: import_color_convert.default.rgb.keyword([r2, g2, b2]),
1338
+ colorSpace: "rgb" /* RGB */,
1339
+ ["rgb" /* RGB */]: value,
1340
+ ["hsl" /* HSL */]: `hsla(${h2}, ${s2}%, ${l2}%, ${a2})`,
1341
+ ["hex" /* HEX */]: `#${import_color_convert.default.rgb.hex([r2, g2, b2]).toLowerCase()}`
1342
+ };
1343
+ }, "parseRgb");
1344
+ var parseHsl = /* @__PURE__ */ __name((value) => {
1345
+ const [h2, s2, l2, a2] = stringToArgs(value);
1346
+ const [r2, g2, b2] = import_color_convert.default.hsl.rgb([h2, s2, l2]) || [0, 0, 0];
1347
+ return {
1348
+ valid: true,
1349
+ value,
1350
+ keyword: import_color_convert.default.hsl.keyword([h2, s2, l2]),
1351
+ colorSpace: "hsl" /* HSL */,
1352
+ ["rgb" /* RGB */]: `rgba(${r2}, ${g2}, ${b2}, ${a2})`,
1353
+ ["hsl" /* HSL */]: value,
1354
+ ["hex" /* HEX */]: `#${import_color_convert.default.hsl.hex([h2, s2, l2]).toLowerCase()}`
1355
+ };
1356
+ }, "parseHsl");
1357
+ var parseHexOrKeyword = /* @__PURE__ */ __name((value) => {
1358
+ const plain = value.replace("#", "");
1359
+ const rgb = import_color_convert.default.keyword.rgb(plain) || import_color_convert.default.hex.rgb(plain);
1360
+ const hsl = import_color_convert.default.rgb.hsl(rgb);
1361
+ let mapped = value;
1362
+ if (/[^#a-f0-9]/i.test(value)) {
1363
+ mapped = plain;
1364
+ } else if (HEX_REGEXP.test(value)) {
1365
+ mapped = `#${plain}`;
1366
+ }
1367
+ let valid = true;
1368
+ if (mapped.startsWith("#")) {
1369
+ valid = HEX_REGEXP.test(mapped);
1370
+ } else {
1371
+ try {
1372
+ import_color_convert.default.keyword.hex(mapped);
1373
+ } catch (e2) {
1374
+ valid = false;
1375
+ }
1376
+ }
1377
+ return {
1378
+ valid,
1379
+ value: mapped,
1380
+ keyword: import_color_convert.default.rgb.keyword(rgb),
1381
+ colorSpace: "hex" /* HEX */,
1382
+ ["rgb" /* RGB */]: `rgba(${rgb[0]}, ${rgb[1]}, ${rgb[2]}, 1)`,
1383
+ ["hsl" /* HSL */]: `hsla(${hsl[0]}, ${hsl[1]}%, ${hsl[2]}%, 1)`,
1384
+ ["hex" /* HEX */]: mapped
1385
+ };
1386
+ }, "parseHexOrKeyword");
1387
+ var parseValue = /* @__PURE__ */ __name((value) => {
1388
+ if (!value) {
1389
+ return void 0;
1390
+ }
1391
+ if (RGB_REGEXP.test(value)) {
1392
+ return parseRgb(value);
1393
+ }
1394
+ if (HSL_REGEXP.test(value)) {
1395
+ return parseHsl(value);
1396
+ }
1397
+ return parseHexOrKeyword(value);
1398
+ }, "parseValue");
1399
+ var getRealValue = /* @__PURE__ */ __name((value, color, colorSpace) => {
1400
+ if (!value || !color?.valid) {
1401
+ return fallbackColor[colorSpace];
1402
+ }
1403
+ if (colorSpace !== "hex" /* HEX */) {
1404
+ return color?.[colorSpace] || fallbackColor[colorSpace];
1405
+ }
1406
+ if (!color.hex.startsWith("#")) {
1407
+ try {
1408
+ return `#${import_color_convert.default.keyword.hex(color.hex)}`;
1409
+ } catch (e2) {
1410
+ return fallbackColor.hex;
1411
+ }
1412
+ }
1413
+ const short = color.hex.match(SHORTHEX_REGEXP);
1414
+ if (!short) {
1415
+ return HEX_REGEXP.test(color.hex) ? color.hex : fallbackColor.hex;
1416
+ }
1417
+ const [r2, g2, b2] = short[1].split("");
1418
+ return `#${r2}${r2}${g2}${g2}${b2}${b2}`;
1419
+ }, "getRealValue");
1420
+ var useColorInput = /* @__PURE__ */ __name((initialValue, onChange) => {
1421
+ const [value, setValue] = useState(initialValue || "");
1422
+ const [color, setColor] = useState(() => parseValue(value));
1423
+ const [colorSpace, setColorSpace] = useState(color?.colorSpace || "hex" /* HEX */);
1424
+ useEffect(() => {
1425
+ const nextValue = initialValue || "";
1426
+ const nextColor = parseValue(nextValue);
1427
+ setValue(nextValue);
1428
+ setColor(nextColor);
1429
+ setColorSpace(nextColor?.colorSpace || "hex" /* HEX */);
1430
+ }, [initialValue]);
1431
+ const realValue = useMemo(
1432
+ () => getRealValue(value, color, colorSpace).toLowerCase(),
1433
+ [value, color, colorSpace]
1434
+ );
1435
+ const updateValue = useCallback(
1436
+ (update) => {
1437
+ const parsed = parseValue(update);
1438
+ const v2 = parsed?.value || update || "";
1439
+ setValue(v2);
1440
+ if (v2 === "") {
1441
+ setColor(void 0);
1442
+ onChange(void 0);
1443
+ }
1444
+ if (!parsed) {
1445
+ return;
1446
+ }
1447
+ setColor(parsed);
1448
+ setColorSpace(parsed.colorSpace);
1449
+ onChange(parsed.value);
1450
+ },
1451
+ [onChange]
1452
+ );
1453
+ const cycleColorSpace = useCallback(() => {
1454
+ const currentIndex = COLOR_SPACES.indexOf(colorSpace);
1455
+ const nextIndex = (currentIndex + 1) % COLOR_SPACES.length;
1456
+ const nextSpace = COLOR_SPACES[nextIndex];
1457
+ setColorSpace(nextSpace);
1458
+ const updatedValue = color?.[nextSpace] || "";
1459
+ setValue(updatedValue);
1460
+ onChange(updatedValue);
1461
+ }, [color, colorSpace, onChange]);
1462
+ return { value, realValue, updateValue, color, colorSpace, cycleColorSpace };
1463
+ }, "useColorInput");
1464
+ var id = /* @__PURE__ */ __name((value) => value.replace(/\s*/, "").toLowerCase(), "id");
1465
+ var usePresets = /* @__PURE__ */ __name((presetColors, currentColor, colorSpace) => {
1466
+ const [selectedColors, setSelectedColors] = useState(currentColor?.valid ? [currentColor] : []);
1467
+ useEffect(() => {
1468
+ if (currentColor !== void 0) {
1469
+ return;
1470
+ }
1471
+ setSelectedColors([]);
1472
+ }, [currentColor]);
1473
+ const presets = useMemo(() => {
1474
+ const initialPresets = (presetColors || []).map((preset) => {
1475
+ if (typeof preset === "string") {
1476
+ return parseValue(preset);
1477
+ }
1478
+ if (preset.title) {
1479
+ return { ...parseValue(preset.color), keyword: preset.title };
1480
+ }
1481
+ return parseValue(preset.color);
1482
+ });
1483
+ return initialPresets.concat(selectedColors).filter(Boolean).slice(-27);
1484
+ }, [presetColors, selectedColors]);
1485
+ const addPreset = useCallback(
1486
+ (color) => {
1487
+ if (!color?.valid) {
1488
+ return;
1489
+ }
1490
+ if (presets.some(
1491
+ (preset) => preset && preset[colorSpace] && id(preset[colorSpace] || "") === id(color[colorSpace] || "")
1492
+ )) {
1493
+ return;
1494
+ }
1495
+ setSelectedColors((arr) => arr.concat(color));
1496
+ },
1497
+ [colorSpace, presets]
1498
+ );
1499
+ return { presets, addPreset };
1500
+ }, "usePresets");
1501
+ var ColorControl = /* @__PURE__ */ __name(({
1502
+ name,
1503
+ value: initialValue,
1504
+ onChange,
1505
+ onFocus,
1506
+ onBlur,
1507
+ presetColors,
1508
+ startOpen = false,
1509
+ argType
1510
+ }) => {
1511
+ const debouncedOnChange = useCallback(debounce(onChange, 200), [onChange]);
1512
+ const { value, realValue, updateValue, color, colorSpace, cycleColorSpace } = useColorInput(
1513
+ initialValue,
1514
+ debouncedOnChange
1515
+ );
1516
+ const { presets, addPreset } = usePresets(presetColors ?? [], color, colorSpace);
1517
+ const Picker = ColorPicker[colorSpace];
1518
+ const readonly = !!argType?.table?.readonly;
1519
+ return React.createElement(Wrapper, { "aria-readonly": readonly }, React.createElement(
1520
+ PickerTooltip,
1521
+ {
1522
+ startOpen,
1523
+ trigger: readonly ? null : void 0,
1524
+ closeOnOutsideClick: true,
1525
+ onVisibleChange: () => color && addPreset(color),
1526
+ tooltip: React.createElement(TooltipContent, null, React.createElement(
1527
+ Picker,
1528
+ {
1529
+ color: realValue === "transparent" ? "#000000" : realValue,
1530
+ ...{ onChange: updateValue, onFocus, onBlur }
1531
+ }
1532
+ ), presets.length > 0 && React.createElement(Swatches, null, presets.map((preset, index) => React.createElement(
1533
+ WithTooltip,
1534
+ {
1535
+ key: `${preset?.value || index}-${index}`,
1536
+ hasChrome: false,
1537
+ tooltip: React.createElement(Note, { note: preset?.keyword || preset?.value || "" })
1538
+ },
1539
+ React.createElement(
1540
+ Swatch,
1541
+ {
1542
+ value: preset?.[colorSpace] || "",
1543
+ active: !!(color && preset && preset[colorSpace] && id(preset[colorSpace] || "") === id(color[colorSpace])),
1544
+ onClick: () => preset && updateValue(preset.value || "")
1545
+ }
1546
+ )
1547
+ ))))
1548
+ },
1549
+ React.createElement(Swatch, { value: realValue, style: { margin: 4 } })
1550
+ ), React.createElement(
1551
+ Input,
1552
+ {
1553
+ id: getControlId(name),
1554
+ value,
1555
+ onChange: (e2) => updateValue(e2.target.value),
1556
+ onFocus: (e2) => e2.target.select(),
1557
+ readOnly: readonly,
1558
+ placeholder: "Choose color..."
1559
+ }
1560
+ ), value ? React.createElement(ToggleIcon, { onClick: cycleColorSpace }) : null);
1561
+ }, "ColorControl");
1562
+ var Color_default = ColorControl;
1563
+ export {
1564
+ ColorControl,
1565
+ Color_default as default
1566
+ };