@spear-ai/spectral 1.4.26 → 1.4.28

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 (209) hide show
  1. package/dist/.js +196 -191
  2. package/dist/Accordion.d.ts +28 -9
  3. package/dist/Accordion.js +203 -183
  4. package/dist/Alert/AlertBase.d.ts +24 -16
  5. package/dist/Alert/AlertBase.js +33 -18
  6. package/dist/Alert.js +1 -1
  7. package/dist/Avatar.js +11 -11
  8. package/dist/Button.d.ts +7 -2
  9. package/dist/Button.js +25 -12
  10. package/dist/ButtonIcon.d.ts +7 -2
  11. package/dist/ButtonIcon.js +25 -16
  12. package/dist/Card.js +1 -1
  13. package/dist/Checkbox/CheckboxBase.d.ts +13 -13
  14. package/dist/Checkbox/CheckboxBase.js +128 -125
  15. package/dist/Checkbox.d.ts +7 -2
  16. package/dist/Checkbox.js +29 -22
  17. package/dist/DataCard.js +3 -3
  18. package/dist/Dialog.js +2 -2
  19. package/dist/Drawer.js +2 -2
  20. package/dist/HoverCard.js +1 -1
  21. package/dist/Icons/AnalyzeIcon.d.ts +3 -1
  22. package/dist/Icons/AnalyzeIcon.js +3 -6
  23. package/dist/Icons/AnnotationsIcon.d.ts +3 -1
  24. package/dist/Icons/AnnotationsIcon.js +3 -6
  25. package/dist/Icons/ApprovedIcon.d.ts +3 -1
  26. package/dist/Icons/ApprovedIcon.js +3 -6
  27. package/dist/Icons/ArrowDownIcon.d.ts +3 -1
  28. package/dist/Icons/ArrowDownIcon.js +3 -6
  29. package/dist/Icons/ArrowUpIcon.d.ts +3 -1
  30. package/dist/Icons/ArrowUpIcon.js +4 -7
  31. package/dist/Icons/CalendarIcon.d.ts +3 -1
  32. package/dist/Icons/CalendarIcon.js +9 -12
  33. package/dist/Icons/CheckCircleIcon.d.ts +3 -1
  34. package/dist/Icons/CheckCircleIcon.js +2 -5
  35. package/dist/Icons/CheckSquareIcon.d.ts +3 -1
  36. package/dist/Icons/CheckSquareIcon.js +4 -7
  37. package/dist/Icons/CheckmarkIcon.d.ts +3 -1
  38. package/dist/Icons/CheckmarkIcon.js +5 -8
  39. package/dist/Icons/ChevronDownIcon.d.ts +3 -1
  40. package/dist/Icons/ChevronDownIcon.js +5 -8
  41. package/dist/Icons/ChevronUpIcon.d.ts +3 -1
  42. package/dist/Icons/ChevronUpIcon.js +5 -8
  43. package/dist/Icons/ClockIcon.d.ts +3 -1
  44. package/dist/Icons/ClockIcon.js +5 -8
  45. package/dist/Icons/CloseCircleIcon.d.ts +3 -1
  46. package/dist/Icons/CloseCircleIcon.js +4 -7
  47. package/dist/Icons/CloseIcon.d.ts +3 -1
  48. package/dist/Icons/CloseIcon.js +5 -8
  49. package/dist/Icons/DashboardIcon.d.ts +3 -1
  50. package/dist/Icons/DashboardIcon.js +3 -6
  51. package/dist/Icons/DatabaseIcon.d.ts +3 -1
  52. package/dist/Icons/DatabaseIcon.js +4 -7
  53. package/dist/Icons/DeleteIcon.d.ts +3 -1
  54. package/dist/Icons/DeleteIcon.js +4 -7
  55. package/dist/Icons/DurationIcon.d.ts +3 -1
  56. package/dist/Icons/DurationIcon.js +3 -6
  57. package/dist/Icons/EditIcon.d.ts +3 -1
  58. package/dist/Icons/EditIcon.js +3 -6
  59. package/dist/Icons/EmailIcon.d.ts +3 -1
  60. package/dist/Icons/EmailIcon.js +4 -7
  61. package/dist/Icons/EraserIcon.d.ts +3 -1
  62. package/dist/Icons/EraserIcon.js +9 -10
  63. package/dist/Icons/ErrorIcon.d.ts +3 -1
  64. package/dist/Icons/ErrorIcon.js +4 -7
  65. package/dist/Icons/EyeClosedIcon.d.ts +3 -1
  66. package/dist/Icons/EyeClosedIcon.js +4 -7
  67. package/dist/Icons/EyeClosedIcon2.d.ts +3 -1
  68. package/dist/Icons/EyeClosedIcon2.js +3 -6
  69. package/dist/Icons/EyeOpenIcon.d.ts +3 -1
  70. package/dist/Icons/EyeOpenIcon.js +6 -9
  71. package/dist/Icons/GoToFirstIcon.d.ts +3 -1
  72. package/dist/Icons/GoToFirstIcon.js +4 -7
  73. package/dist/Icons/GoToLastIcon.d.ts +3 -1
  74. package/dist/Icons/GoToLastIcon.js +4 -7
  75. package/dist/Icons/HarmonicCursorsIcon.d.ts +3 -1
  76. package/dist/Icons/HarmonicCursorsIcon.js +4 -7
  77. package/dist/Icons/IconBase.d.ts +4 -2
  78. package/dist/Icons/IconBase.js +17 -8
  79. package/dist/Icons/InfoIcon.d.ts +3 -1
  80. package/dist/Icons/InfoIcon.js +4 -7
  81. package/dist/Icons/LabelIcon.d.ts +3 -1
  82. package/dist/Icons/LabelIcon.js +3 -6
  83. package/dist/Icons/LassoIcon.d.ts +3 -1
  84. package/dist/Icons/LassoIcon.js +5 -8
  85. package/dist/Icons/LineToolIcon.d.ts +3 -1
  86. package/dist/Icons/LineToolIcon.js +3 -6
  87. package/dist/Icons/LineToolIcon2.d.ts +3 -1
  88. package/dist/Icons/LineToolIcon2.js +3 -6
  89. package/dist/Icons/LiveViewIcon.d.ts +3 -1
  90. package/dist/Icons/LiveViewIcon.js +2 -5
  91. package/dist/Icons/LoaderIcon.d.ts +3 -1
  92. package/dist/Icons/LoaderIcon.js +6 -7
  93. package/dist/Icons/LocationIcon.d.ts +3 -1
  94. package/dist/Icons/LocationIcon.js +3 -6
  95. package/dist/Icons/LogoutIcon.d.ts +3 -1
  96. package/dist/Icons/LogoutIcon.js +4 -7
  97. package/dist/Icons/MessagesIcon.d.ts +3 -1
  98. package/dist/Icons/MessagesIcon.js +5 -8
  99. package/dist/Icons/MetadataIcon.d.ts +3 -1
  100. package/dist/Icons/MetadataIcon.js +4 -7
  101. package/dist/Icons/MinusIcon.d.ts +3 -1
  102. package/dist/Icons/MinusIcon.js +3 -6
  103. package/dist/Icons/OntologyIcon.d.ts +3 -1
  104. package/dist/Icons/OntologyIcon.js +2 -5
  105. package/dist/Icons/PanelIconClose.d.ts +3 -1
  106. package/dist/Icons/PanelIconClose.js +4 -7
  107. package/dist/Icons/PanelIconOpen.d.ts +3 -1
  108. package/dist/Icons/PanelIconOpen.js +8 -11
  109. package/dist/Icons/PlayIcon.d.ts +3 -1
  110. package/dist/Icons/PlayIcon.js +3 -6
  111. package/dist/Icons/PlusIcon.d.ts +3 -1
  112. package/dist/Icons/PlusIcon.js +4 -7
  113. package/dist/Icons/ResetIcon.d.ts +3 -1
  114. package/dist/Icons/ResetIcon.js +4 -7
  115. package/dist/Icons/ReviewedIcon.d.ts +3 -1
  116. package/dist/Icons/ReviewedIcon.js +3 -6
  117. package/dist/Icons/ScissorsIcon.d.ts +3 -1
  118. package/dist/Icons/ScissorsIcon.js +6 -9
  119. package/dist/Icons/SettingsIcon.d.ts +3 -1
  120. package/dist/Icons/SettingsIcon.js +3 -6
  121. package/dist/Icons/SortAscendingIcon.d.ts +3 -1
  122. package/dist/Icons/SortAscendingIcon.js +3 -6
  123. package/dist/Icons/SortAtoZIcon.d.ts +3 -1
  124. package/dist/Icons/SortAtoZIcon.js +3 -6
  125. package/dist/Icons/SortDescendingIcon.d.ts +3 -1
  126. package/dist/Icons/SortDescendingIcon.js +3 -6
  127. package/dist/Icons/SortZtoAIcon.d.ts +3 -1
  128. package/dist/Icons/SortZtoAIcon.js +3 -6
  129. package/dist/Icons/StackIcon.d.ts +3 -1
  130. package/dist/Icons/StackIcon.js +4 -7
  131. package/dist/Icons/StarIcon.d.ts +3 -1
  132. package/dist/Icons/StarIcon.js +3 -6
  133. package/dist/Icons/TrashIcon.d.ts +3 -1
  134. package/dist/Icons/TrashIcon.js +3 -6
  135. package/dist/Icons/UndoIcon.d.ts +3 -1
  136. package/dist/Icons/UndoIcon.js +4 -7
  137. package/dist/Icons/UserIcon.d.ts +3 -1
  138. package/dist/Icons/UserIcon.js +3 -6
  139. package/dist/Icons/WarningIcon.d.ts +3 -1
  140. package/dist/Icons/WarningIcon.js +5 -8
  141. package/dist/Icons/ZoomAllIcon.d.ts +3 -1
  142. package/dist/Icons/ZoomAllIcon.js +3 -6
  143. package/dist/Icons/ZoomXIcon.d.ts +3 -1
  144. package/dist/Icons/ZoomXIcon.js +4 -7
  145. package/dist/Icons/ZoomYIcon.d.ts +3 -1
  146. package/dist/Icons/ZoomYIcon.js +4 -7
  147. package/dist/Input/InputUtils.d.ts +4 -4
  148. package/dist/Input/InputUtils.js +1 -1
  149. package/dist/Input.d.ts +7 -17
  150. package/dist/Input.js +105 -101
  151. package/dist/InputOTP.d.ts +27 -7
  152. package/dist/InputOTP.js +171 -146
  153. package/dist/Kbd.d.ts +16 -0
  154. package/dist/Kbd.js +23 -0
  155. package/dist/Label.d.ts +7 -2
  156. package/dist/Label.js +12 -9
  157. package/dist/MultiSelect/MultiSelectBase.d.ts +7 -2
  158. package/dist/MultiSelect/MultiSelectBase.js +212 -213
  159. package/dist/{MultiSelect/MutiSelect.d.ts → MultiSelect.d.ts} +8 -2
  160. package/dist/MultiSelect.js +27 -0
  161. package/dist/Popover.js +1 -1
  162. package/dist/RadioButtonGroup.js +1 -1
  163. package/dist/RadioGroup.d.ts +20 -14
  164. package/dist/RadioGroup.js +177 -148
  165. package/dist/Select.d.ts +7 -2
  166. package/dist/Select.js +108 -109
  167. package/dist/Separator.d.ts +8 -8
  168. package/dist/Separator.js +14 -15
  169. package/dist/Switch/SwitchBase.d.ts +13 -11
  170. package/dist/Switch/SwitchBase.js +84 -61
  171. package/dist/Switch.d.ts +10 -4
  172. package/dist/Switch.js +19 -20
  173. package/dist/Tabs/TabsBase.d.ts +16 -6
  174. package/dist/Tabs/TabsBase.js +133 -96
  175. package/dist/Tabs/tabsUtils.d.ts +6 -2
  176. package/dist/Tabs/tabsUtils.js +5 -2
  177. package/dist/Tabs.js +18 -18
  178. package/dist/Textarea.d.ts +7 -2
  179. package/dist/Textarea.js +78 -61
  180. package/dist/Toggle/ToggleBase.d.ts +4 -8
  181. package/dist/Toggle/ToggleBase.js +29 -16
  182. package/dist/Toggle.d.ts +4 -2
  183. package/dist/Toggle.js +23 -13
  184. package/dist/ToggleGroup/ToggleGroupBase.d.ts +4 -7
  185. package/dist/ToggleGroup/ToggleGroupBase.js +82 -73
  186. package/dist/ToggleGroup.d.ts +7 -2
  187. package/dist/ToggleGroup.js +31 -19
  188. package/dist/Tray.d.ts +47 -15
  189. package/dist/Tray.js +98 -60
  190. package/dist/hooks/useAccordionAutoScroll.d.ts +1 -1
  191. package/dist/hooks/useAccordionAutoScroll.d.ts.map +1 -1
  192. package/dist/hooks/useAccordionAutoScroll.js +35 -34
  193. package/dist/{index-BSCg4Mei.js → index-B0Kp8R0j.js} +3 -3
  194. package/dist/{index-jgQ7sgLl.js → index-D4jMMaAi.js} +5 -5
  195. package/dist/index.d.ts +11 -9
  196. package/dist/index.d.ts.map +1 -1
  197. package/dist/primitives/input.d.ts.map +1 -1
  198. package/dist/primitives/input.js +1 -4
  199. package/dist/primitives/select.d.ts.map +1 -1
  200. package/dist/primitives/select.js +4 -11
  201. package/dist/primitives/slot.d.ts +11 -4
  202. package/dist/primitives/slot.d.ts.map +1 -1
  203. package/dist/primitives/slot.js +32 -28
  204. package/dist/primitives/textarea.d.ts.map +1 -1
  205. package/dist/primitives/textarea.js +1 -3
  206. package/dist/styles/main.css +1 -1
  207. package/dist/utils/formFieldUtils.js +2 -2
  208. package/package.json +1 -1
  209. package/dist/MultiSelect/MutiSelect.js +0 -19
