@spear-ai/spectral 1.6.17 → 1.8.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 (149) hide show
  1. package/dist/.js +201 -200
  2. package/dist/Accordion.d.ts +13 -15
  3. package/dist/Accordion.js +184 -179
  4. package/dist/Alert/AlertBase.d.ts +7 -7
  5. package/dist/Alert/AlertBase.js +21 -21
  6. package/dist/Alert.d.ts +2 -2
  7. package/dist/Alert.js +31 -31
  8. package/dist/Avatar.d.ts +2 -2
  9. package/dist/Avatar.js +30 -22
  10. package/dist/Badge.d.ts +1 -1
  11. package/dist/Badge.js +3 -2
  12. package/dist/Button.d.ts +3 -3
  13. package/dist/Button.js +108 -46
  14. package/dist/ButtonGroup/ButtonGroupButton.d.ts +1 -1
  15. package/dist/ButtonGroup/ButtonGroupButton.js +5 -5
  16. package/dist/ButtonGroup.d.ts +5 -5
  17. package/dist/ButtonGroup.js +21 -21
  18. package/dist/ButtonIcon.d.ts +2 -2
  19. package/dist/ButtonIcon.js +30 -31
  20. package/dist/Checkbox/CheckboxBase.d.ts +2 -2
  21. package/dist/Checkbox/CheckboxBase.js +50 -57
  22. package/dist/Checkbox.js +15 -19
  23. package/dist/DataCard/Card.d.ts +1 -1
  24. package/dist/DataCard/Card.js +1 -1
  25. package/dist/DataCard.js +1 -1
  26. package/dist/DateTimePicker/Calendar.d.ts +4 -4
  27. package/dist/DateTimePicker/Calendar.js +3 -3
  28. package/dist/DateTimePicker/DateTimeDisplayInput.js +126 -136
  29. package/dist/DateTimePicker/DateTimeInput.js +4 -4
  30. package/dist/DateTimePicker/DateTimeUtils.d.ts +31 -31
  31. package/dist/DateTimePicker/DateTimeUtils.js +139 -197
  32. package/dist/DateTimePicker/TimePicker.d.ts +4 -4
  33. package/dist/DateTimePicker/TimePicker.js +3 -3
  34. package/dist/DateTimePicker.d.ts +5 -5
  35. package/dist/DateTimePicker.js +90 -70
  36. package/dist/Dialog.d.ts +13 -13
  37. package/dist/Dialog.js +57 -84
  38. package/dist/Drawer.d.ts +2 -2
  39. package/dist/Drawer.js +8 -8
  40. package/dist/HoverCard.d.ts +6 -5
  41. package/dist/HoverCard.js +64 -64
  42. package/dist/Icons/PolygonIcon.d.ts +5 -0
  43. package/dist/Icons/PolygonIcon.js +40 -0
  44. package/dist/Icons/index.d.ts +1 -1
  45. package/dist/Icons.js +34 -34
  46. package/dist/IconsAnimated/PanelLeftCloseIcon.js +2 -2
  47. package/dist/IconsAnimated/PanelLeftOpenIcon.js +2 -2
  48. package/dist/Input/InputUtils.d.ts +2 -2
  49. package/dist/Input/InputUtils.js +4 -4
  50. package/dist/Input.d.ts +1 -1
  51. package/dist/Input.js +19 -19
  52. package/dist/InputOTP.d.ts +10 -10
  53. package/dist/InputOTP.js +114 -114
  54. package/dist/Kbd.d.ts +8 -5
  55. package/dist/Kbd.js +85 -20
  56. package/dist/Label.d.ts +4 -2
  57. package/dist/Label.js +3 -3
  58. package/dist/MultiSelect/MultiSelectBase.d.ts +1 -1
  59. package/dist/MultiSelect/MultiSelectBase.js +278 -202
  60. package/dist/MultiSelect.d.ts +6 -6
  61. package/dist/MultiSelect.js +9 -9
  62. package/dist/Popover.js +22 -237
  63. package/dist/RadioButtonGroup/RadioButtonGroupBase.d.ts +11 -11
  64. package/dist/RadioButtonGroup/RadioButtonGroupBase.js +28 -28
  65. package/dist/RadioButtonGroup.d.ts +1 -1
  66. package/dist/RadioGroup.d.ts +15 -15
  67. package/dist/RadioGroup.js +253 -236
  68. package/dist/Select.d.ts +3 -1
  69. package/dist/Select.js +91 -88
  70. package/dist/Separator.js +4 -4
  71. package/dist/Skeleton.d.ts +1 -2
  72. package/dist/Skeleton.js +2 -4
  73. package/dist/Slider.d.ts +6 -6
  74. package/dist/Slider.js +78 -78
  75. package/dist/Switch/SwitchBase.d.ts +4 -4
  76. package/dist/Switch/SwitchBase.js +75 -111
  77. package/dist/Switch.d.ts +4 -4
  78. package/dist/Switch.js +122 -33
  79. package/dist/Tabs/TabsBase.js +39 -38
  80. package/dist/Tabs/tabsUtils.js +7 -7
  81. package/dist/Tabs.d.ts +0 -4
  82. package/dist/Tabs.js +62 -66
  83. package/dist/Textarea/TextareaUtils.d.ts +7 -7
  84. package/dist/Textarea/TextareaUtils.js +13 -13
  85. package/dist/Textarea.js +28 -18
  86. package/dist/Toast.d.ts +43 -0
  87. package/dist/Toast.js +883 -0
  88. package/dist/Toggle/ToggleBase.d.ts +4 -4
  89. package/dist/Toggle/ToggleBase.js +32 -33
  90. package/dist/Toggle.d.ts +1 -1
  91. package/dist/Toggle.js +7 -12
  92. package/dist/ToggleGroup/ToggleGroupBase.d.ts +5 -5
  93. package/dist/ToggleGroup/ToggleGroupBase.js +30 -30
  94. package/dist/ToggleGroup.d.ts +1 -1
  95. package/dist/ToggleGroup.js +27 -30
  96. package/dist/Tooltip.d.ts +1 -1
  97. package/dist/Tooltip.js +97 -97
  98. package/dist/Tray.d.ts +9 -9
  99. package/dist/Tray.js +71 -70
  100. package/dist/hooks/useAccordionAutoScroll.d.ts.map +1 -1
  101. package/dist/hooks/useAccordionAutoScroll.js +42 -39
  102. package/dist/hooks/useControllableState.d.ts +2 -2
  103. package/dist/hooks/useControllableState.d.ts.map +1 -1
  104. package/dist/hooks/useControllableState.js +2 -2
  105. package/dist/index-C12FUuIW.js +13 -0
  106. package/dist/{index-yU8jOTzS.js → index-CpovUAO-.js} +1 -1
  107. package/dist/{index-BdS7Ix8W.js → index-CqbPiOid.js} +1 -1
  108. package/dist/{index-B3UpsZ2x.js → index-CrjD9cAD.js} +1 -1
  109. package/dist/index-DEYs15GP.js +66 -0
  110. package/dist/index-DdFoGvON.js +146 -0
  111. package/dist/index-Q3N6lgwg.js +225 -0
  112. package/dist/index.d.ts +3 -3
  113. package/dist/index.d.ts.map +1 -1
  114. package/dist/primitives/button.d.ts +1 -1
  115. package/dist/primitives/button.js +4 -4
  116. package/dist/primitives/input.d.ts.map +1 -1
  117. package/dist/primitives/input.js +8 -5
  118. package/dist/primitives/select.d.ts +12 -13
  119. package/dist/primitives/select.d.ts.map +1 -1
  120. package/dist/primitives/select.js +59 -88
  121. package/dist/primitives/slot.d.ts +5 -5
  122. package/dist/primitives/slot.d.ts.map +1 -1
  123. package/dist/primitives/slot.js +24 -33
  124. package/dist/primitives/textarea.d.ts.map +1 -1
  125. package/dist/primitives/textarea.js +4 -3
  126. package/dist/{proxy-Cukf-VVj.js → proxy-CgaCj1WQ.js} +7 -3
  127. package/dist/styles/base-colors.css +30 -30
  128. package/dist/styles/horizon/base-colors.css +30 -30
  129. package/dist/styles/horizon/colors.css +43 -13
  130. package/dist/styles/horizon/utilities.css +26 -3
  131. package/dist/styles/main.css +1 -1
  132. package/dist/styles/spectral.css +2 -2
  133. package/dist/styles/theme.css +99 -46
  134. package/dist/{use-animation-zNd5Nq85.js → use-animation-CR-SdV2l.js} +1 -1
  135. package/dist/utils/formFieldUtils.d.ts +2 -2
  136. package/dist/utils/formFieldUtils.d.ts.map +1 -1
  137. package/dist/utils/formFieldUtils.js +14 -11
  138. package/dist/utils/sharedUtils.d.ts +3 -3
  139. package/dist/utils/sharedUtils.d.ts.map +1 -1
  140. package/dist/utils/sharedUtils.js +1 -4
  141. package/dist/utils/twUtils.d.ts +1 -1
  142. package/dist/utils/twUtils.d.ts.map +1 -1
  143. package/dist/utils/twUtils.js +1 -4
  144. package/package.json +6 -1
  145. package/dist/Icons/LineToolIcon2.d.ts +0 -5
  146. package/dist/Icons/LineToolIcon2.js +0 -49
  147. package/dist/createLucideIcon-D4r5Phnh.js +0 -70
  148. package/dist/index-CeP1E2kK.js +0 -209
  149. package/dist/index-Dy-Hzr7y.js +0 -13
