@spear-ai/spectral 1.9.0 → 1.10.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 (237) hide show
  1. package/README.md +6 -5
  2. package/dist/.js +112 -239
  3. package/dist/Accordion-CDXdSAST.js +363 -0
  4. package/dist/Accordion.js +3 -498
  5. package/dist/Alert/AlertBase.js +69 -152
  6. package/dist/Alert.js +58 -106
  7. package/dist/AnimatePresence-D-9jXfgI.js +178 -0
  8. package/dist/App.js +6 -6
  9. package/dist/Avatar.js +83 -65
  10. package/dist/Badge.d.ts +1 -3
  11. package/dist/Badge.js +21 -25
  12. package/dist/Button.js +102 -178
  13. package/dist/ButtonGroup/ButtonGroupButton.js +38 -40
  14. package/dist/ButtonGroup.js +55 -59
  15. package/dist/ButtonIcon.js +58 -134
  16. package/dist/Calendar-s4lyijkn.js +3109 -0
  17. package/dist/Checkbox/CheckboxBase.js +94 -126
  18. package/dist/Checkbox.d.ts +1 -1
  19. package/dist/Checkbox.js +40 -105
  20. package/dist/Combobox/ComboboxBase.js +2 -79
  21. package/dist/Combobox.js +106 -172
  22. package/dist/ComboboxBase-D8Nf4xC-.js +491 -0
  23. package/dist/ControlGroup/ControlGroupSelect.d.ts +1 -1
  24. package/dist/ControlGroup/ControlGroupSelect.js +85 -101
  25. package/dist/ControlGroup.js +45 -48
  26. package/dist/DataCard/Card.js +37 -12
  27. package/dist/DataCard.d.ts +1 -1
  28. package/dist/DataCard.js +36 -16
  29. package/dist/DateTimePicker/Calendar.js +2 -2967
  30. package/dist/DateTimePicker/DateTimeDisplayInput.d.ts +1 -1
  31. package/dist/DateTimePicker/DateTimeDisplayInput.js +379 -274
  32. package/dist/DateTimePicker/DateTimeInput.d.ts +5 -3
  33. package/dist/DateTimePicker/DateTimeInput.js +133 -88
  34. package/dist/DateTimePicker/DateTimeUtils.js +2 -2193
  35. package/dist/DateTimePicker/TimePeriodSelect.d.ts +1 -1
  36. package/dist/DateTimePicker/TimePeriodSelect.js +45 -20
  37. package/dist/DateTimePicker/TimePicker.d.ts +1 -1
  38. package/dist/DateTimePicker/TimePicker.js +76 -60
  39. package/dist/DateTimePicker.d.ts +2 -2
  40. package/dist/DateTimePicker.js +87 -205
  41. package/dist/DateTimeUtils-DVvG6H-p.js +2098 -0
  42. package/dist/Dialog.js +74 -74
  43. package/dist/Drawer.js +67 -37
  44. package/dist/HoverCard-CYDsIiVK.js +201 -0
  45. package/dist/HoverCard.d.ts +1 -1
  46. package/dist/HoverCard.js +2 -218
  47. package/dist/Icons/AnalyzeIcon.js +50 -57
  48. package/dist/Icons/AnnotationsIcon.js +20 -15
  49. package/dist/Icons/ApprovedIcon.js +26 -18
  50. package/dist/Icons/ArrowDownIcon.js +20 -6
  51. package/dist/Icons/ArrowUpIcon.js +20 -6
  52. package/dist/Icons/BoxToolIcon.js +17 -12
  53. package/dist/Icons/CalendarIcon.js +43 -20
  54. package/dist/Icons/CheckCircleIcon.js +26 -10
  55. package/dist/Icons/CheckSquareIcon.js +26 -10
  56. package/dist/Icons/CheckmarkIcon.js +22 -9
  57. package/dist/Icons/ChevronDownIcon.js +22 -9
  58. package/dist/Icons/ChevronUpIcon.js +22 -9
  59. package/dist/Icons/ClockIcon.js +26 -18
  60. package/dist/Icons/CloseCircleIcon.js +26 -10
  61. package/dist/Icons/CloseIcon.js +18 -9
  62. package/dist/Icons/DashboardIcon.js +36 -10
  63. package/dist/Icons/DatabaseIcon.js +36 -19
  64. package/dist/Icons/DeleteIcon.js +36 -19
  65. package/dist/Icons/DurationIcon.js +57 -22
  66. package/dist/Icons/EditIcon.js +26 -27
  67. package/dist/Icons/EmailIcon.js +26 -10
  68. package/dist/Icons/EraserIcon.js +41 -25
  69. package/dist/Icons/ErrorIcon.js +27 -11
  70. package/dist/Icons/EyeClosedIcon.js +29 -13
  71. package/dist/Icons/EyeClosedIcon2.js +27 -11
  72. package/dist/Icons/EyeOpenIcon.js +22 -9
  73. package/dist/Icons/FileDownloadIcon.js +43 -20
  74. package/dist/Icons/GoToFirstIcon.js +26 -9
  75. package/dist/Icons/GoToLastIcon.js +26 -9
  76. package/dist/Icons/HarmonicCursorsIcon.js +23 -9
  77. package/dist/Icons/IconBase.d.ts +3 -3
  78. package/dist/Icons/IconBase.js +49 -23
  79. package/dist/Icons/InfoIcon.js +36 -10
  80. package/dist/Icons/KeyboardIcon.js +26 -27
  81. package/dist/Icons/LabelIcon.js +19 -14
  82. package/dist/Icons/LassoIcon.js +36 -28
  83. package/dist/Icons/LineToolIcon.js +48 -39
  84. package/dist/Icons/LiveViewIcon.js +50 -12
  85. package/dist/Icons/LoaderIcon.js +67 -27
  86. package/dist/Icons/LocationIcon.js +26 -27
  87. package/dist/Icons/LogoutIcon.js +20 -15
  88. package/dist/Icons/MeasureIcon.js +78 -25
  89. package/dist/Icons/MessagesIcon.js +33 -18
  90. package/dist/Icons/MetadataIcon.js +20 -15
  91. package/dist/Icons/MinusIcon.d.ts +1 -1
  92. package/dist/Icons/MinusIcon.js +18 -6
  93. package/dist/Icons/OntologyIcon.js +87 -71
  94. package/dist/Icons/PanelIconClose.js +28 -10
  95. package/dist/Icons/PanelIconOpen.js +28 -10
  96. package/dist/Icons/PlayIcon.js +20 -6
  97. package/dist/Icons/PlusIcon.js +20 -14
  98. package/dist/Icons/PolygonIcon.js +50 -39
  99. package/dist/Icons/ProgressCheckIcon.d.ts +5 -0
  100. package/dist/Icons/ProgressCheckIcon.js +58 -0
  101. package/dist/Icons/ResetIcon.js +17 -12
  102. package/dist/Icons/ReviewedIcon.js +36 -19
  103. package/dist/Icons/ScissorsIcon.js +22 -17
  104. package/dist/Icons/SearchIcon.js +26 -9
  105. package/dist/Icons/SettingsIcon.js +26 -27
  106. package/dist/Icons/SortAscendingIcon.js +50 -12
  107. package/dist/Icons/SortAtoZIcon.js +50 -12
  108. package/dist/Icons/SortDescendingIcon.js +50 -12
  109. package/dist/Icons/SortZtoAIcon.js +50 -12
  110. package/dist/Icons/StackIcon.js +26 -9
  111. package/dist/Icons/StarIcon.js +20 -6
  112. package/dist/Icons/TrashIcon.js +17 -12
  113. package/dist/Icons/UndoIcon.js +20 -15
  114. package/dist/Icons/User2Icon.js +26 -10
  115. package/dist/Icons/UserIcon.js +19 -14
  116. package/dist/Icons/WarningIcon.js +19 -14
  117. package/dist/Icons/ZoomAllIcon.js +71 -15
  118. package/dist/Icons/ZoomXIcon.js +36 -10
  119. package/dist/Icons/ZoomYIcon.js +36 -10
  120. package/dist/Icons/index.d.ts +1 -0
  121. package/dist/Icons.js +68 -136
  122. package/dist/IconsAnimated/PanelLeftCloseIcon.js +66 -36
  123. package/dist/IconsAnimated/PanelLeftOpenIcon.js +66 -36
  124. package/dist/IconsAnimated.js +3 -6
  125. package/dist/Input/InputUtils.js +51 -52
  126. package/dist/Input.js +132 -185
  127. package/dist/InputOTP-XUWW9xcI.js +461 -0
  128. package/dist/InputOTP.js +2 -382
  129. package/dist/Kbd.d.ts +1 -1
  130. package/dist/Kbd.js +182 -86
  131. package/dist/Label.js +12 -14
  132. package/dist/MultiSelect/MultiSelectBase.js +331 -403
  133. package/dist/MultiSelect.d.ts +1 -1
  134. package/dist/MultiSelect.js +23 -23
  135. package/dist/Popover.js +28 -32
  136. package/dist/RadioButton.d.ts +17 -0
  137. package/dist/RadioButton.js +33 -0
  138. package/dist/RadioButtonGroup/RadioButtonGroupBase.d.ts +3 -1
  139. package/dist/RadioButtonGroup/RadioButtonGroupBase.js +49 -46
  140. package/dist/RadioButtonGroup.d.ts +1 -1
  141. package/dist/RadioButtonGroup.js +11 -8
  142. package/dist/RadioGroup-w_q6RGEK.js +447 -0
  143. package/dist/RadioGroup.js +2 -505
  144. package/dist/Select.js +163 -186
  145. package/dist/Separator.js +16 -19
  146. package/dist/Skeleton.js +10 -6
  147. package/dist/Slider-BzzZT3Zm.js +490 -0
  148. package/dist/Slider.js +2 -562
  149. package/dist/SpectralProvider.js +8 -5
  150. package/dist/Switch/SwitchBase.js +91 -95
  151. package/dist/Switch-CVzRJ-0n.js +126 -0
  152. package/dist/Switch.d.ts +1 -1
  153. package/dist/Switch.js +2 -134
  154. package/dist/Tabs/TabsBase.js +242 -250
  155. package/dist/Tabs/tabsUtils.js +65 -73
  156. package/dist/Tabs.d.ts +1 -1
  157. package/dist/Tabs.js +73 -103
  158. package/dist/Textarea/TextareaUtils.js +35 -46
  159. package/dist/Textarea.js +83 -160
  160. package/dist/Toast-9zqXxKKO.js +711 -0
  161. package/dist/Toast.js +2 -885
  162. package/dist/Toggle/ToggleBase.js +46 -56
  163. package/dist/Toggle.d.ts +1 -1
  164. package/dist/Toggle.js +52 -62
  165. package/dist/ToggleGroup/ToggleGroupBase.js +128 -104
  166. package/dist/ToggleGroup.d.ts +1 -1
  167. package/dist/ToggleGroup.js +52 -63
  168. package/dist/Tooltip-D1K8kY1y.js +389 -0
  169. package/dist/Tooltip.js +2 -365
  170. package/dist/Tray.js +174 -217
  171. package/dist/chunk-h9knIhTc.js +20 -0
  172. package/dist/clsx-jM1GlMvB.js +16 -0
  173. package/dist/dist-3Af8168y.js +913 -0
  174. package/dist/dist-7HRQ5IKN.js +249 -0
  175. package/dist/dist-B2k1iWFp.js +129 -0
  176. package/dist/dist-B4FgboI8.js +122 -0
  177. package/dist/dist-B4g6zpUF.js +33 -0
  178. package/dist/dist-B9tup-4O.js +216 -0
  179. package/dist/dist-BK1K0g9W.js +29 -0
  180. package/dist/dist-Bfjk-jx9.js +28 -0
  181. package/dist/dist-Bft31cJh.js +65 -0
  182. package/dist/dist-BtdmHAzK.js +190 -0
  183. package/dist/dist-C0Hifjgh.js +1287 -0
  184. package/dist/dist-CGzgmYB9.js +68 -0
  185. package/dist/dist-ClmepHp4.js +10 -0
  186. package/dist/dist-D8Wb_MX9.js +6 -0
  187. package/dist/dist-Dtvmk11N.js +12 -0
  188. package/dist/dist-fW81qjVl.js +677 -0
  189. package/dist/dist-s1uWaZYZ.js +11 -0
  190. package/dist/es2015-YHaMV-St.js +701 -0
  191. package/dist/hooks/useAccordionAutoScroll.js +66 -67
  192. package/dist/hooks/useControllableState.js +14 -13
  193. package/dist/hooks/useTheme.js +21 -17
  194. package/dist/index.d.ts +2 -1
  195. package/dist/index.d.ts.map +1 -1
  196. package/dist/main.js +18954 -27224
  197. package/dist/primitives/button.js +39 -41
  198. package/dist/primitives/input-group.js +57 -73
  199. package/dist/primitives/input.js +11 -20
  200. package/dist/primitives/popover.d.ts.map +1 -1
  201. package/dist/primitives/popover.js +34 -25
  202. package/dist/primitives/select.js +70 -138
  203. package/dist/primitives/slot.js +32 -31
  204. package/dist/primitives/textarea.js +10 -16
  205. package/dist/proxy-Dn10Pl_g.js +4920 -0
  206. package/dist/styles/main.css +2 -1
  207. package/dist/styles/spectral.css +1 -1
  208. package/dist/twUtils-VNWgstKL.js +1673 -0
  209. package/dist/use-animation-CBUDycyW.js +57 -0
  210. package/dist/utils/constants.js +4 -4
  211. package/dist/utils/formFieldUtils.js +136 -148
  212. package/dist/utils/sharedUtils.js +26 -7
  213. package/dist/utils/twUtils.js +2 -2919
  214. package/package.json +24 -28
  215. package/dist/ComboboxBase-CxNxYtdT.js +0 -408
  216. package/dist/clsx-OuTLNxxd.js +0 -16
  217. package/dist/index-0ioNhtNM.js +0 -10
  218. package/dist/index-6oYKCvIn.js +0 -677
  219. package/dist/index-BFOf48AQ.js +0 -69
  220. package/dist/index-BZPx6jYI.js +0 -8
  221. package/dist/index-BlHU_t18.js +0 -142
  222. package/dist/index-Bm1RbF6w.js +0 -1037
  223. package/dist/index-Bv2OIg5P.js +0 -225
  224. package/dist/index-CKEI0pDv.js +0 -56
  225. package/dist/index-CM_hWgfC.js +0 -32
  226. package/dist/index-C_YVr64u.js +0 -1538
  227. package/dist/index-Cl8VeY0o.js +0 -149
  228. package/dist/index-CwSyIPrv.js +0 -13
  229. package/dist/index-D29mdTf5.js +0 -34
  230. package/dist/index-DEYs15GP.js +0 -66
  231. package/dist/index-Dc0No4pV.js +0 -233
  232. package/dist/index-T6XEa11q.js +0 -822
  233. package/dist/index-pBCLb6Gr.js +0 -240
  234. package/dist/index-psiVrsnE.js +0 -27
  235. package/dist/index-rKs9bXHr.js +0 -6
  236. package/dist/proxy-CO_-Vget.js +0 -4975
  237. package/dist/use-animation-DhEPRwZ3.js +0 -62