@@ -3,95 +3,95 @@ import "./styles/main.css";
3
3
  import { jsx as n, jsxs as N } from "react/jsx-runtime";
4
4
  import { Label as _ } from "./Label.js";
5
5
  import * as c from "react";
6
- import { createContext as Re, forwardRef as G, useMemo as ge, memo as he, useContext as Ie } from "react";
7
- import { c as K, P as S, b as w, u as P, e as Y } from "./index-CfypDjr2.js";
8
- import { c as we, u as j } from "./index-DvqEQspb.js";
9
- import { u as ye } from "./index-CDYW5LDR.js";
10
- import { u as Ce } from "./index-0ioNhtNM.js";
11
- import { u as Ee } from "./index-BRDfoF8s.js";
12
- import { u as Fe } from "./index-BZPx6jYI.js";
13
- import { P as Se } from "./index-DdOwqCfb.js";
6
+ import { createContext as be, memo as Re, useMemo as ge, useContext as he } from "react";
7
+ import { c as B, P as S, b as w, u as G, e as q } from "./index-CfypDjr2.js";
8
+ import { c as Ie, u as Y } from "./index-DvqEQspb.js";
9
+ import { u as we } from "./index-CDYW5LDR.js";
10
+ import { u as ye } from "./index-0ioNhtNM.js";
11
+ import { u as Ce } from "./index-BRDfoF8s.js";
12
+ import { u as Ee } from "./index-BZPx6jYI.js";
13
+ import { P as Fe } from "./index-DdOwqCfb.js";
14
14
  import { cn as F } from "./utils/twUtils.js";