package/dist/Slider.js CHANGED
@@ -1,23 +1,23 @@
1
1
  "use client";
2
2
  import "./styles/main.css";
3
- import { jsx as m, jsxs as G } from "react/jsx-runtime";
4
- import { Input as Z } from "./primitives/input.js";
3
+ import { jsx as m, jsxs as X } from "react/jsx-runtime";
4
+ import { Input as Q } from "./primitives/input.js";
5
5
  import * as p from "react";
6
- import { useMemo as Se, useState as ee, useEffect as ge, useCallback as $ } from "react";
6
+ import { useMemo as Se, useState as Z, useEffect as ge, useCallback as U } from "react";
7
7
  import { c as te } from "./index-rKs9bXHr.js";
8
- import { e as ve, c as be, b as T, P as O, u as z } from "./index-OnYbwQjk.js";
8
+ import { e as ve, c as be, b as N, P as L, u as T } from "./index-OnYbwQjk.js";
9
9
  import { c as we, u as ye } from "./index-DSXuB1g3.js";
10
10
  import { u as xe } from "./index-BZPx6jYI.js";
11
11
  import { u as Re } from "./index-ZExQO1ax.js";
12
- import { cn as N } from "./utils/twUtils.js";
12
+ import { cn as ee } from "./utils/twUtils.js";
13
13
  var ne = ["PageUp", "PageDown"], re = ["ArrowUp", "ArrowDown", "ArrowLeft", "ArrowRight"], oe = {
14
14
  "from-left": ["Home", "PageDown", "ArrowDown", "ArrowLeft"],
15
15
  "from-right": ["Home", "PageDown", "ArrowDown", "ArrowRight"],
16
16
  "from-bottom": ["Home", "PageDown", "ArrowDown", "ArrowLeft"],
17
17
  "from-top": ["Home", "PageDown", "ArrowUp", "ArrowLeft"]
18
- }, B = "Slider", [W, De, Ee] = we(B), [ae] = be(B, [
18
+ }, z = "Slider", [G, De, Ee] = we(z), [ae] = be(z, [
19
19
  Ee
20
- ]), [Pe, Y] = ae(B), ie = p.forwardRef(
20
+ ]), [Pe, $] = ae(z), ie = p.forwardRef(
21
21
  (e, t) => {
22
22
  const {
23
23
  name: r,
@@ -47,21 +47,21 @@ var ne = ["PageUp", "PageDown"], re = ["ArrowUp", "ArrowDown", "ArrowLeft", "Arr
47
47
  const C = ke(l, x);
48
48
  A(x, C);
49
49
  }
50
- function F(x) {
50
+ function O(x) {
51
51
  A(x, v.current);
52
52
  }
53
53
  function V() {
54
54
  const x = I.current[v.current];
55
55
  l[v.current] !== x && f(l);
56
56
  }
57
- function A(x, C, { commit: H } = { commit: !1 }) {
58
- const U = ze(c), L = Be(Math.round((x - n) / c) * c + n, U), K = te(L, [n, s]);
57
+ function A(x, C, { commit: B } = { commit: !1 }) {
58
+ const F = ze(c), H = Be(Math.round((x - n) / c) * c + n, F), K = te(H, [n, s]);
59
59
  D((M = []) => {
60
60
  const u = Ae(M, K, C);
61
61
  if (Te(u, d * c)) {
62
62
  v.current = u.indexOf(K);
63
63
  const E = String(u) !== String(M);
64
- return E && H && f(u), E ? u : M;
64
+ return E && B && f(u), E ? u : M;
65
65
  } else
66
66
  return M;
67
67
  });
@@ -79,27 +79,27 @@ var ne = ["PageUp", "PageDown"], re = ["ArrowUp", "ArrowDown", "ArrowLeft", "Arr
79
79
  values: l,
80
80
  orientation: o,
81
81
  form: b,
82
- children: /* @__PURE__ */ m(W.Provider, { scope: e.__scopeSlider, children: /* @__PURE__ */ m(W.Slot, { scope: e.__scopeSlider, children: /* @__PURE__ */ m(
82
+ children: /* @__PURE__ */ m(G.Provider, { scope: e.__scopeSlider, children: /* @__PURE__ */ m(G.Slot, { scope: e.__scopeSlider, children: /* @__PURE__ */ m(
83
83
  R,
84
84
  {
85
85
  "aria-disabled": a,
86
86
  "data-disabled": a ? "" : void 0,
87
87
  ...S,
88
88
  ref: t,
89
- onPointerDown: T(S.onPointerDown, () => {
89
+ onPointerDown: N(S.onPointerDown, () => {
90
90
  a || (I.current = l);
91
91
  }),
92
92
  min: n,
93
93
  max: s,
94
94
  inverted: y,
95
95
  onSlideStart: a ? void 0 : k,
96
- onSlideMove: a ? void 0 : F,
96
+ onSlideMove: a ? void 0 : O,
97
97
  onSlideEnd: a ? void 0 : V,
98
98
  onHomeKeyDown: () => !a && A(n, 0, { commit: !0 }),
99
99
  onEndKeyDown: () => !a && A(s, l.length - 1, { commit: !0 }),
100
100
  onStepKeyDown: ({ event: x, direction: C }) => {
101
101
  if (!a) {
102
- const L = ne.includes(x.key) || x.shiftKey && re.includes(x.key) ? 10 : 1, K = v.current, M = l[K], u = c * L * C;
102
+ const H = ne.includes(x.key) || x.shiftKey && re.includes(x.key) ? 10 : 1, K = v.current, M = l[K], u = c * H * C;
103
103
  A(M + u, K, { commit: !0 });
104
104
  }
105
105
  }
@@ -109,8 +109,8 @@ var ne = ["PageUp", "PageDown"], re = ["ArrowUp", "ArrowDown", "ArrowLeft", "Arr
109
109
  );
110
110
  }
111
111
  );
112
- ie.displayName = B;
113
- var [se, le] = ae(B, {
112
+ ie.displayName = z;
113
+ var [se, le] = ae(z, {
114
114
  startEdge: "left",
115
115
  endEdge: "right",
116
116
  size: "width",
@@ -127,9 +127,9 @@ var [se, le] = ae(B, {
127
127
  onSlideEnd: d,
128
128
  onStepKeyDown: h,
129
129
  ...w
130
- } = e, [i, f] = p.useState(null), y = z(t, (R) => f(R)), b = p.useRef(void 0), S = ye(s), g = S === "ltr", v = g && !c || !g && c;
130
+ } = e, [i, f] = p.useState(null), y = T(t, (R) => f(R)), b = p.useRef(void 0), S = ye(s), g = S === "ltr", v = g && !c || !g && c;
131
131
  function _(R) {
132
- const l = b.current || i.getBoundingClientRect(), D = [0, l.width], k = Q(D, v ? [r, n] : [n, r]);
132
+ const l = b.current || i.getBoundingClientRect(), D = [0, l.width], k = J(D, v ? [r, n] : [n, r]);
133
133
  return b.current = l, k(R - l.left);
134
134
  }
135
135
  return /* @__PURE__ */ m(
@@ -182,9 +182,9 @@ var [se, le] = ae(B, {
182
182
  onSlideEnd: a,
183
183
  onStepKeyDown: d,
184
184
  ...h
185
- } = e, w = p.useRef(null), i = z(t, w), f = p.useRef(void 0), y = !s;
185
+ } = e, w = p.useRef(null), i = T(t, w), f = p.useRef(void 0), y = !s;
186
186
  function b(S) {
187
- const g = f.current || w.current.getBoundingClientRect(), v = [0, g.height], R = Q(v, y ? [n, r] : [r, n]);
187
+ const g = f.current || w.current.getBoundingClientRect(), v = [0, g.height], R = J(v, y ? [n, r] : [r, n]);
188
188
  return f.current = g, R(S - g.top);
189
189
  }
190
190
  return /* @__PURE__ */ m(
@@ -236,23 +236,23 @@ var [se, le] = ae(B, {
236
236
  onEndKeyDown: a,
237
237
  onStepKeyDown: d,
238
238
  ...h
239
- } = e, w = Y(B, r);
239
+ } = e, w = $(z, r);
240
240
  return /* @__PURE__ */ m(
241
- O.span,
241
+ L.span,
242
242
  {
243
243
  ...h,
244
244
  ref: t,
245
- onKeyDown: T(e.onKeyDown, (i) => {
245
+ onKeyDown: N(e.onKeyDown, (i) => {
246
246
  i.key === "Home" ? (o(i), i.preventDefault()) : i.key === "End" ? (a(i), i.preventDefault()) : ne.concat(re).includes(i.key) && (d(i), i.preventDefault());
247
247
  }),
248
- onPointerDown: T(e.onPointerDown, (i) => {
248
+ onPointerDown: N(e.onPointerDown, (i) => {
249
249
  const f = i.target;
250
250
  f.setPointerCapture(i.pointerId), i.preventDefault(), w.thumbs.has(f) ? f.focus() : n(i);
251
251
  }),
252
- onPointerMove: T(e.onPointerMove, (i) => {
252
+ onPointerMove: N(e.onPointerMove, (i) => {
253
253
  i.target.hasPointerCapture(i.pointerId) && s(i);
254
254
  }),
255
- onPointerUp: T(e.onPointerUp, (i) => {
255
+ onPointerUp: N(e.onPointerUp, (i) => {
256
256
  const f = i.target;
257
257
  f.hasPointerCapture(i.pointerId) && (f.releasePointerCapture(i.pointerId), c(i));
258
258
  })
@@ -261,9 +261,9 @@ var [se, le] = ae(B, {
261
261
  }
262
262
  ), de = "SliderTrack", ue = p.forwardRef(
263
263
  (e, t) => {
264
- const { __scopeSlider: r, ...n } = e, s = Y(de, r);
264
+ const { __scopeSlider: r, ...n } = e, s = $(de, r);
265
265
  return /* @__PURE__ */ m(
266
- O.span,
266
+ L.span,
267
267
  {
268
268
  "data-disabled": s.disabled ? "" : void 0,
269
269
  "data-orientation": s.orientation,
@@ -274,13 +274,13 @@ var [se, le] = ae(B, {
274
274
  }
275
275
  );
276
276
  ue.displayName = de;
277
- var q = "SliderRange", fe = p.forwardRef(
277
+ var W = "SliderRange", fe = p.forwardRef(
278
278
  (e, t) => {
279
- const { __scopeSlider: r, ...n } = e, s = Y(q, r), c = le(q, r), o = p.useRef(null), a = z(t, o), d = s.values.length, h = s.values.map(
279
+ const { __scopeSlider: r, ...n } = e, s = $(W, r), c = le(W, r), o = p.useRef(null), a = T(t, o), d = s.values.length, h = s.values.map(
280
280
  (f) => he(f, s.min, s.max)
281
281
  ), w = d > 1 ? Math.min(...h) : 0, i = 100 - Math.max(...h);
282
282
  return /* @__PURE__ */ m(
283
- O.span,
283
+ L.span,
284
284
  {
285
285
  "data-orientation": s.orientation,
286
286
  "data-disabled": s.disabled ? "" : void 0,
@@ -295,10 +295,10 @@ var q = "SliderRange", fe = p.forwardRef(
295
295
  );
296
296
  }
297
297
  );
298
- fe.displayName = q;
299
- var J = "SliderThumb", me = p.forwardRef(
298
+ fe.displayName = W;
299
+ var q = "SliderThumb", me = p.forwardRef(
300
300
  (e, t) => {
301
- const r = De(e.__scopeSlider), [n, s] = p.useState(null), c = z(t, (a) => s(a)), o = p.useMemo(
301
+ const r = De(e.__scopeSlider), [n, s] = p.useState(null), c = T(t, (a) => s(a)), o = p.useMemo(
302
302
  () => n ? r().findIndex((a) => a.ref.current === n) : -1,
303
303
  [r, n]
304
304
  );
@@ -306,13 +306,13 @@ var J = "SliderThumb", me = p.forwardRef(
306
306
  }
307
307
  ), _e = p.forwardRef(
308
308
  (e, t) => {
309
- const { __scopeSlider: r, index: n, name: s, ...c } = e, o = Y(J, r), a = le(J, r), [d, h] = p.useState(null), w = z(t, (_) => h(_)), i = d ? o.form || !!d.closest("form") : !0, f = Re(d), y = o.values[n], b = y === void 0 ? 0 : he(y, o.min, o.max), S = Ke(n, o.values.length), g = f?.[a.size], v = g ? Ve(g, b, a.direction) : 0;
309
+ const { __scopeSlider: r, index: n, name: s, ...c } = e, o = $(q, r), a = le(q, r), [d, h] = p.useState(null), w = T(t, (_) => h(_)), i = d ? o.form || !!d.closest("form") : !0, f = Re(d), y = o.values[n], b = y === void 0 ? 0 : he(y, o.min, o.max), S = Ke(n, o.values.length), g = f?.[a.size], v = g ? Ve(g, b, a.direction) : 0;
310
310
  return p.useEffect(() => {
311
311
  if (d)
312
312
  return o.thumbs.add(d), () => {
313
313
  o.thumbs.delete(d);
314
314
  };
315
- }, [d, o.thumbs]), /* @__PURE__ */ G(
315
+ }, [d, o.thumbs]), /* @__PURE__ */ X(
316
316
  "span",
317
317
  {
318
318
  style: {
@@ -321,8 +321,8 @@ var J = "SliderThumb", me = p.forwardRef(
321
321
  [a.startEdge]: `calc(${b}% + ${v}px)`
322
322
  },
323
323
  children: [
324
- /* @__PURE__ */ m(W.ItemSlot, { scope: e.__scopeSlider, children: /* @__PURE__ */ m(
325
- O.span,
324
+ /* @__PURE__ */ m(G.ItemSlot, { scope: e.__scopeSlider, children: /* @__PURE__ */ m(
325
+ L.span,
326
326
  {
327
327
  role: "slider",
328
328
  "aria-label": e["aria-label"] || S,
@@ -336,7 +336,7 @@ var J = "SliderThumb", me = p.forwardRef(
336
336
  ...c,
337
337
  ref: w,
338
338
  style: y === void 0 ? { display: "none" } : e.style,
339
- onFocus: T(e.onFocus, () => {
339
+ onFocus: N(e.onFocus, () => {
340
340
  o.valueIndexToChangeRef.current = n;
341
341
  })
342
342
  }
@@ -355,10 +355,10 @@ var J = "SliderThumb", me = p.forwardRef(
355
355
  );
356
356
  }
357
357
  );
358
- me.displayName = J;
358
+ me.displayName = q;
359
359
  var Ie = "RadioBubbleInput", pe = p.forwardRef(
360
360
  ({ __scopeSlider: e, value: t, ...r }, n) => {
361
- const s = p.useRef(null), c = z(s, n), o = xe(t);
361
+ const s = p.useRef(null), c = T(s, n), o = xe(t);
362
362
  return p.useEffect(() => {
363
363
  const a = s.current;
364
364
  if (!a) return;
@@ -368,7 +368,7 @@ var Ie = "RadioBubbleInput", pe = p.forwardRef(
368
368
  w.call(a, t), a.dispatchEvent(i);
369
369
  }
370
370
  }, [o, t]), /* @__PURE__ */ m(
371
- O.input,
371
+ L.input,
372
372
  {
373
373
  style: { display: "none" },
374
374
  ...r,
@@ -396,7 +396,7 @@ function ke(e, t) {
396
396
  return r.indexOf(n);
397
397
  }
398
398
  function Ve(e, t, r) {
399
- const n = e / 2, c = Q([0, 50], [0, n]);
399
+ const n = e / 2, c = J([0, 50], [0, n]);
400
400
  return (n - c(t) * r) * r;
401
401
  }
402
402
  function Ne(e) {
@@ -409,7 +409,7 @@ function Te(e, t) {
409
409
  }
410
410
  return !0;
411
411
  }
412
- function Q(e, t) {
412
+ function J(e, t) {
413
413
  return (r) => {
414
414
  if (e[0] === e[1] || t[0] === t[1]) return t[0];
415
415
  const n = (t[1] - t[0]) / (e[1] - e[0]);
@@ -429,22 +429,22 @@ const Qe = ({ accessibleName: e, className: t, defaultValue: r, disabled: n, inp
429
429
  () => Array.isArray(S) ? S : Array.isArray(r) ? r : [d],
430
430
  // eslint-disable-next-line react-hooks/exhaustive-deps
431
431
  []
432
- ), [_, R] = ee(v), l = g ? S : _, [D, I] = ee(() => l.map(String));
432
+ ), [_, R] = Z(v), l = g ? S : _, [D, I] = Z(() => l.map(String));
433
433
  ge(() => {
434
434
  I(l.map(String));
435
435
  }, [l]);
436
- const k = $(
436
+ const k = U(
437
437
  (u) => {
438
438
  g || R(u), i?.(u);
439
439
  },
440
440
  [g, i]
441
- ), F = $(
441
+ ), O = U(
442
442
  (u, E) => {
443
443
  const P = [...D];
444
444
  P[u] = E.target.value, I(P);
445
445
  },
446
446
  [D]
447
- ), V = $(
447
+ ), V = U(
448
448
  (u) => {
449
449
  const E = D[u];
450
450
  if (E === "") {
@@ -457,27 +457,27 @@ const Qe = ({ accessibleName: e, className: t, defaultValue: r, disabled: n, inp
457
457
  return;
458
458
  }
459
459
  P = Math.max(d, Math.min(a, P));
460
- const j = [...l];
460
+ const Y = [...l];
461
461
  if (u === 0 && l.length > 1) {
462
- const X = l[1] - h * b;
463
- P = Math.min(P, X);
462
+ const j = l[1] - h * b;
463
+ P = Math.min(P, j);
464
464
  } else if (u === 1) {
465
- const X = l[0] + h * b;
466
- P = Math.max(P, X);
465
+ const j = l[0] + h * b;
466
+ P = Math.max(P, j);
467
467
  }
468
- j[u] = P, k(j), f?.(j);
468
+ Y[u] = P, k(Y), f?.(Y);
469
469
  },
470
470
  [D, l, d, a, b, h, k, f]
471
- ), A = $(
471
+ ), A = U(
472
472
  (u, E) => {
473
473
  E.key === "Enter" && (V(u), E.currentTarget.blur());
474
474
  },
475
475
  [V]
476
- ), x = y === "vertical", C = o === "both", H = c && (o === "end" || o === "both"), U = s === "start" || s === "both", L = s === "both" && l.length > 1, K = N("text-slider-label text-sm tabular-nums shrink-0", x ? "text-center" : ""), M = N("w-10 h-fit px-1 shrink-0 text-center text-sm tabular-nums [appearance:textfield] [&::-webkit-inner-spin-button]:appearance-none [&::-webkit-outer-spin-button]:appearance-none");
477
- return /* @__PURE__ */ G("div", { className: N("flex items-center gap-3", x ? "flex-col" : "w-full", t), "data-testid": "spectral-slider-container", children: [
476
+ ), x = y === "vertical", C = o === "both", B = c && (o === "end" || o === "both"), F = s === "start" || s === "both", H = s === "both" && l.length > 1, K = ee("text-slider-label text-sm tabular-nums shrink-0", x ? "text-center" : ""), M = "w-10 h-fit px-1 shrink-0 text-center text-sm tabular-nums [appearance:textfield] [&::-webkit-inner-spin-button]:appearance-none [&::-webkit-outer-spin-button]:appearance-none";
477
+ return /* @__PURE__ */ X("div", { className: ee("flex items-center gap-3", x ? "flex-col" : "w-full", t), "data-testid": "spectral-slider-container", children: [
478
478
  C && /* @__PURE__ */ m("span", { className: K, "data-slot": "slider-label", "data-testid": "spectral-slider-label-start", children: c?.({ values: l, min: d, max: a, position: "start" }) }),
479
- U && /* @__PURE__ */ m(
480
- Z,
479
+ F && /* @__PURE__ */ m(
480
+ Q,
481
481
  {
482
482
  "aria-label": e ? `${e} start value` : "Slider start value",
483
483
  className: M,
@@ -487,57 +487,57 @@ const Qe = ({ accessibleName: e, className: t, defaultValue: r, disabled: n, inp
487
487
  max: l.length > 1 ? l[1] - h * b : a,
488
488
  min: d,
489
489
  onBlur: () => V(0),
490
- onChange: (u) => F(0, u),
490
+ onChange: (u) => O(0, u),
491
491
  onKeyDown: (u) => A(0, u),
492
492
  step: b,
493
493
  type: "number",
494
494
  value: D[0] ?? ""
495
495
  }
496
496
  ),
497
- /* @__PURE__ */ G(
497
+ /* @__PURE__ */ X(
498
498
  He,
499
499
  {
500
500
  "aria-label": e,
501
- "aria-valuemin": d,
502
501
  "aria-valuemax": a,
502
+ "aria-valuemin": d,
503
503
  "aria-valuenow": l[0],
504
+ className: "relative flex w-full touch-none items-center select-none data-disabled:opacity-50 data-[orientation=vertical]:h-full data-[orientation=vertical]:min-h-44 data-[orientation=vertical]:w-auto data-[orientation=vertical]:flex-col",
504
505
  "data-slot": "slider",
505
506
  "data-testid": "spectral-slider",
506
- value: l,
507
- min: d,
507
+ disabled: n,
508
508
  max: a,
509
- step: b,
509
+ min: d,
510
510
  minStepsBetweenThumbs: h,
511
+ name: w,
511
512
  onValueChange: k,
512
- orientation: y,
513
513
  onValueCommit: f,
514
- disabled: n,
515
- name: w,
516
- className: N("relative flex w-full touch-none items-center select-none data-[disabled]:opacity-50 data-[orientation=vertical]:h-full data-[orientation=vertical]:min-h-44 data-[orientation=vertical]:w-auto data-[orientation=vertical]:flex-col"),
514
+ orientation: y,
515
+ step: b,
516
+ value: l,
517
517
  children: [
518
518
  /* @__PURE__ */ m(
519
519
  Le,
520
520
  {
521
+ className: "bg-slider-track relative grow overflow-hidden rounded-full data-[orientation=horizontal]:h-1.5 data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full data-[orientation=vertical]:w-1.5",
521
522
  "data-slot": "slider-track",
522
523
  "data-testid": "spectral-slider-track",
523
- className: N("bg-slider-track relative grow overflow-hidden rounded-full data-[orientation=horizontal]:h-1.5 data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full data-[orientation=vertical]:w-1.5"),
524
- children: /* @__PURE__ */ m(Oe, { "data-slot": "slider-range", "data-testid": "spectral-slider-range", className: N("bg-slider-range absolute data-[orientation=horizontal]:h-full data-[orientation=vertical]:w-full") })
524
+ children: /* @__PURE__ */ m(Oe, { className: "bg-slider-range absolute data-[orientation=horizontal]:h-full data-[orientation=vertical]:w-full", "data-slot": "slider-range", "data-testid": "spectral-slider-range" })
525
525
  }
526
526
  ),
527
527
  Array.from({ length: l.length }, (u, E) => /* @__PURE__ */ m(
528
528
  Fe,
529
529
  {
530
+ className: "border-slider-thumb-border bg-slider-thumb-bg ring-slider-thumb-ring/50 block size-5 shrink-0 rounded-full border shadow-sm transition-[color,box-shadow] hover:ring-4 focus-visible:ring-4 focus-visible:outline-none disabled:pointer-events-none disabled:opacity-50",
530
531
  "data-slot": "slider-thumb",
531
- "data-testid": "spectral-slider-thumb",
532
- className: "border-slider-thumb-border bg-slider-thumb-bg ring-slider-thumb-ring/50 block size-5 shrink-0 rounded-full border shadow-sm transition-[color,box-shadow] hover:ring-4 focus-visible:ring-4 focus-visible:outline-none disabled:pointer-events-none disabled:opacity-50"
532
+ "data-testid": "spectral-slider-thumb"
533
533
  },
534
534
  E
535
535
  ))
536
536
  ]
537
537
  }
538
538
  ),
539
- L && /* @__PURE__ */ m(
540
- Z,
539
+ H && /* @__PURE__ */ m(
540
+ Q,
541
541
  {
542
542
  "aria-label": e ? `${e} end value` : "Slider end value",
543
543
  className: M,
@@ -547,14 +547,14 @@ const Qe = ({ accessibleName: e, className: t, defaultValue: r, disabled: n, inp
547
547
  max: a,
548
548
  min: l[0] + h * b,
549
549
  onBlur: () => V(1),
550
- onChange: (u) => F(1, u),
550
+ onChange: (u) => O(1, u),
551
551
  onKeyDown: (u) => A(1, u),
552
552
  step: b,
553
553
  type: "number",
554
554
  value: D[1] ?? ""
555
555
  }
556
556
  ),
557
- H && /* @__PURE__ */ m("span", { className: K, "data-slot": "slider-label", "data-testid": "spectral-slider-label-end", children: c({ values: l, min: d, max: a, position: "end" }) })
557
+ B && /* @__PURE__ */ m("span", { className: K, "data-slot": "slider-label", "data-testid": "spectral-slider-label-end", children: c({ values: l, min: d, max: a, position: "end" }) })
558
558
  ] });
559
559
  };
560
560
  export {
@@ -1,7 +1,7 @@
1
1
  import { AsChildProp } from '../primitives/slot';
2
2
  import { ButtonHTMLAttributes, HTMLAttributes, Ref } from 'react';
3
3
  type BaseButtonProps = Omit<ButtonHTMLAttributes<HTMLButtonElement>, 'onChange' | 'value'>;
4
- export type SwitchProps = BaseButtonProps & AsChildProp & {
4
+ export interface SwitchProps extends BaseButtonProps, AsChildProp {
5
5
  checked?: boolean;
6
6
  defaultChecked?: boolean;
7
7
  form?: string;
@@ -9,16 +9,16 @@ export type SwitchProps = BaseButtonProps & AsChildProp & {
9
9
  onCheckedChange?: (checked: boolean) => void;
10
10
  required?: boolean;
11
11
  value?: string;
12
- };
12
+ }
13
13
  export declare const Switch: {
14
- ({ ref, asChild, className, checked, defaultChecked, onCheckedChange, name, value, required, form, disabled, id, onClick, onKeyDown, children, ...rest }: SwitchProps & {
14
+ ({ asChild, checked, children, className, defaultChecked, disabled, form, id, name, onCheckedChange, onClick, onKeyDown, ref, required, value, ...rest }: SwitchProps & {
15
15
  ref?: Ref<HTMLButtonElement>;
16
16
  }): import("react/jsx-runtime").JSX.Element;
17
17
  displayName: string;
18
18
  };
19
19
  export type SwitchThumbProps = HTMLAttributes<HTMLSpanElement> & AsChildProp;
20
20
  export declare const SwitchThumb: {
21
- ({ ref, asChild, className, ...props }: SwitchThumbProps & {
21
+ ({ asChild, className, ref, ...props }: SwitchThumbProps & {
22
22
  ref?: Ref<HTMLSpanElement>;
23
23
  }): import("react/jsx-runtime").JSX.Element;
24
24
  displayName: string;
@@ -1,132 +1,96 @@
1
1
  "use client";
2
2
  import "../styles/main.css";
3
- import { jsx as f, jsxs as F } from "react/jsx-runtime";
4
- import { useControllableState as K } from "../hooks/useControllableState.js";
5
- import { Slot as w } from "../primitives/slot.js";
6
- import { cn as g } from "../utils/twUtils.js";
7
- import { createContext as M, useRef as O, useId as V, useEffect as v, useCallback as a, useContext as $ } from "react";
8
- const x = M(null), z = ({
9
- ref: u,
10
- asChild: d,
3
+ import { jsx as a, jsxs as L, Fragment as N } from "react/jsx-runtime";
4
+ import { useControllableState as q } from "../hooks/useControllableState.js";
5
+ import { Slot as v } from "../primitives/slot.js";
6
+ import { createContext as K, useRef as M, useId as O, useEffect as V, useCallback as i, useContext as $ } from "react";
7
+ const w = K(null), z = ({
8
+ asChild: u,
9
+ checked: d,
10
+ children: h,
11
11
  className: l,
12
- checked: h,
13
- defaultChecked: n = !1,
14
- onCheckedChange: m,
12
+ defaultChecked: t = !1,
13
+ disabled: n,
14
+ form: b,
15
+ id: C,
15
16
  name: y,
16
- value: C = "on",
17
- required: E,
18
- form: S,
19
- disabled: r,
20
- id: I,
21
- onClick: p,
22
- onKeyDown: b,
23
- children: N,
24
- ...P
17
+ onCheckedChange: x,
18
+ onClick: f,
19
+ onKeyDown: p,
20
+ ref: E,
21
+ required: S,
22
+ value: g = "on",
23
+ ...I
25
24
  }) => {
26
- const c = O(null), R = V(), T = I ?? `swt-${R}`, [t, s] = K({
27
- value: h,
28
- defaultValue: n,
29
- onChange: m
25
+ const m = M(null), P = O(), R = C ?? `swt-${P}`, [r, c] = q({
26
+ value: d,
27
+ defaultValue: t,
28
+ onChange: x
30
29
  });
31
- v(() => {
32
- c.current && (c.current.checked = t);
33
- }, [t]), v(() => {
34
- const e = c.current?.form ?? null;
30
+ V(() => {
31
+ const e = m.current?.form ?? null;
35
32
  if (!e) return;
36
- const o = () => s(n);
33
+ const o = () => c(t);
37
34
  return e.addEventListener("reset", o), () => e.removeEventListener("reset", o);
38
- }, [n, s]);
39
- const k = a((e) => {
40
- const o = c.current;
35
+ }, [t, c]);
36
+ const k = i((e) => {
37
+ const o = m.current;
41
38
  if (!o) return;
42
39
  o.checked = e;
43
- const q = new Event("change", { bubbles: !0 });
44
- o.dispatchEvent(q);
45
- }, []), i = a(() => {
46
- if (r) return;
47
- const e = !t;
48
- s(e), queueMicrotask(() => k(e));
49
- }, [r, k, t, s]), j = a(
40
+ const F = new Event("change", { bubbles: !0 });
41
+ o.dispatchEvent(F);
42
+ }, []), s = i(() => {
43
+ if (n) return;
44
+ const e = !r;
45
+ c(e), queueMicrotask(() => k(e));
46
+ }, [n, k, r, c]), T = i(
50
47
  (e) => {
51
- p?.(e), !e.defaultPrevented && i();
48
+ f?.(e), !e.defaultPrevented && s();
52
49
  },
53
- [p, i]
54
- ), D = a(
50
+ [f, s]
51
+ ), j = i(
55
52
  (e) => {
56
- b?.(e), !e.defaultPrevented && (e.key === " " || e.key === "Enter") && (e.preventDefault(), i());
53
+ p?.(e), !e.defaultPrevented && (e.key === " " || e.key === "Enter") && (e.preventDefault(), s());
57
54
  },
58
- [b, i]
59
- ), L = d ? w : "button";
60
- return /* @__PURE__ */ f(x.Provider, { value: { checked: t, disabled: r }, children: /* @__PURE__ */ F(
61
- L,
62
- {
63
- "aria-checked": t,
64
- "aria-disabled": r || void 0,
65
- className: g(
66
- "peer border-input inline-flex h-6 w-11 shrink-0 cursor-pointer items-center rounded-full border",
67
- "bg-input focus-visible:ring-ring transition-colors focus-visible:ring-2 focus-visible:ring-offset-2 focus-visible:outline-none",
68
- "disabled:cursor-not-allowed disabled:opacity-50",
69
- "data-[state=checked]:bg-primary",
70
- l
71
- ),
72
- "data-disabled": r || void 0,
73
- "data-state": t ? "checked" : "unchecked",
74
- disabled: r,
75
- id: T,
76
- onClick: j,
77
- onKeyDown: D,
78
- ref: u,
79
- role: "switch",
80
- type: "button",
81
- ...P,
82
- children: [
83
- /* @__PURE__ */ f(
84
- "input",
85
- {
86
- "aria-hidden": "true",
87
- checked: t,
88
- disabled: r,
89
- form: S,
90
- name: y,
91
- readOnly: !0,
92
- ref: c,
93
- required: E,
94
- tabIndex: -1,
95
- type: "checkbox",
96
- value: C,
97
- style: {
98
- position: "absolute",
99
- opacity: 0,
100
- width: 0,
101
- height: 0,
102
- pointerEvents: "none"
103
- }
104
- }
105
- ),
106
- N
107
- ]
108
- }
109
- ) });
55
+ [p, s]
56
+ ), D = u ? v : "button";
57
+ return /* @__PURE__ */ a(w.Provider, { value: { checked: r, disabled: n }, children: /* @__PURE__ */ L(N, { children: [
58
+ /* @__PURE__ */ a(D, { "aria-checked": r, className: l, "data-disabled": n ?? void 0, "data-state": r ? "checked" : "unchecked", disabled: n, id: R, onClick: T, onKeyDown: j, ref: E, role: "switch", type: "button", ...I, children: h }),
59
+ /* @__PURE__ */ a(
60
+ "input",
61
+ {
62
+ "aria-hidden": "true",
63
+ checked: r,
64
+ disabled: n,
65
+ form: b,
66
+ name: y,
67
+ readOnly: !0,
68
+ ref: m,
69
+ required: S,
70
+ tabIndex: -1,
71
+ type: "checkbox",
72
+ value: g,
73
+ style: {
74
+ height: 0,
75
+ opacity: 0,
76
+ pointerEvents: "none",
77
+ position: "absolute",
78
+ width: 0
79
+ }
80
+ }
81
+ )
82
+ ] }) });
110
83
  };
111
84
  z.displayName = "Switch";
112
85
  const A = ({
113
- ref: u,
114
- asChild: d,
115
- className: l,
116
- ...h
86
+ asChild: u,
87
+ className: d,
88
+ ref: h,
89
+ ...l
117
90
  }) => {
118
- const n = $(x);
119
- if (!n) throw new Error("SwitchThumb must be used within Switch");
120
- return /* @__PURE__ */ f(
121
- d ? w : "span",
122
- {
123
- className: g("bg-background pointer-events-none block h-5 w-5 rounded-full shadow-lg ring-0 transition-transform", "translate-x-0 data-[state=checked]:translate-x-5", l),
124
- "data-disabled": n.disabled || void 0,
125
- "data-state": n.checked ? "checked" : "unchecked",
126
- ref: u,
127
- ...h
128
- }
129
- );
91
+ const t = $(w);
92
+ if (!t) throw new Error("SwitchThumb must be used within Switch");
93
+ return /* @__PURE__ */ a(u ? v : "span", { className: d, "data-disabled": t.disabled ?? void 0, "data-state": t.checked ? "checked" : "unchecked", ref: h, ...l });
130
94
  };
131
95
  A.displayName = "SwitchThumb";
132
96
  export {