@drjoshcsimmons/scl 0.1.10 → 0.1.11

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 (101) hide show
  1. package/dist/index100.js +47 -49
  2. package/dist/index101.js +51 -44
  3. package/dist/index102.js +30 -9
  4. package/dist/index103.js +3 -14
  5. package/dist/index104.js +3 -3
  6. package/dist/index105.js +46 -7
  7. package/dist/index107.js +7 -46
  8. package/dist/index108.js +176 -43
  9. package/dist/index109.js +47 -29
  10. package/dist/index11.js +2 -2
  11. package/dist/index110.js +30 -55
  12. package/dist/index111.js +650 -30
  13. package/dist/index112.js +30 -13
  14. package/dist/index115.js +6 -48
  15. package/dist/index116.js +1 -1
  16. package/dist/index12.js +1 -1
  17. package/dist/index124.js +48 -6
  18. package/dist/index125.js +2 -25
  19. package/dist/index126.js +53 -29
  20. package/dist/index127.js +65 -5
  21. package/dist/index128.js +25 -2
  22. package/dist/index129.js +29 -53
  23. package/dist/index13.js +2 -2
  24. package/dist/index130.js +5 -65
  25. package/dist/index131.js +2 -5
  26. package/dist/index132.js +2 -3
  27. package/dist/index133.js +5 -24
  28. package/dist/index134.js +3 -113
  29. package/dist/index135.js +23 -15
  30. package/dist/index136.js +113 -2
  31. package/dist/index137.js +16 -2
  32. package/dist/index14.js +2 -2
  33. package/dist/index141.js +1 -1
  34. package/dist/index142.js +1 -1
  35. package/dist/index15.js +2 -2
  36. package/dist/index17.js +4 -4
  37. package/dist/index18.js +2 -2
  38. package/dist/index20.js +1 -1
  39. package/dist/index21.js +1 -1
  40. package/dist/index22.js +1 -1
  41. package/dist/index23.js +2 -2
  42. package/dist/index24.js +1 -1
  43. package/dist/index25.js +3 -3
  44. package/dist/index26.js +1 -1
  45. package/dist/index27.js +2 -2
  46. package/dist/index29.js +1 -1
  47. package/dist/index31.js +1 -1
  48. package/dist/index33.js +1 -1
  49. package/dist/index36.js +1 -1
  50. package/dist/index37.js +1 -1
  51. package/dist/index45.js +1 -1
  52. package/dist/index48.js +310 -12
  53. package/dist/index49.js +5 -2
  54. package/dist/index50.js +124 -59
  55. package/dist/index51.js +62 -107
  56. package/dist/index52.js +55 -244
  57. package/dist/index53.js +256 -18
  58. package/dist/index54.js +12 -236
  59. package/dist/index55.js +249 -11
  60. package/dist/index56.js +9 -530
  61. package/dist/index57.js +102 -209
  62. package/dist/index58.js +5 -4
  63. package/dist/index59.js +31 -82
  64. package/dist/index6.js +1 -1
  65. package/dist/index60.js +71 -249
  66. package/dist/index61.js +860 -12
  67. package/dist/index62.js +9 -435
  68. package/dist/index63.js +147 -111
  69. package/dist/index64.js +333 -28
  70. package/dist/index65.js +410 -285
  71. package/dist/index66.js +241 -12
  72. package/dist/index67.js +18 -332
  73. package/dist/index68.js +219 -248
  74. package/dist/index69.js +11 -241
  75. package/dist/index7.js +1 -1
  76. package/dist/index70.js +11 -860
  77. package/dist/index71.js +130 -9
  78. package/dist/index72.js +234 -16
  79. package/dist/index73.js +509 -109
  80. package/dist/index74.js +16 -159
  81. package/dist/index75.js +247 -66
  82. package/dist/index80.js +1 -1
  83. package/dist/index82.js +1 -1
  84. package/dist/index84.js +15 -4
  85. package/dist/index85.js +51 -65
  86. package/dist/index86.js +11 -30
  87. package/dist/index87.js +4 -6
  88. package/dist/index88.js +30 -25
  89. package/dist/index89.js +10 -178
  90. package/dist/index9.js +1 -1
  91. package/dist/index90.js +8 -10
  92. package/dist/index91.js +5 -3
  93. package/dist/index92.js +24 -649
  94. package/dist/index93.js +65 -51
  95. package/dist/index94.js +124 -29
  96. package/dist/index95.js +125 -115
  97. package/dist/index96.js +13 -134
  98. package/dist/index97.js +14 -13
  99. package/dist/index98.js +8 -14
  100. package/dist/index99.js +50 -9
  101. package/package.json +1 -1