15
- var O = "rovingFocusGroup.onEntryFocus", xe = { bubbles: !1, cancelable: !0 }, x = "RovingFocusGroup", [M, z, Ne] = we(x), [_e, H] = K(
15
+ var L = "rovingFocusGroup.onEntryFocus", Se = { bubbles: !1, cancelable: !0 }, x = "RovingFocusGroup", [O, j, xe] = Ie(x), [Ne, z] = B(
16
16
  x,
17
- [Ne]
18
- ), [Ae, Ge] = _e(x), $ = c.forwardRef(
19
- (e, t) => /* @__PURE__ */ n(M.Provider, { scope: e.__scopeRovingFocusGroup, children: /* @__PURE__ */ n(M.Slot, { scope: e.__scopeRovingFocusGroup, children: /* @__PURE__ */ n(Pe, { ...e, ref: t }) }) })
17
+ [xe]
18
+ ), [_e, Ae] = Ne(x), H = c.forwardRef(
19
+ (e, t) => /* @__PURE__ */ n(O.Provider, { scope: e.__scopeRovingFocusGroup, children: /* @__PURE__ */ n(O.Slot, { scope: e.__scopeRovingFocusGroup, children: /* @__PURE__ */ n(Ge, { ...e, ref: t }) }) })
20
20
  );
21
- $.displayName = x;
22
- var Pe = c.forwardRef((e, t) => {
21
+ H.displayName = x;
22
+ var Ge = c.forwardRef((e, t) => {
23
23
  const {
24
24
  __scopeRovingFocusGroup: o,
25
25
  orientation: r,
26
26
  loop: a = !1,
27
27
  dir: s,
28
28
  currentTabStopId: i,
29
- defaultCurrentTabStopId: v,
29
+ defaultCurrentTabStopId: m,
30
30
  onCurrentTabStopIdChange: b,
31
31
  onEntryFocus: f,
32
32
  preventScrollOnEntryFocus: d = !1,
33
33
  ...R
34
- } = e, g = c.useRef(null), l = P(t, g), p = j(s), [m, u] = Y({
34
+ } = e, g = c.useRef(null), l = G(t, g), p = Y(s), [v, u] = q({
35
35
  prop: i,
36
- defaultProp: v ?? null,
36
+ defaultProp: m ?? null,
37
37
  onChange: b,
38
38
  caller: x
39
- }), [y, k] = c.useState(!1), I = Ce(f), C = z(o), D = c.useRef(!1), [fe, V] = c.useState(0);
39
+ }), [y, T] = c.useState(!1), I = ye(f), C = j(o), k = c.useRef(!1), [le, U] = c.useState(0);
40
40
  return c.useEffect(() => {
41
41
  const h = g.current;
42
42
  if (h)
43
- return h.addEventListener(O, I), () => h.removeEventListener(O, I);
43
+ return h.addEventListener(L, I), () => h.removeEventListener(L, I);
44
44
  }, [I]), /* @__PURE__ */ n(
45
- Ae,
45
+ _e,
46
46
  {
47
47
  scope: o,
48
48
  orientation: r,
49
49
  dir: p,
50
50
  loop: a,
51
- currentTabStopId: m,
51
+ currentTabStopId: v,
52
52
  onItemFocus: c.useCallback(
53
53
  (h) => u(h),
54
54
  [u]
55
55
  ),
56
- onItemShiftTab: c.useCallback(() => k(!0), []),
56
+ onItemShiftTab: c.useCallback(() => T(!0), []),
57
57
  onFocusableItemAdd: c.useCallback(
58
- () => V((h) => h + 1),
58
+ () => U((h) => h + 1),
59
59
  []
60
60
  ),
61
61
  onFocusableItemRemove: c.useCallback(
62
- () => V((h) => h - 1),
62
+ () => U((h) => h - 1),
63
63
  []
64
64
  ),
65
65
  children: /* @__PURE__ */ n(
66
66
  S.div,
67
67
  {
68
- tabIndex: y || fe === 0 ? -1 : 0,
68
+ tabIndex: y || le === 0 ? -1 : 0,
69
69
  "data-orientation": r,
70
70
  ...R,
71
71
  ref: l,
72
72
  style: { outline: "none", ...e.style },
73
73
  onMouseDown: w(e.onMouseDown, () => {
74
- D.current = !0;
74
+ k.current = !0;
75
75
  }),
76
76
  onFocus: w(e.onFocus, (h) => {
77
- const pe = !D.current;
78
- if (h.target === h.currentTarget && pe && !y) {
79
- const q = new CustomEvent(O, xe);
80
- if (h.currentTarget.dispatchEvent(q), !q.defaultPrevented) {
81
- const L = C().filter((E) => E.focusable), me = L.find((E) => E.active), ve = L.find((E) => E.id === m), be = [me, ve, ...L].filter(
77
+ const fe = !k.current;
78
+ if (h.target === h.currentTarget && fe && !y) {
79
+ const V = new CustomEvent(L, Se);
80
+ if (h.currentTarget.dispatchEvent(V), !V.defaultPrevented) {
81
+ const D = C().filter((E) => E.focusable), pe = D.find((E) => E.active), me = D.find((E) => E.id === v), ve = [pe, me, ...D].filter(
82
82
  Boolean
83
83
  ).map((E) => E.ref.current);
84
- J(be, d);
84
+ X(ve, d);
85
85
  }
86
86
  }
87
- D.current = !1;
87
+ k.current = !1;
88
88
  }),
89
- onBlur: w(e.onBlur, () => k(!1))
89
+ onBlur: w(e.onBlur, () => T(!1))
90
90
  }
91
91
  )
92
92
  }
93
93
  );
94
- }), W = "RovingFocusGroupItem", X = c.forwardRef(
94
+ }), $ = "RovingFocusGroupItem", W = c.forwardRef(
95
95
  (e, t) => {
96
96
  const {
97
97
  __scopeRovingFocusGroup: o,
@@ -99,13 +99,13 @@ var Pe = c.forwardRef((e, t) => {
99
99
  active: a = !1,
100
100
  tabStopId: s,
101
101
  children: i,
102
- ...v
103
- } = e, b = ye(), f = s || b, d = Ge(W, o), R = d.currentTabStopId === f, g = z(o), { onFocusableItemAdd: l, onFocusableItemRemove: p, currentTabStopId: m } = d;
102
+ ...m
103
+ } = e, b = we(), f = s || b, d = Ae($, o), R = d.currentTabStopId === f, g = j(o), { onFocusableItemAdd: l, onFocusableItemRemove: p, currentTabStopId: v } = d;
104
104
  return c.useEffect(() => {
105
105
  if (r)
106
106
  return l(), () => p();
107
107
  }, [r, l, p]), /* @__PURE__ */ n(
108
- M.ItemSlot,
108
+ O.ItemSlot,
109
109
  {
110
110
  scope: o,
111
111
  id: f,
@@ -116,7 +116,7 @@ var Pe = c.forwardRef((e, t) => {
116
116
  {
117
117
  tabIndex: R ? 0 : -1,
118
118
  "data-orientation": d.orientation,
119
- ...v,
119
+ ...m,
120
120
  ref: t,
121
121
  onMouseDown: w(e.onMouseDown, (u) => {
122
122
  r ? d.onItemFocus(f) : u.preventDefault();
@@ -128,7 +128,7 @@ var Pe = c.forwardRef((e, t) => {
128
128
  return;
129
129
  }
130
130
  if (u.target !== u.currentTarget) return;
131
- const y = De(u, d.orientation, d.dir);
131
+ const y = ke(u, d.orientation, d.dir);
132
132
  if (y !== void 0) {
133
133
  if (u.metaKey || u.ctrlKey || u.altKey || u.shiftKey) return;
134
134
  u.preventDefault();
@@ -137,20 +137,20 @@ var Pe = c.forwardRef((e, t) => {
137
137
  else if (y === "prev" || y === "next") {
138
138
  y === "prev" && I.reverse();
139
139
  const C = I.indexOf(u.currentTarget);
140
- I = d.loop ? Le(I, C + 1) : I.slice(C + 1);
140
+ I = d.loop ? De(I, C + 1) : I.slice(C + 1);
141
141
  }
142
- setTimeout(() => J(I));
142
+ setTimeout(() => X(I));
143
143
  }
144
144
  }),
145
- children: typeof i == "function" ? i({ isCurrentTabStop: R, hasTabStop: m != null }) : i
145
+ children: typeof i == "function" ? i({ isCurrentTabStop: R, hasTabStop: v != null }) : i
146
146
  }
147
147
  )
148
148
  }
149
149
  );
150
150
  }
151
151
  );
152
- X.displayName = W;
153
- var Te = {
152
+ W.displayName = $;
153
+ var Pe = {
154
154
  ArrowLeft: "prev",
155
155
  ArrowUp: "prev",
156
156
  ArrowRight: "next",
@@ -160,23 +160,23 @@ var Te = {
160
160
  PageDown: "last",
161
161
  End: "last"
162
162
  };
163
- function ke(e, t) {
163
+ function Te(e, t) {
164
164
  return t !== "rtl" ? e : e === "ArrowLeft" ? "ArrowRight" : e === "ArrowRight" ? "ArrowLeft" : e;
165
165
  }
166
- function De(e, t, o) {
167
- const r = ke(e.key, o);
166
+ function ke(e, t, o) {
167
+ const r = Te(e.key, o);
168
168
  if (!(t === "vertical" && ["ArrowLeft", "ArrowRight"].includes(r)) && !(t === "horizontal" && ["ArrowUp", "ArrowDown"].includes(r)))
169
- return Te[r];
169
+ return Pe[r];
170
170
  }
171
- function J(e, t = !1) {
171
+ function X(e, t = !1) {
172
172
  const o = document.activeElement;
173
173
  for (const r of e)
174
174
  if (r === o || (r.focus({ preventScroll: t }), document.activeElement !== o)) return;
175
175
  }
176
- function Le(e, t) {
176
+ function De(e, t) {
177
177
  return e.map((o, r) => e[(t + r) % e.length]);
178
178
  }
179
- var Oe = $, Me = X, U = "Radio", [Be, Q] = K(U), [Ke, Ue] = Be(U), Z = c.forwardRef(
179
+ var Le = H, Oe = W, K = "Radio", [Me, J] = B(K), [Be, Ke] = Me(K), Q = c.forwardRef(
180
180
  (e, t) => {
181
181
  const {
182
182
  __scopeRadio: o,
@@ -184,36 +184,36 @@ var Oe = $, Me = X, U = "Radio", [Be, Q] = K(U), [Ke, Ue] = Be(U), Z = c.forward
184
184
  checked: a = !1,
185
185
  required: s,
186
186
  disabled: i,
187
- value: v = "on",
187
+ value: m = "on",
188
188
  onCheck: b,
189
189
  form: f,
190
190
  ...d
191
- } = e, [R, g] = c.useState(null), l = P(t, (u) => g(u)), p = c.useRef(!1), m = R ? f || !!R.closest("form") : !0;
192
- return /* @__PURE__ */ N(Ke, { scope: o, checked: a, disabled: i, children: [
191
+ } = e, [R, g] = c.useState(null), l = G(t, (u) => g(u)), p = c.useRef(!1), v = R ? f || !!R.closest("form") : !0;
192
+ return /* @__PURE__ */ N(Be, { scope: o, checked: a, disabled: i, children: [
193
193
  /* @__PURE__ */ n(
194
194
  S.button,
195
195
  {
196
196
  type: "button",
197
197
  role: "radio",
198
198
  "aria-checked": a,
199
- "data-state": re(a),
199
+ "data-state": te(a),
200
200
  "data-disabled": i ? "" : void 0,
201
201
  disabled: i,
202
- value: v,
202
+ value: m,
203
203
  ...d,
204
204
  ref: l,
205
205
  onClick: w(e.onClick, (u) => {
206
- a || b?.(), m && (p.current = u.isPropagationStopped(), p.current || u.stopPropagation());
206
+ a || b?.(), v && (p.current = u.isPropagationStopped(), p.current || u.stopPropagation());
207
207
  })
208
208
  }
209
209
  ),
210
- m && /* @__PURE__ */ n(
211
- te,
210
+ v && /* @__PURE__ */ n(
211
+ oe,
212
212
  {
213
213
  control: R,
214
214
  bubbles: !p.current,
215
215
  name: r,
216
- value: v,
216
+ value: m,
217
217
  checked: a,
218
218
  required: s,
219
219
  disabled: i,
@@ -224,14 +224,14 @@ var Oe = $, Me = X, U = "Radio", [Be, Q] = K(U), [Ke, Ue] = Be(U), Z = c.forward
224
224
  ] });
225
225
  }
226
226
  );
227
- Z.displayName = U;
228
- var ee = "RadioIndicator", oe = c.forwardRef(
227
+ Q.displayName = K;
228
+ var Z = "RadioIndicator", ee = c.forwardRef(
229
229
  (e, t) => {
230
- const { __scopeRadio: o, forceMount: r, ...a } = e, s = Ue(ee, o);
231
- return /* @__PURE__ */ n(Se, { present: r || s.checked, children: /* @__PURE__ */ n(
230
+ const { __scopeRadio: o, forceMount: r, ...a } = e, s = Ke(Z, o);
231
+ return /* @__PURE__ */ n(Fe, { present: r || s.checked, children: /* @__PURE__ */ n(
232
232
  S.span,
233
233
  {
234
- "data-state": re(s.checked),
234
+ "data-state": te(s.checked),
235
235
  "data-disabled": s.disabled ? "" : void 0,
236
236
  ...a,
237
237
  ref: t
@@ -239,8 +239,8 @@ var ee = "RadioIndicator", oe = c.forwardRef(
239
239
  ) });
240
240
  }
241
241
  );
242
- oe.displayName = ee;
243
- var Ve = "RadioBubbleInput", te = c.forwardRef(
242
+ ee.displayName = Z;
243
+ var Ue = "RadioBubbleInput", oe = c.forwardRef(
244
244
  ({
245
245
  __scopeRadio: e,
246
246
  control: t,
@@ -248,7 +248,7 @@ var Ve = "RadioBubbleInput", te = c.forwardRef(
248
248
  bubbles: r = !0,
249
249
  ...a
250
250
  }, s) => {
251
- const i = c.useRef(null), v = P(i, s), b = Fe(o), f = Ee(t);
251
+ const i = c.useRef(null), m = G(i, s), b = Ee(o), f = Ce(t);
252
252
  return c.useEffect(() => {
253
253
  const d = i.current;
254
254
  if (!d) return;
@@ -268,7 +268,7 @@ var Ve = "RadioBubbleInput", te = c.forwardRef(
268
268
  defaultChecked: o,
269
269
  ...a,
270
270
  tabIndex: -1,
271
- ref: v,
271
+ ref: m,
272
272
  style: {
273
273
  ...a.style,
274
274
  ...f,
@@ -281,14 +281,14 @@ var Ve = "RadioBubbleInput", te = c.forwardRef(
281
281
  );
282
282
  }
283
283
  );
284
- te.displayName = Ve;
285
- function re(e) {
284
+ oe.displayName = Ue;
285
+ function te(e) {
286
286
  return e ? "checked" : "unchecked";
287
287
  }
288
- var qe = ["ArrowUp", "ArrowDown", "ArrowLeft", "ArrowRight"], T = "RadioGroup", [Ye] = K(T, [
289
- H,
290
- Q
291
- ]), ae = H(), ne = Q(), [je, ze] = Ye(T), se = c.forwardRef(
288
+ var Ve = ["ArrowUp", "ArrowDown", "ArrowLeft", "ArrowRight"], P = "RadioGroup", [qe] = B(P, [
289
+ z,
290
+ J
291
+ ]), re = z(), ae = J(), [Ye, je] = qe(P), ne = c.forwardRef(
292
292
  (e, t) => {
293
293
  const {
294
294
  __scopeRadioGroup: o,
@@ -296,29 +296,29 @@ var qe = ["ArrowUp", "ArrowDown", "ArrowLeft", "ArrowRight"], T = "RadioGroup",
296
296
  defaultValue: a,
297
297
  value: s,
298
298
  required: i = !1,
299
- disabled: v = !1,
299
+ disabled: m = !1,
300
300
  orientation: b,
301
301
  dir: f,
302
302
  loop: d = !0,
303
303
  onValueChange: R,
304
304
  ...g
305
- } = e, l = ae(o), p = j(f), [m, u] = Y({
305
+ } = e, l = re(o), p = Y(f), [v, u] = q({
306
306
  prop: s,
307
307
  defaultProp: a ?? null,
308
308
  onChange: R,
309
- caller: T
309
+ caller: P
310
310
  });
311
311
  return /* @__PURE__ */ n(
312
- je,
312
+ Ye,
313
313
  {
314
314
  scope: o,
315
315
  name: r,
316
316
  required: i,
317
- disabled: v,
318
- value: m,
317
+ disabled: m,
318
+ value: v,
319
319
  onValueChange: u,
320
320
  children: /* @__PURE__ */ n(
321
- Oe,
321
+ Le,
322
322
  {
323
323
  asChild: !0,
324
324
  ...l,
@@ -331,7 +331,7 @@ var qe = ["ArrowUp", "ArrowDown", "ArrowLeft", "ArrowRight"], T = "RadioGroup",
331
331
  role: "radiogroup",
332
332
  "aria-required": i,
333
333
  "aria-orientation": b,
334
- "data-disabled": v ? "" : void 0,
334
+ "data-disabled": m ? "" : void 0,
335
335
  dir: p,
336
336
  ...g,
337
337
  ref: t
@@ -343,26 +343,26 @@ var qe = ["ArrowUp", "ArrowDown", "ArrowLeft", "ArrowRight"], T = "RadioGroup",
343
343
  );
344
344
  }
345
345
  );
346
- se.displayName = T;
347
- var ie = "RadioGroupItem", ce = c.forwardRef(
346
+ ne.displayName = P;
347
+ var se = "RadioGroupItem", ie = c.forwardRef(
348
348
  (e, t) => {
349
- const { __scopeRadioGroup: o, disabled: r, ...a } = e, s = ze(ie, o), i = s.disabled || r, v = ae(o), b = ne(o), f = c.useRef(null), d = P(t, f), R = s.value === a.value, g = c.useRef(!1);
349
+ const { __scopeRadioGroup: o, disabled: r, ...a } = e, s = je(se, o), i = s.disabled || r, m = re(o), b = ae(o), f = c.useRef(null), d = G(t, f), R = s.value === a.value, g = c.useRef(!1);
350
350
  return c.useEffect(() => {
351
- const l = (m) => {
352
- qe.includes(m.key) && (g.current = !0);
351
+ const l = (v) => {
352
+ Ve.includes(v.key) && (g.current = !0);
353
353
  }, p = () => g.current = !1;
354
354
  return document.addEventListener("keydown", l), document.addEventListener("keyup", p), () => {
355
355
  document.removeEventListener("keydown", l), document.removeEventListener("keyup", p);
356
356
  };
357
357
  }, []), /* @__PURE__ */ n(
358
- Me,
358
+ Oe,
359
359
  {
360
360
  asChild: !0,
361
- ...v,
361
+ ...m,
362
362
  focusable: !i,
363
363
  active: R,
364
364
  children: /* @__PURE__ */ n(
365
- Z,
365
+ Q,
366
366
  {
367
367
  disabled: i,
368
368
  required: s.required,
@@ -384,86 +384,115 @@ var ie = "RadioGroupItem", ce = c.forwardRef(
384
384
  );
385
385
  }
386
386
  );
387
- ce.displayName = ie;
388
- var He = "RadioGroupIndicator", ue = c.forwardRef(
387
+ ie.displayName = se;
388
+ var ze = "RadioGroupIndicator", ce = c.forwardRef(
389
389
  (e, t) => {
390
- const { __scopeRadioGroup: o, ...r } = e, a = ne(o);
391
- return /* @__PURE__ */ n(oe, { ...a, ...r, ref: t });
390
+ const { __scopeRadioGroup: o, ...r } = e, a = ae(o);
391
+ return /* @__PURE__ */ n(ee, { ...a, ...r, ref: t });
392
392
  }
393
393
  );
394
- ue.displayName = He;
395
- var $e = se, de = ce, We = ue;
396
- const le = Re({
394
+ ce.displayName = ze;
395
+ var He = ne, ue = ie, $e = ce;
396
+ const de = be({
397
397
  orientation: "vertical",
398
398
  variant: "default",
399
399
  disabledValues: [],
400
400
  groupDisabled: !1
401
- }), A = "pointer-events-none opacity-60", Xe = G(({ className: e, itemClassName: t, onValueChange: o, orientation: r = "vertical", disabled: a, selected: s, variant: i = "default", ...v }, b) => {
401
+ }), A = "pointer-events-none opacity-60", We = ({
402
+ ref: e,
403
+ className: t,
404
+ itemClassName: o,
405
+ onValueChange: r,
406
+ orientation: a = "vertical",
407
+ disabled: s,
408
+ selected: i,
409
+ variant: m = "default",
410
+ ...b
411
+ }) => {
402
412
  const f = ge(
403
413
  () => ({
404
- orientation: r,
405
- variant: i,
406
- disabledValues: Array.isArray(a) ? a : [],
407
- groupDisabled: typeof a == "boolean" ? a : !1,
408
- itemClassName: t,
409
- selected: s
414
+ orientation: a,
415
+ variant: m,
416
+ disabledValues: Array.isArray(s) ? s : [],
417
+ groupDisabled: typeof s == "boolean" ? s : !1,
418
+ itemClassName: o,
419
+ selected: i
410
420
  }),
411
- [r, i, a, t, s]
421
+ [a, m, s, o, i]
412
422
  );
413
- return /* @__PURE__ */ n(le.Provider, { value: f, children: /* @__PURE__ */ n(
414
- $e,
423
+ return /* @__PURE__ */ n(de.Provider, { value: f, children: /* @__PURE__ */ n(
424
+ He,
415
425
  {
416
- className: F("flex text-text-primary w-full", r === "vertical" ? "flex-col gap-4" : "flex-row gap-5", i === "unstyled" && "gap-2.5 w-fit", e),
426
+ className: F("text-text-primary flex w-full", a === "vertical" ? "flex-col gap-4" : "flex-row gap-5", m === "unstyled" && "w-fit gap-2.5", t),
417
427
  "data-testid": "spectral-radio-group",
418
428
  disabled: f.groupDisabled,
419
- onValueChange: o,
420
- ref: b,
421
- value: s,
422
- ...v
429
+ onValueChange: r,
430
+ ref: e,
431
+ value: i,
432
+ ...b
423
433
  }
424
434
  ) });
425
- });
426
- Xe.displayName = "RadioGroup";
427
- const B = he(
428
- G(({ value: e, id: t, isDisabled: o, className: r, ...a }, s) => /* @__PURE__ */ n(
429
- de,
435
+ };
436
+ We.displayName = "RadioGroup";
437
+ const M = Re(
438
+ ({
439
+ ref: e,
440
+ value: t,
441
+ id: o,
442
+ isDisabled: r,
443
+ className: a,
444
+ ...s
445
+ }) => /* @__PURE__ */ n(
446
+ ue,
430
447
  {
431
- ref: s,
448
+ ref: e,
432
449
  "data-testid": "spectral-radio-group-item",
433
450
  className: F(
434
- "relative aspect-square h-4.5 w-4.5 rounded-full border-2 border-border-subtle bg-radio-bg ring-black transition-colors cursor-pointer",
435
- "hover:border-radio-border--hover focus-visible:outline-1 focus-visible:outline-offset-2 focus-visible:outline-accent",
451
+ "border-border-subtle bg-radio-bg relative aspect-square h-4.5 w-4.5 cursor-pointer rounded-full border-2 ring-black transition-colors",
452
+ "hover:border-radio-border--hover focus-visible:outline-accent focus-visible:outline-1 focus-visible:outline-offset-2",
436
453
  "[&[data-state=checked]]:border-radio-border--selected [&[data-state=checked]]:bg-radio-bg",
437
- o && A,
438
- r
454
+ r && A,
455
+ a
439
456
  ),
440
- disabled: o,
441
- value: e,
442
- id: t,
443
- ...a,
444
- children: /* @__PURE__ */ n(We, { className: "after:absolute after:inset-0 after:m-auto after:content-[''] transition-colors after:h-2.5 after:w-2.5 after:rounded-full after:bg-radio-bg--selected" })
457
+ disabled: r,
458
+ value: t,
459
+ id: o,
460
+ ...s,
461
+ children: /* @__PURE__ */ n($e, { className: "after:bg-radio-bg--selected transition-colors after:absolute after:inset-0 after:m-auto after:h-2.5 after:w-2.5 after:rounded-full after:content-['']" })
445
462
  }
446
- ))
463
+ )
447
464
  );
448
- B.displayName = "RadioButton";
449
- const Je = G(({ className: e, children: t, value: o, description: r, disabled: a, ...s }, i) => {
450
- const { disabledValues: v, groupDisabled: b, itemClassName: f, variant: d, selected: R, orientation: g } = Ie(le), l = o.toString(), p = s.id?.toString() || l, m = b || v.includes(l) || !!a, u = R === l;
451
- return d === "tiles" ? /* @__PURE__ */ n(_, { htmlFor: p, className: F("flex items-start p-4 rounded-xl border w-full border-border-subtle cursor-pointer", u && "border-tile-border--selected bg-tile-bg--selected", m && A, f, e), children: /* @__PURE__ */ N("div", { className: "flex w-full gap-4 items-start justify-between", children: [
452
- /* @__PURE__ */ n("div", { className: "flex-shrink-0 mr-3 relative top-0.75", children: /* @__PURE__ */ n(B, { ref: i, value: l, id: p, isDisabled: m, ...s }) }),
453
- /* @__PURE__ */ N("div", { className: "flex flex-col flex-grow", children: [
454
- /* @__PURE__ */ n("div", { className: "font-bold", children: t }),
455
- r && /* @__PURE__ */ n("div", { className: "text-sm mt-1", children: r })
465
+ M.displayName = "RadioButton";
466
+ const Xe = ({
467
+ ref: e,
468
+ className: t,
469
+ children: o,
470
+ value: r,
471
+ description: a,
472
+ disabled: s,
473
+ ...i
474
+ }) => {
475
+ const { disabledValues: m, groupDisabled: b, itemClassName: f, variant: d, selected: R, orientation: g } = he(de), l = r.toString(), p = i.id?.toString() || l, v = b || m.includes(l) || !!s, u = R === l;
476
+ return d === "tiles" ? /* @__PURE__ */ n(_, { htmlFor: p, className: F("border-border-subtle flex w-full cursor-pointer items-start rounded-xl border p-4", u && "border-tile-border--selected bg-tile-bg--selected", v && A, f, t), children: /* @__PURE__ */ N("div", { className: "flex w-full items-start justify-between gap-4", children: [
477
+ /* @__PURE__ */ n("div", { className: "relative top-0.75 mr-3 flex-shrink-0", children: /* @__PURE__ */ n(M, { ref: e, value: l, id: p, isDisabled: v, ...i }) }),
478
+ /* @__PURE__ */ N("div", { className: "flex flex-grow flex-col", children: [
479
+ /* @__PURE__ */ n("div", { className: "font-bold", children: o }),
480
+ a && /* @__PURE__ */ n("div", { className: "mt-1 text-sm", children: a })
456
481
  ] })
457
- ] }) }) : d === "unstyled" ? /* @__PURE__ */ n(de, { ref: i, value: l, id: p, disabled: m, asChild: !0, ...s, children: /* @__PURE__ */ n(_, { htmlFor: p, className: F("h-fit w-fit border-2 border-transparent rounded [&[data-state=checked]]:border-radio-border--selected flex", m && A, f, e), children: t }) }) : /* @__PURE__ */ N("div", { className: F("flex items-center", m && A, f, e, g), children: [
458
- /* @__PURE__ */ n(B, { ref: i, value: l, id: p, isDisabled: m, ...s }),
459
- t && /* @__PURE__ */ n(_, { className: F("text-md cursor-pointer font-normal", g === "vertical" ? "ml-2" : "ml-1"), htmlFor: p, children: t })
482
+ ] }) }) : d === "unstyled" ? /* @__PURE__ */ n(ue, { ref: e, value: l, id: p, disabled: v, asChild: !0, ...i, children: /* @__PURE__ */ n(_, { htmlFor: p, className: F("[&[data-state=checked]]:border-radio-border--selected flex h-fit w-fit rounded border-2 border-transparent", v && A, f, t), children: o }) }) : /* @__PURE__ */ N("div", { className: F("flex items-center", v && A, f, t, g), children: [
483
+ /* @__PURE__ */ n(M, { ref: e, value: l, id: p, isDisabled: v, ...i }),
484
+ o && /* @__PURE__ */ n(_, { className: F("text-md cursor-pointer font-normal", g === "vertical" ? "ml-2" : "ml-1"), htmlFor: p, children: o })
460
485
  ] });
461
- });
462
- Je.displayName = "RadioGroup.Item";
463
- const Qe = G(({ className: e, ...t }, o) => /* @__PURE__ */ n(_, { ref: o, "data-testid": "spectral-radio-group-label", className: F("block text-md font-medium", e), ...t }));
464
- Qe.displayName = "RadioGroup.Label";
486
+ };
487
+ Xe.displayName = "RadioGroup.Item";
488
+ const Je = ({
489
+ ref: e,
490
+ className: t,
491
+ ...o
492
+ }) => /* @__PURE__ */ n(_, { ref: e, "data-testid": "spectral-radio-group-label", className: F("text-md block font-medium", t), ...o });
493
+ Je.displayName = "RadioGroup.Label";
465
494
  export {
466
- Xe as RadioGroup,
467
- Je as RadioGroupItem,
468
- Qe as RadioGroupLabel
495
+ We as RadioGroup,
496
+ Xe as RadioGroupItem,
497
+ Je as RadioGroupLabel
469
498
  };
package/dist/Select.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import { BaseFormFieldProps, BaseOption } from './utils/formFieldUtils';
2
- import { ComponentPropsWithoutRef, ReactNode } from 'react';
2
+ import { ComponentPropsWithoutRef, ReactNode, Ref } from 'react';
3
3
  type SelectOption = BaseOption;
4
4
  type Align = 'start' | 'center' | 'end';
5
5
  type Side = 'top' | 'bottom' | 'left' | 'right';
@@ -23,6 +23,11 @@ export interface SelectExtendedProps extends SelectProps {
23
23
  side?: Side;
24
24
  sideOffset?: number;
25
25
  }
26
- export declare const Select: import('react').ForwardRefExoticComponent<SelectExtendedProps & import('react').RefAttributes<HTMLButtonElement>>;
26
+ export declare const Select: {
27
+ ({ ref, align, alignOffset, className, collisionPadding, defaultValue, emptyMessage, errorMessage, id, label, labelClassName, loadingMessage, name, onChange, options, placeholder, position, side, sideOffset, state, value, "aria-label": ariaLabel, "aria-describedby": ariaDescribedBy, ...props }: SelectExtendedProps & {
28
+ ref?: Ref<HTMLButtonElement>;
29
+ }): import("react/jsx-runtime").JSX.Element;
30
+ displayName: string;
31
+ };
27
32
  export {};
28
33
  //# sourceMappingURL=Select.d.ts.map