@epilot/volt-ui 1.1.2-alpha.4 → 1.1.2-alpha.6

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 (213) hide show
  1. package/dist/components/button/button.d.ts +2 -2
  2. package/dist/index.cjs.js +1 -51
  3. package/dist/index.cjs10.js +1 -0
  4. package/dist/index.cjs100.js +1 -0
  5. package/dist/index.cjs101.js +1 -0
  6. package/dist/index.cjs102.js +1 -0
  7. package/dist/index.cjs103.js +1 -0
  8. package/dist/index.cjs104.js +1 -0
  9. package/dist/index.cjs105.js +1 -0
  10. package/dist/index.cjs106.js +1 -0
  11. package/dist/index.cjs107.js +1 -0
  12. package/dist/index.cjs11.js +1 -0
  13. package/dist/index.cjs12.js +1 -0
  14. package/dist/index.cjs13.js +1 -0
  15. package/dist/index.cjs14.js +1 -0
  16. package/dist/index.cjs15.js +1 -0
  17. package/dist/index.cjs16.js +1 -0
  18. package/dist/index.cjs17.js +1 -0
  19. package/dist/index.cjs18.js +1 -0
  20. package/dist/index.cjs19.js +1 -0
  21. package/dist/index.cjs20.js +1 -0
  22. package/dist/index.cjs21.js +1 -0
  23. package/dist/index.cjs22.js +1 -0
  24. package/dist/index.cjs23.js +1 -0
  25. package/dist/index.cjs24.js +1 -0
  26. package/dist/index.cjs25.js +1 -0
  27. package/dist/index.cjs26.js +1 -0
  28. package/dist/index.cjs27.js +1 -0
  29. package/dist/index.cjs28.js +1 -0
  30. package/dist/index.cjs29.js +1 -0
  31. package/dist/index.cjs30.js +1 -0
  32. package/dist/index.cjs31.js +1 -0
  33. package/dist/index.cjs32.js +1 -0
  34. package/dist/index.cjs33.js +1 -0
  35. package/dist/index.cjs34.js +1 -0
  36. package/dist/index.cjs35.js +1 -0
  37. package/dist/index.cjs36.js +1 -0
  38. package/dist/index.cjs37.js +1 -0
  39. package/dist/index.cjs38.js +1 -0
  40. package/dist/index.cjs39.js +1 -0
  41. package/dist/index.cjs4.js +1 -0
  42. package/dist/index.cjs40.js +1 -0
  43. package/dist/index.cjs41.js +5 -0
  44. package/dist/index.cjs42.js +1 -0
  45. package/dist/index.cjs43.js +1 -0
  46. package/dist/index.cjs44.js +1 -0
  47. package/dist/index.cjs45.js +7 -0
  48. package/dist/index.cjs46.js +1 -0
  49. package/dist/index.cjs47.js +1 -0
  50. package/dist/index.cjs48.js +1 -0
  51. package/dist/index.cjs49.js +1 -0
  52. package/dist/index.cjs5.js +1 -0
  53. package/dist/index.cjs50.js +1 -0
  54. package/dist/index.cjs51.js +1 -0
  55. package/dist/index.cjs52.js +1 -0
  56. package/dist/index.cjs53.js +1 -0
  57. package/dist/index.cjs54.js +1 -0
  58. package/dist/index.cjs55.js +1 -0
  59. package/dist/index.cjs56.js +1 -0
  60. package/dist/index.cjs57.js +1 -0
  61. package/dist/index.cjs58.js +1 -0
  62. package/dist/index.cjs59.js +1 -0
  63. package/dist/index.cjs6.js +1 -0
  64. package/dist/index.cjs60.js +1 -0
  65. package/dist/index.cjs61.js +1 -0
  66. package/dist/index.cjs62.js +1 -0
  67. package/dist/index.cjs63.js +1 -0
  68. package/dist/index.cjs64.js +1 -0
  69. package/dist/index.cjs65.js +1 -0
  70. package/dist/index.cjs66.js +1 -0
  71. package/dist/index.cjs67.js +1 -0
  72. package/dist/index.cjs68.js +1 -0
  73. package/dist/index.cjs69.js +1 -0
  74. package/dist/index.cjs7.js +1 -0
  75. package/dist/index.cjs70.js +1 -0
  76. package/dist/index.cjs71.js +1 -0
  77. package/dist/index.cjs72.js +1 -0
  78. package/dist/index.cjs73.js +1 -0
  79. package/dist/index.cjs74.js +1 -0
  80. package/dist/index.cjs75.js +1 -0
  81. package/dist/index.cjs76.js +1 -0
  82. package/dist/index.cjs77.js +1 -0
  83. package/dist/index.cjs78.js +1 -0
  84. package/dist/index.cjs79.js +1 -0
  85. package/dist/index.cjs8.js +1 -0
  86. package/dist/index.cjs80.js +1 -0
  87. package/dist/index.cjs81.js +1 -0
  88. package/dist/index.cjs82.js +1 -0
  89. package/dist/index.cjs83.js +1 -0
  90. package/dist/index.cjs84.js +1 -0
  91. package/dist/index.cjs85.js +1 -0
  92. package/dist/index.cjs86.js +1 -0
  93. package/dist/index.cjs87.js +1 -0
  94. package/dist/index.cjs88.js +1 -0
  95. package/dist/index.cjs89.js +1 -0
  96. package/dist/index.cjs9.js +1 -0
  97. package/dist/index.cjs90.js +1 -0
  98. package/dist/index.cjs91.js +1 -0
  99. package/dist/index.cjs92.js +4 -0
  100. package/dist/index.cjs93.js +1 -0
  101. package/dist/index.cjs94.js +1 -0
  102. package/dist/index.cjs95.js +1 -0
  103. package/dist/index.cjs96.js +1 -0
  104. package/dist/index.cjs97.js +1 -0
  105. package/dist/index.cjs98.js +38 -0
  106. package/dist/index.cjs99.js +1 -0
  107. package/dist/index.es.js +133 -11724
  108. package/dist/index.es10.js +29 -0
  109. package/dist/index.es100.js +16 -0
  110. package/dist/index.es101.js +68 -0
  111. package/dist/index.es102.js +6 -0
  112. package/dist/index.es103.js +25 -0
  113. package/dist/index.es104.js +25 -0
  114. package/dist/index.es105.js +15 -0
  115. package/dist/index.es106.js +30 -0
  116. package/dist/index.es107.js +7 -0
  117. package/dist/index.es11.js +250 -0
  118. package/dist/index.es12.js +230 -0
  119. package/dist/index.es13.js +34 -0
  120. package/dist/index.es14.js +43 -0
  121. package/dist/index.es15.js +43 -0
  122. package/dist/index.es16.js +115 -0
  123. package/dist/index.es17.js +24 -0
  124. package/dist/index.es18.js +36 -0
  125. package/dist/index.es19.js +137 -0
  126. package/dist/index.es20.js +50 -0
  127. package/dist/index.es21.js +54 -0
  128. package/dist/index.es22.js +74 -0
  129. package/dist/index.es23.js +172 -0
  130. package/dist/index.es24.js +89 -0
  131. package/dist/index.es25.js +113 -0
  132. package/dist/index.es26.js +85 -0
  133. package/dist/index.es27.js +61 -0
  134. package/dist/index.es28.js +73 -0
  135. package/dist/index.es29.js +746 -0
  136. package/dist/index.es30.js +17 -0
  137. package/dist/index.es31.js +2763 -0
  138. package/dist/index.es32.js +62 -0
  139. package/dist/index.es33.js +35 -0
  140. package/dist/index.es34.js +126 -0
  141. package/dist/index.es35.js +862 -0
  142. package/dist/index.es36.js +20 -0
  143. package/dist/index.es37.js +331 -0
  144. package/dist/index.es38.js +132 -0
  145. package/dist/index.es39.js +24 -0
  146. package/dist/index.es4.js +6 -0
  147. package/dist/index.es40.js +243 -0
  148. package/dist/index.es41.js +262 -0
  149. package/dist/index.es42.js +251 -0
  150. package/dist/index.es43.js +238 -0
  151. package/dist/index.es44.js +239 -0
  152. package/dist/index.es45.js +127 -0
  153. package/dist/index.es46.js +163 -0
  154. package/dist/index.es47.js +29 -0
  155. package/dist/index.es48.js +32 -0
  156. package/dist/index.es49.js +9 -0
  157. package/dist/index.es5.js +52 -0
  158. package/dist/index.es50.js +70 -0
  159. package/dist/index.es51.js +54 -0
  160. package/dist/index.es52.js +8 -0
  161. package/dist/index.es53.js +27 -0
  162. package/dist/index.es54.js +36 -0
  163. package/dist/index.es55.js +183 -0
  164. package/dist/index.es56.js +10 -0
  165. package/dist/index.es57.js +71 -0
  166. package/dist/index.es58.js +6 -0
  167. package/dist/index.es59.js +48 -0
  168. package/dist/index.es6.js +66 -0
  169. package/dist/index.es60.js +127 -0
  170. package/dist/index.es61.js +17 -0
  171. package/dist/index.es62.js +137 -0
  172. package/dist/index.es63.js +13 -0
  173. package/dist/index.es64.js +221 -0
  174. package/dist/index.es65.js +16 -0
  175. package/dist/index.es66.js +50 -0
  176. package/dist/index.es67.js +13 -0
  177. package/dist/index.es68.js +6 -0
  178. package/dist/index.es69.js +32 -0
  179. package/dist/index.es7.js +167 -0
  180. package/dist/index.es70.js +52 -0
  181. package/dist/index.es71.js +11 -0
  182. package/dist/index.es72.js +32 -0
  183. package/dist/index.es73.js +11 -0
  184. package/dist/index.es74.js +50 -0
  185. package/dist/index.es75.js +50 -0
  186. package/dist/index.es76.js +11 -0
  187. package/dist/index.es77.js +120 -0
  188. package/dist/index.es78.js +312 -0
  189. package/dist/index.es79.js +50 -0
  190. package/dist/index.es8.js +39 -0
  191. package/dist/index.es80.js +14 -0
  192. package/dist/index.es81.js +208 -0
  193. package/dist/index.es82.js +24 -0
  194. package/dist/index.es83.js +402 -0
  195. package/dist/index.es84.js +17 -0
  196. package/dist/index.es85.js +32 -0
  197. package/dist/index.es86.js +27 -0
  198. package/dist/index.es87.js +31 -0
  199. package/dist/index.es88.js +7 -0
  200. package/dist/index.es89.js +7 -0
  201. package/dist/index.es9.js +33 -0
  202. package/dist/index.es90.js +5 -0
  203. package/dist/index.es91.js +26 -0
  204. package/dist/index.es92.js +112 -0
  205. package/dist/index.es93.js +18 -0
  206. package/dist/index.es94.js +527 -0
  207. package/dist/index.es95.js +130 -0
  208. package/dist/index.es96.js +136 -0
  209. package/dist/index.es97.js +67 -0
  210. package/dist/index.es98.js +71 -0
  211. package/dist/index.es99.js +11 -0
  212. package/dist/style.css +1 -7320
  213. package/package.json +1 -1