package/dist/index65.js CHANGED
@@ -1,312 +1,437 @@
1
- import { a as pe } from "./index103.js";
2
- import { Root as ge, Portal as he, Overlay as be, Content as Ee } from "./index60.js";
3
- import * as n from "react";
4
- import { Primitive as I } from "./index81.js";
5
- import { useId as K } from "./index82.js";
6
- import { composeRefs as q } from "./index78.js";
7
- var $ = '[cmdk-group=""]', X = '[cmdk-group-items=""]', ye = '[cmdk-group-heading=""]', oe = '[cmdk-item=""]', ie = `${oe}:not([aria-disabled="true"])`, Y = "cmdk-item-select", D = "data-value", Ce = (t, a, r) => pe(t, a, r), ce = n.createContext(void 0), O = () => n.useContext(ce), de = n.createContext(void 0), Z = () => n.useContext(de), se = n.createContext(void 0), fe = n.forwardRef((t, a) => {
8
- let r = F(() => {
9
- var e, u;
10
- return { search: "", value: (u = (e = t.value) != null ? e : t.defaultValue) != null ? u : "", selectedItemId: void 0, filtered: { count: 0, items: /* @__PURE__ */ new Map(), groups: /* @__PURE__ */ new Set() } };
11
- }), v = F(() => /* @__PURE__ */ new Set()), i = F(() => /* @__PURE__ */ new Map()), c = F(() => /* @__PURE__ */ new Map()), d = F(() => /* @__PURE__ */ new Set()), m = me(t), { label: b, children: s, value: h, onValueChange: R, filter: k, shouldFilter: w, loop: V, disablePointerSelection: B = !1, vimBindings: x = !0, ...j } = t, U = K(), ee = K(), W = K(), A = n.useRef(null), g = Fe();
12
- M(() => {
13
- if (h !== void 0) {
14
- let e = h.trim();
15
- r.current.value = e, y.emit();
16
- }
17
- }, [h]), M(() => {
18
- g(6, re);
19
- }, []);
20
- let y = n.useMemo(() => ({ subscribe: (e) => (d.current.add(e), () => d.current.delete(e)), snapshot: () => r.current, setState: (e, u, o) => {
21
- var l, f, p, C;
22
- if (!Object.is(r.current[e], u)) {
23
- if (r.current[e] = u, e === "search") T(), G(), g(1, H);
24
- else if (e === "value") {
25
- if (document.activeElement.hasAttribute("cmdk-input") || document.activeElement.hasAttribute("cmdk-root")) {
26
- let E = document.getElementById(W);
27
- E ? E.focus() : (l = document.getElementById(U)) == null || l.focus();
28
- }
29
- if (g(7, () => {
30
- var E;
31
- r.current.selectedItemId = (E = P()) == null ? void 0 : E.id, y.emit();
32
- }), o || g(5, re), ((f = m.current) == null ? void 0 : f.value) !== void 0) {
33
- let E = u ?? "";
34
- (C = (p = m.current).onValueChange) == null || C.call(p, E);
35
- return;
36
- }
1
+ import * as d from "react";
2
+ import { clamp as $ } from "./index103.js";
3
+ import { composeEventHandlers as C } from "./index79.js";
4
+ import { useComposedRefs as M } from "./index78.js";
5
+ import { createContextScope as ce } from "./index76.js";
6
+ import { useControllableState as le } from "./index80.js";
7
+ import { useDirection as de } from "./index83.js";
8
+ import { usePrevious as ue } from "./index91.js";
9
+ import { useSize as fe } from "./index92.js";
10
+ import { Primitive as K } from "./index81.js";
11
+ import { createCollection as me } from "./index77.js";
12
+ import { jsx as v, jsxs as pe } from "react/jsx-runtime";
13
+ var j = ["PageUp", "PageDown"], X = ["ArrowUp", "ArrowDown", "ArrowLeft", "ArrowRight"], G = {
14
+ "from-left": ["Home", "PageDown", "ArrowDown", "ArrowLeft"],
15
+ "from-right": ["Home", "PageDown", "ArrowDown", "ArrowRight"],
16
+ "from-bottom": ["Home", "PageDown", "ArrowDown", "ArrowLeft"],
17
+ "from-top": ["Home", "PageDown", "ArrowUp", "ArrowLeft"]
18
+ }, I = "Slider", [z, he, Se] = me(I), [W] = ce(I, [
19
+ Se
20
+ ]), [ge, T] = W(I), q = d.forwardRef(
21
+ (e, t) => {
22
+ const {
23
+ name: o,
24
+ min: n = 0,
25
+ max: a = 100,
26
+ step: c = 1,
27
+ orientation: r = "horizontal",
28
+ disabled: s = !1,
29
+ minStepsBetweenThumbs: l = 0,
30
+ defaultValue: h = [n],
31
+ value: S,
32
+ onValueChange: i = () => {
33
+ },
34
+ onValueCommit: u = () => {
35
+ },
36
+ inverted: w = !1,
37
+ form: P,
38
+ ...g
39
+ } = e, m = d.useRef(/* @__PURE__ */ new Set()), f = d.useRef(0), b = r === "horizontal" ? ve : we, [p = [], A] = le({
40
+ prop: S,
41
+ defaultProp: h,
42
+ onChange: (R) => {
43
+ var E;
44
+ (E = [...m.current][f.current]) == null || E.focus(), i(R);
37
45
  }
38
- y.emit();
46
+ }), k = d.useRef(p);
47
+ function H(R) {
48
+ const x = ye(p, R);
49
+ V(R, x);
39
50
  }
40
- }, emit: () => {
41
- d.current.forEach((e) => e());
42
- } }), []), _ = n.useMemo(() => ({ value: (e, u, o) => {
43
- var l;
44
- u !== ((l = c.current.get(e)) == null ? void 0 : l.value) && (c.current.set(e, { value: u, keywords: o }), r.current.filtered.items.set(e, te(u, o)), g(2, () => {
45
- G(), y.emit();
46
- }));
47
- }, item: (e, u) => (v.current.add(e), u && (i.current.has(u) ? i.current.get(u).add(e) : i.current.set(u, /* @__PURE__ */ new Set([e]))), g(3, () => {
48
- T(), G(), r.current.value || H(), y.emit();
49
- }), () => {
50
- c.current.delete(e), v.current.delete(e), r.current.filtered.items.delete(e);
51
- let o = P();
52
- g(4, () => {
53
- T(), (o == null ? void 0 : o.getAttribute("id")) === e && H(), y.emit();
54
- });
55
- }), group: (e) => (i.current.has(e) || i.current.set(e, /* @__PURE__ */ new Set()), () => {
56
- c.current.delete(e), i.current.delete(e);
57
- }), filter: () => m.current.shouldFilter, label: b || t["aria-label"], getDisablePointerSelection: () => m.current.disablePointerSelection, listId: U, inputId: W, labelId: ee, listInnerRef: A }), []);
58
- function te(e, u) {
59
- var o, l;
60
- let f = (l = (o = m.current) == null ? void 0 : o.filter) != null ? l : Ce;
61
- return e ? f(e, r.current.search, u) : 0;
62
- }
63
- function G() {
64
- if (!r.current.search || m.current.shouldFilter === !1) return;
65
- let e = r.current.filtered.items, u = [];
66
- r.current.filtered.groups.forEach((l) => {
67
- let f = i.current.get(l), p = 0;
68
- f.forEach((C) => {
69
- let E = e.get(C);
70
- p = Math.max(E, p);
71
- }), u.push([l, p]);
72
- });
73
- let o = A.current;
74
- L().sort((l, f) => {
75
- var p, C;
76
- let E = l.getAttribute("id"), N = f.getAttribute("id");
77
- return ((p = e.get(N)) != null ? p : 0) - ((C = e.get(E)) != null ? C : 0);
78
- }).forEach((l) => {
79
- let f = l.closest(X);
80
- f ? f.appendChild(l.parentElement === f ? l : l.closest(`${X} > *`)) : o.appendChild(l.parentElement === o ? l : l.closest(`${X} > *`));
81
- }), u.sort((l, f) => f[1] - l[1]).forEach((l) => {
82
- var f;
83
- let p = (f = A.current) == null ? void 0 : f.querySelector(`${$}[${D}="${encodeURIComponent(l[0])}"]`);
84
- p == null || p.parentElement.appendChild(p);
85
- });
86
- }
87
- function H() {
88
- let e = L().find((o) => o.getAttribute("aria-disabled") !== "true"), u = e == null ? void 0 : e.getAttribute(D);
89
- y.setState("value", u || void 0);
90
- }
91
- function T() {
92
- var e, u, o, l;
93
- if (!r.current.search || m.current.shouldFilter === !1) {
94
- r.current.filtered.count = v.current.size;
95
- return;
51
+ function se(R) {
52
+ V(R, f.current);
96
53
  }
97
- r.current.filtered.groups = /* @__PURE__ */ new Set();
98
- let f = 0;
99
- for (let p of v.current) {
100
- let C = (u = (e = c.current.get(p)) == null ? void 0 : e.value) != null ? u : "", E = (l = (o = c.current.get(p)) == null ? void 0 : o.keywords) != null ? l : [], N = te(C, E);
101
- r.current.filtered.items.set(p, N), N > 0 && f++;
54
+ function ae() {
55
+ const R = k.current[f.current];
56
+ p[f.current] !== R && u(p);
102
57
  }
103
- for (let [p, C] of i.current) for (let E of C) if (r.current.filtered.items.get(E) > 0) {
104
- r.current.filtered.groups.add(p);
105
- break;
58
+ function V(R, x, { commit: E } = { commit: !1 }) {
59
+ const F = Ce(c), N = Me(Math.round((R - n) / c) * c + n, F), B = $(N, [n, a]);
60
+ A((_ = []) => {
61
+ const y = Pe(_, B, x);
62
+ if (_e(y, l * c)) {
63
+ f.current = y.indexOf(B);
64
+ const Y = String(y) !== String(_);
65
+ return Y && E && u(y), Y ? y : _;
66
+ } else
67
+ return _;
68
+ });
106
69
  }
107
- r.current.filtered.count = f;
70
+ return /* @__PURE__ */ v(
71
+ ge,
72
+ {
73
+ scope: e.__scopeSlider,
74
+ name: o,
75
+ disabled: s,
76
+ min: n,
77
+ max: a,
78
+ valueIndexToChangeRef: f,
79
+ thumbs: m.current,
80
+ values: p,
81
+ orientation: r,
82
+ form: P,
83
+ children: /* @__PURE__ */ v(z.Provider, { scope: e.__scopeSlider, children: /* @__PURE__ */ v(z.Slot, { scope: e.__scopeSlider, children: /* @__PURE__ */ v(
84
+ b,
85
+ {
86
+ "aria-disabled": s,
87
+ "data-disabled": s ? "" : void 0,
88
+ ...g,
89
+ ref: t,
90
+ onPointerDown: C(g.onPointerDown, () => {
91
+ s || (k.current = p);
92
+ }),
93
+ min: n,
94
+ max: a,
95
+ inverted: w,
96
+ onSlideStart: s ? void 0 : H,
97
+ onSlideMove: s ? void 0 : se,
98
+ onSlideEnd: s ? void 0 : ae,
99
+ onHomeKeyDown: () => !s && V(n, 0, { commit: !0 }),
100
+ onEndKeyDown: () => !s && V(a, p.length - 1, { commit: !0 }),
101
+ onStepKeyDown: ({ event: R, direction: x }) => {
102
+ if (!s) {
103
+ const N = j.includes(R.key) || R.shiftKey && X.includes(R.key) ? 10 : 1, B = f.current, _ = p[B], y = c * N * x;
104
+ V(_ + y, B, { commit: !0 });
105
+ }
106
+ }
107
+ }
108
+ ) }) })
109
+ }
110
+ );
108
111
  }
109
- function re() {
110
- var e, u, o;
111
- let l = P();
112
- l && (((e = l.parentElement) == null ? void 0 : e.firstChild) === l && ((o = (u = l.closest($)) == null ? void 0 : u.querySelector(ye)) == null || o.scrollIntoView({ block: "nearest" })), l.scrollIntoView({ block: "nearest" }));
112
+ );
113
+ q.displayName = I;
114
+ var [J, Q] = W(I, {
115
+ startEdge: "left",
116
+ endEdge: "right",
117
+ size: "width",
118
+ direction: 1
119
+ }), ve = d.forwardRef(
120
+ (e, t) => {
121
+ const {
122
+ min: o,
123
+ max: n,
124
+ dir: a,
125
+ inverted: c,
126
+ onSlideStart: r,
127
+ onSlideMove: s,
128
+ onSlideEnd: l,
129
+ onStepKeyDown: h,
130
+ ...S
131
+ } = e, [i, u] = d.useState(null), w = M(t, (b) => u(b)), P = d.useRef(void 0), g = de(a), m = g === "ltr", f = m && !c || !m && c;
132
+ function D(b) {
133
+ const p = P.current || i.getBoundingClientRect(), A = [0, p.width], H = U(A, f ? [o, n] : [n, o]);
134
+ return P.current = p, H(b - p.left);
135
+ }
136
+ return /* @__PURE__ */ v(
137
+ J,
138
+ {
139
+ scope: e.__scopeSlider,
140
+ startEdge: f ? "left" : "right",
141
+ endEdge: f ? "right" : "left",
142
+ direction: f ? 1 : -1,
143
+ size: "width",
144
+ children: /* @__PURE__ */ v(
145
+ Z,
146
+ {
147
+ dir: g,
148
+ "data-orientation": "horizontal",
149
+ ...S,
150
+ ref: w,
151
+ style: {
152
+ ...S.style,
153
+ "--radix-slider-thumb-transform": "translateX(-50%)"
154
+ },
155
+ onSlideStart: (b) => {
156
+ const p = D(b.clientX);
157
+ r == null || r(p);
158
+ },
159
+ onSlideMove: (b) => {
160
+ const p = D(b.clientX);
161
+ s == null || s(p);
162
+ },
163
+ onSlideEnd: () => {
164
+ P.current = void 0, l == null || l();
165
+ },
166
+ onStepKeyDown: (b) => {
167
+ const A = G[f ? "from-left" : "from-right"].includes(b.key);
168
+ h == null || h({ event: b, direction: A ? -1 : 1 });
169
+ }
170
+ }
171
+ )
172
+ }
173
+ );
113
174
  }
114
- function P() {
115
- var e;
116
- return (e = A.current) == null ? void 0 : e.querySelector(`${oe}[aria-selected="true"]`);
175
+ ), we = d.forwardRef(
176
+ (e, t) => {
177
+ const {
178
+ min: o,
179
+ max: n,
180
+ inverted: a,
181
+ onSlideStart: c,
182
+ onSlideMove: r,
183
+ onSlideEnd: s,
184
+ onStepKeyDown: l,
185
+ ...h
186
+ } = e, S = d.useRef(null), i = M(t, S), u = d.useRef(void 0), w = !a;
187
+ function P(g) {
188
+ const m = u.current || S.current.getBoundingClientRect(), f = [0, m.height], b = U(f, w ? [n, o] : [o, n]);
189
+ return u.current = m, b(g - m.top);
190
+ }
191
+ return /* @__PURE__ */ v(
192
+ J,
193
+ {
194
+ scope: e.__scopeSlider,
195
+ startEdge: w ? "bottom" : "top",
196
+ endEdge: w ? "top" : "bottom",
197
+ size: "height",
198
+ direction: w ? 1 : -1,
199
+ children: /* @__PURE__ */ v(
200
+ Z,
201
+ {
202
+ "data-orientation": "vertical",
203
+ ...h,
204
+ ref: i,
205
+ style: {
206
+ ...h.style,
207
+ "--radix-slider-thumb-transform": "translateY(50%)"
208
+ },
209
+ onSlideStart: (g) => {
210
+ const m = P(g.clientY);
211
+ c == null || c(m);
212
+ },
213
+ onSlideMove: (g) => {
214
+ const m = P(g.clientY);
215
+ r == null || r(m);
216
+ },
217
+ onSlideEnd: () => {
218
+ u.current = void 0, s == null || s();
219
+ },
220
+ onStepKeyDown: (g) => {
221
+ const f = G[w ? "from-bottom" : "from-top"].includes(g.key);
222
+ l == null || l({ event: g, direction: f ? -1 : 1 });
223
+ }
224
+ }
225
+ )
226
+ }
227
+ );
117
228
  }
118
- function L() {
119
- var e;
120
- return Array.from(((e = A.current) == null ? void 0 : e.querySelectorAll(ie)) || []);
229
+ ), Z = d.forwardRef(
230
+ (e, t) => {
231
+ const {
232
+ __scopeSlider: o,
233
+ onSlideStart: n,
234
+ onSlideMove: a,
235
+ onSlideEnd: c,
236
+ onHomeKeyDown: r,
237
+ onEndKeyDown: s,
238
+ onStepKeyDown: l,
239
+ ...h
240
+ } = e, S = T(I, o);
241
+ return /* @__PURE__ */ v(
242
+ K.span,
243
+ {
244
+ ...h,
245
+ ref: t,
246
+ onKeyDown: C(e.onKeyDown, (i) => {
247
+ i.key === "Home" ? (r(i), i.preventDefault()) : i.key === "End" ? (s(i), i.preventDefault()) : j.concat(X).includes(i.key) && (l(i), i.preventDefault());
248
+ }),
249
+ onPointerDown: C(e.onPointerDown, (i) => {
250
+ const u = i.target;
251
+ u.setPointerCapture(i.pointerId), i.preventDefault(), S.thumbs.has(u) ? u.focus() : n(i);
252
+ }),
253
+ onPointerMove: C(e.onPointerMove, (i) => {
254
+ i.target.hasPointerCapture(i.pointerId) && a(i);
255
+ }),
256
+ onPointerUp: C(e.onPointerUp, (i) => {
257
+ const u = i.target;
258
+ u.hasPointerCapture(i.pointerId) && (u.releasePointerCapture(i.pointerId), c(i));
259
+ })
260
+ }
261
+ );
121
262
  }
122
- function J(e) {
123
- let u = L()[e];
124
- u && y.setState("value", u.getAttribute(D));
263
+ ), ee = "SliderTrack", te = d.forwardRef(
264
+ (e, t) => {
265
+ const { __scopeSlider: o, ...n } = e, a = T(ee, o);
266
+ return /* @__PURE__ */ v(
267
+ K.span,
268
+ {
269
+ "data-disabled": a.disabled ? "" : void 0,
270
+ "data-orientation": a.orientation,
271
+ ...n,
272
+ ref: t
273
+ }
274
+ );
125
275
  }
126
- function Q(e) {
127
- var u;
128
- let o = P(), l = L(), f = l.findIndex((C) => C === o), p = l[f + e];
129
- (u = m.current) != null && u.loop && (p = f + e < 0 ? l[l.length - 1] : f + e === l.length ? l[0] : l[f + e]), p && y.setState("value", p.getAttribute(D));
276
+ );
277
+ te.displayName = ee;
278
+ var L = "SliderRange", ne = d.forwardRef(
279
+ (e, t) => {
280
+ const { __scopeSlider: o, ...n } = e, a = T(L, o), c = Q(L, o), r = d.useRef(null), s = M(t, r), l = a.values.length, h = a.values.map(
281
+ (u) => ie(u, a.min, a.max)
282
+ ), S = l > 1 ? Math.min(...h) : 0, i = 100 - Math.max(...h);
283
+ return /* @__PURE__ */ v(
284
+ K.span,
285
+ {
286
+ "data-orientation": a.orientation,
287
+ "data-disabled": a.disabled ? "" : void 0,
288
+ ...n,
289
+ ref: s,
290
+ style: {
291
+ ...e.style,
292
+ [c.startEdge]: S + "%",
293
+ [c.endEdge]: i + "%"
294
+ }
295
+ }
296
+ );
130
297
  }
131
- function ne(e) {
132
- let u = P(), o = u == null ? void 0 : u.closest($), l;
133
- for (; o && !l; ) o = e > 0 ? Pe(o, $) : De(o, $), l = o == null ? void 0 : o.querySelector(ie);
134
- l ? y.setState("value", l.getAttribute(D)) : Q(e);
298
+ );
299
+ ne.displayName = L;
300
+ var O = "SliderThumb", oe = d.forwardRef(
301
+ (e, t) => {
302
+ const o = he(e.__scopeSlider), [n, a] = d.useState(null), c = M(t, (s) => a(s)), r = d.useMemo(
303
+ () => n ? o().findIndex((s) => s.ref.current === n) : -1,
304
+ [o, n]
305
+ );
306
+ return /* @__PURE__ */ v(be, { ...e, ref: c, index: r });
135
307
  }
136
- let le = () => J(L().length - 1), ae = (e) => {
137
- e.preventDefault(), e.metaKey ? le() : e.altKey ? ne(1) : Q(1);
138
- }, ue = (e) => {
139
- e.preventDefault(), e.metaKey ? J(0) : e.altKey ? ne(-1) : Q(-1);
140
- };
141
- return n.createElement(I.div, { ref: a, tabIndex: -1, ...j, "cmdk-root": "", onKeyDown: (e) => {
142
- var u;
143
- (u = j.onKeyDown) == null || u.call(j, e);
144
- let o = e.nativeEvent.isComposing || e.keyCode === 229;
145
- if (!(e.defaultPrevented || o)) switch (e.key) {
146
- case "n":
147
- case "j": {
148
- x && e.ctrlKey && ae(e);
149
- break;
308
+ ), be = d.forwardRef(
309
+ (e, t) => {
310
+ const { __scopeSlider: o, index: n, name: a, ...c } = e, r = T(O, o), s = Q(O, o), [l, h] = d.useState(null), S = M(t, (D) => h(D)), i = l ? r.form || !!l.closest("form") : !0, u = fe(l), w = r.values[n], P = w === void 0 ? 0 : ie(w, r.min, r.max), g = xe(n, r.values.length), m = u == null ? void 0 : u[s.size], f = m ? De(m, P, s.direction) : 0;
311
+ return d.useEffect(() => {
312
+ if (l)
313
+ return r.thumbs.add(l), () => {
314
+ r.thumbs.delete(l);
315
+ };
316
+ }, [l, r.thumbs]), /* @__PURE__ */ pe(
317
+ "span",
318
+ {
319
+ style: {
320
+ transform: "var(--radix-slider-thumb-transform)",
321
+ position: "absolute",
322
+ [s.startEdge]: `calc(${P}% + ${f}px)`
323
+ },
324
+ children: [
325
+ /* @__PURE__ */ v(z.ItemSlot, { scope: e.__scopeSlider, children: /* @__PURE__ */ v(
326
+ K.span,
327
+ {
328
+ role: "slider",
329
+ "aria-label": e["aria-label"] || g,
330
+ "aria-valuemin": r.min,
331
+ "aria-valuenow": w,
332
+ "aria-valuemax": r.max,
333
+ "aria-orientation": r.orientation,
334
+ "data-orientation": r.orientation,
335
+ "data-disabled": r.disabled ? "" : void 0,
336
+ tabIndex: r.disabled ? void 0 : 0,
337
+ ...c,
338
+ ref: S,
339
+ style: w === void 0 ? { display: "none" } : e.style,
340
+ onFocus: C(e.onFocus, () => {
341
+ r.valueIndexToChangeRef.current = n;
342
+ })
343
+ }
344
+ ) }),
345
+ i && /* @__PURE__ */ v(
346
+ re,
347
+ {
348
+ name: a ?? (r.name ? r.name + (r.values.length > 1 ? "[]" : "") : void 0),
349
+ form: r.form,
350
+ value: w
351
+ },
352
+ n
353
+ )
354
+ ]
150
355
  }
151
- case "ArrowDown": {
152
- ae(e);
153
- break;
154
- }
155
- case "p":
156
- case "k": {
157
- x && e.ctrlKey && ue(e);
158
- break;
159
- }
160
- case "ArrowUp": {
161
- ue(e);
162
- break;
163
- }
164
- case "Home": {
165
- e.preventDefault(), J(0);
166
- break;
356
+ );
357
+ }
358
+ );
359
+ oe.displayName = O;
360
+ var Re = "RadioBubbleInput", re = d.forwardRef(
361
+ ({ __scopeSlider: e, value: t, ...o }, n) => {
362
+ const a = d.useRef(null), c = M(a, n), r = ue(t);
363
+ return d.useEffect(() => {
364
+ const s = a.current;
365
+ if (!s) return;
366
+ const l = window.HTMLInputElement.prototype, S = Object.getOwnPropertyDescriptor(l, "value").set;
367
+ if (r !== t && S) {
368
+ const i = new Event("input", { bubbles: !0 });
369
+ S.call(s, t), s.dispatchEvent(i);
167
370
  }
168
- case "End": {
169
- e.preventDefault(), le();
170
- break;
371
+ }, [r, t]), /* @__PURE__ */ v(
372
+ K.input,
373
+ {
374
+ style: { display: "none" },
375
+ ...o,
376
+ ref: c,
377
+ defaultValue: t
171
378
  }
172
- case "Enter": {
173
- e.preventDefault();
174
- let l = P();
175
- if (l) {
176
- let f = new Event(Y);
177
- l.dispatchEvent(f);
178
- }
179
- }
180
- }
181
- } }, n.createElement("label", { "cmdk-label": "", htmlFor: _.inputId, id: _.labelId, style: Le }, b), z(t, (e) => n.createElement(de.Provider, { value: y }, n.createElement(ce.Provider, { value: _ }, e))));
182
- }), we = n.forwardRef((t, a) => {
183
- var r, v;
184
- let i = K(), c = n.useRef(null), d = n.useContext(se), m = O(), b = me(t), s = (v = (r = b.current) == null ? void 0 : r.forceMount) != null ? v : d == null ? void 0 : d.forceMount;
185
- M(() => {
186
- if (!s) return m.item(i, d == null ? void 0 : d.id);
187
- }, [s]);
188
- let h = ve(i, c, [t.value, t.children, c], t.keywords), R = Z(), k = S((g) => g.value && g.value === h.current), w = S((g) => s || m.filter() === !1 ? !0 : g.search ? g.filtered.items.get(i) > 0 : !0);
189
- n.useEffect(() => {
190
- let g = c.current;
191
- if (!(!g || t.disabled)) return g.addEventListener(Y, V), () => g.removeEventListener(Y, V);
192
- }, [w, t.onSelect, t.disabled]);
193
- function V() {
194
- var g, y;
195
- B(), (y = (g = b.current).onSelect) == null || y.call(g, h.current);
196
- }
197
- function B() {
198
- R.setState("value", h.current, !0);
199
- }
200
- if (!w) return null;
201
- let { disabled: x, value: j, onSelect: U, forceMount: ee, keywords: W, ...A } = t;
202
- return n.createElement(I.div, { ref: q(c, a), ...A, id: i, "cmdk-item": "", role: "option", "aria-disabled": !!x, "aria-selected": !!k, "data-disabled": !!x, "data-selected": !!k, onPointerMove: x || m.getDisablePointerSelection() ? void 0 : B, onClick: x ? void 0 : V }, t.children);
203
- }), ke = n.forwardRef((t, a) => {
204
- let { heading: r, children: v, forceMount: i, ...c } = t, d = K(), m = n.useRef(null), b = n.useRef(null), s = K(), h = O(), R = S((w) => i || h.filter() === !1 ? !0 : w.search ? w.filtered.groups.has(d) : !0);
205
- M(() => h.group(d), []), ve(d, m, [t.value, t.heading, b]);
206
- let k = n.useMemo(() => ({ id: d, forceMount: i }), [i]);
207
- return n.createElement(I.div, { ref: q(m, a), ...c, "cmdk-group": "", role: "presentation", hidden: R ? void 0 : !0 }, r && n.createElement("div", { ref: b, "cmdk-group-heading": "", "aria-hidden": !0, id: s }, r), z(t, (w) => n.createElement("div", { "cmdk-group-items": "", role: "group", "aria-labelledby": r ? s : void 0 }, n.createElement(se.Provider, { value: k }, w))));
208
- }), Se = n.forwardRef((t, a) => {
209
- let { alwaysRender: r, ...v } = t, i = n.useRef(null), c = S((d) => !d.search);
210
- return !r && !c ? null : n.createElement(I.div, { ref: q(i, a), ...v, "cmdk-separator": "", role: "separator" });
211
- }), Ie = n.forwardRef((t, a) => {
212
- let { onValueChange: r, ...v } = t, i = t.value != null, c = Z(), d = S((s) => s.search), m = S((s) => s.selectedItemId), b = O();
213
- return n.useEffect(() => {
214
- t.value != null && c.setState("search", t.value);
215
- }, [t.value]), n.createElement(I.input, { ref: a, ...v, "cmdk-input": "", autoComplete: "off", autoCorrect: "off", spellCheck: !1, "aria-autocomplete": "list", role: "combobox", "aria-expanded": !0, "aria-controls": b.listId, "aria-labelledby": b.labelId, "aria-activedescendant": m, id: b.inputId, type: "text", value: i ? t.value : d, onChange: (s) => {
216
- i || c.setState("search", s.target.value), r == null || r(s.target.value);
217
- } });
218
- }), Re = n.forwardRef((t, a) => {
219
- let { children: r, label: v = "Suggestions", ...i } = t, c = n.useRef(null), d = n.useRef(null), m = S((s) => s.selectedItemId), b = O();
220
- return n.useEffect(() => {
221
- if (d.current && c.current) {
222
- let s = d.current, h = c.current, R, k = new ResizeObserver(() => {
223
- R = requestAnimationFrame(() => {
224
- let w = s.offsetHeight;
225
- h.style.setProperty("--cmdk-list-height", w.toFixed(1) + "px");
226
- });
227
- });
228
- return k.observe(s), () => {
229
- cancelAnimationFrame(R), k.unobserve(s);
230
- };
231
- }
232
- }, []), n.createElement(I.div, { ref: q(c, a), ...i, "cmdk-list": "", role: "listbox", tabIndex: -1, "aria-activedescendant": m, "aria-label": v, id: b.listId }, z(t, (s) => n.createElement("div", { ref: q(d, b.listInnerRef), "cmdk-list-sizer": "" }, s)));
233
- }), xe = n.forwardRef((t, a) => {
234
- let { open: r, onOpenChange: v, overlayClassName: i, contentClassName: c, container: d, ...m } = t;
235
- return n.createElement(ge, { open: r, onOpenChange: v }, n.createElement(he, { container: d }, n.createElement(be, { "cmdk-overlay": "", className: i }), n.createElement(Ee, { "aria-label": t.label, "cmdk-dialog": "", className: c }, n.createElement(fe, { ref: a, ...m }))));
236
- }), Ae = n.forwardRef((t, a) => S((r) => r.filtered.count === 0) ? n.createElement(I.div, { ref: a, ...t, "cmdk-empty": "", role: "presentation" }) : null), Me = n.forwardRef((t, a) => {
237
- let { progress: r, children: v, label: i = "Loading...", ...c } = t;
238
- return n.createElement(I.div, { ref: a, ...c, "cmdk-loading": "", role: "progressbar", "aria-valuenow": r, "aria-valuemin": 0, "aria-valuemax": 100, "aria-label": i }, z(t, (d) => n.createElement("div", { "aria-hidden": !0 }, d)));
239
- }), Ne = Object.assign(fe, { List: Re, Item: we, Input: Ie, Group: ke, Separator: Se, Dialog: xe, Empty: Ae, Loading: Me });
240
- function Pe(t, a) {
241
- let r = t.nextElementSibling;
242
- for (; r; ) {
243
- if (r.matches(a)) return r;
244
- r = r.nextElementSibling;
379
+ );
245
380
  }
381
+ );
382
+ re.displayName = Re;
383
+ function Pe(e = [], t, o) {
384
+ const n = [...e];
385
+ return n[o] = t, n.sort((a, c) => a - c);
246
386
  }
247
- function De(t, a) {
248
- let r = t.previousElementSibling;
249
- for (; r; ) {
250
- if (r.matches(a)) return r;
251
- r = r.previousElementSibling;
252
- }
387
+ function ie(e, t, o) {
388
+ const c = 100 / (o - t) * (e - t);
389
+ return $(c, [0, 100]);
253
390
  }
254
- function me(t) {
255
- let a = n.useRef(t);
256
- return M(() => {
257
- a.current = t;
258
- }), a;
391
+ function xe(e, t) {
392
+ return t > 2 ? `Value ${e + 1} of ${t}` : t === 2 ? ["Minimum", "Maximum"][e] : void 0;
259
393
  }
260
- var M = typeof window > "u" ? n.useEffect : n.useLayoutEffect;
261
- function F(t) {
262
- let a = n.useRef();
263
- return a.current === void 0 && (a.current = t()), a;
394
+ function ye(e, t) {
395
+ if (e.length === 1) return 0;
396
+ const o = e.map((a) => Math.abs(a - t)), n = Math.min(...o);
397
+ return o.indexOf(n);
264
398
  }
265
- function S(t) {
266
- let a = Z(), r = () => t(a.snapshot());
267
- return n.useSyncExternalStore(a.subscribe, r, r);
399
+ function De(e, t, o) {
400
+ const n = e / 2, c = U([0, 50], [0, n]);
401
+ return (n - c(t) * o) * o;
268
402
  }
269
- function ve(t, a, r, v = []) {
270
- let i = n.useRef(), c = O();
271
- return M(() => {
272
- var d;
273
- let m = (() => {
274
- var s;
275
- for (let h of r) {
276
- if (typeof h == "string") return h.trim();
277
- if (typeof h == "object" && "current" in h) return h.current ? (s = h.current.textContent) == null ? void 0 : s.trim() : i.current;
278
- }
279
- })(), b = v.map((s) => s.trim());
280
- c.value(t, m, b), (d = a.current) == null || d.setAttribute(D, m), i.current = m;
281
- }), i;
403
+ function Ee(e) {
404
+ return e.slice(0, -1).map((t, o) => e[o + 1] - t);
282
405
  }
283
- var Fe = () => {
284
- let [t, a] = n.useState(), r = F(() => /* @__PURE__ */ new Map());
285
- return M(() => {
286
- r.current.forEach((v) => v()), r.current = /* @__PURE__ */ new Map();
287
- }, [t]), (v, i) => {
288
- r.current.set(v, i), a({});
406
+ function _e(e, t) {
407
+ if (t > 0) {
408
+ const o = Ee(e);
409
+ return Math.min(...o) >= t;
410
+ }
411
+ return !0;
412
+ }
413
+ function U(e, t) {
414
+ return (o) => {
415
+ if (e[0] === e[1] || t[0] === t[1]) return t[0];
416
+ const n = (t[1] - t[0]) / (e[1] - e[0]);
417
+ return t[0] + n * (o - e[0]);
289
418
  };
290
- };
291
- function Ke(t) {
292
- let a = t.type;
293
- return typeof a == "function" ? a(t.props) : "render" in a ? a.render(t.props) : t;
294
419
  }
295
- function z({ asChild: t, children: a }, r) {
296
- return t && n.isValidElement(a) ? n.cloneElement(Ke(a), { ref: a.ref }, r(a.props.children)) : r(a);
420
+ function Ce(e) {
421
+ return (String(e).split(".")[1] || "").length;
422
+ }
423
+ function Me(e, t) {
424
+ const o = Math.pow(10, t);
425
+ return Math.round(e * o) / o;
297
426
  }
298
- var Le = { position: "absolute", width: "1px", height: "1px", padding: "0", margin: "-1px", overflow: "hidden", clip: "rect(0, 0, 0, 0)", whiteSpace: "nowrap", borderWidth: "0" };
427
+ var Oe = q, Ue = te, Fe = ne, Ye = oe;
299
428
  export {
300
- Ne as Command,
301
- xe as CommandDialog,
302
- Ae as CommandEmpty,
303
- ke as CommandGroup,
304
- Ie as CommandInput,
305
- we as CommandItem,
306
- Re as CommandList,
307
- Me as CommandLoading,
308
- fe as CommandRoot,
309
- Se as CommandSeparator,
310
- Ce as defaultFilter,
311
- S as useCommandState
429
+ Fe as Range,
430
+ Oe as Root,
431
+ q as Slider,
432
+ ne as SliderRange,
433
+ oe as SliderThumb,
434
+ te as SliderTrack,
435
+ Ye as Thumb,
436
+ Ue as Track
312
437
  };