@@ -1,253 +1,245 @@
1
1
  "use client";
2
2
  import "../styles/main.css";
3
- import { jsx as p, jsxs as E } from "react/jsx-runtime";
4
- import { generateId as K, prefersReducedMotion as $, calculateIndicatorStyle as S, debounce as j } from "./tabsUtils.js";
5
- import { cn as x } from "../utils/twUtils.js";
6
- import { createContext as k, useState as M, useId as U, useCallback as T, useRef as F, useMemo as q, useEffect as R, useContext as B } from "react";
7
- import { j as H } from "../index-DEYs15GP.js";
8
- import { m as D } from "../proxy-CO_-Vget.js";
9
- import { A as G } from "../index-Cl8VeY0o.js";
10
- const N = k(null), A = (y = "Tabs") => {
11
- const d = B(N);
12
- if (d === null)
13
- throw new Error(`${y} components must be used within a Tabs.Root`);
14
- return d;
15
- }, V = function({
16
- ref: d,
17
- activationMode: g = "automatic",
18
- children: o,
19
- defaultValue: s,
20
- dir: f = "ltr",
21
- disabled: u = !1,
22
- onValueChange: n,
23
- orientation: m = "horizontal",
24
- rightSlot: b,
25
- value: t,
26
- ...C
27
- }) {
28
- const [w, I] = M(s ?? ""), v = U() ?? K("tabs"), h = t !== void 0, c = h ? t : w, r = T(
29
- (e) => {
30
- u || (h || I(e), n?.(e));
31
- },
32
- [h, n, u]
33
- ), a = {
34
- activationMode: g,
35
- baseId: v,
36
- dir: f,
37
- disabled: u,
38
- onValueChange: r,
39
- orientation: m,
40
- rightSlot: b,
41
- value: c
42
- };
43
- return /* @__PURE__ */ p(N.Provider, { value: a, children: /* @__PURE__ */ p("div", { ref: d, "data-testid": "spectral-tabs", "data-orientation": m, "data-disabled": u ? "" : void 0, dir: f, ...C, children: o }) });
44
- }, tt = function({
45
- ref: d,
46
- children: g,
47
- className: o,
48
- loop: s = !0,
49
- rightSlot: f,
50
- ...u
51
- }) {
52
- const { orientation: n, disabled: m, value: b } = A("TabsList"), [t, C] = M(null), w = F(null), I = $(), v = T(() => {
53
- const r = S(w);
54
- (r.width > 0 || r.height > 0) && C(r);
55
- }, []), h = q(() => j(v, 16), [v]);
56
- R(() => {
57
- if (v(), typeof ResizeObserver > "u" || typeof MutationObserver > "u")
58
- return;
59
- const r = new ResizeObserver(h), a = new MutationObserver(h), e = w.current;
60
- return e && (r.observe(e), a.observe(e, {
61
- attributes: !0,
62
- childList: !0,
63
- subtree: !0
64
- })), () => {
65
- r.disconnect(), a.disconnect(), h.cancel();
66
- };
67
- }, [v, h]), R(() => {
68
- v();
69
- }, [b, v]);
70
- const c = T(
71
- (r) => {
72
- if (m) return;
73
- const a = Array.from(w.current?.querySelectorAll("[role='tab']:not([disabled]):not([aria-disabled='true'])") ?? []);
74
- if (a.length === 0) return;
75
- const e = a.findIndex((P) => P === document.activeElement);
76
- if (e === -1) return;
77
- let i = null;
78
- const { key: l, ctrlKey: L, metaKey: O } = r, z = L || O;
79
- n === "horizontal" ? l === "ArrowLeft" || l === "ArrowUp" && z ? i = e > 0 ? e - 1 : s ? a.length - 1 : e : (l === "ArrowRight" || l === "ArrowDown" && z) && (i = e < a.length - 1 ? e + 1 : s ? 0 : e) : l === "ArrowUp" || l === "ArrowLeft" && z ? i = e > 0 ? e - 1 : s ? a.length - 1 : e : (l === "ArrowDown" || l === "ArrowRight" && z) && (i = e < a.length - 1 ? e + 1 : s ? 0 : e), l === "Home" ? i = 0 : l === "End" && (i = a.length - 1), i !== null && i !== e && (r.preventDefault(), r.stopPropagation(), a[i]?.focus());
80
- },
81
- [m, n, s]
82
- );
83
- return /* @__PURE__ */ E("div", { className: "relative", ref: w, children: [
84
- /* @__PURE__ */ E(
85
- "div",
86
- {
87
- ref: d,
88
- role: "tablist",
89
- "data-testid": "spectral-tabs-list",
90
- "aria-orientation": n,
91
- "aria-disabled": m,
92
- className: x("tabs-list flex", n === "horizontal" && "items-center justify-between", n === "vertical" && "flex-col", o),
93
- onKeyDown: c,
94
- ...u,
95
- children: [
96
- /* @__PURE__ */ p("div", { className: x("flex", n === "horizontal" && "items-center", n === "vertical" && "flex-col"), children: g }),
97
- f && /* @__PURE__ */ p("div", { className: "z-10 flex items-center", children: f })
98
- ]
99
- }
100
- ),
101
- t && /* @__PURE__ */ p(
102
- D.div,
103
- {
104
- className: x(
105
- "pointer-events-none absolute top-0 left-0 will-change-transform select-none",
106
- t.orientation === "horizontal" && !t.isEnclosed && "after:border-tabs-indicator bottom-px z-10 after:absolute after:bottom-0 after:left-0 after:w-full after:rounded-t-[0.3rem] after:border-b-[0.3rem] after:content-['']",
107
- t.orientation === "vertical" && !t.isEnclosed && "after:border-tabs-indicator right-px z-10 after:absolute after:top-0 after:right-0 after:h-full after:w-1 after:rounded-l-[0.3rem] after:border-r-[0.3rem] after:content-['']",
108
- t.orientation === "horizontal" && t.isEnclosed && "bg-tabs-enclosed-indicator z-0 rounded-lg shadow-lg",
109
- t.orientation === "vertical" && t.isEnclosed && "bg-tabs-enclosed-indicator z-0 rounded-lg shadow-lg"
110
- ),
111
- initial: !1,
112
- animate: {
113
- // Use x/y (translateX/translateY) for position - compositor-friendly, no reflows
114
- x: t.left,
115
- y: t.isEnclosed ? t.top + t.height * 0.1 : t.top,
116
- // Width/height required for correct rendering: scaleX/Y would distort
117
- // border-radius on enclosed variant and border widths on default variant
118
- width: t.width,
119
- height: t.isEnclosed ? t.orientation === "vertical" ? 40 : t.height * 0.8 : t.height
120
- },
121
- transition: I ? { duration: 0 } : {
122
- // Separate transition configs: spring for transforms, tween for layout
123
- x: { type: "spring", stiffness: 500, damping: 40, mass: 1 },
124
- y: { type: "spring", stiffness: 500, damping: 40, mass: 1 },
125
- width: { type: "spring", stiffness: 500, damping: 40, mass: 1 },
126
- height: { type: "spring", stiffness: 500, damping: 40, mass: 1 }
127
- },
128
- "aria-hidden": "true"
129
- }
130
- )
131
- ] });
132
- }, et = function({
133
- ref: d,
134
- className: g,
135
- value: o,
136
- onClick: s,
137
- onKeyDown: f,
138
- disabled: u = !1,
139
- ...n
140
- }) {
141
- const { value: m, onValueChange: b, activationMode: t, disabled: C, baseId: w } = A("TabsTrigger"), I = `${w}-trigger-${o}`, v = `${w}-content-${o}`, h = m === o, c = C || u, r = T(
142
- (i) => {
143
- if (c) {
144
- i.preventDefault();
145
- return;
146
- }
147
- b(o), s?.(i);
148
- },
149
- [o, b, s, c]
150
- ), a = T(
151
- (i) => {
152
- if (c) {
153
- i.preventDefault();
154
- return;
155
- }
156
- const { key: l } = i;
157
- (l === "Enter" || l === " ") && (i.preventDefault(), i.stopPropagation(), b(o)), f?.(i);
158
- },
159
- [o, b, f, c]
160
- ), e = T(() => {
161
- c || t === "automatic" && b(o);
162
- }, [t, b, o, c]);
163
- return /* @__PURE__ */ p(
164
- "button",
165
- {
166
- "aria-controls": v,
167
- "aria-disabled": c,
168
- "aria-selected": h,
169
- className: x("tabs-trigger focus-visible:outline-accent z-10 hover:cursor-pointer focus:outline-none focus-visible:outline-2 focus-visible:outline-offset-2", g),
170
- "data-disabled": c ? "" : void 0,
171
- "data-state": h ? "active" : "inactive",
172
- "data-testid": "spectral-tabs-trigger",
173
- disabled: c,
174
- id: I,
175
- onClick: r,
176
- onFocus: e,
177
- onKeyDown: a,
178
- ref: d,
179
- role: "tab",
180
- tabIndex: h ? 0 : -1,
181
- type: "button",
182
- ...n
183
- }
184
- );
185
- }, nt = function({
186
- ref: d,
187
- children: g,
188
- className: o
189
- }) {
190
- const { value: s } = A("TabsContentContainer"), [f, u] = H(), n = $();
191
- return /* @__PURE__ */ p(
192
- D.div,
193
- {
194
- ref: d,
195
- className: x("overflow-hidden", o),
196
- "data-testid": "spectral-tabs-content-container",
197
- animate: {
198
- height: u.height || "auto"
199
- },
200
- transition: n ? { duration: 0 } : {
201
- duration: 0.3,
202
- ease: [0.25, 1, 0.5, 1]
203
- },
204
- children: /* @__PURE__ */ p(G, { mode: "wait", initial: !1, children: /* @__PURE__ */ p(
205
- D.div,
206
- {
207
- ref: f,
208
- initial: n ? !1 : { opacity: 0, y: 8 },
209
- animate: { opacity: 1, y: 0 },
210
- exit: n ? void 0 : { opacity: 0, y: -8 },
211
- transition: n ? { duration: 0 } : {
212
- duration: 0.2,
213
- ease: [0.25, 1, 0.5, 1]
214
- },
215
- children: g
216
- },
217
- s
218
- ) })
219
- }
220
- );
221
- }, ot = function({
222
- ref: d,
223
- className: g,
224
- value: o,
225
- forceMount: s = !1,
226
- ...f
227
- }) {
228
- const { value: u, baseId: n } = A("TabsContent"), m = `${n}-content-${o}`, b = `${n}-trigger-${o}`, t = u === o;
229
- return !s && !t ? null : /* @__PURE__ */ p(
230
- "div",
231
- {
232
- "aria-labelledby": b,
233
- className: x("tabs-content focus:outline-none focus-visible:outline-none", g),
234
- "data-state": t ? "active" : "inactive",
235
- "data-testid": "spectral-tabs-content",
236
- hidden: !t,
237
- id: m,
238
- ref: d,
239
- role: "tabpanel",
240
- tabIndex: 0,
241
- ...f
242
- }
243
- );
244
- };
245
- export {
246
- V as TabsBase,
247
- ot as TabsContent,
248
- nt as TabsContentContainer,
249
- N as TabsContext,
250
- tt as TabsList,
251
- et as TabsTrigger,
252
- A as useTabsContext
3
+ import { t as e } from "../twUtils-VNWgstKL.js";
4
+ import { t } from "../proxy-Dn10Pl_g.js";
5
+ import { t as n } from "../AnimatePresence-D-9jXfgI.js";
6
+ import { t as r } from "../dist-B4FgboI8.js";
7
+ import { calculateIndicatorStyle as i, debounce as a, generateId as o, prefersReducedMotion as s } from "./tabsUtils.js";
8
+ import { createContext as c, useCallback as l, useContext as u, useEffect as d, useId as f, useMemo as p, useRef as m, useState as h } from "react";
9
+ import { jsx as g, jsxs as _ } from "react/jsx-runtime";
10
+ //#region src/components/Tabs/TabsBase.tsx
11
+ var v = c(null), y = (e = "Tabs") => {
12
+ let t = u(v);
13
+ if (t === null) throw Error(`${e} components must be used within a Tabs.Root`);
14
+ return t;
15
+ }, b = function({ ref: e, activationMode: t = "automatic", children: n, defaultValue: r, dir: i = "ltr", disabled: a = !1, onValueChange: s, orientation: c = "horizontal", rightSlot: u, value: d, ...p }) {
16
+ let [m, _] = h(r ?? ""), y = f() ?? o("tabs"), b = d !== void 0, x = b ? d : m, S = {
17
+ activationMode: t,
18
+ baseId: y,
19
+ dir: i,
20
+ disabled: a,
21
+ onValueChange: l((e) => {
22
+ a || (b || _(e), s?.(e));
23
+ }, [
24
+ b,
25
+ s,
26
+ a
27
+ ]),
28
+ orientation: c,
29
+ rightSlot: u,
30
+ value: x
31
+ };
32
+ return /* @__PURE__ */ g(v.Provider, {
33
+ value: S,
34
+ children: /* @__PURE__ */ g("div", {
35
+ ref: e,
36
+ "data-testid": "spectral-tabs",
37
+ "data-orientation": c,
38
+ "data-disabled": a ? "" : void 0,
39
+ dir: i,
40
+ ...p,
41
+ children: n
42
+ })
43
+ });
44
+ }, x = function({ ref: n, children: r, className: o, loop: c = !0, rightSlot: u, ...f }) {
45
+ let { orientation: v, disabled: b, value: x } = y("TabsList"), [S, C] = h(null), w = m(null), T = s(), E = l(() => {
46
+ let e = i(w);
47
+ (e.width > 0 || e.height > 0) && C(e);
48
+ }, []), D = p(() => a(E, 16), [E]);
49
+ d(() => {
50
+ if (E(), typeof ResizeObserver > "u" || typeof MutationObserver > "u") return;
51
+ let e = new ResizeObserver(D), t = new MutationObserver(D), n = w.current;
52
+ return n && (e.observe(n), t.observe(n, {
53
+ attributes: !0,
54
+ childList: !0,
55
+ subtree: !0
56
+ })), () => {
57
+ e.disconnect(), t.disconnect(), D.cancel();
58
+ };
59
+ }, [E, D]), d(() => {
60
+ E();
61
+ }, [x, E]);
62
+ let O = l((e) => {
63
+ if (b) return;
64
+ let t = Array.from(w.current?.querySelectorAll("[role='tab']:not([disabled]):not([aria-disabled='true'])") ?? []);
65
+ if (t.length === 0) return;
66
+ let n = t.findIndex((e) => e === document.activeElement);
67
+ if (n === -1) return;
68
+ let r = null, { key: i, ctrlKey: a, metaKey: o } = e, s = a || o;
69
+ v === "horizontal" ? i === "ArrowLeft" || i === "ArrowUp" && s ? r = n > 0 ? n - 1 : c ? t.length - 1 : n : (i === "ArrowRight" || i === "ArrowDown" && s) && (r = n < t.length - 1 ? n + 1 : c ? 0 : n) : i === "ArrowUp" || i === "ArrowLeft" && s ? r = n > 0 ? n - 1 : c ? t.length - 1 : n : (i === "ArrowDown" || i === "ArrowRight" && s) && (r = n < t.length - 1 ? n + 1 : c ? 0 : n), i === "Home" ? r = 0 : i === "End" && (r = t.length - 1), r !== null && r !== n && (e.preventDefault(), e.stopPropagation(), t[r]?.focus());
70
+ }, [
71
+ b,
72
+ v,
73
+ c
74
+ ]);
75
+ return /* @__PURE__ */ _("div", {
76
+ className: "relative",
77
+ ref: w,
78
+ children: [/* @__PURE__ */ _("div", {
79
+ ref: n,
80
+ role: "tablist",
81
+ "data-testid": "spectral-tabs-list",
82
+ "aria-orientation": v,
83
+ "aria-disabled": b,
84
+ className: e("tabs-list flex", v === "horizontal" && "items-center justify-between", v === "vertical" && "flex-col", o),
85
+ onKeyDown: O,
86
+ ...f,
87
+ children: [/* @__PURE__ */ g("div", {
88
+ className: e("flex", v === "horizontal" && "items-center", v === "vertical" && "flex-col"),
89
+ children: r
90
+ }), u && /* @__PURE__ */ g("div", {
91
+ className: "z-10 flex items-center",
92
+ children: u
93
+ })]
94
+ }), S && /* @__PURE__ */ g(t.div, {
95
+ className: e("top-0 left-0 pointer-events-none absolute will-change-transform select-none", S.orientation === "horizontal" && !S.isEnclosed && "after:bottom-0 after:left-0 bottom-px z-10 after:absolute after:w-full after:rounded-t-[0.3rem] after:border-b-[0.3rem] after:border-tabs-indicator after:content-['']", S.orientation === "vertical" && !S.isEnclosed && "after:right-0 after:top-0 after:w-1 right-px z-10 after:absolute after:h-full after:rounded-l-[0.3rem] after:border-r-[0.3rem] after:border-tabs-indicator after:content-['']", S.orientation === "horizontal" && S.isEnclosed && "rounded-lg shadow-lg z-0 bg-tabs-enclosed-indicator", S.orientation === "vertical" && S.isEnclosed && "rounded-lg shadow-lg z-0 bg-tabs-enclosed-indicator"),
96
+ initial: !1,
97
+ animate: {
98
+ x: S.left,
99
+ y: S.isEnclosed ? S.top + S.height * .1 : S.top,
100
+ width: S.width,
101
+ height: S.isEnclosed ? S.orientation === "vertical" ? 40 : S.height * .8 : S.height
102
+ },
103
+ transition: T ? { duration: 0 } : {
104
+ x: {
105
+ type: "spring",
106
+ stiffness: 500,
107
+ damping: 40,
108
+ mass: 1
109
+ },
110
+ y: {
111
+ type: "spring",
112
+ stiffness: 500,
113
+ damping: 40,
114
+ mass: 1
115
+ },
116
+ width: {
117
+ type: "spring",
118
+ stiffness: 500,
119
+ damping: 40,
120
+ mass: 1
121
+ },
122
+ height: {
123
+ type: "spring",
124
+ stiffness: 500,
125
+ damping: 40,
126
+ mass: 1
127
+ }
128
+ },
129
+ "aria-hidden": "true"
130
+ })]
131
+ });
132
+ }, S = function({ ref: t, className: n, value: r, onClick: i, onKeyDown: a, disabled: o = !1, ...s }) {
133
+ let { value: c, onValueChange: u, activationMode: d, disabled: f, baseId: p } = y("TabsTrigger"), m = `${p}-trigger-${r}`, h = `${p}-content-${r}`, _ = c === r, v = f || o, b = l((e) => {
134
+ if (v) {
135
+ e.preventDefault();
136
+ return;
137
+ }
138
+ u(r), i?.(e);
139
+ }, [
140
+ r,
141
+ u,
142
+ i,
143
+ v
144
+ ]), x = l((e) => {
145
+ if (v) {
146
+ e.preventDefault();
147
+ return;
148
+ }
149
+ let { key: t } = e;
150
+ (t === "Enter" || t === " ") && (e.preventDefault(), e.stopPropagation(), u(r)), a?.(e);
151
+ }, [
152
+ r,
153
+ u,
154
+ a,
155
+ v
156
+ ]), S = l(() => {
157
+ v || d === "automatic" && u(r);
158
+ }, [
159
+ d,
160
+ u,
161
+ r,
162
+ v
163
+ ]);
164
+ return /* @__PURE__ */ g("button", {
165
+ "aria-controls": h,
166
+ "aria-disabled": v,
167
+ "aria-selected": _,
168
+ className: e("tabs-trigger z-10 hover:cursor-pointer focus:outline-none focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-accent", n),
169
+ "data-disabled": v ? "" : void 0,
170
+ "data-state": _ ? "active" : "inactive",
171
+ "data-testid": "spectral-tabs-trigger",
172
+ disabled: v,
173
+ id: m,
174
+ onClick: b,
175
+ onFocus: S,
176
+ onKeyDown: x,
177
+ ref: t,
178
+ role: "tab",
179
+ tabIndex: _ ? 0 : -1,
180
+ type: "button",
181
+ ...s
182
+ });
183
+ }, C = function({ ref: i, children: a, className: o }) {
184
+ let { value: c } = y("TabsContentContainer"), [l, u] = r(), d = s();
185
+ return /* @__PURE__ */ g(t.div, {
186
+ ref: i,
187
+ className: e("overflow-hidden", o),
188
+ "data-testid": "spectral-tabs-content-container",
189
+ animate: { height: u.height || "auto" },
190
+ transition: d ? { duration: 0 } : {
191
+ duration: .3,
192
+ ease: [
193
+ .25,
194
+ 1,
195
+ .5,
196
+ 1
197
+ ]
198
+ },
199
+ children: /* @__PURE__ */ g(n, {
200
+ mode: "wait",
201
+ initial: !1,
202
+ children: /* @__PURE__ */ g(t.div, {
203
+ ref: l,
204
+ initial: d ? !1 : {
205
+ opacity: 0,
206
+ y: 8
207
+ },
208
+ animate: {
209
+ opacity: 1,
210
+ y: 0
211
+ },
212
+ exit: d ? void 0 : {
213
+ opacity: 0,
214
+ y: -8
215
+ },
216
+ transition: d ? { duration: 0 } : {
217
+ duration: .2,
218
+ ease: [
219
+ .25,
220
+ 1,
221
+ .5,
222
+ 1
223
+ ]
224
+ },
225
+ children: a
226
+ }, c)
227
+ })
228
+ });
229
+ }, w = function({ ref: t, className: n, value: r, forceMount: i = !1, ...a }) {
230
+ let { value: o, baseId: s } = y("TabsContent"), c = `${s}-content-${r}`, l = `${s}-trigger-${r}`, u = o === r;
231
+ return !i && !u ? null : /* @__PURE__ */ g("div", {
232
+ "aria-labelledby": l,
233
+ className: e("tabs-content focus:outline-none focus-visible:outline-none", n),
234
+ "data-state": u ? "active" : "inactive",
235
+ "data-testid": "spectral-tabs-content",
236
+ hidden: !u,
237
+ id: c,
238
+ ref: t,
239
+ role: "tabpanel",
240
+ tabIndex: 0,
241
+ ...a
242
+ });
253
243
  };
244
+ //#endregion
245
+ export { b as TabsBase, w as TabsContent, C as TabsContentContainer, v as TabsContext, x as TabsList, S as TabsTrigger, y as useTabsContext };