@drjoshcsimmons/scl 0.1.6 → 0.1.7

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 (108) hide show
  1. package/dist/index100.js +30 -4
  2. package/dist/index101.js +647 -12
  3. package/dist/index102.js +178 -27
  4. package/dist/index103.js +24 -180
  5. package/dist/index104.js +12 -647
  6. package/dist/index105.js +6 -12
  7. package/dist/index106.js +10 -204
  8. package/dist/index107.js +20 -21
  9. package/dist/index108.js +9 -400
  10. package/dist/index109.js +38 -6
  11. package/dist/index11.js +2 -2
  12. package/dist/index110.js +11 -14
  13. package/dist/index111.js +206 -9
  14. package/dist/index112.js +21 -37
  15. package/dist/index113.js +399 -17
  16. package/dist/index114.js +2 -25
  17. package/dist/index115.js +53 -29
  18. package/dist/index116.js +65 -5
  19. package/dist/index117.js +25 -2
  20. package/dist/index118.js +29 -53
  21. package/dist/index119.js +5 -65
  22. package/dist/index12.js +1 -1
  23. package/dist/index125.js +1 -1
  24. package/dist/index126.js +1 -1
  25. package/dist/index13.js +2 -2
  26. package/dist/index130.js +1 -1
  27. package/dist/index131.js +1 -1
  28. package/dist/index132.js +1 -1
  29. package/dist/index137.js +11 -21
  30. package/dist/index138.js +26 -11
  31. package/dist/index139.js +4 -27
  32. package/dist/index14.js +2 -2
  33. package/dist/index140.js +22 -4
  34. package/dist/index15.js +2 -2
  35. package/dist/index17.js +4 -4
  36. package/dist/index18.js +2 -2
  37. package/dist/index20.js +1 -1
  38. package/dist/index21.js +1 -1
  39. package/dist/index22.js +1 -1
  40. package/dist/index23.js +2 -2
  41. package/dist/index24.js +1 -1
  42. package/dist/index25.js +4 -4
  43. package/dist/index26.js +1 -1
  44. package/dist/index27.js +2 -2
  45. package/dist/index29.js +1 -1
  46. package/dist/index31.js +1 -1
  47. package/dist/index33.js +1 -1
  48. package/dist/index36.js +1 -1
  49. package/dist/index37.js +1 -1
  50. package/dist/index4.js +2 -2
  51. package/dist/index46.js +210 -214
  52. package/dist/index47.js +11 -249
  53. package/dist/index48.js +73 -9
  54. package/dist/index49.js +125 -12
  55. package/dist/index50.js +57 -257
  56. package/dist/index51.js +260 -12
  57. package/dist/index52.js +12 -73
  58. package/dist/index53.js +12 -237
  59. package/dist/index54.js +3 -5
  60. package/dist/index55.js +811 -481
  61. package/dist/index56.js +9 -125
  62. package/dist/index57.js +215 -300
  63. package/dist/index58.js +3 -4
  64. package/dist/index59.js +11 -435
  65. package/dist/index6.js +1 -1
  66. package/dist/index60.js +114 -56
  67. package/dist/index61.js +20 -252
  68. package/dist/index62.js +250 -126
  69. package/dist/index63.js +224 -70
  70. package/dist/index64.js +160 -21
  71. package/dist/index65.js +434 -30
  72. package/dist/index66.js +334 -16
  73. package/dist/index67.js +16 -234
  74. package/dist/index68.js +530 -11
  75. package/dist/index69.js +222 -134
  76. package/dist/index7.js +1 -1
  77. package/dist/index70.js +119 -325
  78. package/dist/index71.js +25 -219
  79. package/dist/index72.js +241 -11
  80. package/dist/index73.js +68 -846
  81. package/dist/index74.js +310 -9
  82. package/dist/index75.js +12 -118
  83. package/dist/index76.js +66 -5
  84. package/dist/index77.js +44 -25
  85. package/dist/index78.js +23 -64
  86. package/dist/index79.js +5 -123
  87. package/dist/index80.js +50 -13
  88. package/dist/index81.js +32 -133
  89. package/dist/index82.js +1 -1
  90. package/dist/index83.js +7 -218
  91. package/dist/index84.js +55 -14
  92. package/dist/index85.js +10 -68
  93. package/dist/index86.js +4 -34
  94. package/dist/index87.js +29 -53
  95. package/dist/index88.js +10 -49
  96. package/dist/index89.js +53 -49
  97. package/dist/index9.js +1 -1
  98. package/dist/index90.js +124 -8
  99. package/dist/index91.js +134 -5
  100. package/dist/index92.js +14 -25
  101. package/dist/index93.js +65 -51
  102. package/dist/index94.js +12 -8
  103. package/dist/index95.js +9 -4
  104. package/dist/index96.js +49 -29
  105. package/dist/index97.js +3 -12
  106. package/dist/index98.js +216 -43
  107. package/dist/index99.js +5 -7
  108. package/package.json +11 -19