@@ -0,0 +1,70 @@
1
+ import * as u from "react";
2
+ import { jsx as h } from "react/jsx-runtime";
3
+ function w(e, c) {
4
+ const o = u.createContext(c), a = (r) => {
5
+ const { children: t, ...n } = r, s = u.useMemo(() => n, Object.values(n));
6
+ return /* @__PURE__ */ h(o.Provider, { value: s, children: t });
7
+ };
8
+ a.displayName = e + "Provider";
9
+ function i(r) {
10
+ const t = u.useContext(o);
11
+ if (t) return t;
12
+ if (c !== void 0) return c;
13
+ throw new Error(`\`${r}\` must be used within \`${e}\``);
14
+ }
15
+ return [a, i];
16
+ }
17
+ function _(e, c = []) {
18
+ let o = [];
19
+ function a(r, t) {
20
+ const n = u.createContext(t), s = o.length;
21
+ o = [...o, t];
22
+ const p = (d) => {
23
+ var S;
24
+ const { scope: x, children: C, ...m } = d, v = ((S = x == null ? void 0 : x[e]) == null ? void 0 : S[s]) || n, P = u.useMemo(() => m, Object.values(m));
25
+ return /* @__PURE__ */ h(v.Provider, { value: P, children: C });
26
+ };
27
+ p.displayName = r + "Provider";
28
+ function f(d, x) {
29
+ var v;
30
+ const C = ((v = x == null ? void 0 : x[e]) == null ? void 0 : v[s]) || n, m = u.useContext(C);
31
+ if (m) return m;
32
+ if (t !== void 0) return t;
33
+ throw new Error(`\`${d}\` must be used within \`${r}\``);
34
+ }
35
+ return [p, f];
36
+ }
37
+ const i = () => {
38
+ const r = o.map((t) => u.createContext(t));
39
+ return function(n) {
40
+ const s = (n == null ? void 0 : n[e]) || r;
41
+ return u.useMemo(
42
+ () => ({ [`__scope${e}`]: { ...n, [e]: s } }),
43
+ [n, s]
44
+ );
45
+ };
46
+ };
47
+ return i.scopeName = e, [a, l(i, ...c)];
48
+ }
49
+ function l(...e) {
50
+ const c = e[0];
51
+ if (e.length === 1) return c;
52
+ const o = () => {
53
+ const a = e.map((i) => ({
54
+ useScope: i(),
55
+ scopeName: i.scopeName
56
+ }));
57
+ return function(r) {
58
+ const t = a.reduce((n, { useScope: s, scopeName: p }) => {
59
+ const d = s(r)[`__scope${p}`];
60
+ return { ...n, ...d };
61
+ }, {});
62
+ return u.useMemo(() => ({ [`__scope${c.scopeName}`]: t }), [t]);
63
+ };
64
+ };
65
+ return o.scopeName = c.scopeName, o;
66
+ }
67
+ export {
68
+ w as createContext,
69
+ _ as createContextScope
70
+ };
@@ -0,0 +1,54 @@
1
+ import * as n from "react";
2
+ import { useLayoutEffect as v } from "./index.es68.js";
3
+ var E = n[" useInsertionEffect ".trim().toString()] || v;
4
+ function y({
5
+ prop: t,
6
+ defaultProp: u,
7
+ onChange: o = () => {
8
+ },
9
+ caller: i
10
+ }) {
11
+ const [l, e, r] = w({
12
+ defaultProp: u,
13
+ onChange: o
14
+ }), c = t !== void 0, a = c ? t : l;
15
+ {
16
+ const s = n.useRef(t !== void 0);
17
+ n.useEffect(() => {
18
+ const f = s.current;
19
+ f !== c && console.warn(
20
+ `${i} is changing from ${f ? "controlled" : "uncontrolled"} to ${c ? "controlled" : "uncontrolled"}. Components should not switch from controlled to uncontrolled (or vice versa). Decide between using a controlled or uncontrolled value for the lifetime of the component.`
21
+ ), s.current = c;
22
+ }, [c, i]);
23
+ }
24
+ const m = n.useCallback(
25
+ (s) => {
26
+ var f;
27
+ if (c) {
28
+ const d = R(s) ? s(t) : s;
29
+ d !== t && ((f = r.current) == null || f.call(r, d));
30
+ } else
31
+ e(s);
32
+ },
33
+ [c, t, e, r]
34
+ );
35
+ return [a, m];
36
+ }
37
+ function w({
38
+ defaultProp: t,
39
+ onChange: u
40
+ }) {
41
+ const [o, i] = n.useState(t), l = n.useRef(o), e = n.useRef(u);
42
+ return E(() => {
43
+ e.current = u;
44
+ }, [u]), n.useEffect(() => {
45
+ var r;
46
+ l.current !== o && ((r = e.current) == null || r.call(e, o), l.current = o);
47
+ }, [o, l]), [o, i, e];
48
+ }
49
+ function R(t) {
50
+ return typeof t == "function";
51
+ }
52
+ export {
53
+ y as useControllableState
54
+ };
@@ -0,0 +1,8 @@
1
+ import * as u from "react";
2
+ function t(r) {
3
+ const e = u.useRef({ value: r, previous: r });
4
+ return u.useMemo(() => (e.current.value !== r && (e.current.previous = e.current.value, e.current.value = r), e.current.previous), [r]);
5
+ }
6
+ export {
7
+ t as usePrevious
8
+ };
@@ -0,0 +1,27 @@
1
+ import * as h from "react";
2
+ import { useLayoutEffect as z } from "./index.es68.js";
3
+ function c(r) {
4
+ const [d, e] = h.useState(void 0);
5
+ return z(() => {
6
+ if (r) {
7
+ e({ width: r.offsetWidth, height: r.offsetHeight });
8
+ const f = new ResizeObserver((i) => {
9
+ if (!Array.isArray(i) || !i.length)
10
+ return;
11
+ const b = i[0];
12
+ let o, t;
13
+ if ("borderBoxSize" in b) {
14
+ const s = b.borderBoxSize, u = Array.isArray(s) ? s[0] : s;
15
+ o = u.inlineSize, t = u.blockSize;
16
+ } else
17
+ o = r.offsetWidth, t = r.offsetHeight;
18
+ e({ width: o, height: t });
19
+ });
20
+ return f.observe(r, { box: "border-box" }), () => f.unobserve(r);
21
+ } else
22
+ e(void 0);
23
+ }, [r]), d;
24
+ }
25
+ export {
26
+ c as useSize
27
+ };
@@ -0,0 +1,36 @@
1
+ import * as f from "react";
2
+ import * as p from "react-dom";
3
+ import { createSlot as c } from "./index.es79.js";
4
+ import { jsx as l } from "react/jsx-runtime";
5
+ var u = [
6
+ "a",
7
+ "button",
8
+ "div",
9
+ "form",
10
+ "h2",
11
+ "h3",
12
+ "img",
13
+ "input",
14
+ "label",
15
+ "li",
16
+ "nav",
17
+ "ol",
18
+ "p",
19
+ "select",
20
+ "span",
21
+ "svg",
22
+ "ul"
23
+ ], h = u.reduce((t, i) => {
24
+ const o = c(`Primitive.${i}`), r = f.forwardRef((e, m) => {
25
+ const { asChild: s, ...a } = e, n = s ? o : i;
26
+ return typeof window < "u" && (window[Symbol.for("radix-ui")] = !0), /* @__PURE__ */ l(n, { ...a, ref: m });
27
+ });
28
+ return r.displayName = `Primitive.${i}`, { ...t, [i]: r };
29
+ }, {});
30
+ function w(t, i) {
31
+ t && p.flushSync(() => t.dispatchEvent(i));
32
+ }
33
+ export {
34
+ h as Primitive,
35
+ w as dispatchDiscreteCustomEvent
36
+ };
@@ -0,0 +1,183 @@
1
+ import * as c from "react";
2
+ import { composeEventHandlers as p } from "./index.es49.js";
3
+ import { createCollection as V } from "./index.es59.js";
4
+ import { useComposedRefs as j } from "./index.es47.js";
5
+ import { createContextScope as z } from "./index.es50.js";
6
+ import { useId as q } from "./index.es63.js";
7
+ import { Primitive as G } from "./index.es54.js";
8
+ import { useCallbackRef as J } from "./index.es67.js";
9
+ import { useControllableState as Q } from "./index.es51.js";
10
+ import { useDirection as W } from "./index.es56.js";
11
+ import { jsx as d } from "react/jsx-runtime";
12
+ var y = "rovingFocusGroup.onEntryFocus", X = { bubbles: !1, cancelable: !0 }, I = "RovingFocusGroup", [D, N, Z] = V(I), [$, Fe] = z(
13
+ I,
14
+ [Z]
15
+ ), [ee, oe] = $(I), O = c.forwardRef(
16
+ (e, r) => /* @__PURE__ */ d(D.Provider, { scope: e.__scopeRovingFocusGroup, children: /* @__PURE__ */ d(D.Slot, { scope: e.__scopeRovingFocusGroup, children: /* @__PURE__ */ d(te, { ...e, ref: r }) }) })
17
+ );
18
+ O.displayName = I;
19
+ var te = c.forwardRef((e, r) => {
20
+ const {
21
+ __scopeRovingFocusGroup: s,
22
+ orientation: o,
23
+ loop: T = !1,
24
+ dir: w,
25
+ currentTabStopId: v,
26
+ defaultCurrentTabStopId: C,
27
+ onCurrentTabStopIdChange: S,
28
+ onEntryFocus: m,
29
+ preventScrollOnEntryFocus: u = !1,
30
+ ...b
31
+ } = e, F = c.useRef(null), g = j(r, F), R = W(w), [E, t] = Q({
32
+ prop: v,
33
+ defaultProp: C ?? null,
34
+ onChange: S,
35
+ caller: I
36
+ }), [i, h] = c.useState(!1), a = J(m), l = N(s), A = c.useRef(!1), [L, P] = c.useState(0);
37
+ return c.useEffect(() => {
38
+ const n = F.current;
39
+ if (n)
40
+ return n.addEventListener(y, a), () => n.removeEventListener(y, a);
41
+ }, [a]), /* @__PURE__ */ d(
42
+ ee,
43
+ {
44
+ scope: s,
45
+ orientation: o,
46
+ dir: R,
47
+ loop: T,
48
+ currentTabStopId: E,
49
+ onItemFocus: c.useCallback(
50
+ (n) => t(n),
51
+ [t]
52
+ ),
53
+ onItemShiftTab: c.useCallback(() => h(!0), []),
54
+ onFocusableItemAdd: c.useCallback(
55
+ () => P((n) => n + 1),
56
+ []
57
+ ),
58
+ onFocusableItemRemove: c.useCallback(
59
+ () => P((n) => n - 1),
60
+ []
61
+ ),
62
+ children: /* @__PURE__ */ d(
63
+ G.div,
64
+ {
65
+ tabIndex: i || L === 0 ? -1 : 0,
66
+ "data-orientation": o,
67
+ ...b,
68
+ ref: g,
69
+ style: { outline: "none", ...e.style },
70
+ onMouseDown: p(e.onMouseDown, () => {
71
+ A.current = !0;
72
+ }),
73
+ onFocus: p(e.onFocus, (n) => {
74
+ const U = !A.current;
75
+ if (n.target === n.currentTarget && U && !i) {
76
+ const x = new CustomEvent(y, X);
77
+ if (n.currentTarget.dispatchEvent(x), !x.defaultPrevented) {
78
+ const _ = l().filter((f) => f.focusable), B = _.find((f) => f.active), Y = _.find((f) => f.id === E), H = [B, Y, ..._].filter(
79
+ Boolean
80
+ ).map((f) => f.ref.current);
81
+ k(H, u);
82
+ }
83
+ }
84
+ A.current = !1;
85
+ }),
86
+ onBlur: p(e.onBlur, () => h(!1))
87
+ }
88
+ )
89
+ }
90
+ );
91
+ }), K = "RovingFocusGroupItem", M = c.forwardRef(
92
+ (e, r) => {
93
+ const {
94
+ __scopeRovingFocusGroup: s,
95
+ focusable: o = !0,
96
+ active: T = !1,
97
+ tabStopId: w,
98
+ children: v,
99
+ ...C
100
+ } = e, S = q(), m = w || S, u = oe(K, s), b = u.currentTabStopId === m, F = N(s), { onFocusableItemAdd: g, onFocusableItemRemove: R, currentTabStopId: E } = u;
101
+ return c.useEffect(() => {
102
+ if (o)
103
+ return g(), () => R();
104
+ }, [o, g, R]), /* @__PURE__ */ d(
105
+ D.ItemSlot,
106
+ {
107
+ scope: s,
108
+ id: m,
109
+ focusable: o,
110
+ active: T,
111
+ children: /* @__PURE__ */ d(
112
+ G.span,
113
+ {
114
+ tabIndex: b ? 0 : -1,
115
+ "data-orientation": u.orientation,
116
+ ...C,
117
+ ref: r,
118
+ onMouseDown: p(e.onMouseDown, (t) => {
119
+ o ? u.onItemFocus(m) : t.preventDefault();
120
+ }),
121
+ onFocus: p(e.onFocus, () => u.onItemFocus(m)),
122
+ onKeyDown: p(e.onKeyDown, (t) => {
123
+ if (t.key === "Tab" && t.shiftKey) {
124
+ u.onItemShiftTab();
125
+ return;
126
+ }
127
+ if (t.target !== t.currentTarget) return;
128
+ const i = ce(t, u.orientation, u.dir);
129
+ if (i !== void 0) {
130
+ if (t.metaKey || t.ctrlKey || t.altKey || t.shiftKey) return;
131
+ t.preventDefault();
132
+ let a = F().filter((l) => l.focusable).map((l) => l.ref.current);
133
+ if (i === "last") a.reverse();
134
+ else if (i === "prev" || i === "next") {
135
+ i === "prev" && a.reverse();
136
+ const l = a.indexOf(t.currentTarget);
137
+ a = u.loop ? se(a, l + 1) : a.slice(l + 1);
138
+ }
139
+ setTimeout(() => k(a));
140
+ }
141
+ }),
142
+ children: typeof v == "function" ? v({ isCurrentTabStop: b, hasTabStop: E != null }) : v
143
+ }
144
+ )
145
+ }
146
+ );
147
+ }
148
+ );
149
+ M.displayName = K;
150
+ var re = {
151
+ ArrowLeft: "prev",
152
+ ArrowUp: "prev",
153
+ ArrowRight: "next",
154
+ ArrowDown: "next",
155
+ PageUp: "first",
156
+ Home: "first",
157
+ PageDown: "last",
158
+ End: "last"
159
+ };
160
+ function ne(e, r) {
161
+ return r !== "rtl" ? e : e === "ArrowLeft" ? "ArrowRight" : e === "ArrowRight" ? "ArrowLeft" : e;
162
+ }
163
+ function ce(e, r, s) {
164
+ const o = ne(e.key, s);
165
+ if (!(r === "vertical" && ["ArrowLeft", "ArrowRight"].includes(o)) && !(r === "horizontal" && ["ArrowUp", "ArrowDown"].includes(o)))
166
+ return re[o];
167
+ }
168
+ function k(e, r = !1) {
169
+ const s = document.activeElement;
170
+ for (const o of e)
171
+ if (o === s || (o.focus({ preventScroll: r }), document.activeElement !== s)) return;
172
+ }
173
+ function se(e, r) {
174
+ return e.map((s, o) => e[(r + o) % e.length]);
175
+ }
176
+ var ge = O, Re = M;
177
+ export {
178
+ Re as Item,
179
+ ge as Root,
180
+ O as RovingFocusGroup,
181
+ M as RovingFocusGroupItem,
182
+ Fe as createRovingFocusGroupScope
183
+ };
@@ -0,0 +1,10 @@
1
+ import * as t from "react";
2
+ import "react/jsx-runtime";
3
+ var r = t.createContext(void 0);
4
+ function n(o) {
5
+ const e = t.useContext(r);
6
+ return o || e || "ltr";
7
+ }
8
+ export {
9
+ n as useDirection
10
+ };
@@ -0,0 +1,71 @@
1
+ import * as a from "react";
2
+ import { useComposedRefs as E } from "./index.es47.js";
3
+ import { useLayoutEffect as A } from "./index.es68.js";
4
+ function T(n, e) {
5
+ return a.useReducer((r, t) => e[r][t] ?? r, n);
6
+ }
7
+ var R = (n) => {
8
+ const { present: e, children: r } = n, t = v(e), i = typeof r == "function" ? r({ present: t.isPresent }) : a.Children.only(r), c = E(t.ref, P(i));
9
+ return typeof r == "function" || t.isPresent ? a.cloneElement(i, { ref: c }) : null;
10
+ };
11
+ R.displayName = "Presence";
12
+ function v(n) {
13
+ const [e, r] = a.useState(), t = a.useRef(null), i = a.useRef(n), c = a.useRef("none"), p = n ? "mounted" : "unmounted", [N, s] = T(p, {
14
+ mounted: {
15
+ UNMOUNT: "unmounted",
16
+ ANIMATION_OUT: "unmountSuspended"
17
+ },
18
+ unmountSuspended: {
19
+ MOUNT: "mounted",
20
+ ANIMATION_END: "unmounted"
21
+ },
22
+ unmounted: {
23
+ MOUNT: "mounted"
24
+ }
25
+ });
26
+ return a.useEffect(() => {
27
+ const o = l(t.current);
28
+ c.current = N === "mounted" ? o : "none";
29
+ }, [N]), A(() => {
30
+ const o = t.current, m = i.current;
31
+ if (m !== n) {
32
+ const f = c.current, u = l(o);
33
+ n ? s("MOUNT") : u === "none" || (o == null ? void 0 : o.display) === "none" ? s("UNMOUNT") : s(m && f !== u ? "ANIMATION_OUT" : "UNMOUNT"), i.current = n;
34
+ }
35
+ }, [n, s]), A(() => {
36
+ if (e) {
37
+ let o;
38
+ const m = e.ownerDocument.defaultView ?? window, d = (u) => {
39
+ const g = l(t.current).includes(CSS.escape(u.animationName));
40
+ if (u.target === e && g && (s("ANIMATION_END"), !i.current)) {
41
+ const O = e.style.animationFillMode;
42
+ e.style.animationFillMode = "forwards", o = m.setTimeout(() => {
43
+ e.style.animationFillMode === "forwards" && (e.style.animationFillMode = O);
44
+ });
45
+ }
46
+ }, f = (u) => {
47
+ u.target === e && (c.current = l(t.current));
48
+ };
49
+ return e.addEventListener("animationstart", f), e.addEventListener("animationcancel", d), e.addEventListener("animationend", d), () => {
50
+ m.clearTimeout(o), e.removeEventListener("animationstart", f), e.removeEventListener("animationcancel", d), e.removeEventListener("animationend", d);
51
+ };
52
+ } else
53
+ s("ANIMATION_END");
54
+ }, [e, s]), {
55
+ isPresent: ["mounted", "unmountSuspended"].includes(N),
56
+ ref: a.useCallback((o) => {
57
+ t.current = o ? getComputedStyle(o) : null, r(o);
58
+ }, [])
59
+ };
60
+ }
61
+ function l(n) {
62
+ return (n == null ? void 0 : n.animationName) || "none";
63
+ }
64
+ function P(n) {
65
+ var t, i;
66
+ let e = (t = Object.getOwnPropertyDescriptor(n.props, "ref")) == null ? void 0 : t.get, r = e && "isReactWarning" in e && e.isReactWarning;
67
+ return r ? n.ref : (e = (i = Object.getOwnPropertyDescriptor(n, "ref")) == null ? void 0 : i.get, r = e && "isReactWarning" in e && e.isReactWarning, r ? n.props.ref : n.props.ref || n.ref);
68
+ }
69
+ export {
70
+ R as Presence
71
+ };
@@ -0,0 +1,6 @@
1
+ function m(t, [a, n]) {
2
+ return Math.min(n, Math.max(a, t));
3
+ }
4
+ export {
5
+ m as clamp
6
+ };
@@ -0,0 +1,48 @@
1
+ import r from "react";
2
+ import { createContextScope as y } from "./index.es50.js";
3
+ import { useComposedRefs as M } from "./index.es47.js";
4
+ import { createSlot as x } from "./index.es79.js";
5
+ import { jsx as u } from "react/jsx-runtime";
6
+ function g(s) {
7
+ const m = s + "CollectionProvider", [A, N] = y(m), [_, f] = A(
8
+ m,
9
+ { collectionRef: { current: null }, itemMap: /* @__PURE__ */ new Map() }
10
+ ), p = (c) => {
11
+ const { scope: e, children: l } = c, o = r.useRef(null), t = r.useRef(/* @__PURE__ */ new Map()).current;
12
+ return /* @__PURE__ */ u(_, { scope: e, itemMap: t, collectionRef: o, children: l });
13
+ };
14
+ p.displayName = m;
15
+ const a = s + "CollectionSlot", E = x(a), C = r.forwardRef(
16
+ (c, e) => {
17
+ const { scope: l, children: o } = c, t = f(a, l), n = M(e, t.collectionRef);
18
+ return /* @__PURE__ */ u(E, { ref: n, children: o });
19
+ }
20
+ );
21
+ C.displayName = a;
22
+ const d = s + "CollectionItemSlot", R = "data-radix-collection-item", T = x(d), I = r.forwardRef(
23
+ (c, e) => {
24
+ const { scope: l, children: o, ...t } = c, n = r.useRef(null), S = M(e, n), i = f(d, l);
25
+ return r.useEffect(() => (i.itemMap.set(n, { ref: n, ...t }), () => void i.itemMap.delete(n))), /* @__PURE__ */ u(T, { [R]: "", ref: S, children: o });
26
+ }
27
+ );
28
+ I.displayName = d;
29
+ function O(c) {
30
+ const e = f(s + "CollectionConsumer", c);
31
+ return r.useCallback(() => {
32
+ const o = e.collectionRef.current;
33
+ if (!o) return [];
34
+ const t = Array.from(o.querySelectorAll(`[${R}]`));
35
+ return Array.from(e.itemMap.values()).sort(
36
+ (i, v) => t.indexOf(i.ref.current) - t.indexOf(v.ref.current)
37
+ );
38
+ }, [e.collectionRef, e.itemMap]);
39
+ }
40
+ return [
41
+ { Provider: p, Slot: C, ItemSlot: I },
42
+ O,
43
+ N
44
+ ];
45
+ }
46
+ export {
47
+ g as createCollection
48
+ };
@@ -0,0 +1,66 @@
1
+ import { jsx as l } from "react/jsx-runtime";
2
+ import { Root as n } from "./index.es32.js";
3
+ import { cva as a } from "./index.es33.js";
4
+ import { Separator as s } from "./index.es17.js";
5
+ import { cn as e } from "./index.es4.js";
6
+ const i = a(
7
+ "volt-group/button-group volt-flex volt-w-fit volt-items-stretch [&>*:focus-visible]:z-10 [&>*:focus-visible]:relative has-[>[data-slot=button-group]]:gap-2",
8
+ {
9
+ variants: {
10
+ orientation: {
11
+ horizontal: "[&>*:not(:first-child)]:rounded-l-none [&>*:not(:first-child)]:border-l-0 [&>*:not(:last-child)]:rounded-r-none",
12
+ vertical: "volt-flex-col [&>*:not(:first-child)]:rounded-t-none [&>*:not(:first-child)]:border-t-0 [&>*:not(:last-child)]:rounded-b-none"
13
+ }
14
+ },
15
+ defaultVariants: {
16
+ orientation: "horizontal"
17
+ }
18
+ }
19
+ ), f = ({
20
+ className: o,
21
+ orientation: t,
22
+ ...r
23
+ }) => /* @__PURE__ */ l(
24
+ "div",
25
+ {
26
+ role: "group",
27
+ "data-slot": "button-group",
28
+ "data-orientation": t,
29
+ className: e(i({ orientation: t }), o),
30
+ ...r
31
+ }
32
+ ), h = ({
33
+ className: o,
34
+ asChild: t = !1,
35
+ ...r
36
+ }) => /* @__PURE__ */ l(
37
+ t ? n : "div",
38
+ {
39
+ className: e(
40
+ "volt-bg-gray-a4 volt-flex volt-items-center volt-gap-2 volt-rounded-md volt-border volt-px-4 volt-py-3 volt-text-sm volt-font-medium volt-shadow-xs [&_svg]:pointer-events-none [&_svg:not([class*='volt-size-'])]:size-4",
41
+ o
42
+ ),
43
+ ...r
44
+ }
45
+ ), b = ({
46
+ className: o,
47
+ orientation: t = "vertical",
48
+ ...r
49
+ }) => /* @__PURE__ */ l(
50
+ s,
51
+ {
52
+ "data-slot": "volt-button-group-separator",
53
+ orientation: t,
54
+ className: e(
55
+ "volt-m-0 volt-relative volt-self-stretch volt-data-[orientation=vertical]:h-px",
56
+ o
57
+ ),
58
+ ...r
59
+ }
60
+ );
61
+ export {
62
+ f as ButtonGroup,
63
+ b as ButtonGroupSeparator,
64
+ h as ButtonGroupText,
65
+ i as buttonGroupVariants
66
+ };