package/dist/index70.js CHANGED
@@ -1,338 +1,132 @@
1
- import * as s from "react";
2
- import { composeEventHandlers as g } from "./index76.js";
3
- import { useComposedRefs as N } from "./index77.js";
4
- import { createContextScope as K } from "./index78.js";
5
- import { DismissableLayer as W } from "./index79.js";
6
- import { useId as $ } from "./index82.js";
7
- import { createPopperScope as S, Root as z, Anchor as J, Content as Q, Arrow as Z } from "./index83.js";
8
- import { Portal as ee } from "./index84.js";
9
- import { Presence as G } from "./index85.js";
10
- import { Primitive as te } from "./index86.js";
11
- import { createSlottable as oe } from "./index87.js";
12
- import { useControllableState as re } from "./index88.js";
13
- import { Root as ne } from "./index102.js";
14
- import { jsx as f, jsxs as se } from "react/jsx-runtime";
15
- var [D] = K("Tooltip", [
16
- S
17
- ]), O = S(), j = "TooltipProvider", ie = 700, L = "tooltip.open", [ae, k] = D(j), F = (t) => {
18
- const {
19
- __scopeTooltip: o,
20
- delayDuration: e = ie,
21
- skipDelayDuration: r = 300,
22
- disableHoverableContent: n = !1,
23
- children: a
24
- } = t, l = s.useRef(!0), v = s.useRef(!1), i = s.useRef(0);
25
- return s.useEffect(() => {
26
- const p = i.current;
27
- return () => window.clearTimeout(p);
28
- }, []), /* @__PURE__ */ f(
29
- ae,
30
- {
31
- scope: o,
32
- isOpenDelayedRef: l,
33
- delayDuration: e,
34
- onOpen: s.useCallback(() => {
35
- window.clearTimeout(i.current), l.current = !1;
36
- }, []),
37
- onClose: s.useCallback(() => {
38
- window.clearTimeout(i.current), i.current = window.setTimeout(
39
- () => l.current = !0,
40
- r
41
- );
42
- }, [r]),
43
- isPointerInTransitRef: v,
44
- onPointerInTransitChange: s.useCallback((p) => {
45
- v.current = p;
46
- }, []),
47
- disableHoverableContent: n,
48
- children: a
49
- }
50
- );
51
- };
52
- F.displayName = j;
53
- var R = "Tooltip", [le, _] = D(R), B = (t) => {
54
- const {
55
- __scopeTooltip: o,
56
- children: e,
57
- open: r,
58
- defaultOpen: n,
59
- onOpenChange: a,
60
- disableHoverableContent: l,
61
- delayDuration: v
62
- } = t, i = k(R, t.__scopeTooltip), p = O(o), [c, d] = s.useState(null), h = $(), u = s.useRef(0), m = l ?? i.disableHoverableContent, y = v ?? i.delayDuration, T = s.useRef(!1), [x, C] = re({
63
- prop: r,
64
- defaultProp: n ?? !1,
65
- onChange: (H) => {
66
- H ? (i.onOpen(), document.dispatchEvent(new CustomEvent(L))) : i.onClose(), a == null || a(H);
67
- },
68
- caller: R
69
- }), w = s.useMemo(() => x ? T.current ? "delayed-open" : "instant-open" : "closed", [x]), P = s.useCallback(() => {
70
- window.clearTimeout(u.current), u.current = 0, T.current = !1, C(!0);
71
- }, [C]), E = s.useCallback(() => {
72
- window.clearTimeout(u.current), u.current = 0, C(!1);
73
- }, [C]), I = s.useCallback(() => {
74
- window.clearTimeout(u.current), u.current = window.setTimeout(() => {
75
- T.current = !0, C(!0), u.current = 0;
76
- }, y);
77
- }, [y, C]);
78
- return s.useEffect(() => () => {
79
- u.current && (window.clearTimeout(u.current), u.current = 0);
80
- }, []), /* @__PURE__ */ f(z, { ...p, children: /* @__PURE__ */ f(
81
- le,
82
- {
83
- scope: o,
84
- contentId: h,
85
- open: x,
86
- stateAttribute: w,
87
- trigger: c,
88
- onTriggerChange: d,
89
- onTriggerEnter: s.useCallback(() => {
90
- i.isOpenDelayedRef.current ? I() : P();
91
- }, [i.isOpenDelayedRef, I, P]),
92
- onTriggerLeave: s.useCallback(() => {
93
- m ? E() : (window.clearTimeout(u.current), u.current = 0);
94
- }, [E, m]),
95
- onOpen: P,
96
- onClose: E,
97
- disableHoverableContent: m,
98
- children: e
99
- }
100
- ) });
101
- };
102
- B.displayName = R;
103
- var A = "TooltipTrigger", U = s.forwardRef(
104
- (t, o) => {
105
- const { __scopeTooltip: e, ...r } = t, n = _(A, e), a = k(A, e), l = O(e), v = s.useRef(null), i = N(o, v, n.onTriggerChange), p = s.useRef(!1), c = s.useRef(!1), d = s.useCallback(() => p.current = !1, []);
106
- return s.useEffect(() => () => document.removeEventListener("pointerup", d), [d]), /* @__PURE__ */ f(J, { asChild: !0, ...l, children: /* @__PURE__ */ f(
107
- te.button,
1
+ import * as r from "react";
2
+ import { composeEventHandlers as T } from "./index79.js";
3
+ import { useComposedRefs as P } from "./index78.js";
4
+ import { createContextScope as I } from "./index76.js";
5
+ import { useControllableState as M } from "./index80.js";
6
+ import { usePrevious as H } from "./index99.js";
7
+ import { useSize as j } from "./index103.js";
8
+ import { Primitive as y } from "./index81.js";
9
+ import { jsxs as A, jsx as m } from "react/jsx-runtime";
10
+ var h = "Switch", [U] = I(h), [q, z] = U(h), R = r.forwardRef(
11
+ (t, a) => {
12
+ const {
13
+ __scopeSwitch: e,
14
+ name: c,
15
+ checked: o,
16
+ defaultChecked: v,
17
+ required: i,
18
+ disabled: n,
19
+ value: p = "on",
20
+ onCheckedChange: w,
21
+ form: s,
22
+ ...S
23
+ } = t, [d, u] = r.useState(null), b = P(a, (f) => u(f)), C = r.useRef(!1), k = d ? s || !!d.closest("form") : !0, [l, B] = M({
24
+ prop: o,
25
+ defaultProp: v ?? !1,
26
+ onChange: w,
27
+ caller: h
28
+ });
29
+ return /* @__PURE__ */ A(q, { scope: e, checked: l, disabled: n, children: [
30
+ /* @__PURE__ */ m(
31
+ y.button,
32
+ {
33
+ type: "button",
34
+ role: "switch",
35
+ "aria-checked": l,
36
+ "aria-required": i,
37
+ "data-state": g(l),
38
+ "data-disabled": n ? "" : void 0,
39
+ disabled: n,
40
+ value: p,
41
+ ...S,
42
+ ref: b,
43
+ onClick: T(t.onClick, (f) => {
44
+ B((N) => !N), k && (C.current = f.isPropagationStopped(), C.current || f.stopPropagation());
45
+ })
46
+ }
47
+ ),
48
+ k && /* @__PURE__ */ m(
49
+ x,
50
+ {
51
+ control: d,
52
+ bubbles: !C.current,
53
+ name: c,
54
+ value: p,
55
+ checked: l,
56
+ required: i,
57
+ disabled: n,
58
+ form: s,
59
+ style: { transform: "translateX(-100%)" }
60
+ }
61
+ )
62
+ ] });
63
+ }
64
+ );
65
+ R.displayName = h;
66
+ var E = "SwitchThumb", _ = r.forwardRef(
67
+ (t, a) => {
68
+ const { __scopeSwitch: e, ...c } = t, o = z(E, e);
69
+ return /* @__PURE__ */ m(
70
+ y.span,
108
71
  {
109
- "aria-describedby": n.open ? n.contentId : void 0,
110
- "data-state": n.stateAttribute,
111
- ...r,
112
- ref: i,
113
- onPointerMove: g(t.onPointerMove, (h) => {
114
- h.pointerType !== "touch" && !c.current && !a.isPointerInTransitRef.current && (n.onTriggerEnter(), c.current = !0);
115
- }),
116
- onPointerLeave: g(t.onPointerLeave, () => {
117
- n.onTriggerLeave(), c.current = !1;
118
- }),
119
- onPointerDown: g(t.onPointerDown, () => {
120
- n.open && n.onClose(), p.current = !0, document.addEventListener("pointerup", d, { once: !0 });
121
- }),
122
- onFocus: g(t.onFocus, () => {
123
- p.current || n.onOpen();
124
- }),
125
- onBlur: g(t.onBlur, n.onClose),
126
- onClick: g(t.onClick, n.onClose)
72
+ "data-state": g(o.checked),
73
+ "data-disabled": o.disabled ? "" : void 0,
74
+ ...c,
75
+ ref: a
127
76
  }
128
- ) });
77
+ );
129
78
  }
130
79
  );
131
- U.displayName = A;
132
- var M = "TooltipPortal", [ce, ue] = D(M, {
133
- forceMount: void 0
134
- }), V = (t) => {
135
- const { __scopeTooltip: o, forceMount: e, children: r, container: n } = t, a = _(M, o);
136
- return /* @__PURE__ */ f(ce, { scope: o, forceMount: e, children: /* @__PURE__ */ f(G, { present: e || a.open, children: /* @__PURE__ */ f(ee, { asChild: !0, container: n, children: r }) }) });
137
- };
138
- V.displayName = M;
139
- var b = "TooltipContent", Y = s.forwardRef(
140
- (t, o) => {
141
- const e = ue(b, t.__scopeTooltip), { forceMount: r = e.forceMount, side: n = "top", ...a } = t, l = _(b, t.__scopeTooltip);
142
- return /* @__PURE__ */ f(G, { present: r || l.open, children: l.disableHoverableContent ? /* @__PURE__ */ f(q, { side: n, ...a, ref: o }) : /* @__PURE__ */ f(pe, { side: n, ...a, ref: o }) });
143
- }
144
- ), pe = s.forwardRef((t, o) => {
145
- const e = _(b, t.__scopeTooltip), r = k(b, t.__scopeTooltip), n = s.useRef(null), a = N(o, n), [l, v] = s.useState(null), { trigger: i, onClose: p } = e, c = n.current, { onPointerInTransitChange: d } = r, h = s.useCallback(() => {
146
- v(null), d(!1);
147
- }, [d]), u = s.useCallback(
148
- (m, y) => {
149
- const T = m.currentTarget, x = { x: m.clientX, y: m.clientY }, C = me(x, T.getBoundingClientRect()), w = Te(x, C), P = ye(y.getBoundingClientRect()), E = xe([...w, ...P]);
150
- v(E), d(!0);
151
- },
152
- [d]
153
- );
154
- return s.useEffect(() => () => h(), [h]), s.useEffect(() => {
155
- if (i && c) {
156
- const m = (T) => u(T, c), y = (T) => u(T, i);
157
- return i.addEventListener("pointerleave", m), c.addEventListener("pointerleave", y), () => {
158
- i.removeEventListener("pointerleave", m), c.removeEventListener("pointerleave", y);
159
- };
160
- }
161
- }, [i, c, u, h]), s.useEffect(() => {
162
- if (l) {
163
- const m = (y) => {
164
- const T = y.target, x = { x: y.clientX, y: y.clientY }, C = (i == null ? void 0 : i.contains(T)) || (c == null ? void 0 : c.contains(T)), w = !Ce(x, l);
165
- C ? h() : w && (h(), p());
166
- };
167
- return document.addEventListener("pointermove", m), () => document.removeEventListener("pointermove", m);
168
- }
169
- }, [i, c, l, p, h]), /* @__PURE__ */ f(q, { ...t, ref: a });
170
- }), [de, fe] = D(R, { isInside: !1 }), ve = oe("TooltipContent"), q = s.forwardRef(
171
- (t, o) => {
172
- const {
173
- __scopeTooltip: e,
174
- children: r,
175
- "aria-label": n,
176
- onEscapeKeyDown: a,
177
- onPointerDownOutside: l,
178
- ...v
179
- } = t, i = _(b, e), p = O(e), { onClose: c } = i;
180
- return s.useEffect(() => (document.addEventListener(L, c), () => document.removeEventListener(L, c)), [c]), s.useEffect(() => {
181
- if (i.trigger) {
182
- const d = (h) => {
183
- const u = h.target;
184
- u != null && u.contains(i.trigger) && c();
185
- };
186
- return window.addEventListener("scroll", d, { capture: !0 }), () => window.removeEventListener("scroll", d, { capture: !0 });
80
+ _.displayName = E;
81
+ var L = "SwitchBubbleInput", x = r.forwardRef(
82
+ ({
83
+ __scopeSwitch: t,
84
+ control: a,
85
+ checked: e,
86
+ bubbles: c = !0,
87
+ ...o
88
+ }, v) => {
89
+ const i = r.useRef(null), n = P(i, v), p = H(e), w = j(a);
90
+ return r.useEffect(() => {
91
+ const s = i.current;
92
+ if (!s) return;
93
+ const S = window.HTMLInputElement.prototype, u = Object.getOwnPropertyDescriptor(
94
+ S,
95
+ "checked"
96
+ ).set;
97
+ if (p !== e && u) {
98
+ const b = new Event("click", { bubbles: c });
99
+ u.call(s, e), s.dispatchEvent(b);
187
100
  }
188
- }, [i.trigger, c]), /* @__PURE__ */ f(
189
- W,
101
+ }, [p, e, c]), /* @__PURE__ */ m(
102
+ "input",
190
103
  {
191
- asChild: !0,
192
- disableOutsidePointerEvents: !1,
193
- onEscapeKeyDown: a,
194
- onPointerDownOutside: l,
195
- onFocusOutside: (d) => d.preventDefault(),
196
- onDismiss: c,
197
- children: /* @__PURE__ */ se(
198
- Q,
199
- {
200
- "data-state": i.stateAttribute,
201
- ...p,
202
- ...v,
203
- ref: o,
204
- style: {
205
- ...v.style,
206
- "--radix-tooltip-content-transform-origin": "var(--radix-popper-transform-origin)",
207
- "--radix-tooltip-content-available-width": "var(--radix-popper-available-width)",
208
- "--radix-tooltip-content-available-height": "var(--radix-popper-available-height)",
209
- "--radix-tooltip-trigger-width": "var(--radix-popper-anchor-width)",
210
- "--radix-tooltip-trigger-height": "var(--radix-popper-anchor-height)"
211
- },
212
- children: [
213
- /* @__PURE__ */ f(ve, { children: r }),
214
- /* @__PURE__ */ f(de, { scope: e, isInside: !0, children: /* @__PURE__ */ f(ne, { id: i.contentId, role: "tooltip", children: n || r }) })
215
- ]
216
- }
217
- )
104
+ type: "checkbox",
105
+ "aria-hidden": !0,
106
+ defaultChecked: e,
107
+ ...o,
108
+ tabIndex: -1,
109
+ ref: n,
110
+ style: {
111
+ ...o.style,
112
+ ...w,
113
+ position: "absolute",
114
+ pointerEvents: "none",
115
+ opacity: 0,
116
+ margin: 0
117
+ }
218
118
  }
219
119
  );
220
120
  }
221
121
  );
222
- Y.displayName = b;
223
- var X = "TooltipArrow", he = s.forwardRef(
224
- (t, o) => {
225
- const { __scopeTooltip: e, ...r } = t, n = O(e);
226
- return fe(
227
- X,
228
- e
229
- ).isInside ? null : /* @__PURE__ */ f(Z, { ...n, ...r, ref: o });
230
- }
231
- );
232
- he.displayName = X;
233
- function me(t, o) {
234
- const e = Math.abs(o.top - t.y), r = Math.abs(o.bottom - t.y), n = Math.abs(o.right - t.x), a = Math.abs(o.left - t.x);
235
- switch (Math.min(e, r, n, a)) {
236
- case a:
237
- return "left";
238
- case n:
239
- return "right";
240
- case e:
241
- return "top";
242
- case r:
243
- return "bottom";
244
- default:
245
- throw new Error("unreachable");
246
- }
247
- }
248
- function Te(t, o, e = 5) {
249
- const r = [];
250
- switch (o) {
251
- case "top":
252
- r.push(
253
- { x: t.x - e, y: t.y + e },
254
- { x: t.x + e, y: t.y + e }
255
- );
256
- break;
257
- case "bottom":
258
- r.push(
259
- { x: t.x - e, y: t.y - e },
260
- { x: t.x + e, y: t.y - e }
261
- );
262
- break;
263
- case "left":
264
- r.push(
265
- { x: t.x + e, y: t.y - e },
266
- { x: t.x + e, y: t.y + e }
267
- );
268
- break;
269
- case "right":
270
- r.push(
271
- { x: t.x - e, y: t.y - e },
272
- { x: t.x - e, y: t.y + e }
273
- );
274
- break;
275
- }
276
- return r;
277
- }
278
- function ye(t) {
279
- const { top: o, right: e, bottom: r, left: n } = t;
280
- return [
281
- { x: n, y: o },
282
- { x: e, y: o },
283
- { x: e, y: r },
284
- { x: n, y: r }
285
- ];
286
- }
287
- function Ce(t, o) {
288
- const { x: e, y: r } = t;
289
- let n = !1;
290
- for (let a = 0, l = o.length - 1; a < o.length; l = a++) {
291
- const v = o[a], i = o[l], p = v.x, c = v.y, d = i.x, h = i.y;
292
- c > r != h > r && e < (d - p) * (r - c) / (h - c) + p && (n = !n);
293
- }
294
- return n;
295
- }
296
- function xe(t) {
297
- const o = t.slice();
298
- return o.sort((e, r) => e.x < r.x ? -1 : e.x > r.x ? 1 : e.y < r.y ? -1 : e.y > r.y ? 1 : 0), ge(o);
299
- }
300
- function ge(t) {
301
- if (t.length <= 1) return t.slice();
302
- const o = [];
303
- for (let r = 0; r < t.length; r++) {
304
- const n = t[r];
305
- for (; o.length >= 2; ) {
306
- const a = o[o.length - 1], l = o[o.length - 2];
307
- if ((a.x - l.x) * (n.y - l.y) >= (a.y - l.y) * (n.x - l.x)) o.pop();
308
- else break;
309
- }
310
- o.push(n);
311
- }
312
- o.pop();
313
- const e = [];
314
- for (let r = t.length - 1; r >= 0; r--) {
315
- const n = t[r];
316
- for (; e.length >= 2; ) {
317
- const a = e[e.length - 1], l = e[e.length - 2];
318
- if ((a.x - l.x) * (n.y - l.y) >= (a.y - l.y) * (n.x - l.x)) e.pop();
319
- else break;
320
- }
321
- e.push(n);
322
- }
323
- return e.pop(), o.length === 1 && e.length === 1 && o[0].x === e[0].x && o[0].y === e[0].y ? o : o.concat(e);
122
+ x.displayName = L;
123
+ function g(t) {
124
+ return t ? "checked" : "unchecked";
324
125
  }
325
- var He = F, Ne = B, Se = U, Ge = V, je = Y;
126
+ var Q = R, V = _;
326
127
  export {
327
- je as Content,
328
- Ge as Portal,
329
- He as Provider,
330
- Ne as Root,
331
- B as Tooltip,
332
- he as TooltipArrow,
333
- Y as TooltipContent,
334
- V as TooltipPortal,
335
- F as TooltipProvider,
336
- U as TooltipTrigger,
337
- Se as Trigger
128
+ Q as Root,
129
+ R as Switch,
130
+ _ as SwitchThumb,
131
+ V as Thumb
338
132
  };