@zag-js/slider 0.0.0-dev-20220612194202 → 0.0.0-dev-20220615082220
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.
- package/dist/index.d.ts +0 -1
- package/dist/index.js +21 -26
- package/dist/index.mjs +21 -26
- package/dist/slider.connect.d.ts +0 -1
- package/dist/slider.dom.d.ts +0 -1
- package/dist/slider.machine.d.ts +0 -1
- package/dist/slider.style.d.ts +0 -1
- package/dist/slider.types.d.ts +0 -1
- package/dist/slider.utils.d.ts +0 -1
- package/package.json +2 -2
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -7
- package/dist/index.mjs.map +0 -7
- package/dist/slider.connect.d.ts.map +0 -1
- package/dist/slider.dom.d.ts.map +0 -1
- package/dist/slider.machine.d.ts.map +0 -1
- package/dist/slider.style.d.ts.map +0 -1
- package/dist/slider.types.d.ts.map +0 -1
- package/dist/slider.utils.d.ts.map +0 -1
package/dist/index.d.ts
CHANGED
package/dist/index.js
CHANGED
|
@@ -47,25 +47,6 @@ var __pow = Math.pow;
|
|
|
47
47
|
var dataAttr = (guard) => {
|
|
48
48
|
return guard ? "" : void 0;
|
|
49
49
|
};
|
|
50
|
-
function nextTick(fn) {
|
|
51
|
-
const set = /* @__PURE__ */ new Set();
|
|
52
|
-
function raf2(fn2) {
|
|
53
|
-
const id = globalThis.requestAnimationFrame(fn2);
|
|
54
|
-
set.add(() => globalThis.cancelAnimationFrame(id));
|
|
55
|
-
}
|
|
56
|
-
raf2(() => raf2(fn));
|
|
57
|
-
return function cleanup() {
|
|
58
|
-
set.forEach(function(fn2) {
|
|
59
|
-
fn2();
|
|
60
|
-
});
|
|
61
|
-
};
|
|
62
|
-
}
|
|
63
|
-
function raf(fn) {
|
|
64
|
-
const id = globalThis.requestAnimationFrame(fn);
|
|
65
|
-
return function cleanup() {
|
|
66
|
-
globalThis.cancelAnimationFrame(id);
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
50
|
var isDom = () => typeof window !== "undefined";
|
|
70
51
|
var isArray = (v) => Array.isArray(v);
|
|
71
52
|
var isObject = (v) => !(v == null || typeof v !== "object" || isArray(v));
|
|
@@ -76,7 +57,7 @@ function getPlatform() {
|
|
|
76
57
|
return (_a = agent == null ? void 0 : agent.platform) != null ? _a : navigator.platform;
|
|
77
58
|
}
|
|
78
59
|
var pt = (v) => isDom() && v.test(getPlatform());
|
|
79
|
-
var isTouchDevice = isDom() && !!navigator.maxTouchPoints;
|
|
60
|
+
var isTouchDevice = () => isDom() && !!navigator.maxTouchPoints;
|
|
80
61
|
var isMac = () => pt(/^Mac/) && !isTouchDevice;
|
|
81
62
|
var isApple = () => pt(/mac|iphone|ipad|ipod/i);
|
|
82
63
|
var isIos = () => isApple() && !isMac();
|
|
@@ -216,6 +197,25 @@ function getEventName(evt) {
|
|
|
216
197
|
return mouseEventNames[evt];
|
|
217
198
|
return evt;
|
|
218
199
|
}
|
|
200
|
+
function nextTick(fn) {
|
|
201
|
+
const set = /* @__PURE__ */ new Set();
|
|
202
|
+
function raf2(fn2) {
|
|
203
|
+
const id = globalThis.requestAnimationFrame(fn2);
|
|
204
|
+
set.add(() => globalThis.cancelAnimationFrame(id));
|
|
205
|
+
}
|
|
206
|
+
raf2(() => raf2(fn));
|
|
207
|
+
return function cleanup() {
|
|
208
|
+
set.forEach(function(fn2) {
|
|
209
|
+
fn2();
|
|
210
|
+
});
|
|
211
|
+
};
|
|
212
|
+
}
|
|
213
|
+
function raf(fn) {
|
|
214
|
+
const id = globalThis.requestAnimationFrame(fn);
|
|
215
|
+
return function cleanup() {
|
|
216
|
+
globalThis.cancelAnimationFrame(id);
|
|
217
|
+
};
|
|
218
|
+
}
|
|
219
219
|
function getOwnerWindow(el) {
|
|
220
220
|
var _a;
|
|
221
221
|
return (_a = el == null ? void 0 : el.ownerDocument.defaultView) != null ? _a : window;
|
|
@@ -384,11 +384,9 @@ function trackPointerMove(opts) {
|
|
|
384
384
|
}
|
|
385
385
|
|
|
386
386
|
// ../../utilities/rect/dist/index.mjs
|
|
387
|
-
var isDom2 = () => typeof window !== "undefined";
|
|
388
387
|
var isArray2 = (v) => Array.isArray(v);
|
|
389
388
|
var isObject2 = (v) => !(v == null || typeof v !== "object" || isArray2(v));
|
|
390
389
|
var hasProp2 = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop);
|
|
391
|
-
var isTouchDevice2 = isDom2() && !!navigator.maxTouchPoints;
|
|
392
390
|
var isTouchEvent2 = (v) => isObject2(v) && hasProp2(v, "touches");
|
|
393
391
|
var fallback2 = { pageX: 0, pageY: 0, clientX: 0, clientY: 0 };
|
|
394
392
|
function getEventPoint(e, t = "page") {
|
|
@@ -666,8 +664,6 @@ function createNormalizer(fn) {
|
|
|
666
664
|
var normalizeProp = createNormalizer((v) => v);
|
|
667
665
|
|
|
668
666
|
// ../../utilities/core/dist/index.mjs
|
|
669
|
-
var isDom3 = () => typeof window !== "undefined";
|
|
670
|
-
var isTouchDevice3 = isDom3() && !!navigator.maxTouchPoints;
|
|
671
667
|
var isLeftClick2 = (v) => v.button === 0;
|
|
672
668
|
var isModifiedEvent = (v) => v.ctrlKey || v.altKey || v.metaKey;
|
|
673
669
|
|
|
@@ -1000,7 +996,7 @@ function machine(ctx = {}) {
|
|
|
1000
996
|
let cleanup;
|
|
1001
997
|
nextTick(() => {
|
|
1002
998
|
cleanup = trackFieldsetDisabled(dom.getRootEl(ctx2), (disabled) => {
|
|
1003
|
-
if (disabled
|
|
999
|
+
if (disabled) {
|
|
1004
1000
|
ctx2.disabled = disabled;
|
|
1005
1001
|
}
|
|
1006
1002
|
});
|
|
@@ -1095,4 +1091,3 @@ function machine(ctx = {}) {
|
|
|
1095
1091
|
}
|
|
1096
1092
|
});
|
|
1097
1093
|
}
|
|
1098
|
-
//# sourceMappingURL=index.js.map
|
package/dist/index.mjs
CHANGED
|
@@ -23,25 +23,6 @@ var __pow = Math.pow;
|
|
|
23
23
|
var dataAttr = (guard) => {
|
|
24
24
|
return guard ? "" : void 0;
|
|
25
25
|
};
|
|
26
|
-
function nextTick(fn) {
|
|
27
|
-
const set = /* @__PURE__ */ new Set();
|
|
28
|
-
function raf2(fn2) {
|
|
29
|
-
const id = globalThis.requestAnimationFrame(fn2);
|
|
30
|
-
set.add(() => globalThis.cancelAnimationFrame(id));
|
|
31
|
-
}
|
|
32
|
-
raf2(() => raf2(fn));
|
|
33
|
-
return function cleanup() {
|
|
34
|
-
set.forEach(function(fn2) {
|
|
35
|
-
fn2();
|
|
36
|
-
});
|
|
37
|
-
};
|
|
38
|
-
}
|
|
39
|
-
function raf(fn) {
|
|
40
|
-
const id = globalThis.requestAnimationFrame(fn);
|
|
41
|
-
return function cleanup() {
|
|
42
|
-
globalThis.cancelAnimationFrame(id);
|
|
43
|
-
};
|
|
44
|
-
}
|
|
45
26
|
var isDom = () => typeof window !== "undefined";
|
|
46
27
|
var isArray = (v) => Array.isArray(v);
|
|
47
28
|
var isObject = (v) => !(v == null || typeof v !== "object" || isArray(v));
|
|
@@ -52,7 +33,7 @@ function getPlatform() {
|
|
|
52
33
|
return (_a = agent == null ? void 0 : agent.platform) != null ? _a : navigator.platform;
|
|
53
34
|
}
|
|
54
35
|
var pt = (v) => isDom() && v.test(getPlatform());
|
|
55
|
-
var isTouchDevice = isDom() && !!navigator.maxTouchPoints;
|
|
36
|
+
var isTouchDevice = () => isDom() && !!navigator.maxTouchPoints;
|
|
56
37
|
var isMac = () => pt(/^Mac/) && !isTouchDevice;
|
|
57
38
|
var isApple = () => pt(/mac|iphone|ipad|ipod/i);
|
|
58
39
|
var isIos = () => isApple() && !isMac();
|
|
@@ -192,6 +173,25 @@ function getEventName(evt) {
|
|
|
192
173
|
return mouseEventNames[evt];
|
|
193
174
|
return evt;
|
|
194
175
|
}
|
|
176
|
+
function nextTick(fn) {
|
|
177
|
+
const set = /* @__PURE__ */ new Set();
|
|
178
|
+
function raf2(fn2) {
|
|
179
|
+
const id = globalThis.requestAnimationFrame(fn2);
|
|
180
|
+
set.add(() => globalThis.cancelAnimationFrame(id));
|
|
181
|
+
}
|
|
182
|
+
raf2(() => raf2(fn));
|
|
183
|
+
return function cleanup() {
|
|
184
|
+
set.forEach(function(fn2) {
|
|
185
|
+
fn2();
|
|
186
|
+
});
|
|
187
|
+
};
|
|
188
|
+
}
|
|
189
|
+
function raf(fn) {
|
|
190
|
+
const id = globalThis.requestAnimationFrame(fn);
|
|
191
|
+
return function cleanup() {
|
|
192
|
+
globalThis.cancelAnimationFrame(id);
|
|
193
|
+
};
|
|
194
|
+
}
|
|
195
195
|
function getOwnerWindow(el) {
|
|
196
196
|
var _a;
|
|
197
197
|
return (_a = el == null ? void 0 : el.ownerDocument.defaultView) != null ? _a : window;
|
|
@@ -360,11 +360,9 @@ function trackPointerMove(opts) {
|
|
|
360
360
|
}
|
|
361
361
|
|
|
362
362
|
// ../../utilities/rect/dist/index.mjs
|
|
363
|
-
var isDom2 = () => typeof window !== "undefined";
|
|
364
363
|
var isArray2 = (v) => Array.isArray(v);
|
|
365
364
|
var isObject2 = (v) => !(v == null || typeof v !== "object" || isArray2(v));
|
|
366
365
|
var hasProp2 = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop);
|
|
367
|
-
var isTouchDevice2 = isDom2() && !!navigator.maxTouchPoints;
|
|
368
366
|
var isTouchEvent2 = (v) => isObject2(v) && hasProp2(v, "touches");
|
|
369
367
|
var fallback2 = { pageX: 0, pageY: 0, clientX: 0, clientY: 0 };
|
|
370
368
|
function getEventPoint(e, t = "page") {
|
|
@@ -642,8 +640,6 @@ function createNormalizer(fn) {
|
|
|
642
640
|
var normalizeProp = createNormalizer((v) => v);
|
|
643
641
|
|
|
644
642
|
// ../../utilities/core/dist/index.mjs
|
|
645
|
-
var isDom3 = () => typeof window !== "undefined";
|
|
646
|
-
var isTouchDevice3 = isDom3() && !!navigator.maxTouchPoints;
|
|
647
643
|
var isLeftClick2 = (v) => v.button === 0;
|
|
648
644
|
var isModifiedEvent = (v) => v.ctrlKey || v.altKey || v.metaKey;
|
|
649
645
|
|
|
@@ -976,7 +972,7 @@ function machine(ctx = {}) {
|
|
|
976
972
|
let cleanup;
|
|
977
973
|
nextTick(() => {
|
|
978
974
|
cleanup = trackFieldsetDisabled(dom.getRootEl(ctx2), (disabled) => {
|
|
979
|
-
if (disabled
|
|
975
|
+
if (disabled) {
|
|
980
976
|
ctx2.disabled = disabled;
|
|
981
977
|
}
|
|
982
978
|
});
|
|
@@ -1076,4 +1072,3 @@ export {
|
|
|
1076
1072
|
machine,
|
|
1077
1073
|
dom as unstable__dom
|
|
1078
1074
|
};
|
|
1079
|
-
//# sourceMappingURL=index.mjs.map
|
package/dist/slider.connect.d.ts
CHANGED
package/dist/slider.dom.d.ts
CHANGED
package/dist/slider.machine.d.ts
CHANGED
|
@@ -1,3 +1,2 @@
|
|
|
1
1
|
import { MachineContext, MachineState, UserDefinedContext } from "./slider.types";
|
|
2
2
|
export declare function machine(ctx?: UserDefinedContext): import("@zag-js/core").Machine<MachineContext, MachineState, import("@zag-js/core").StateMachine.AnyEventObject>;
|
|
3
|
-
//# sourceMappingURL=slider.machine.d.ts.map
|
package/dist/slider.style.d.ts
CHANGED
package/dist/slider.types.d.ts
CHANGED
package/dist/slider.utils.d.ts
CHANGED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@zag-js/slider",
|
|
3
|
-
"version": "0.0.0-dev-
|
|
3
|
+
"version": "0.0.0-dev-20220615082220",
|
|
4
4
|
"description": "Core logic for the slider widget implemented as a state machine",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"js",
|
|
@@ -30,7 +30,7 @@
|
|
|
30
30
|
},
|
|
31
31
|
"dependencies": {
|
|
32
32
|
"@zag-js/core": "0.1.6",
|
|
33
|
-
"@zag-js/dom-utils": "0.0.0-dev-
|
|
33
|
+
"@zag-js/dom-utils": "0.0.0-dev-20220615082220",
|
|
34
34
|
"@zag-js/number-utils": "0.1.2",
|
|
35
35
|
"@zag-js/rect-utils": "0.1.2",
|
|
36
36
|
"@zag-js/types": "0.1.2",
|
package/dist/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,IAAI,aAAa,EAAE,MAAM,cAAc,CAAA;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAC1C,YAAY,EAAE,kBAAkB,IAAI,OAAO,EAAE,MAAM,gBAAgB,CAAA"}
|
package/dist/index.js.map
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../src/index.ts", "../../../utilities/dom/src/attrs.ts", "../../../utilities/dom/src/computed-style.ts", "../../../utilities/dom/src/next-tick.ts", "../../../utilities/dom/src/auto-resize.ts", "../../../utilities/core/src/array.ts", "../../../utilities/core/src/guard.ts", "../../../utilities/core/src/platform.ts", "../../../utilities/core/src/events.ts", "../../../utilities/core/src/functions.ts", "../../../utilities/core/src/warning.ts", "../../../utilities/dom/src/global-listener.ts", "../../../utilities/dom/src/listener.ts", "../../../utilities/dom/src/body-pointer-event.ts", "../../../utilities/dom/src/constants.ts", "../../../utilities/dom/src/query.ts", "../../../utilities/dom/src/event.ts", "../../../utilities/dom/src/fire-event.ts", "../../../utilities/dom/src/focus-event.ts", "../../../utilities/dom/src/focusable.ts", "../../../utilities/dom/src/mutation-observer.ts", "../../../utilities/dom/src/form.ts", "../../../utilities/dom/src/input-event.ts", "../../../utilities/dom/src/keyboard-event.ts", "../../../utilities/dom/src/visually-hidden.ts", "../../../utilities/dom/src/live-region.ts", "../../../utilities/dom/src/nodelist.ts", "../../../utilities/dom/src/text-selection.ts", "../../../utilities/dom/src/pointer-event.ts", "../../../utilities/dom/src/pointerlock.ts", "../../../utilities/dom/src/rect-observer.ts", "../../../utilities/dom/src/scrollable.ts", "../../../utilities/dom/src/typeahead.ts", "../../../utilities/dom/src/visibility-event.ts", "../../../utilities/dom/src/visual-viewport.ts", "../../../utilities/dom/src/wait.ts", "../../../utilities/rect/src/rect.ts", "../../../utilities/rect/src/computed-style.ts", "../../../utilities/rect/src/from-element.ts", "../../../utilities/core/src/array.ts", "../../../utilities/core/src/guard.ts", "../../../utilities/core/src/platform.ts", "../../../utilities/core/src/events.ts", "../../../utilities/core/src/functions.ts", "../../../utilities/core/src/warning.ts", "../../../utilities/rect/src/point.ts", "../../../utilities/rect/src/operations.ts", "../../../utilities/rect/src/polygon.ts", "../../../utilities/number/src/number.ts", "../../../utilities/number/src/rangy.ts", "../../../utilities/number/src/number-format.ts", "../../../utilities/number/src/transform.ts", "../src/slider.style.ts", "../src/slider.utils.ts", "../src/slider.dom.ts", "../../../types/src/prop-types.ts", "../../../types/src/controls.ts", "../../../utilities/core/src/array.ts", "../../../utilities/core/src/guard.ts", "../../../utilities/core/src/platform.ts", "../../../utilities/core/src/events.ts", "../../../utilities/core/src/functions.ts", "../../../utilities/core/src/warning.ts", "../src/slider.connect.ts", "../src/slider.machine.ts"],
|
|
4
|
-
"sourcesContent": ["export { dom as unstable__dom } from \"./slider.dom\"\nexport { connect } from \"./slider.connect\"\nexport { machine } from \"./slider.machine\"\nexport type { UserDefinedContext as Context } from \"./slider.types\"\n", "type Booleanish = boolean | \"true\" | \"false\"\n\nexport const dataAttr = (guard: boolean | undefined) => {\n return (guard ? \"\" : undefined) as Booleanish\n}\n\nexport const ariaAttr = (guard: boolean | undefined) => {\n return guard ? \"true\" : undefined\n}\n\nexport const matchAttr = (el: Element) => {\n return {\n get: (key: string) => el.getAttribute(key),\n set: (key: string, value: string) => el.setAttribute(key, value),\n is: (key: string, value: string) => {\n return el.getAttribute(key) === value\n },\n }\n}\n", "type Key = keyof CSSStyleDeclaration | (string & {})\ntype Styles = Record<Key, any>\ntype El = HTMLElement | null | undefined\n\nfunction getStyleCache(): WeakMap<HTMLElement, Styles> {\n ;(globalThis as any).__styleCache__ = (globalThis as any).__styleCache__ || new WeakMap()\n return (globalThis as any).__styleCache__\n}\n\nexport function getComputedStyle(el: El): Styles {\n if (!el) return {} as Styles\n const cache = getStyleCache()\n let style: Styles | undefined = cache.get(el)\n if (!style) {\n const win = el?.ownerDocument.defaultView ?? window\n style = win.getComputedStyle(el) as Styles\n cache.set(el, style)\n }\n return style\n}\n\nexport function copyVisualStyles(fromEl: HTMLElement | null, toEl: HTMLElement) {\n if (!fromEl) return\n const el = getComputedStyle(fromEl)\n // prettier-ignore\n const cssText = 'box-sizing:' + el.boxSizing +\n ';border-left:' + el.borderLeftWidth + ' solid red' +\n ';border-right:' + el.borderRightWidth + ' solid red' +\n ';font-family:' + el.fontFamily +\n ';font-feature-settings:' + el.fontFeatureSettings +\n ';font-kerning:' + el.fontKerning +\n ';font-size:' + el.fontSize +\n ';font-stretch:' + el.fontStretch +\n ';font-style:' + el.fontStyle +\n ';font-variant:' + el.fontVariant +\n ';font-variant-caps:' + el.fontVariantCaps +\n ';font-variant-ligatures:' + el.fontVariantLigatures +\n ';font-variant-numeric:' + el.fontVariantNumeric +\n ';font-weight:' + el.fontWeight +\n ';letter-spacing:' + el.letterSpacing +\n ';margin-left:' + el.marginLeft +\n ';margin-right:' + el.marginRight +\n ';padding-left:' + el.paddingLeft +\n ';padding-right:' + el.paddingRight +\n ';text-indent:' + el.textIndent +\n ';text-transform:' + el.textTransform\n\n toEl.style.cssText += cssText\n}\n", "export function nextTick(fn: VoidFunction) {\n const set = new Set<VoidFunction>()\n function raf(fn: VoidFunction) {\n const id = globalThis.requestAnimationFrame(fn)\n set.add(() => globalThis.cancelAnimationFrame(id))\n }\n raf(() => raf(fn))\n return function cleanup() {\n set.forEach(function (fn) {\n fn()\n })\n }\n}\n\nexport function raf(fn: VoidFunction) {\n const id = globalThis.requestAnimationFrame(fn)\n return function cleanup() {\n globalThis.cancelAnimationFrame(id)\n }\n}\n\nexport function queueMicrotask(fn: VoidFunction) {\n if (typeof globalThis.queueMicrotask === \"function\") {\n globalThis.queueMicrotask(fn)\n } else {\n Promise.resolve().then(fn)\n }\n}\n", "import { copyVisualStyles } from \"./computed-style\"\nimport { raf } from \"./next-tick\"\n\nfunction createGhostElement(doc: Document) {\n var el = doc.createElement(\"div\")\n el.id = \"ghost\"\n el.style.cssText =\n \"display:inline-block;height:0;overflow:hidden;position:absolute;top:0;visibility:hidden;white-space:nowrap;\"\n doc.body.appendChild(el)\n return el\n}\n\nexport function autoResizeInput(input: HTMLInputElement | null) {\n if (!input) return\n const doc = input.ownerDocument ?? document\n const ghost = createGhostElement(doc)\n\n copyVisualStyles(input, ghost)\n\n function resize() {\n raf(() => {\n ghost.innerHTML = input!.value\n const rect = getComputedStyle(ghost)\n input?.style.setProperty(\"width\", rect.width)\n })\n }\n\n resize()\n\n input?.addEventListener(\"input\", resize)\n input?.addEventListener(\"change\", resize)\n\n return () => {\n doc.body.removeChild(ghost)\n input?.removeEventListener(\"input\", resize)\n input?.removeEventListener(\"change\", resize)\n }\n}\n", "export function toArray<T>(v: T | T[] | undefined | null): T[] {\n if (!v) return []\n return Array.isArray(v) ? v : [v]\n}\n\nexport const fromLength = (length: number) => Array.from(Array(length).keys())\n\nexport const first = <T>(v: T[]): T | undefined => v[0]\n\nexport const last = <T>(v: T[]): T | undefined => v[v.length - 1]\n\nexport const isEmpty = <T>(v: T[]): boolean => v.length === 0\n\nexport const has = <T>(v: T[], t: any): boolean => v.indexOf(t) !== -1\n\nexport const add = <T>(v: T[], ...items: T[]): T[] => v.concat(items)\n\nexport const remove = <T>(v: T[], item: T): T[] => removeAt(v, v.indexOf(item))\n\nexport const removeAt = <T>(v: T[], i: number): T[] => {\n if (i > -1) v.splice(i, 1)\n return v\n}\n\nexport function clear<T>(v: T[]): T[] {\n while (v.length > 0) v.pop()\n return v\n}\n\nexport type IndexOptions = {\n step?: number\n loop?: boolean\n}\n\nexport function nextIndex<T>(v: T[], idx: number, opts: IndexOptions = {}): number {\n const { step = 1, loop = true } = opts\n const next = idx + step\n const len = v.length\n const last = len - 1\n if (idx === -1) return step > 0 ? 0 : last\n if (next < 0) return loop ? last : 0\n if (next >= len) return loop ? 0 : idx > len ? len : idx\n return next\n}\n\nexport function next<T>(v: T[], idx: number, opts: IndexOptions = {}): T | undefined {\n return v[nextIndex(v, idx, opts)]\n}\n\nexport function prevIndex<T>(v: T[], idx: number, opts: IndexOptions = {}): number {\n const { step = 1, loop = true } = opts\n return nextIndex(v, idx, { step: -step, loop })\n}\n\nexport function prev<T>(v: T[], index: number, opts: IndexOptions = {}): T | undefined {\n return v[prevIndex(v, index, opts)]\n}\n\nexport const chunk = <T>(v: T[], size: number): T[][] => {\n const res: T[][] = []\n return v.reduce((rows, value, index) => {\n if (index % size === 0) rows.push([value])\n else last(rows)?.push(value)\n return rows\n }, res)\n}\n", "export const isDev = () => process.env.NODE_ENV !== \"production\"\nexport const isDom = () => typeof window !== \"undefined\"\n\nexport const isArray = (v: any): v is any[] => Array.isArray(v)\nexport const isBoolean = (v: any): v is boolean => v === true || v === false\nexport const isObject = (v: any): v is Record<string, any> => !(v == null || typeof v !== \"object\" || isArray(v))\nexport const isNumber = (v: any): v is number => typeof v === \"number\" && !Number.isNaN(v)\nexport const isString = (v: any): v is string => typeof v === \"string\"\nexport const isFunction = (v: any): v is Function => typeof v === \"function\"\n\nexport const hasProp = <T extends string>(obj: any, prop: T): obj is Record<T, any> =>\n Object.prototype.hasOwnProperty.call(obj, prop)\n", "import { isDom } from \"./guard\"\n\nexport function getPlatform() {\n const agent = (navigator as any).userAgentData\n return agent?.platform ?? navigator.platform\n}\n\nconst pt = (v: RegExp) => isDom() && v.test(getPlatform())\nconst ua = (v: RegExp) => isDom() && v.test(navigator.userAgent)\nconst vn = (v: RegExp) => isDom() && v.test(navigator.vendor)\n\nexport const isTouchDevice = isDom() && !!navigator.maxTouchPoints\nexport const isMac = () => pt(/^Mac/) && !isTouchDevice\nexport const isIPhone = () => pt(/^iPhone/)\nexport const isSafari = () => isApple() && vn(/apple/i)\nexport const isFirefox = () => ua(/firefox\\//i)\nexport const isApple = () => pt(/mac|iphone|ipad|ipod/i)\nexport const isIos = () => isApple() && !isMac()\n", "import { hasProp, isDom, isObject } from \"./guard\"\nimport { isMac } from \"./platform\"\n\nexport const supportsPointerEvent = () => isDom() && window.onpointerdown === null\nexport const supportsTouchEvent = () => isDom() && window.ontouchstart === null\nexport const supportsMouseEvent = () => isDom() && window.onmousedown === null\n\nexport const isMouseEvent = (v: any): v is MouseEvent => isObject(v) && hasProp(v, \"button\")\nexport const isTouchEvent = (v: any): v is TouchEvent => isObject(v) && hasProp(v, \"touches\")\nexport const isLeftClick = (v: { button: number }) => v.button === 0\nexport const isRightClick = (v: { button: number }) => v.button === 2\nexport const isModifiedEvent = (v: Pick<KeyboardEvent, \"ctrlKey\" | \"metaKey\" | \"altKey\">) =>\n v.ctrlKey || v.altKey || v.metaKey\n\nexport const isCtrlKey = (v: Pick<KeyboardEvent, \"ctrlKey\" | \"metaKey\">) =>\n isMac() ? v.metaKey && !v.ctrlKey : v.ctrlKey && !v.metaKey\n", "export const runIfFn = <T>(\n v: T | undefined,\n ...a: T extends (...a: any[]) => void ? Parameters<T> : never\n): T extends (...a: any[]) => void ? NonNullable<ReturnType<T>> : NonNullable<T> => {\n const res = typeof v === \"function\" ? v(...a) : v\n return res ?? undefined\n}\n\nexport const cast = <T>(v: unknown): T => v as T\n\nexport const noop = () => {}\n\nexport const pipe =\n <T>(...fns: Array<(a: T) => T>) =>\n (v: T) =>\n fns.reduce((a, b) => b(a), v)\n\nexport const callAll =\n <T extends (...a: any[]) => void>(...fns: (T | undefined)[]) =>\n (...a: Parameters<T>) => {\n fns.forEach(function (fn) {\n fn?.(...a)\n })\n }\n\nexport const uuid = /*#__PURE__*/ (() => {\n let id = 0\n return () => {\n id++\n return id.toString(36)\n }\n})()\n\nexport function merge<T, U>(origin: T, patch: U): T & U {\n if (!(typeof patch === \"object\")) return patch as any\n const result = !(typeof origin === \"object\") ? {} : Object.assign({}, origin)\n for (const key of Object.keys(patch)) {\n const value = patch[key]\n const src = result[key]\n if (value === null) delete result[key]\n else if (Array.isArray(value) || Array.isArray(src)) result[key] = (src || []).concat(value || [])\n else result[key] = merge(src, value)\n }\n return result as any\n}\n", "export function warn(m: string): void\nexport function warn(c: boolean, m: string): void\nexport function warn(...a: any[]): void {\n const m = a.length === 1 ? a[0] : a[1]\n const c = a.length === 2 ? a[0] : true\n if (c && process.env.NODE_ENV !== \"production\") {\n console.warn(m)\n }\n}\n\nexport function invariant(m: string): void\nexport function invariant(c: boolean, m: string): void\nexport function invariant(...a: any[]): void {\n const m = a.length === 1 ? a[0] : a[1]\n const c = a.length === 2 ? a[0] : true\n if (c && process.env.NODE_ENV !== \"production\") {\n throw new Error(m)\n }\n}\n", "import { noop } from \"@zag-js/utils\"\n\ntype El = HTMLElement | Document | VisualViewport | Window\ntype Handler = (event: Event) => void\ntype Group = Map<string, Set<Handler>>\ntype Option = boolean | AddEventListenerOptions\n\nfunction getListenerElements(): Map<El, Group> {\n ;(globalThis as any).__listenerElements__ = (globalThis as any).__listenerElements__ || new Map()\n return (globalThis as any).__listenerElements__\n}\n\nfunction getListenerCache(): Map<El, Map<string, Handler>> {\n ;(globalThis as any).__listenerCache__ = (globalThis as any).__listenerCache__ || new Map()\n return (globalThis as any).__listenerCache__\n}\n\n/**\n * The global event bus for managing event listeners attached to DOM elements.\n *\n * It's goal is to ensure that only one listener is attached to a DOM element for a given event,\n * regardless of the number of times `addEventListener` is called.\n */\n\nexport function addGlobalEventListener(node: El | null, type: string, handler: Handler, options?: Option) {\n if (!node) return noop\n\n // unique identifier for the event listener\n const hash = JSON.stringify({ type, options })\n\n // Subscribe pattern\n const listenerElements = getListenerElements()\n const listenerCache = getListenerCache()\n\n const group = listenerElements.get(node)\n\n if (!listenerElements.has(node)) {\n // create group of listeners per hash\n const group: Group = new Map([[hash, new Set([handler])]])\n listenerElements.set(node, group)\n } else if (group?.has(hash)) {\n group?.get(hash)?.add(handler)\n } else {\n group?.set(hash, new Set([handler]))\n }\n\n // add the event listener to the node or register it in the cache\n function attach(node: El) {\n // Publish pattern\n function listener(event: Event) {\n const group = listenerElements.get(node)\n group?.get(hash)?.forEach((fn) => fn(event))\n }\n\n if (!listenerCache?.has(node)) {\n listenerCache.set(node, new Map([[hash, listener]]))\n node.addEventListener(type, listener, options)\n return\n }\n\n if (!listenerCache?.get(node)?.has(hash)) {\n listenerCache.get(node)?.set(hash, listener)\n node.addEventListener(type, listener, options)\n }\n }\n\n attach(node)\n\n return function remove() {\n if (!listenerElements.has(node)) return\n\n const group = listenerElements.get(node)\n group?.get(hash)?.delete(handler)\n\n if (group?.get(hash)?.size === 0) {\n const listener = listenerCache.get(node)?.get(hash)!\n node.removeEventListener(type, listener, options)\n group?.delete(hash)\n listenerCache.get(node)?.delete(hash)\n\n if (group?.size === 0) {\n listenerElements.delete(node)\n listenerCache.delete(node)\n }\n }\n }\n}\n", "import {\n supportsMouseEvent,\n supportsPointerEvent,\n supportsTouchEvent,\n runIfFn,\n hasProp,\n isTouchEvent,\n} from \"@zag-js/utils\"\nimport { addGlobalEventListener } from \"./global-listener\"\nimport {\n AnyPointerEvent,\n DOMEventTarget,\n EventMap,\n PointerEventInfo,\n PointerNameMap,\n RefTarget,\n} from \"./listener.types\"\n\nconst isRef = (v: any): v is RefTarget => hasProp(v, \"current\")\n\nconst fallback = { pageX: 0, pageY: 0, clientX: 0, clientY: 0 }\n\nexport function extractInfo<T extends AnyPointerEvent = AnyPointerEvent>(event: T, type: \"page\" | \"client\" = \"page\") {\n const point = isTouchEvent(event) ? event.touches[0] || event.changedTouches[0] || fallback : event\n return {\n point: {\n x: point[`${type}X`],\n y: point[`${type}Y`],\n },\n }\n}\n\nexport function addDomEvent<K extends keyof EventMap>(\n target: DOMEventTarget,\n event: K,\n listener: (event: EventMap[K]) => void,\n options?: boolean | AddEventListenerOptions,\n) {\n const node = isRef(target) ? target.current : runIfFn(target)\n return addGlobalEventListener(node as HTMLElement | null, event, listener as any, options)\n}\n\nexport function addPointerEvent<K extends keyof EventMap>(\n target: DOMEventTarget,\n event: K,\n listener: (event: EventMap[K], info: PointerEventInfo) => void,\n options?: boolean | AddEventListenerOptions,\n) {\n const type = getEventName(event) ?? event\n return addDomEvent(target, type, wrapHandler(listener, event === \"pointerdown\"), options)\n}\n\nfunction wrapHandler<E extends EventMap[keyof EventMap]>(\n fn: (event: E, info: PointerEventInfo) => void,\n filter = false,\n) {\n const listener: EventListener = (event: any) => {\n fn(event, extractInfo(event))\n }\n return filter ? filterPrimaryPointer(listener) : listener\n}\n\nfunction filterPrimaryPointer(fn: EventListener): EventListener {\n return (event: Event) => {\n const win = ((event as UIEvent).view ?? window) as typeof window\n const isMouseEvent = event instanceof win.MouseEvent\n const isPrimary = !isMouseEvent || (isMouseEvent && (event as MouseEvent).button === 0)\n if (isPrimary) fn(event)\n }\n}\n\nexport function extractClientInfo(event: AnyPointerEvent) {\n return extractInfo(event, \"client\")\n}\n\nconst mouseEventNames: PointerNameMap = {\n pointerdown: \"mousedown\",\n pointermove: \"mousemove\",\n pointerup: \"mouseup\",\n pointercancel: \"mousecancel\",\n pointerover: \"mouseover\",\n pointerout: \"mouseout\",\n pointerenter: \"mouseenter\",\n pointerleave: \"mouseleave\",\n}\n\nconst touchEventNames: PointerNameMap = {\n pointerdown: \"touchstart\",\n pointermove: \"touchmove\",\n pointerup: \"touchend\",\n pointercancel: \"touchcancel\",\n}\n\nexport function getEventName(evt: keyof EventMap): keyof EventMap {\n if (supportsPointerEvent()) return evt\n if (supportsTouchEvent()) return touchEventNames[evt]\n if (supportsMouseEvent()) return mouseEventNames[evt]\n return evt\n}\n", "import { isLeftClick, pipe } from \"@zag-js/utils\"\nimport { addDomEvent } from \"./listener\"\nimport { nextTick } from \"./next-tick\"\n\nlet changeCount = 0\nlet originalBodyPointerEvents: string\n\ntype PointerEventOptions = {\n disabled: boolean\n document?: Document\n}\n\nexport function preventBodyPointerEvents(el: HTMLElement | null, opts: Partial<PointerEventOptions> = {}) {\n const { disabled = false, document: docProp } = opts\n const doc: Document = docProp || document\n\n let isTouchOrPenPressed = false\n let isLeftClickPressed = false\n\n function listen() {\n const onPointerDown = (event: PointerEvent) => {\n const isMouse = event.pointerType === \"mouse\"\n isTouchOrPenPressed = !isMouse\n isLeftClickPressed = isMouse && isLeftClick(event)\n }\n\n const onPointerUp = () => {\n isTouchOrPenPressed = false\n isLeftClickPressed = false\n }\n\n // prettier-ignore\n return pipe(\n addDomEvent(doc, \"pointerdown\", onPointerDown),\n addDomEvent(doc,\"pointerup\", onPointerUp)\n )\n }\n\n function reset() {\n changeCount--\n if (changeCount === 0) {\n doc.body.style.pointerEvents = originalBodyPointerEvents\n }\n if (el) {\n el.style.pointerEvents = \"\"\n }\n }\n\n function apply() {\n if (disabled) return\n\n if (changeCount === 0) {\n originalBodyPointerEvents = doc.body.style.pointerEvents\n }\n\n doc.body.style.pointerEvents = \"none\"\n if (el) {\n el.style.pointerEvents = \"auto\"\n }\n\n changeCount++\n\n return function () {\n if (isTouchOrPenPressed) {\n addDomEvent(doc, \"click\", reset, { once: true })\n } else if (isLeftClickPressed) {\n addDomEvent(doc, \"pointerup\", reset, { once: true })\n } else {\n reset()\n }\n }\n }\n\n const cleanups: Array<VoidFunction | undefined> = []\n cleanups.push(apply())\n nextTick(() => {\n cleanups.push(listen())\n })\n\n return function () {\n cleanups.forEach((cleanup) => cleanup?.())\n }\n}\n", "export const MAX_Z_INDEX = 2147483647\n", "export function isShadowRoot(el: any): el is ShadowRoot {\n return el?.toString() === \"[object ShadowRoot]\"\n}\n\nexport function isWindow(value: any): value is Window {\n return value?.toString() === \"[object Window]\"\n}\n\nexport const isWithinShadowRoot = (node: HTMLElement) => {\n return isShadowRoot(node.getRootNode())\n}\n\nexport function getOwnerDocument(el: Element | Window | null) {\n if (isWindow(el)) return el.document\n return el?.ownerDocument ?? document\n}\n\nexport function getOwnerWindow(el: HTMLElement) {\n return el?.ownerDocument.defaultView ?? window\n}\n\nexport function getDocumentElement(el: HTMLElement | Window): HTMLElement {\n return getOwnerDocument(el).documentElement\n}\n\nexport function getNodeName(node: HTMLElement | Window): string {\n return isWindow(node) ? \"\" : node ? node.localName || \"\" : \"\"\n}\n\nexport function getEventWindow(event: UIEvent) {\n if (event.view) return event.view\n let target = event.currentTarget\n if (target != null) return getOwnerWindow(target as HTMLElement)\n return window\n}\n\nexport function getEventTarget<T extends EventTarget>(event: Event): T | null {\n return (event.composedPath?.()[0] ?? event.target) as T | null\n}\n\nexport function getActiveElement(el: HTMLElement): HTMLElement | null {\n let activeElement = getOwnerDocument(el).activeElement as HTMLElement | null\n\n while (activeElement && activeElement.shadowRoot) {\n const el = activeElement.shadowRoot.activeElement as HTMLElement | null\n if (el === activeElement) break\n else activeElement = el\n }\n\n return activeElement\n}\n\nexport function getActiveDescendant(node: HTMLElement | null): HTMLElement | null {\n if (!node) return null\n const id = node.getAttribute(\"aria-activedescendant\")\n if (!id) return null\n return getOwnerDocument(node).getElementById(id)\n}\n\nexport function getParent(el: HTMLElement): HTMLElement {\n const doc = getOwnerDocument(el)\n if (getNodeName(el) === \"html\") return el\n return el.assignedSlot || el.parentElement || doc.documentElement\n}\n\nexport function contains(\n parent: HTMLElement | EventTarget | null | undefined,\n child: HTMLElement | EventTarget | null,\n) {\n if (!parent) return false\n return parent === child || (isHTMLElement(parent) && isHTMLElement(child) && parent.contains(child))\n}\n\nexport function isHTMLElement(v: any): v is HTMLElement {\n return typeof v === \"object\" && v?.nodeType === Node.ELEMENT_NODE && typeof v?.nodeName === \"string\"\n}\n\nexport const isDisabled = (el: HTMLElement | null): boolean => {\n return el?.getAttribute(\"disabled\") != null || !!el?.getAttribute(\"aria-disabled\") === true\n}\n\nexport function isElementEditable(el: HTMLElement | null) {\n if (el == null) return false\n try {\n return (\n (el instanceof getOwnerWindow(el).HTMLInputElement && el.selectionStart != null) ||\n /(textarea|select)/.test(el.localName) ||\n el.isContentEditable\n )\n } catch (error) {\n return false\n }\n}\n", "import { contains } from \"./query\"\n\nexport function isKeyboardClick(e: Pick<MouseEvent, \"detail\" | \"clientX\" | \"clientY\">) {\n return e.detail === 0 || (e.clientX === 0 && e.clientY === 0)\n}\n\nexport function isPrintableKey(e: Pick<KeyboardEvent, \"key\" | \"ctrlKey\" | \"metaKey\">): boolean {\n return e.key.length === 1 && !e.ctrlKey && !e.metaKey\n}\n\ntype NativeEvent<E> = React.ChangeEvent<any> extends E\n ? InputEvent\n : E extends React.SyntheticEvent<any, infer T>\n ? T\n : never\n\nexport function getNativeEvent<E>(e: E): NativeEvent<E> {\n return (e as any).nativeEvent ?? e\n}\n\nexport function queueBeforeEvent(el: Element, type: string, fn: VoidFunction) {\n const raf = requestAnimationFrame(() => {\n el.removeEventListener(type, invoke, true)\n fn()\n })\n\n const invoke = () => {\n cancelAnimationFrame(raf)\n fn()\n }\n\n el.addEventListener(type, invoke, { once: true, capture: true })\n\n return raf\n}\n\nexport function isPortalEvent(event: Pick<Event, \"currentTarget\" | \"target\">): boolean {\n return !contains(event.currentTarget, event.target)\n}\n\nexport function isSelfTarget(event: Pick<Event, \"target\" | \"currentTarget\">): boolean {\n return event.target === event.currentTarget\n}\n", "export function fireEvent(el: Element, type: string, init?: EventInit) {\n const event = new Event(type, init)\n return el.dispatchEvent(event)\n}\n\nexport function fireCustomEvent(el: Element, type: string, init?: CustomEventInit) {\n const event = new CustomEvent(type, init)\n return el.dispatchEvent(event)\n}\n\nexport function fireBlurEvent(el: Element, init?: FocusEventInit) {\n const event = new FocusEvent(\"blur\", init)\n const allowed = el.dispatchEvent(event)\n const bubbleInit = { ...init, bubbles: true }\n el.dispatchEvent(new FocusEvent(\"focusout\", bubbleInit))\n return allowed\n}\n\nexport function fireKeyboardEvent(el: Element, type: string, init?: KeyboardEventInit) {\n const event = new KeyboardEvent(type, init)\n return el.dispatchEvent(event)\n}\n\nexport function fireClickEvent(el: Element, init?: PointerEventInit) {\n const event = typeof PointerEvent !== \"undefined\" ? new PointerEvent(\"click\", init) : new MouseEvent(\"click\", init)\n return el.dispatchEvent(event)\n}\n", "/**\n * Determine if the blur event within an element is valid\n */\nexport function validateBlur(event: Event, opts: Options) {\n const exclude = Array.isArray(opts.exclude) ? opts.exclude : [opts.exclude]\n const relatedTarget = (event.relatedTarget ?? opts.fallback) as HTMLElement\n return exclude.every((el) => !el?.contains(relatedTarget))\n}\n\ntype MaybeArray<T> = T | T[]\n\ntype Options = {\n exclude: MaybeArray<HTMLElement | null>\n fallback?: HTMLElement | null\n}\n\ntype Event = Pick<FocusEvent, \"relatedTarget\">\n", "import { getComputedStyle } from \"./computed-style\"\nimport { isDisabled, isHTMLElement } from \"./query\"\n\nexport const focusableSelector = /*#__PURE__*/ [\n \"input:not([disabled]):not([type=hidden])\",\n \"select:not([disabled])\",\n \"textarea:not([disabled])\",\n \"button:not([disabled])\",\n \"embed\",\n \"iframe\",\n \"object\",\n \"a[href]\",\n \"area[href]\",\n \"[tabindex]\",\n \"audio[controls]\",\n \"video[controls]\",\n \"*[tabindex]:not([aria-disabled])\",\n \"[contenteditable]:not([contenteditable=false])\",\n \"details > summary:first-of-type\",\n].join(\",\")\n\nexport function isHidden(el: HTMLElement | null, until?: HTMLElement) {\n const style = getComputedStyle(el)\n if (!el || style.getPropertyValue(\"visibility\") === \"hidden\") return true\n while (el) {\n if (until != null && el === until) return false\n if (style.getPropertyValue(\"display\") === \"none\") return true\n el = el.parentElement\n }\n return false\n}\n\n/**\n * Returns the focusable elements within the element\n */\nexport const getFocusables = (el: HTMLElement | Document | null, includeContainer: boolean | \"if-empty\" = false) => {\n if (!el) return []\n let els = Array.from(el.querySelectorAll<HTMLElement>(focusableSelector))\n\n const shouldAddContainer = includeContainer == true || (includeContainer == \"if-empty\" && els.length === 0)\n\n if (shouldAddContainer && isHTMLElement(el)) {\n els.unshift(el)\n }\n\n return els.filter((el) => isFocusable(el) && !isHidden(el))\n}\n\n/**\n * Whether this element is focusable\n */\nexport const isFocusable = (el: HTMLElement | null) => {\n if (!isHTMLElement(el) || isHidden(el) || isDisabled(el)) return false\n return el?.matches(focusableSelector)\n}\n\n/**\n * Returns the tabbable elements within the element\n */\nexport const getTabbables = (el: HTMLElement | Document | null, includeContainer: boolean | \"if-empty\" = false) => {\n if (!el) return []\n return getFocusables(el, includeContainer).filter(isTabbable)\n}\n\n/**\n * Whether this element is tabbable\n */\nexport const isTabbable = (el: HTMLElement | null) => {\n return isFocusable(el) && !isDisabled(el) && !isHidden(el)\n}\n", "import { noop } from \"@zag-js/utils\"\n\ntype Callback = (v: MutationRecord) => void\n\nexport function observeAttributes(node: Element | null, attributes: string | string[], fn: Callback) {\n if (!node) return noop\n const attrs = Array.isArray(attributes) ? attributes : [attributes]\n const win = node.ownerDocument.defaultView || window\n const obs = new win.MutationObserver((changes) => {\n for (const change of changes) {\n if (change.type === \"attributes\" && change.attributeName && attrs.includes(change.attributeName)) {\n fn(change)\n }\n }\n })\n\n obs.observe(node, { attributes: true, attributeFilter: attrs })\n\n return () => obs.disconnect()\n}\n\nexport function observeChildren(node: Element | null, fn: Callback) {\n if (!node) return noop\n const win = node.ownerDocument.defaultView || window\n const obs = new win.MutationObserver((changes) => {\n for (const change of changes) {\n if (change.type === \"childList\") {\n fn(change)\n }\n }\n })\n\n obs.observe(node, { childList: true, subtree: true })\n\n return () => obs.disconnect()\n}\n", "import { observeAttributes } from \"./mutation-observer\"\n\nexport function getClosestForm(el: HTMLElement) {\n if (isFormElement(el)) return el.form\n else return el.closest(\"form\")\n}\n\nfunction isFormElement(el: HTMLElement): el is HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement {\n return el.matches(\"textarea, input, select, button\")\n}\n\nexport function trackFormReset(el: HTMLElement | null | undefined, callback: () => void) {\n if (!el) return\n const form = getClosestForm(el)\n form?.addEventListener(\"reset\", callback, { passive: true })\n return () => {\n form?.removeEventListener(\"reset\", callback)\n }\n}\n\nexport function trackFieldsetDisabled(el: HTMLElement | null | undefined, callback: (disabled: boolean) => void) {\n const fieldset = el?.closest(\"fieldset\")\n if (!fieldset) return\n callback(fieldset.disabled)\n return observeAttributes(fieldset, [\"disabled\"], () => callback(fieldset.disabled))\n}\n\nexport function isNativeDisabled(el: HTMLElement) {\n return el.matches(\":disabled\")\n}\n", "import { getOwnerWindow } from \"./query\"\n\ntype DescriptorOptions = {\n type: \"input\" | \"textarea\"\n property: \"value\" | \"checked\"\n}\n\nfunction getDescriptor(el: HTMLElement, options: DescriptorOptions) {\n const { type, property } = options\n const win = getOwnerWindow(el)\n const _type = type === \"input\" ? \"HTMLInputElement\" : \"HTMLTextAreaElement\"\n const proto = win[_type].prototype\n return Object.getOwnPropertyDescriptor(proto, property) ?? {}\n}\n\nexport function dispatchInputValueEvent(el: HTMLElement, value: string | number) {\n const win = getOwnerWindow(el)\n if (!(el instanceof win.HTMLInputElement)) return\n const desc = getDescriptor(el, { type: \"input\", property: \"value\" })\n desc.set?.call(el, value)\n const event = new win.Event(\"input\", { bubbles: true })\n el.dispatchEvent(event)\n}\n\nexport function dispatchInputCheckedEvent(el: HTMLElement, checked: boolean) {\n const win = getOwnerWindow(el)\n if (!(el instanceof win.HTMLInputElement)) return\n const desc = getDescriptor(el, { type: \"input\", property: \"checked\" })\n desc.set?.call(el, checked)\n const event = new win.Event(\"click\", { bubbles: true })\n el.dispatchEvent(event)\n}\n\nexport function trackInputPropertyMutation(\n el: HTMLInputElement | null,\n options: DescriptorOptions & { fn?: (value: string) => void },\n) {\n const { fn, property, type } = options\n\n if (!fn || !el) return\n\n const { get, set } = getDescriptor(el, { property, type })\n\n let run = true\n\n Object.defineProperty(el, property, {\n get() {\n return get?.call(this)\n },\n set(value: string) {\n if (run) fn(value)\n return set?.call(this, value)\n },\n })\n\n return () => {\n run = false\n }\n}\n", "import type { KeyboardEvent } from \"react\"\n\ntype EventKey =\n | \"ArrowDown\"\n | \"ArrowUp\"\n | \"ArrowLeft\"\n | \"ArrowRight\"\n | \"Space\"\n | \"Enter\"\n | \"Comma\"\n | \"Escape\"\n | \"Backspace\"\n | \"Delete\"\n | \"Home\"\n | \"End\"\n | \"Tab\"\n | \"PageUp\"\n | \"PageDown\"\n | (string & {})\n\nexport type EventKeyMap = Partial<Record<EventKey, (event: React.KeyboardEvent) => void>>\n\nconst rtlKeyMap = {\n ArrowLeft: \"ArrowRight\",\n ArrowRight: \"ArrowLeft\",\n Home: \"End\",\n End: \"Home\",\n}\n\nconst sameKeyMap = {\n Up: \"ArrowUp\",\n Down: \"ArrowDown\",\n Esc: \"Escape\",\n \" \": \"Space\",\n \",\": \"Comma\",\n Left: \"ArrowLeft\",\n Right: \"ArrowRight\",\n}\n\ntype EventKeyOptions = {\n dir?: \"ltr\" | \"rtl\"\n orientation?: \"horizontal\" | \"vertical\"\n}\n\n/**\n * Determine the event key based on text direction.\n */\nexport function getEventKey(event: KeyboardEvent, options: EventKeyOptions = {}) {\n const { dir = \"ltr\", orientation = \"horizontal\" } = options\n\n let { key } = event\n key = sameKeyMap[key] ?? key // normalize key\n\n const isRtl = dir === \"rtl\" && orientation === \"horizontal\"\n\n if (isRtl && key in rtlKeyMap) {\n key = rtlKeyMap[key]\n }\n\n return key\n}\n\nconst PAGE_KEYS = new Set([\"PageUp\", \"PageDown\"])\nconst ARROW_KEYS = new Set([\"ArrowUp\", \"ArrowDown\", \"ArrowLeft\", \"ArrowRight\"])\n\n/**\n * Determine the step factor for keyboard events\n */\nexport function getEventStep(event: KeyboardEvent) {\n if (event.ctrlKey || event.metaKey) {\n return 0.1\n } else {\n const isPageKey = PAGE_KEYS.has(event.key)\n const isSkipKey = isPageKey || (event.shiftKey && ARROW_KEYS.has(event.key))\n return isSkipKey ? 10 : 1\n }\n}\n", "export const visuallyHiddenStyle = {\n border: \"0\",\n clip: \"rect(0 0 0 0)\",\n height: \"1px\",\n margin: \"-1px\",\n overflow: \"hidden\",\n padding: \"0\",\n position: \"absolute\",\n width: \"1px\",\n whiteSpace: \"nowrap\",\n wordWrap: \"normal\",\n} as const\n\nexport function setVisuallyHidden(el: HTMLElement) {\n Object.assign(el.style, visuallyHiddenStyle)\n}\n", "import { setVisuallyHidden } from \"./visually-hidden\"\n\nexport type LiveRegionOptions = {\n level: \"polite\" | \"assertive\"\n document?: Document\n root?: HTMLElement | null\n delay?: number\n}\n\nexport type LiveRegion = ReturnType<typeof createLiveRegion>\n\nconst LIVE_REGION_ID = \"__live-region__\"\n\nexport function createLiveRegion(opts: Partial<LiveRegionOptions> = {}) {\n const { level = \"polite\", document: doc = document, root, delay: _delay = 0 } = opts\n\n const win = doc.defaultView ?? window\n const parent = root ?? doc.body\n\n function announce(message: string, delay?: number) {\n const oldRegion = doc.getElementById(LIVE_REGION_ID)\n\n // remove old region\n oldRegion?.remove()\n\n // Did an override level get set?\n delay = delay ?? _delay\n\n // create fresh region\n const region = doc.createElement(\"span\")\n region.id = LIVE_REGION_ID\n region.dataset.liveAnnouncer = \"true\"\n\n // Determine redundant role\n const role = level !== \"assertive\" ? \"status\" : \"alert\"\n\n // add role and attributes\n region.setAttribute(\"aria-live\", level)\n region.setAttribute(\"role\", role)\n\n // hide live region\n setVisuallyHidden(region)\n\n parent.appendChild(region)\n\n // populate region to trigger it\n win.setTimeout(() => {\n region.textContent = message\n }, delay)\n }\n\n function destroy() {\n const oldRegion = doc.getElementById(LIVE_REGION_ID)\n oldRegion?.remove()\n }\n\n return {\n announce,\n destroy,\n toJSON() {\n return LIVE_REGION_ID\n },\n }\n}\n", "type Root = Document | Element | null | undefined\n\nexport function queryAll<T extends HTMLElement = HTMLElement>(root: Root, selector: string) {\n return Array.from(root?.querySelectorAll<T>(selector) ?? [])\n}\n\nexport function query<T extends HTMLElement = HTMLElement>(root: Root, selector: string) {\n return root?.querySelector<T>(selector)\n}\n\nexport function itemById<T extends HTMLElement>(v: T[], id: string) {\n return v.find((node) => node.id === id)\n}\n\nexport function indexOfId<T extends HTMLElement>(v: T[], id: string) {\n const item = itemById(v, id)\n return item ? v.indexOf(item) : -1\n}\n\nexport function nextById<T extends HTMLElement>(v: T[], id: string, loop = true) {\n let idx = indexOfId(v, id)\n idx = loop ? (idx + 1) % v.length : Math.min(idx + 1, v.length - 1)\n return v[idx]\n}\n\nexport function prevById<T extends HTMLElement>(v: T[], id: string, loop = true) {\n let idx = indexOfId(v, id)\n if (idx === -1) return loop ? v[v.length - 1] : null\n idx = loop ? (idx - 1 + v.length) % v.length : Math.max(0, idx - 1)\n return v[idx]\n}\n\nconst getValueText = <T extends HTMLElement>(item: T) => item.dataset.valuetext ?? item.textContent ?? \"\"\n\nconst match = (valueText: string, query: string) => valueText.toLowerCase().startsWith(query.toLowerCase())\n\nconst wrap = <T>(v: T[], idx: number) => {\n return v.map((_, index) => v[(Math.max(idx, 0) + index) % v.length])\n}\n\nexport function findByText<T extends HTMLElement>(v: T[], text: string, currentId?: string | null) {\n const index = currentId ? indexOfId(v, currentId) : -1\n let items = currentId ? wrap(v, index) : v\n\n const isSingleKey = text.length === 1\n\n if (isSingleKey) {\n items = items.filter((item) => item.id !== currentId)\n }\n\n return items.find((item) => match(getValueText(item), text))\n}\n\nexport function sortByTreeOrder<T extends HTMLElement>(v: T[]) {\n return v.sort((a, b) => (a.compareDocumentPosition(b) & 2 ? 1 : -1))\n}\n", "// Credits: https://github.com/adobe/react-spectrum/blob/e81cfec20056338c7987c513826dc45df32f3db4/packages/%40react-aria/interactions/src/textSelection.ts\nimport { isIos } from \"@zag-js/utils\"\nimport { nextTick } from \"./next-tick\"\n\ntype State = \"default\" | \"disabled\" | \"restoring\"\n\nlet state: State = \"default\"\nlet savedUserSelect = \"\"\nlet modifiedElementMap = new WeakMap<HTMLElement, string>()\n\nexport function disableTextSelection({ target, doc }: { target?: HTMLElement; doc?: Document } = {}) {\n const _document = doc ?? document\n\n if (isIos()) {\n if (state === \"default\") {\n savedUserSelect = _document.documentElement.style.webkitUserSelect\n _document.documentElement.style.webkitUserSelect = \"none\"\n }\n\n state = \"disabled\"\n } else if (target) {\n modifiedElementMap.set(target, target.style.userSelect)\n target.style.userSelect = \"none\"\n }\n\n return () => restoreTextSelection({ target, doc: _document })\n}\n\nexport function restoreTextSelection({ target, doc }: { target?: HTMLElement; doc?: Document } = {}) {\n const _document = doc ?? document\n\n if (isIos()) {\n if (state !== \"disabled\") return\n state = \"restoring\"\n\n setTimeout(() => {\n nextTick(() => {\n if (state === \"restoring\") {\n if (_document.documentElement.style.webkitUserSelect === \"none\") {\n _document.documentElement.style.webkitUserSelect = savedUserSelect || \"\"\n }\n\n savedUserSelect = \"\"\n state = \"default\"\n }\n })\n }, 300)\n } else {\n if (target && modifiedElementMap.has(target)) {\n let targetOldUserSelect = modifiedElementMap.get(target)\n\n if (target.style.userSelect === \"none\") {\n target.style.userSelect = targetOldUserSelect ?? \"\"\n }\n\n if (target.getAttribute(\"style\") === \"\") {\n target.removeAttribute(\"style\")\n }\n modifiedElementMap.delete(target)\n }\n }\n}\n", "import { isLeftClick, isMouseEvent, pipe } from \"@zag-js/utils\"\nimport { addDomEvent, addPointerEvent } from \"./listener\"\nimport type { AnyPointerEvent, EventListenerWithPointInfo as Listener, PointerEventInfo } from \"./listener.types\"\nimport { disableTextSelection } from \"./text-selection\"\n\nexport function trackPointerDown(doc: Document, onPointerDown: (el: HTMLElement) => void) {\n const win = doc.defaultView ?? window\n const fn = (event: PointerEvent) => {\n if (event.target instanceof win.HTMLElement) {\n onPointerDown(event.target)\n }\n }\n return addDomEvent(doc, \"pointerdown\", fn)\n}\n\ntype TrackPointerMoveOptions = {\n ctx: { doc?: Document; threshold?: number }\n onPointerUp: VoidFunction\n onPointerMove: (info: PointerEventInfo, event: AnyPointerEvent) => void\n}\n\nexport function trackPointerMove(opts: TrackPointerMoveOptions) {\n const { onPointerMove, onPointerUp, ctx } = opts\n const { doc = document, threshold = 5 } = ctx\n\n const handlePointerMove: Listener = (event, info) => {\n const { point: p } = info\n const distance = Math.sqrt(p.x ** 2 + p.y ** 2)\n if (distance < threshold) return\n\n // Because Safari doesn't trigger mouseup events when it's above a `<select>`\n if (isMouseEvent(event) && isLeftClick(event)) {\n onPointerUp()\n return\n }\n\n onPointerMove(info, event)\n }\n\n return pipe(\n addPointerEvent(doc, \"pointermove\", handlePointerMove, false),\n addPointerEvent(doc, \"pointerup\", onPointerUp, false),\n addPointerEvent(doc, \"pointercancel\", onPointerUp, false),\n addPointerEvent(doc, \"contextmenu\", onPointerUp, false),\n disableTextSelection({ doc }),\n )\n}\n", "import { pipe } from \"@zag-js/utils\"\nimport { addDomEvent } from \"./listener\"\n\ntype PointerLockHandlers = {\n onPointerLock?: VoidFunction\n onPointerUnlock?: VoidFunction\n}\n\nexport function addPointerlockChangeListener(doc: Document, fn: VoidFunction) {\n return addDomEvent(doc, \"pointerlockchange\", fn, false)\n}\n\nexport function addPointerlockErrorListener(doc: Document, fn: (e: Event) => void) {\n doc.addEventListener(\"pointerlockerror\", fn, false)\n return function cleanup() {\n doc.removeEventListener(\"pointerlockerror\", fn, false)\n }\n}\n\nexport function requestPointerLock(doc: Document, handlers: PointerLockHandlers = {}) {\n const { onPointerLock, onPointerUnlock } = handlers\n const body = doc.body\n\n const supported = \"pointerLockElement\" in doc || \"mozPointerLockElement\" in doc\n const locked = !!doc.pointerLockElement\n\n function onPointerChange() {\n if (locked) onPointerLock?.()\n else onPointerUnlock?.()\n }\n\n function onPointerError(event: Event) {\n if (locked) onPointerUnlock?.()\n console.error(\"PointerLock error occured:\", event)\n exit()\n }\n\n function exit() {\n doc.exitPointerLock()\n }\n\n if (!supported) return\n\n body.requestPointerLock()\n\n const cleanup = pipe(\n addPointerlockChangeListener(doc, onPointerChange),\n addPointerlockErrorListener(doc, onPointerError),\n )\n\n return function dispose() {\n if (!supported) return\n cleanup()\n exit()\n }\n}\n", "// Credit goes to the radix-ui team for this utility:\n// https://github.com/radix-ui/primitives/blob/main/packages/core/rect/src/observeElementRect.ts\n\ntype Fn = (rect: DOMRect) => void\ntype ObservedData = { rect: DOMRect; callbacks: Fn[] }\nexport type Measurable = { getBoundingClientRect(): DOMRect }\n\nfunction getObservedElements(): Map<Measurable, ObservedData> {\n ;(globalThis as any).__rectObserverMap__ = (globalThis as any).__rectObserverMap__ || new Map()\n return (globalThis as any).__rectObserverMap__\n}\n\nexport function observeElementRect(el: Measurable, fn: Fn) {\n const observedElements = getObservedElements()\n\n const data = observedElements.get(el)\n\n if (!data) {\n observedElements.set(el, { rect: {} as DOMRect, callbacks: [fn] })\n\n if (observedElements.size === 1) {\n rafId = requestAnimationFrame(runLoop)\n }\n } else {\n data.callbacks.push(fn)\n fn(el.getBoundingClientRect())\n }\n\n return function unobserve() {\n const data = observedElements.get(el)\n if (!data) return\n\n const index = data.callbacks.indexOf(fn)\n if (index > -1) {\n data.callbacks.splice(index, 1)\n }\n\n if (data.callbacks.length === 0) {\n observedElements.delete(el)\n\n if (observedElements.size === 0) {\n cancelAnimationFrame(rafId)\n }\n }\n }\n}\n\nlet rafId: number\n\nfunction runLoop() {\n const observedElements = getObservedElements()\n\n const changedRectsData: Array<ObservedData> = []\n\n observedElements.forEach((data, element) => {\n const newRect = element.getBoundingClientRect()\n\n if (!isEqual(data.rect, newRect)) {\n data.rect = newRect\n changedRectsData.push(data)\n }\n })\n\n changedRectsData.forEach((data) => {\n data.callbacks.forEach((callback) => callback(data.rect))\n })\n\n rafId = requestAnimationFrame(runLoop)\n}\n\nfunction isEqual(rect1: DOMRect, rect2: DOMRect) {\n return (\n rect1.width === rect2.width &&\n rect1.height === rect2.height &&\n rect1.top === rect2.top &&\n rect1.right === rect2.right &&\n rect1.bottom === rect2.bottom &&\n rect1.left === rect2.left\n )\n}\n", "import { getComputedStyle } from \"./computed-style\"\nimport { getNodeName, getOwnerDocument, getOwnerWindow, getParent, isHTMLElement, isWindow } from \"./query\"\n\nexport function isScrollParent(el: HTMLElement): boolean {\n const { overflow, overflowX, overflowY } = getComputedStyle(el)\n return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX)\n}\n\nexport function getScrollParent(el: HTMLElement): HTMLElement {\n if ([\"html\", \"body\", \"#document\"].includes(getNodeName(el))) {\n return getOwnerDocument(el).body\n }\n\n if (isHTMLElement(el) && isScrollParent(el)) {\n return el\n }\n\n return getScrollParent(getParent(el))\n}\n\ntype Target = Array<VisualViewport | Window | HTMLElement>\n\nexport function getScrollParents(el: HTMLElement, list: Target = []): Target {\n const scrollParent = getScrollParent(el)\n const isBody = scrollParent === getOwnerDocument(el).body\n const win = getOwnerWindow(scrollParent)\n\n const target = isBody\n ? ([win] as Target).concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : [])\n : scrollParent\n\n const parents = list.concat(target)\n if (isBody) return parents\n\n return parents.concat(getScrollParents(getParent(<HTMLElement>target)))\n}\n\nexport function getScrollOffset(el: HTMLElement) {\n if (isWindow(el)) {\n return { scrollLeft: el.scrollX, scrollTop: el.scrollY }\n }\n\n return { scrollLeft: el.scrollLeft, scrollTop: el.scrollTop }\n}\n", "import { findByText } from \"./nodelist\"\n\nexport type TypeaheadState = {\n keysSoFar: string\n timer: number\n}\n\nexport type TypeaheadOptions = {\n state: TypeaheadState\n activeId: string | null\n key: string\n timeout?: number\n}\n\nfunction findByTypeaheadImpl<T extends HTMLElement>(_items: T[], options: TypeaheadOptions) {\n const { state, activeId, key, timeout = 350 } = options\n\n const search = state.keysSoFar + key\n const isRepeated = search.length > 1 && Array.from(search).every((char) => char === search[0])\n\n const query = isRepeated ? search[0] : search\n\n let items = _items.slice()\n\n const next = findByText(items, query, activeId)\n\n function cleanup() {\n clearTimeout(state.timer)\n state.timer = -1\n }\n\n function update(value: string) {\n state.keysSoFar = value\n cleanup()\n\n if (value !== \"\") {\n state.timer = +setTimeout(() => {\n update(\"\")\n cleanup()\n }, timeout)\n }\n }\n\n update(search)\n\n return next\n}\nexport const findByTypeahead = /*#__PURE__*/ Object.assign(findByTypeaheadImpl, {\n defaultOptions: {\n keysSoFar: \"\",\n timer: -1,\n },\n})\n", "import { cast } from \"@zag-js/utils\"\nimport { addDomEvent } from \"./listener\"\n\nexport function trackDocumentVisibility(_doc: Document, callback: (hidden: boolean) => void) {\n const doc = cast(_doc) as Document & { msHidden?: boolean; webkitHidden?: boolean }\n return addDomEvent(doc, \"visibilitychange\", () => {\n const hidden = doc.hidden || doc.msHidden || doc.webkitHidden\n callback(!!hidden)\n })\n}\n", "import { addDomEvent } from \"./listener\"\n\ntype ViewportSize = {\n width: number\n height: number\n}\n\ntype Options = {\n document?: Document\n resolve?(data: ViewportSize): void\n}\n\nexport function trackVisualViewport(options: Options) {\n const { document: doc, resolve } = options\n const win = doc?.defaultView || window\n resolve?.(getViewportSize(win))\n const onResize = () => resolve?.(getViewportSize(win))\n return addDomEvent(win.visualViewport ?? win, \"resize\", onResize)\n}\n\nfunction getViewportSize(win: Window): ViewportSize {\n return {\n width: win.visualViewport?.width || win.innerWidth,\n height: win.visualViewport?.height || win.innerHeight,\n }\n}\n", "export function waitFor<T>(predicate: () => T): Promise<T> {\n let value = predicate()\n if (!!value) return Promise.resolve(value)\n return new Promise((resolve) => {\n const id = globalThis.setInterval(function () {\n let value = predicate()\n if (value) {\n globalThis.clearInterval(id)\n resolve(value)\n }\n }, 0)\n })\n}\n\nexport function waitForEvent(el: HTMLElement, eventName: string) {\n return new Promise<void>((resolve) => {\n function done(event: Event) {\n if (event.target === el) {\n el.removeEventListener(eventName, done)\n resolve()\n }\n }\n\n el.addEventListener(eventName, done)\n })\n}\n", "import { RectEdge, RectValue } from \"./types\"\n\nconst point = (x: number, y: number) => ({ x, y })\n\nexport class Rect {\n static create(v: RectValue) {\n return new Rect(v)\n }\n protected constructor(private v: RectValue) {}\n set(n: Partial<RectValue>) {\n return new Rect(Object.assign({}, this.v, n))\n }\n clone() {\n return new Rect(this.v)\n }\n get x() {\n return this.v.x\n }\n get y() {\n return this.v.y\n }\n get width() {\n return this.v.width\n }\n get height() {\n return this.v.height\n }\n get minX() {\n return this.v.x\n }\n get midX() {\n return this.v.x + this.v.width / 2\n }\n get maxX() {\n return this.v.x + this.v.width\n }\n get minY() {\n return this.v.y\n }\n get midY() {\n return this.v.y + this.v.height / 2\n }\n get maxY() {\n return this.v.y + this.v.height\n }\n get center() {\n return point(this.midX, this.midY)\n }\n get centers() {\n const top = point(this.midX, this.minY)\n const right = point(this.maxX, this.midY)\n const bottom = point(this.midX, this.maxY)\n const left = point(this.minX, this.midY)\n return { top, right, bottom, left }\n }\n get corners() {\n const top = point(this.minX, this.minY)\n const right = point(this.maxX, this.minY)\n const bottom = point(this.maxX, this.maxY)\n const left = point(this.minX, this.maxY)\n return { top, right, bottom, left }\n }\n\n get edges() {\n const c = this.corners\n const top: RectEdge = [c.top, c.right]\n const right: RectEdge = [c.right, c.bottom]\n const bottom: RectEdge = [c.left, c.bottom]\n const left: RectEdge = [c.top, c.left]\n return { top, right, bottom, left }\n }\n}\n", "type Key = keyof CSSStyleDeclaration | (string & {})\ntype Styles = Record<Key, any>\ntype El = HTMLElement | null | undefined\n\nconst styleCache: WeakMap<HTMLElement, Styles> = new WeakMap()\n\nexport function getComputedStyle(el: El): Styles {\n if (!el) return {} as Styles\n let style: Styles | undefined = styleCache.get(el)\n if (!style) {\n const win = el?.ownerDocument.defaultView ?? window\n style = win.getComputedStyle(el) as Styles\n styleCache.set(el, style)\n }\n return style\n}\n", "import { Rect } from \"./rect\"\nimport { getComputedStyle } from \"./computed-style\"\n\nexport function getElementRect(el: HTMLElement, opts: ElementRectOptions = {}): Rect {\n return Rect.create(getClientRect(el, opts))\n}\n\nexport type ElementRectOptions = {\n /**\n * Whether to exclude the element's scrollbar size from the calculation.\n */\n excludeScrollbar?: boolean\n /**\n * Whether to exclude the element's borders from the calculation.\n */\n excludeBorders?: boolean\n}\n\nfunction getClientRect(el: HTMLElement, opts: ElementRectOptions = {}) {\n const { excludeScrollbar = false, excludeBorders = false } = opts\n\n const { x, y, width, height } = el.getBoundingClientRect()\n const r = { x, y, width, height }\n\n const style = getComputedStyle(el)\n\n const { borderLeftWidth, borderTopWidth, borderRightWidth, borderBottomWidth } = style\n\n const borderXWidth = sum(borderLeftWidth, borderRightWidth)\n const borderYWidth = sum(borderTopWidth, borderBottomWidth)\n\n if (excludeBorders) {\n r.width -= borderXWidth\n r.height -= borderYWidth\n r.x += px(borderLeftWidth)\n r.y += px(borderTopWidth)\n }\n\n if (excludeScrollbar) {\n const scrollbarWidth = el.offsetWidth - el.clientWidth - borderXWidth\n const scrollbarHeight = el.offsetHeight - el.clientHeight - borderYWidth\n r.width -= scrollbarWidth\n r.height -= scrollbarHeight\n }\n\n return r\n}\n\nconst px = (v: string) => parseFloat(v.replace(\"px\", \"\"))\n\nconst sum = (...vals: string[]) => vals.reduce((sum, v) => sum + (v ? px(v) : 0), 0)\n", "export function toArray<T>(v: T | T[] | undefined | null): T[] {\n if (!v) return []\n return Array.isArray(v) ? v : [v]\n}\n\nexport const fromLength = (length: number) => Array.from(Array(length).keys())\n\nexport const first = <T>(v: T[]): T | undefined => v[0]\n\nexport const last = <T>(v: T[]): T | undefined => v[v.length - 1]\n\nexport const isEmpty = <T>(v: T[]): boolean => v.length === 0\n\nexport const has = <T>(v: T[], t: any): boolean => v.indexOf(t) !== -1\n\nexport const add = <T>(v: T[], ...items: T[]): T[] => v.concat(items)\n\nexport const remove = <T>(v: T[], item: T): T[] => removeAt(v, v.indexOf(item))\n\nexport const removeAt = <T>(v: T[], i: number): T[] => {\n if (i > -1) v.splice(i, 1)\n return v\n}\n\nexport function clear<T>(v: T[]): T[] {\n while (v.length > 0) v.pop()\n return v\n}\n\nexport type IndexOptions = {\n step?: number\n loop?: boolean\n}\n\nexport function nextIndex<T>(v: T[], idx: number, opts: IndexOptions = {}): number {\n const { step = 1, loop = true } = opts\n const next = idx + step\n const len = v.length\n const last = len - 1\n if (idx === -1) return step > 0 ? 0 : last\n if (next < 0) return loop ? last : 0\n if (next >= len) return loop ? 0 : idx > len ? len : idx\n return next\n}\n\nexport function next<T>(v: T[], idx: number, opts: IndexOptions = {}): T | undefined {\n return v[nextIndex(v, idx, opts)]\n}\n\nexport function prevIndex<T>(v: T[], idx: number, opts: IndexOptions = {}): number {\n const { step = 1, loop = true } = opts\n return nextIndex(v, idx, { step: -step, loop })\n}\n\nexport function prev<T>(v: T[], index: number, opts: IndexOptions = {}): T | undefined {\n return v[prevIndex(v, index, opts)]\n}\n\nexport const chunk = <T>(v: T[], size: number): T[][] => {\n const res: T[][] = []\n return v.reduce((rows, value, index) => {\n if (index % size === 0) rows.push([value])\n else last(rows)?.push(value)\n return rows\n }, res)\n}\n", "export const isDev = () => process.env.NODE_ENV !== \"production\"\nexport const isDom = () => typeof window !== \"undefined\"\n\nexport const isArray = (v: any): v is any[] => Array.isArray(v)\nexport const isBoolean = (v: any): v is boolean => v === true || v === false\nexport const isObject = (v: any): v is Record<string, any> => !(v == null || typeof v !== \"object\" || isArray(v))\nexport const isNumber = (v: any): v is number => typeof v === \"number\" && !Number.isNaN(v)\nexport const isString = (v: any): v is string => typeof v === \"string\"\nexport const isFunction = (v: any): v is Function => typeof v === \"function\"\n\nexport const hasProp = <T extends string>(obj: any, prop: T): obj is Record<T, any> =>\n Object.prototype.hasOwnProperty.call(obj, prop)\n", "import { isDom } from \"./guard\"\n\nexport function getPlatform() {\n const agent = (navigator as any).userAgentData\n return agent?.platform ?? navigator.platform\n}\n\nconst pt = (v: RegExp) => isDom() && v.test(getPlatform())\nconst ua = (v: RegExp) => isDom() && v.test(navigator.userAgent)\nconst vn = (v: RegExp) => isDom() && v.test(navigator.vendor)\n\nexport const isTouchDevice = isDom() && !!navigator.maxTouchPoints\nexport const isMac = () => pt(/^Mac/) && !isTouchDevice\nexport const isIPhone = () => pt(/^iPhone/)\nexport const isSafari = () => isApple() && vn(/apple/i)\nexport const isFirefox = () => ua(/firefox\\//i)\nexport const isApple = () => pt(/mac|iphone|ipad|ipod/i)\nexport const isIos = () => isApple() && !isMac()\n", "import { hasProp, isDom, isObject } from \"./guard\"\nimport { isMac } from \"./platform\"\n\nexport const supportsPointerEvent = () => isDom() && window.onpointerdown === null\nexport const supportsTouchEvent = () => isDom() && window.ontouchstart === null\nexport const supportsMouseEvent = () => isDom() && window.onmousedown === null\n\nexport const isMouseEvent = (v: any): v is MouseEvent => isObject(v) && hasProp(v, \"button\")\nexport const isTouchEvent = (v: any): v is TouchEvent => isObject(v) && hasProp(v, \"touches\")\nexport const isLeftClick = (v: { button: number }) => v.button === 0\nexport const isRightClick = (v: { button: number }) => v.button === 2\nexport const isModifiedEvent = (v: Pick<KeyboardEvent, \"ctrlKey\" | \"metaKey\" | \"altKey\">) =>\n v.ctrlKey || v.altKey || v.metaKey\n\nexport const isCtrlKey = (v: Pick<KeyboardEvent, \"ctrlKey\" | \"metaKey\">) =>\n isMac() ? v.metaKey && !v.ctrlKey : v.ctrlKey && !v.metaKey\n", "export const runIfFn = <T>(\n v: T | undefined,\n ...a: T extends (...a: any[]) => void ? Parameters<T> : never\n): T extends (...a: any[]) => void ? NonNullable<ReturnType<T>> : NonNullable<T> => {\n const res = typeof v === \"function\" ? v(...a) : v\n return res ?? undefined\n}\n\nexport const cast = <T>(v: unknown): T => v as T\n\nexport const noop = () => {}\n\nexport const pipe =\n <T>(...fns: Array<(a: T) => T>) =>\n (v: T) =>\n fns.reduce((a, b) => b(a), v)\n\nexport const callAll =\n <T extends (...a: any[]) => void>(...fns: (T | undefined)[]) =>\n (...a: Parameters<T>) => {\n fns.forEach(function (fn) {\n fn?.(...a)\n })\n }\n\nexport const uuid = /*#__PURE__*/ (() => {\n let id = 0\n return () => {\n id++\n return id.toString(36)\n }\n})()\n\nexport function merge<T, U>(origin: T, patch: U): T & U {\n if (!(typeof patch === \"object\")) return patch as any\n const result = !(typeof origin === \"object\") ? {} : Object.assign({}, origin)\n for (const key of Object.keys(patch)) {\n const value = patch[key]\n const src = result[key]\n if (value === null) delete result[key]\n else if (Array.isArray(value) || Array.isArray(src)) result[key] = (src || []).concat(value || [])\n else result[key] = merge(src, value)\n }\n return result as any\n}\n", "export function warn(m: string): void\nexport function warn(c: boolean, m: string): void\nexport function warn(...a: any[]): void {\n const m = a.length === 1 ? a[0] : a[1]\n const c = a.length === 2 ? a[0] : true\n if (c && process.env.NODE_ENV !== \"production\") {\n console.warn(m)\n }\n}\n\nexport function invariant(m: string): void\nexport function invariant(c: boolean, m: string): void\nexport function invariant(...a: any[]): void {\n const m = a.length === 1 ? a[0] : a[1]\n const c = a.length === 2 ? a[0] : true\n if (c && process.env.NODE_ENV !== \"production\") {\n throw new Error(m)\n }\n}\n", "import { isTouchEvent } from \"@zag-js/utils\"\nimport { Point } from \"./types\"\n\nexport function distance(a: Point, b: Point = { x: 0, y: 0 }): number {\n return Math.sqrt(Math.pow(a.x - b.x, 2) + Math.pow(a.y - b.y, 2))\n}\n\nexport function closest(...pts: Point[]) {\n return (a: Point): Point => {\n const ds = pts.map((b) => distance(b, a))\n const c = Math.min.apply(Math, ds)\n return pts[ds.indexOf(c)]\n }\n}\n\nconst fallback = { pageX: 0, pageY: 0, clientX: 0, clientY: 0 }\n\nexport function getEventPoint(e: AnyPointerEvent, t: PointType = \"page\"): Point {\n const p = isTouchEvent(e) ? e.touches[0] || e.changedTouches[0] || fallback : e\n return { x: p[`${t}X`], y: p[`${t}Y`] }\n}\n\nexport function relativeToNode(p: Point, el: HTMLElement): RelativeValue {\n const dx = p.x - el.offsetLeft - el.clientLeft + el.scrollLeft\n const dy = p.y - el.offsetTop - el.clientTop + el.scrollTop\n return {\n point: { x: dx, y: dy },\n progress: { x: dx / el.offsetWidth, y: dy / el.offsetHeight },\n }\n}\n\ntype AnyPointerEvent = MouseEvent | TouchEvent | PointerEvent\n\ntype RelativeValue = {\n point: Point\n progress: { x: number; y: number }\n}\n\ntype PointType = \"page\" | \"client\"\n", "import { Rect } from \"./rect\"\nimport type { Point, RectInset, SymmetricRectInset } from \"./types\"\n\nexport const isSymmetric = (v: any): v is SymmetricRectInset => \"dx\" in v || \"dy\" in v\n\nexport function inset(r: Rect, i: RectInset | SymmetricRectInset): Rect {\n const v = isSymmetric(i) ? { left: i.dx, right: i.dx, top: i.dy, bottom: i.dy } : i\n const { top = 0, right = 0, bottom = 0, left = 0 } = v\n return Rect.create({ x: r.x + left, y: r.y + top, width: r.width - left - right, height: r.height - top - bottom })\n}\n\nexport function expand(r: Rect, v: number | SymmetricRectInset): Rect {\n const value = typeof v === \"number\" ? { dx: -v, dy: -v } : v\n return inset(r, value)\n}\n\nexport function shrink(r: Rect, v: number | SymmetricRectInset): Rect {\n const value = typeof v === \"number\" ? { dx: -v, dy: -v } : v\n return inset(r, value)\n}\n\nexport function shift(r: Rect, o: Partial<Point>): Rect {\n const { x = 0, y = 0 } = o\n return Rect.create({ x: r.x + x, y: r.y + y, width: r.width, height: r.height })\n}\n", "import { Point } from \"./types\"\n\nexport function withinPolygon(polygon: Point[], point: Point) {\n const { x, y } = point\n let c = false\n\n for (let i = 0, j = polygon.length - 1; i < polygon.length; j = i++) {\n const xi = polygon[i].x\n const yi = polygon[i].y\n const xj = polygon[j].x\n const yj = polygon[j].y\n\n if (yi > y !== yj > y && x < ((xj - xi) * (y - yi)) / (yj - yi) + xi) {\n c = !c\n }\n }\n return c\n}\n\nfunction createPolygonElement() {\n const id = \"debug-polygon\"\n const existingPolygon = document.getElementById(id)\n if (existingPolygon) {\n return existingPolygon\n }\n const svg = document.createElementNS(\"http://www.w3.org/2000/svg\", \"svg\")\n Object.assign(svg.style, {\n top: \"0\",\n left: \"0\",\n width: \"100%\",\n height: \"100%\",\n opacity: \"0.15\",\n position: \"fixed\",\n pointerEvents: \"none\",\n })\n\n const polygon = document.createElementNS(\"http://www.w3.org/2000/svg\", \"polygon\")\n polygon.setAttribute(\"id\", id)\n polygon.setAttribute(\"points\", \"0,0 0,0\")\n svg.appendChild(polygon)\n document.body.appendChild(svg)\n return polygon\n}\n\nexport function debugPolygon(polygon: Point[]) {\n const el = createPolygonElement()\n const points = polygon.map((point) => `${point.x},${point.y}`).join(\" \")\n el.setAttribute(\"points\", points)\n}\n", "export type Num<T extends string> = Record<T, number>\n\nexport function wrap(num: number, max: number): number {\n return ((num % max) + max) % max\n}\n\nexport function round(v: number | string, t?: number) {\n let num = valueOf(v)\n const p = 10 ** (t ?? 10)\n num = Math.round(num * p) / p\n return t ? num.toFixed(t) : v.toString()\n}\n\nexport function roundToDevicePixel(num: number) {\n if (typeof window === \"undefined\") return Math.round(num)\n const dp = window.devicePixelRatio\n return Math.floor(num * dp + 0.5) / dp\n}\n\nexport const valueToPercent = (v: number | string, r: Num<\"step\" | \"min\" | \"max\">) =>\n ((valueOf(v) - r.min) * 100) / (r.max - r.min)\n\nexport const percentToValue = (v: number | string, r: Num<\"min\" | \"max\">) => r.min + (r.max - r.min) * valueOf(v)\n\nexport function clamp(v: number | string, o: Num<\"min\" | \"max\">) {\n return Math.min(Math.max(valueOf(v), o.min), o.max)\n}\n\nexport function countDecimals(value: number) {\n if (!Number.isFinite(value)) return 0\n let e = 1,\n p = 0\n while (Math.round(value * e) / e !== value) {\n e *= 10\n p += 1\n }\n return p\n}\n\nexport const increment = (v: number | string, s: number) => decimalOperation(valueOf(v), \"+\", s)\n\nexport const decrement = (v: number | string, s: number) => decimalOperation(valueOf(v), \"-\", s)\n\nexport function snapToStep(value: number | string, step: number) {\n const num = valueOf(value)\n const p = countDecimals(step)\n const v = Math.round(num / step) * step\n return round(v, p)\n}\n\nexport function valueOf(v: string | number) {\n if (typeof v === \"number\") return v\n const num = parseFloat(v.toString().replace(/[^\\w.-]+/g, \"\"))\n return !Number.isNaN(num) ? num : 0\n}\n\nexport type FormatDecimalOptions = {\n /**\n * The minimum number of fraction digits to use. Possible values are from 0 to 20\n */\n minFractionDigits?: number\n /**\n * The maximum number of fraction digits to use. Possible values are from 0 to 20;\n */\n maxFractionDigits?: number\n}\n\nexport function formatDecimal(v: number | string, o: Omit<FormatDecimalOptions, \"value\">) {\n return new Intl.NumberFormat(\"en-US\", {\n useGrouping: false,\n style: \"decimal\",\n minimumFractionDigits: o.minFractionDigits,\n maximumFractionDigits: o.maxFractionDigits,\n }).format(valueOf(v))\n}\n\nexport function isAtMax(v: number | string, o: Num<\"max\">) {\n const val = valueOf(v)\n return val >= o.max\n}\n\nexport function isAtMin(v: number | string, o: Num<\"min\">) {\n const val = valueOf(v)\n return val <= o.min\n}\n\nexport function isWithinRange(v: number | string, o: Num<\"min\" | \"max\">) {\n const val = valueOf(v)\n return val >= o.min && val <= o.max\n}\n\nfunction decimalOperation(a: number, op: \"-\" | \"+\", b: number): number {\n let result = op === \"+\" ? a + b : a - b\n\n // Check if we have decimals\n if (a % 1 !== 0 || b % 1 !== 0) {\n const multiplier = 10 ** Math.max(countDecimals(a), countDecimals(b))\n\n // Transform the decimals to integers based on the precision\n a = Math.round(a * multiplier)\n b = Math.round(b * multiplier)\n\n // Perform the operation on integers values to make sure we don't get a fancy decimal value\n result = op === \"+\" ? a + b : a - b\n\n // Transform the integer result back to decimal\n result /= multiplier\n }\n\n return result\n}\n", "import {\n clamp,\n decrement,\n increment,\n isAtMax,\n isAtMin,\n isWithinRange,\n Num,\n percentToValue,\n FormatDecimalOptions,\n formatDecimal,\n snapToStep,\n valueOf,\n valueToPercent,\n} from \"./number\"\n\nexport type RangeOptions<T = string | number> = Num<\"min\" | \"max\"> &\n FormatDecimalOptions & {\n value: T\n step: number\n }\n\nexport function rangy(o: RangeOptions) {\n const wrap = (v: string | number) => rangy({ ...o, value: v })\n return {\n isInRange: isWithinRange(o.value, o),\n isAtMax: isAtMax(o.value, o),\n isAtMin: isAtMin(o.value, o),\n percent: valueToPercent(o.value, o),\n valueAsNumber: valueOf(o.value),\n value: formatDecimal(o.value, o),\n snapToStep: () => wrap(snapToStep(o.value, o.step)),\n increment: (s?: number) => wrap(increment(o.value, s || o.step)),\n decrement: (s?: number) => wrap(decrement(o.value, s || o.step)),\n toMax: () => wrap(o.max),\n toMin: () => wrap(o.min),\n fromPercent: (p: number) => wrap(percentToValue(p, o)),\n clamp: () => wrap(clamp(o.value, o)),\n }\n}\n", "export const nf = new Intl.NumberFormat(\"en-US\", { style: \"decimal\", maximumFractionDigits: 20 })\n\nexport function formatter(n: number) {\n return parseFloat(nf.format(n))\n}\n", "import { formatter } from \"./number-format\"\n\ntype Num<T extends string> = Record<T, number>\n\nexport const transform = (a: [number, number], b: [number, number]) => {\n const i = { min: a[0], max: a[1] }\n const o = { min: b[0], max: b[1] }\n return (v: number) => {\n if (i.min === i.max || o.min === o.max) return o.min\n const ratio = (o.max - o.min) / (i.max - i.min)\n return o.min + ratio * (v - i.min)\n }\n}\n\nexport function toRanges(o: Num<\"min\" | \"max\"> & { value: number[]; spacing: number }) {\n const spacing = o.spacing ?? 0\n return o.value.map((v, i) => {\n const min = i === 0 ? o.min : o.value[i - 1] + spacing\n const max = i === o.value.length - 1 ? o.max : o.value[i + 1] - spacing\n return { min, max, value: v }\n })\n}\n\nexport function toRangeArray(o: Num<\"min\" | \"max\" | \"step\">): number[] {\n let i = o.min\n const range: number[] = []\n while (i <= o.max) {\n range.push(i)\n i = formatter(i + o.step)\n }\n return range\n}\n", "import { transform, valueToPercent } from \"@zag-js/number-utils\"\nimport type { Style } from \"@zag-js/types\"\nimport type { MachineContext as Ctx, SharedContext } from \"./slider.types\"\n\n/* -----------------------------------------------------------------------------\n * Thumb style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getVerticalThumbOffset(ctx: SharedContext) {\n const { height = 0 } = ctx.thumbSize ?? {}\n const getValue = transform([ctx.min, ctx.max], [-height / 2, height / 2])\n return parseFloat(getValue(ctx.value).toFixed(2))\n}\n\nfunction getHorizontalThumbOffset(ctx: SharedContext) {\n const { width = 0 } = ctx.thumbSize ?? {}\n\n if (ctx.isRtl) {\n const getValue = transform([ctx.max, ctx.min], [-width * 1.5, -width / 2])\n return -1 * parseFloat(getValue(ctx.value).toFixed(2))\n }\n\n const getValue = transform([ctx.min, ctx.max], [-width / 2, width / 2])\n return parseFloat(getValue(ctx.value).toFixed(2))\n}\n\nfunction getThumbOffset(ctx: SharedContext) {\n const percent = valueToPercent(ctx.value, ctx)\n const offset = ctx.isVertical ? getVerticalThumbOffset(ctx) : getHorizontalThumbOffset(ctx)\n return `calc(${percent}% - ${offset}px)`\n}\n\nfunction getThumbStyle(ctx: SharedContext): Style {\n const placementProp = ctx.isVertical ? \"bottom\" : ctx.isRtl ? \"right\" : \"left\"\n return {\n visibility: ctx.hasMeasuredThumbSize ? \"visible\" : \"hidden\",\n position: \"absolute\",\n transform: \"var(--slider-thumb-transform)\",\n [placementProp]: \"var(--slider-thumb-offset)\",\n }\n}\n\n/* -----------------------------------------------------------------------------\n * Range style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getRangeOffsets(ctx: Ctx) {\n const percent = valueToPercent(ctx.value, ctx)\n\n let start = \"0%\"\n let end = `${100 - percent}%`\n\n if (ctx.origin === \"center\") {\n const isNegative = percent < 50\n start = isNegative ? `${percent}%` : \"50%\"\n end = isNegative ? \"50%\" : end\n }\n\n return { start, end }\n}\n\nfunction getRangeStyle(ctx: Pick<SharedContext, \"isVertical\" | \"isRtl\">): Style {\n if (ctx.isVertical) {\n return {\n position: \"absolute\",\n bottom: \"var(--slider-range-start)\",\n top: \"var(--slider-range-end)\",\n }\n }\n\n return {\n position: \"absolute\",\n [ctx.isRtl ? \"right\" : \"left\"]: \"var(--slider-range-start)\",\n [ctx.isRtl ? \"left\" : \"right\"]: \"var(--slider-range-end)\",\n }\n}\n\n/* -----------------------------------------------------------------------------\n * Control style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getControlStyle(): Style {\n return {\n touchAction: \"none\",\n userSelect: \"none\",\n position: \"relative\",\n }\n}\n\n/* -----------------------------------------------------------------------------\n * Root style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getRootStyle(ctx: Ctx): Style {\n const range = getRangeOffsets(ctx)\n return {\n \"--slider-thumb-transform\": ctx.isVertical ? \"translateY(50%)\" : \"translateX(-50%)\",\n \"--slider-thumb-offset\": getThumbOffset(ctx),\n \"--slider-range-start\": range.start,\n \"--slider-range-end\": range.end,\n }\n}\n\n/* -----------------------------------------------------------------------------\n * Marker style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getMarkerStyle(ctx: Pick<SharedContext, \"isHorizontal\" | \"isRtl\">, percent: number): Style {\n return {\n position: \"absolute\",\n pointerEvents: \"none\",\n [ctx.isHorizontal ? \"left\" : \"bottom\"]: `${ctx.isRtl ? 100 - percent : percent}%`,\n }\n}\n\n/* -----------------------------------------------------------------------------\n * Label style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getLabelStyle(): Style {\n return { userSelect: \"none\" }\n}\n\n/* -----------------------------------------------------------------------------\n * Label style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getTrackStyle(): Style {\n return { position: \"relative\" }\n}\n\n/* -----------------------------------------------------------------------------\n * Label style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getMarkerGroupStyle(): Style {\n return {\n userSelect: \"none\",\n pointerEvents: \"none\",\n position: \"relative\",\n }\n}\n\nexport const styles = {\n getThumbOffset,\n getControlStyle,\n getThumbStyle,\n getRangeStyle,\n getRootStyle,\n getMarkerStyle,\n getLabelStyle,\n getTrackStyle,\n getMarkerGroupStyle,\n}\n", "import { clamp, decrement, increment, percentToValue, snapToStep } from \"@zag-js/number-utils\"\nimport { MachineContext as Ctx } from \"./slider.types\"\n\nexport const utils = {\n fromPercent(ctx: Ctx, percent: number) {\n percent = clamp(percent, { min: 0, max: 1 })\n return parseFloat(snapToStep(percentToValue(percent, ctx), ctx.step))\n },\n clamp(ctx: Ctx, value: number) {\n return clamp(value, ctx)\n },\n convert(ctx: Ctx, value: number) {\n return clamp(parseFloat(snapToStep(value, ctx.step)), ctx)\n },\n decrement(ctx: Ctx, step?: number) {\n let value = decrement(ctx.value, step ?? ctx.step)\n return utils.convert(ctx, value)\n },\n increment(ctx: Ctx, step?: number) {\n let value = increment(ctx.value, step ?? ctx.step)\n return utils.convert(ctx, value)\n },\n}\n", "import { dispatchInputValueEvent } from \"@zag-js/dom-utils\"\nimport type { Point } from \"@zag-js/rect-utils\"\nimport { relativeToNode } from \"@zag-js/rect-utils\"\nimport { styles } from \"./slider.style\"\nimport type { MachineContext as Ctx } from \"./slider.types\"\nimport { utils } from \"./slider.utils\"\n\nexport const dom = {\n ...styles,\n getDoc: (ctx: Ctx) => ctx.doc ?? document,\n getRootNode: (ctx: Ctx) => ctx.rootNode ?? dom.getDoc(ctx),\n\n getRootId: (ctx: Ctx) => ctx.ids?.root ?? `slider:${ctx.uid}`,\n getThumbId: (ctx: Ctx) => ctx.ids?.thumb ?? `slider:${ctx.uid}:thumb`,\n getControlId: (ctx: Ctx) => ctx.ids?.control ?? `slider:${ctx.uid}:control`,\n getInputId: (ctx: Ctx) => `slider:${ctx.uid}:input`,\n getOutputId: (ctx: Ctx) => ctx.ids?.output ?? `slider:${ctx.uid}:output`,\n getTrackId: (ctx: Ctx) => ctx.ids?.track ?? `slider:${ctx.uid}track`,\n getRangeId: (ctx: Ctx) => ctx.ids?.track ?? `slider:${ctx.uid}:range`,\n getLabelId: (ctx: Ctx) => ctx.ids?.label ?? `slider:${ctx.uid}:label`,\n getMarkerId: (ctx: Ctx, value: number) => `slider:${ctx.uid}:marker:${value}`,\n\n getRootEl: (ctx: Ctx) => dom.getRootNode(ctx).getElementById(dom.getRootId(ctx)),\n getThumbEl: (ctx: Ctx) => dom.getRootNode(ctx).getElementById(dom.getThumbId(ctx)),\n getControlEl: (ctx: Ctx) => dom.getRootNode(ctx).getElementById(dom.getControlId(ctx)),\n getInputEl: (ctx: Ctx) => dom.getRootNode(ctx).getElementById(dom.getInputId(ctx)) as HTMLInputElement | null,\n\n getValueFromPoint(ctx: Ctx, point: Point): number | undefined {\n // get the slider root element\n const control = dom.getControlEl(ctx)\n if (!control) return\n\n // get the position/progress % of the point relative to the root's width/height\n const { progress } = relativeToNode(point, control)\n\n // get the progress % depending on the orientation\n let percent: number\n\n if (ctx.isHorizontal) {\n percent = ctx.isRtl ? 1 - progress.x : progress.x\n } else {\n percent = 1 - progress.y\n }\n\n return utils.fromPercent(ctx, percent)\n },\n\n dispatchChangeEvent(ctx: Ctx) {\n const input = dom.getInputEl(ctx)\n if (!input) return\n dispatchInputValueEvent(input, ctx.value)\n },\n}\n", "import type * as React from \"react\"\n\ntype Dict<T = any> = Record<string, T>\n\ntype Booleanish = boolean | \"true\" | \"false\"\n\ntype Omit<T, K extends keyof T> = { [P in Exclude<keyof T, K>]?: T[P] }\n\ntype WithStyle<T extends { style?: any }> = Omit<T, \"style\"> & {\n style?: T[\"style\"] & {\n [prop: string]: string | number | undefined\n }\n}\n\ntype DataAttr = {\n \"data-uid\"?: string\n \"data-name\"?: string\n \"data-ownedby\"?: string\n \"data-selected\"?: Booleanish\n \"data-expanded\"?: Booleanish\n \"data-highlighted\"?: Booleanish\n \"data-readonly\"?: Booleanish\n \"data-invalid\"?: Booleanish\n \"data-hover\"?: Booleanish\n \"data-active\"?: Booleanish\n \"data-focus\"?: Booleanish\n \"data-disabled\"?: Booleanish\n \"data-type\"?: string\n \"data-value\"?: string | number\n \"data-valuetext\"?: string\n \"data-open\"?: Booleanish\n \"data-placement\"?: string\n \"data-orientation\"?: \"horizontal\" | \"vertical\"\n \"data-label\"?: string\n \"data-checked\"?: Booleanish\n \"data-pressed\"?: Booleanish\n \"data-state\"?: string | null\n \"data-half\"?: Booleanish\n \"data-count\"?: number\n \"data-controls\"?: string\n \"data-part\"?: string\n \"data-index\"?: number\n \"data-complete\"?: Booleanish\n \"data-empty\"?: Booleanish\n \"data-placeholder-shown\"?: Booleanish\n}\n\ntype JSXElementAttributes = DataAttr & React.HTMLAttributes<HTMLElement>\ntype JSXButtonAttributes = DataAttr & React.ButtonHTMLAttributes<HTMLButtonElement>\ntype JSXInputAttributes = DataAttr & React.InputHTMLAttributes<HTMLInputElement>\ntype JSXLabelAttributes = DataAttr & React.LabelHTMLAttributes<HTMLLabelElement>\ntype JSXOutputAttributes = DataAttr & React.OutputHTMLAttributes<HTMLOutputElement>\n\nexport type PropTypes = Record<\"button\" | \"label\" | \"input\" | \"output\" | \"element\", Dict>\n\nexport type ReactPropTypes = {\n button: JSXButtonAttributes\n label: JSXLabelAttributes\n input: JSXInputAttributes\n output: JSXOutputAttributes\n element: JSXElementAttributes\n}\n\nexport type NormalizeProps = {\n button<T extends PropTypes>(props: WithStyle<JSXButtonAttributes>): T[\"button\"]\n label<T extends PropTypes>(props: WithStyle<JSXLabelAttributes>): T[\"label\"]\n input<T extends PropTypes>(props: WithStyle<JSXInputAttributes>): T[\"input\"]\n output<T extends PropTypes>(props: WithStyle<JSXOutputAttributes>): T[\"output\"]\n element<T extends PropTypes>(props: WithStyle<JSXElementAttributes>): T[\"element\"]\n}\n\nexport function createNormalizer(fn: (props: Dict) => Dict): NormalizeProps {\n return new Proxy({} as any, {\n get() {\n return fn\n },\n })\n}\n\nexport const normalizeProp = createNormalizer((v) => v)\n", "export type ControlProp =\n | { type: \"boolean\"; label?: string; defaultValue: boolean }\n | { type: \"string\"; label?: string; defaultValue: string; placeholder?: string }\n | { type: \"select\"; options: readonly string[]; defaultValue: string; label?: string }\n | { type: \"multiselect\"; options: readonly string[]; defaultValue: string[]; label?: string }\n | { type: \"number\"; label?: string; defaultValue: number; min?: number; max?: number }\n\nexport type ControlRecord = Record<string, ControlProp>\n\nexport type ControlValue<T extends ControlRecord> = {\n [K in keyof T]: T[K] extends { type: \"boolean\" }\n ? boolean\n : T[K] extends { type: \"string\" }\n ? string\n : T[K] extends { type: \"select\" }\n ? T[K][\"options\"][number]\n : T[K] extends { type: \"multiselect\" }\n ? T[K][\"options\"][number][]\n : T[K] extends { type: \"number\" }\n ? number\n : never\n}\n\nexport function defineControls<T extends ControlRecord>(config: T) {\n return config\n}\n", "export function toArray<T>(v: T | T[] | undefined | null): T[] {\n if (!v) return []\n return Array.isArray(v) ? v : [v]\n}\n\nexport const fromLength = (length: number) => Array.from(Array(length).keys())\n\nexport const first = <T>(v: T[]): T | undefined => v[0]\n\nexport const last = <T>(v: T[]): T | undefined => v[v.length - 1]\n\nexport const isEmpty = <T>(v: T[]): boolean => v.length === 0\n\nexport const has = <T>(v: T[], t: any): boolean => v.indexOf(t) !== -1\n\nexport const add = <T>(v: T[], ...items: T[]): T[] => v.concat(items)\n\nexport const remove = <T>(v: T[], item: T): T[] => removeAt(v, v.indexOf(item))\n\nexport const removeAt = <T>(v: T[], i: number): T[] => {\n if (i > -1) v.splice(i, 1)\n return v\n}\n\nexport function clear<T>(v: T[]): T[] {\n while (v.length > 0) v.pop()\n return v\n}\n\nexport type IndexOptions = {\n step?: number\n loop?: boolean\n}\n\nexport function nextIndex<T>(v: T[], idx: number, opts: IndexOptions = {}): number {\n const { step = 1, loop = true } = opts\n const next = idx + step\n const len = v.length\n const last = len - 1\n if (idx === -1) return step > 0 ? 0 : last\n if (next < 0) return loop ? last : 0\n if (next >= len) return loop ? 0 : idx > len ? len : idx\n return next\n}\n\nexport function next<T>(v: T[], idx: number, opts: IndexOptions = {}): T | undefined {\n return v[nextIndex(v, idx, opts)]\n}\n\nexport function prevIndex<T>(v: T[], idx: number, opts: IndexOptions = {}): number {\n const { step = 1, loop = true } = opts\n return nextIndex(v, idx, { step: -step, loop })\n}\n\nexport function prev<T>(v: T[], index: number, opts: IndexOptions = {}): T | undefined {\n return v[prevIndex(v, index, opts)]\n}\n\nexport const chunk = <T>(v: T[], size: number): T[][] => {\n const res: T[][] = []\n return v.reduce((rows, value, index) => {\n if (index % size === 0) rows.push([value])\n else last(rows)?.push(value)\n return rows\n }, res)\n}\n", "export const isDev = () => process.env.NODE_ENV !== \"production\"\nexport const isDom = () => typeof window !== \"undefined\"\n\nexport const isArray = (v: any): v is any[] => Array.isArray(v)\nexport const isBoolean = (v: any): v is boolean => v === true || v === false\nexport const isObject = (v: any): v is Record<string, any> => !(v == null || typeof v !== \"object\" || isArray(v))\nexport const isNumber = (v: any): v is number => typeof v === \"number\" && !Number.isNaN(v)\nexport const isString = (v: any): v is string => typeof v === \"string\"\nexport const isFunction = (v: any): v is Function => typeof v === \"function\"\n\nexport const hasProp = <T extends string>(obj: any, prop: T): obj is Record<T, any> =>\n Object.prototype.hasOwnProperty.call(obj, prop)\n", "import { isDom } from \"./guard\"\n\nexport function getPlatform() {\n const agent = (navigator as any).userAgentData\n return agent?.platform ?? navigator.platform\n}\n\nconst pt = (v: RegExp) => isDom() && v.test(getPlatform())\nconst ua = (v: RegExp) => isDom() && v.test(navigator.userAgent)\nconst vn = (v: RegExp) => isDom() && v.test(navigator.vendor)\n\nexport const isTouchDevice = isDom() && !!navigator.maxTouchPoints\nexport const isMac = () => pt(/^Mac/) && !isTouchDevice\nexport const isIPhone = () => pt(/^iPhone/)\nexport const isSafari = () => isApple() && vn(/apple/i)\nexport const isFirefox = () => ua(/firefox\\//i)\nexport const isApple = () => pt(/mac|iphone|ipad|ipod/i)\nexport const isIos = () => isApple() && !isMac()\n", "import { hasProp, isDom, isObject } from \"./guard\"\nimport { isMac } from \"./platform\"\n\nexport const supportsPointerEvent = () => isDom() && window.onpointerdown === null\nexport const supportsTouchEvent = () => isDom() && window.ontouchstart === null\nexport const supportsMouseEvent = () => isDom() && window.onmousedown === null\n\nexport const isMouseEvent = (v: any): v is MouseEvent => isObject(v) && hasProp(v, \"button\")\nexport const isTouchEvent = (v: any): v is TouchEvent => isObject(v) && hasProp(v, \"touches\")\nexport const isLeftClick = (v: { button: number }) => v.button === 0\nexport const isRightClick = (v: { button: number }) => v.button === 2\nexport const isModifiedEvent = (v: Pick<KeyboardEvent, \"ctrlKey\" | \"metaKey\" | \"altKey\">) =>\n v.ctrlKey || v.altKey || v.metaKey\n\nexport const isCtrlKey = (v: Pick<KeyboardEvent, \"ctrlKey\" | \"metaKey\">) =>\n isMac() ? v.metaKey && !v.ctrlKey : v.ctrlKey && !v.metaKey\n", "export const runIfFn = <T>(\n v: T | undefined,\n ...a: T extends (...a: any[]) => void ? Parameters<T> : never\n): T extends (...a: any[]) => void ? NonNullable<ReturnType<T>> : NonNullable<T> => {\n const res = typeof v === \"function\" ? v(...a) : v\n return res ?? undefined\n}\n\nexport const cast = <T>(v: unknown): T => v as T\n\nexport const noop = () => {}\n\nexport const pipe =\n <T>(...fns: Array<(a: T) => T>) =>\n (v: T) =>\n fns.reduce((a, b) => b(a), v)\n\nexport const callAll =\n <T extends (...a: any[]) => void>(...fns: (T | undefined)[]) =>\n (...a: Parameters<T>) => {\n fns.forEach(function (fn) {\n fn?.(...a)\n })\n }\n\nexport const uuid = /*#__PURE__*/ (() => {\n let id = 0\n return () => {\n id++\n return id.toString(36)\n }\n})()\n\nexport function merge<T, U>(origin: T, patch: U): T & U {\n if (!(typeof patch === \"object\")) return patch as any\n const result = !(typeof origin === \"object\") ? {} : Object.assign({}, origin)\n for (const key of Object.keys(patch)) {\n const value = patch[key]\n const src = result[key]\n if (value === null) delete result[key]\n else if (Array.isArray(value) || Array.isArray(src)) result[key] = (src || []).concat(value || [])\n else result[key] = merge(src, value)\n }\n return result as any\n}\n", "export function warn(m: string): void\nexport function warn(c: boolean, m: string): void\nexport function warn(...a: any[]): void {\n const m = a.length === 1 ? a[0] : a[1]\n const c = a.length === 2 ? a[0] : true\n if (c && process.env.NODE_ENV !== \"production\") {\n console.warn(m)\n }\n}\n\nexport function invariant(m: string): void\nexport function invariant(c: boolean, m: string): void\nexport function invariant(...a: any[]): void {\n const m = a.length === 1 ? a[0] : a[1]\n const c = a.length === 2 ? a[0] : true\n if (c && process.env.NODE_ENV !== \"production\") {\n throw new Error(m)\n }\n}\n", "import { dataAttr, EventKeyMap, getEventKey, getEventStep, getNativeEvent } from \"@zag-js/dom-utils\"\nimport { percentToValue, valueToPercent } from \"@zag-js/number-utils\"\nimport { getEventPoint } from \"@zag-js/rect-utils\"\nimport { normalizeProp, PropTypes, ReactPropTypes } from \"@zag-js/types\"\nimport { isLeftClick, isModifiedEvent } from \"@zag-js/utils\"\nimport { dom } from \"./slider.dom\"\nimport type { Send, State } from \"./slider.types\"\n\nexport function connect<T extends PropTypes = ReactPropTypes>(state: State, send: Send, normalize = normalizeProp) {\n const ariaLabel = state.context[\"aria-label\"]\n const ariaLabelledBy = state.context[\"aria-labelledby\"]\n const ariaValueText = state.context.getAriaValueText?.(state.context.value)\n\n const isFocused = state.matches(\"focus\")\n const isDragging = state.matches(\"dragging\")\n const isDisabled = state.context.disabled\n const isInteractive = state.context.isInteractive\n const isInvalid = state.context.invalid\n\n return {\n isFocused,\n isDragging,\n value: state.context.value,\n percent: valueToPercent(state.context.value, state.context),\n setValue(value: number) {\n send({ type: \"SET_VALUE\", value })\n },\n getPercentValue(percent: number) {\n return percentToValue(percent, state.context)\n },\n focus() {\n dom.getThumbEl(state.context)?.focus()\n },\n increment() {\n send(\"INCREMENT\")\n },\n decrement() {\n send(\"DECREMENT\")\n },\n\n rootProps: normalize.element<T>({\n \"data-part\": \"root\",\n \"data-disabled\": dataAttr(isDisabled),\n \"data-orientation\": state.context.orientation,\n id: dom.getRootId(state.context),\n dir: state.context.dir,\n style: dom.getRootStyle(state.context),\n }),\n\n labelProps: normalize.label<T>({\n \"data-part\": \"label\",\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n id: dom.getLabelId(state.context),\n htmlFor: dom.getInputId(state.context),\n onClick(event) {\n if (!isInteractive) return\n event.preventDefault()\n dom.getThumbEl(state.context)?.focus()\n },\n style: dom.getLabelStyle(),\n }),\n\n thumbProps: normalize.element<T>({\n \"data-part\": \"thumb\",\n id: dom.getThumbId(state.context),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-orientation\": state.context.orientation,\n \"data-focus\": dataAttr(isFocused),\n draggable: false,\n \"aria-invalid\": isInvalid || undefined,\n \"data-invalid\": dataAttr(isInvalid),\n \"aria-disabled\": isDisabled || undefined,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabel ? undefined : ariaLabelledBy ?? dom.getLabelId(state.context),\n \"aria-orientation\": state.context.orientation,\n \"aria-valuemax\": state.context.max,\n \"aria-valuemin\": state.context.min,\n \"aria-valuenow\": state.context.value,\n \"aria-valuetext\": ariaValueText,\n role: \"slider\",\n tabIndex: isDisabled ? undefined : 0,\n onBlur() {\n if (!isInteractive) return\n send(\"BLUR\")\n },\n onFocus() {\n if (!isInteractive) return\n send(\"FOCUS\")\n },\n onKeyDown(event) {\n if (!isInteractive) return\n const step = getEventStep(event) * state.context.step\n let prevent = true\n const keyMap: EventKeyMap = {\n ArrowUp() {\n send({ type: \"ARROW_UP\", step })\n prevent = state.context.isVertical\n },\n ArrowDown() {\n send({ type: \"ARROW_DOWN\", step })\n prevent = state.context.isVertical\n },\n ArrowLeft() {\n send({ type: \"ARROW_LEFT\", step })\n prevent = state.context.isHorizontal\n },\n ArrowRight() {\n send({ type: \"ARROW_RIGHT\", step })\n prevent = state.context.isHorizontal\n },\n PageUp() {\n send({ type: \"PAGE_UP\", step })\n },\n PageDown() {\n send({ type: \"PAGE_DOWN\", step })\n },\n Home() {\n send(\"HOME\")\n },\n End() {\n send(\"END\")\n },\n }\n\n const key = getEventKey(event, state.context)\n const exec = keyMap[key]\n\n if (!exec) return\n exec(event)\n\n if (prevent) {\n event.preventDefault()\n }\n },\n style: dom.getThumbStyle(state.context),\n }),\n\n inputProps: normalize.input<T>({\n \"data-part\": \"input\",\n type: \"text\",\n defaultValue: state.context.value,\n name: state.context.name,\n id: dom.getInputId(state.context),\n hidden: true,\n }),\n\n outputProps: normalize.output<T>({\n \"data-part\": \"output\",\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n id: dom.getOutputId(state.context),\n htmlFor: dom.getInputId(state.context),\n \"aria-live\": \"off\",\n }),\n\n trackProps: normalize.element<T>({\n \"data-part\": \"track\",\n id: dom.getTrackId(state.context),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n \"data-orientation\": state.context.orientation,\n \"data-focus\": dataAttr(isFocused),\n style: dom.getTrackStyle(),\n }),\n\n rangeProps: normalize.element<T>({\n \"data-part\": \"range\",\n id: dom.getRangeId(state.context),\n \"data-invalid\": dataAttr(isInvalid),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-orientation\": state.context.orientation,\n style: dom.getRangeStyle(state.context),\n }),\n\n controlProps: normalize.element<T>({\n \"data-part\": \"control\",\n id: dom.getControlId(state.context),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n \"data-orientation\": state.context.orientation,\n \"data-focus\": dataAttr(isFocused),\n onPointerDown(event) {\n if (!isInteractive) return\n\n const evt = getNativeEvent(event)\n if (!isLeftClick(evt) || isModifiedEvent(evt)) return\n\n const point = getEventPoint(evt)\n send({ type: \"POINTER_DOWN\", point })\n\n event.preventDefault()\n event.stopPropagation()\n },\n style: dom.getControlStyle(),\n }),\n\n markerGroupProps: normalize.element<T>({\n \"data-part\": \"marker-group\",\n role: \"presentation\",\n \"aria-hidden\": true,\n \"data-orientation\": state.context.orientation,\n style: dom.getMarkerGroupStyle(),\n }),\n\n getMarkerProps({ value }: { value: number }) {\n const percent = valueToPercent(value, state.context)\n const style = dom.getMarkerStyle(state.context, percent)\n const markerState =\n value > state.context.value ? \"over-value\" : value < state.context.value ? \"under-value\" : \"at-value\"\n\n return normalize.element<T>({\n \"data-part\": \"marker\",\n \"data-orientation\": state.context.orientation,\n id: dom.getMarkerId(state.context, value),\n \"data-value\": value,\n \"data-disabled\": dataAttr(isDisabled),\n \"data-state\": markerState,\n style,\n })\n },\n }\n}\n", "import { createMachine, ref } from \"@zag-js/core\"\nimport { nextTick, raf, trackFieldsetDisabled, trackFormReset, trackPointerMove } from \"@zag-js/dom-utils\"\nimport { dom } from \"./slider.dom\"\nimport { MachineContext, MachineState, UserDefinedContext } from \"./slider.types\"\nimport { utils } from \"./slider.utils\"\n\nexport function machine(ctx: UserDefinedContext = {}) {\n return createMachine<MachineContext, MachineState>(\n {\n id: \"slider\",\n initial: \"unknown\",\n context: {\n thumbSize: null,\n uid: \"\",\n disabled: false,\n threshold: 5,\n dir: \"ltr\",\n origin: \"start\",\n orientation: \"horizontal\",\n initialValue: null,\n value: 0,\n step: 1,\n min: 0,\n max: 100,\n ...ctx,\n },\n\n computed: {\n isHorizontal: (ctx) => ctx.orientation === \"horizontal\",\n isVertical: (ctx) => ctx.orientation === \"vertical\",\n isRtl: (ctx) => ctx.orientation === \"horizontal\" && ctx.dir === \"rtl\",\n isInteractive: (ctx) => !(ctx.disabled || ctx.readonly),\n hasMeasuredThumbSize: (ctx) => ctx.thumbSize !== null,\n },\n\n watch: {\n value: [\"invokeOnChange\", \"dispatchChangeEvent\"],\n },\n\n activities: [\"trackFormReset\", \"trackFieldsetDisabled\"],\n\n on: {\n SET_VALUE: {\n actions: \"setValue\",\n },\n INCREMENT: {\n actions: \"increment\",\n },\n DECREMENT: {\n actions: \"decrement\",\n },\n },\n\n states: {\n unknown: {\n on: {\n SETUP: {\n target: \"idle\",\n actions: [\"setupDocument\", \"setThumbSize\", \"checkValue\"],\n },\n },\n },\n\n idle: {\n on: {\n POINTER_DOWN: {\n target: \"dragging\",\n actions: [\"setPointerValue\", \"invokeOnChangeStart\", \"focusThumb\"],\n },\n FOCUS: \"focus\",\n },\n },\n\n focus: {\n entry: \"focusThumb\",\n on: {\n POINTER_DOWN: {\n target: \"dragging\",\n actions: [\"setPointerValue\", \"invokeOnChangeStart\", \"focusThumb\"],\n },\n ARROW_LEFT: {\n guard: \"isHorizontal\",\n actions: \"decrement\",\n },\n ARROW_RIGHT: {\n guard: \"isHorizontal\",\n actions: \"increment\",\n },\n ARROW_UP: {\n guard: \"isVertical\",\n actions: \"increment\",\n },\n ARROW_DOWN: {\n guard: \"isVertical\",\n actions: \"decrement\",\n },\n PAGE_UP: {\n actions: \"increment\",\n },\n PAGE_DOWN: {\n actions: \"decrement\",\n },\n HOME: {\n actions: \"setToMin\",\n },\n END: {\n actions: \"setToMax\",\n },\n BLUR: \"idle\",\n },\n },\n\n dragging: {\n entry: \"focusThumb\",\n activities: \"trackPointerMove\",\n on: {\n POINTER_UP: {\n target: \"focus\",\n actions: \"invokeOnChangeEnd\",\n },\n POINTER_MOVE: {\n actions: \"setPointerValue\",\n },\n },\n },\n },\n },\n {\n guards: {\n isHorizontal: (ctx) => ctx.isHorizontal,\n isVertical: (ctx) => ctx.isVertical,\n },\n\n activities: {\n trackFieldsetDisabled(ctx) {\n let cleanup: VoidFunction | undefined\n nextTick(() => {\n cleanup = trackFieldsetDisabled(dom.getRootEl(ctx), (disabled) => {\n if (disabled != ctx.disabled) {\n ctx.disabled = disabled\n }\n })\n })\n return () => cleanup?.()\n },\n trackFormReset(ctx) {\n let cleanup: VoidFunction | undefined\n nextTick(() => {\n cleanup = trackFormReset(dom.getInputEl(ctx), () => {\n if (ctx.initialValue != null) {\n ctx.value = ctx.initialValue\n }\n })\n })\n return () => cleanup?.()\n },\n trackPointerMove(ctx, _evt, { send }) {\n return trackPointerMove({\n ctx,\n onPointerMove(info) {\n send({ type: \"POINTER_MOVE\", point: info.point })\n },\n onPointerUp() {\n send(\"POINTER_UP\")\n },\n })\n },\n },\n\n actions: {\n setupDocument(ctx, evt) {\n if (evt.doc) ctx.doc = ref(evt.doc)\n if (evt.root) ctx.rootNode = ref(evt.root)\n ctx.uid = evt.id\n },\n checkValue(ctx) {\n const value = utils.convert(ctx, ctx.value)\n Object.assign(ctx, { value, initialValue: value })\n },\n invokeOnChangeStart(ctx) {\n ctx.onChangeStart?.({ value: ctx.value })\n },\n invokeOnChangeEnd(ctx) {\n ctx.onChangeEnd?.({ value: ctx.value })\n },\n invokeOnChange(ctx) {\n ctx.onChange?.({ value: ctx.value })\n },\n dispatchChangeEvent(ctx) {\n dom.dispatchChangeEvent(ctx)\n },\n setThumbSize(ctx) {\n raf(() => {\n const el = dom.getThumbEl(ctx)\n if (!el) return\n ctx.thumbSize = { width: el.offsetWidth, height: el.offsetHeight }\n })\n },\n setPointerValue(ctx, evt) {\n const value = dom.getValueFromPoint(ctx, evt.point)\n if (value == null) return\n ctx.value = utils.clamp(ctx, value)\n },\n focusThumb(ctx) {\n raf(() => dom.getThumbEl(ctx)?.focus())\n },\n decrement(ctx, evt) {\n ctx.value = utils.decrement(ctx, evt.step)\n },\n increment(ctx, evt) {\n ctx.value = utils.increment(ctx, evt.step)\n },\n setToMin(ctx) {\n ctx.value = ctx.min\n },\n setToMax(ctx) {\n ctx.value = ctx.max\n },\n setValue(ctx, evt) {\n ctx.value = utils.convert(ctx, evt.value)\n },\n },\n },\n )\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
package/dist/index.mjs.map
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../utilities/dom/src/attrs.ts", "../../../utilities/dom/src/computed-style.ts", "../../../utilities/dom/src/next-tick.ts", "../../../utilities/dom/src/auto-resize.ts", "../../../utilities/core/src/array.ts", "../../../utilities/core/src/guard.ts", "../../../utilities/core/src/platform.ts", "../../../utilities/core/src/events.ts", "../../../utilities/core/src/functions.ts", "../../../utilities/core/src/warning.ts", "../../../utilities/dom/src/global-listener.ts", "../../../utilities/dom/src/listener.ts", "../../../utilities/dom/src/body-pointer-event.ts", "../../../utilities/dom/src/constants.ts", "../../../utilities/dom/src/query.ts", "../../../utilities/dom/src/event.ts", "../../../utilities/dom/src/fire-event.ts", "../../../utilities/dom/src/focus-event.ts", "../../../utilities/dom/src/focusable.ts", "../../../utilities/dom/src/mutation-observer.ts", "../../../utilities/dom/src/form.ts", "../../../utilities/dom/src/input-event.ts", "../../../utilities/dom/src/keyboard-event.ts", "../../../utilities/dom/src/visually-hidden.ts", "../../../utilities/dom/src/live-region.ts", "../../../utilities/dom/src/nodelist.ts", "../../../utilities/dom/src/text-selection.ts", "../../../utilities/dom/src/pointer-event.ts", "../../../utilities/dom/src/pointerlock.ts", "../../../utilities/dom/src/rect-observer.ts", "../../../utilities/dom/src/scrollable.ts", "../../../utilities/dom/src/typeahead.ts", "../../../utilities/dom/src/visibility-event.ts", "../../../utilities/dom/src/visual-viewport.ts", "../../../utilities/dom/src/wait.ts", "../../../utilities/rect/src/rect.ts", "../../../utilities/rect/src/computed-style.ts", "../../../utilities/rect/src/from-element.ts", "../../../utilities/core/src/array.ts", "../../../utilities/core/src/guard.ts", "../../../utilities/core/src/platform.ts", "../../../utilities/core/src/events.ts", "../../../utilities/core/src/functions.ts", "../../../utilities/core/src/warning.ts", "../../../utilities/rect/src/point.ts", "../../../utilities/rect/src/operations.ts", "../../../utilities/rect/src/polygon.ts", "../../../utilities/number/src/number.ts", "../../../utilities/number/src/rangy.ts", "../../../utilities/number/src/number-format.ts", "../../../utilities/number/src/transform.ts", "../src/slider.style.ts", "../src/slider.utils.ts", "../src/slider.dom.ts", "../../../types/src/prop-types.ts", "../../../types/src/controls.ts", "../../../utilities/core/src/array.ts", "../../../utilities/core/src/guard.ts", "../../../utilities/core/src/platform.ts", "../../../utilities/core/src/events.ts", "../../../utilities/core/src/functions.ts", "../../../utilities/core/src/warning.ts", "../src/slider.connect.ts", "../src/slider.machine.ts"],
|
|
4
|
-
"sourcesContent": ["type Booleanish = boolean | \"true\" | \"false\"\n\nexport const dataAttr = (guard: boolean | undefined) => {\n return (guard ? \"\" : undefined) as Booleanish\n}\n\nexport const ariaAttr = (guard: boolean | undefined) => {\n return guard ? \"true\" : undefined\n}\n\nexport const matchAttr = (el: Element) => {\n return {\n get: (key: string) => el.getAttribute(key),\n set: (key: string, value: string) => el.setAttribute(key, value),\n is: (key: string, value: string) => {\n return el.getAttribute(key) === value\n },\n }\n}\n", "type Key = keyof CSSStyleDeclaration | (string & {})\ntype Styles = Record<Key, any>\ntype El = HTMLElement | null | undefined\n\nfunction getStyleCache(): WeakMap<HTMLElement, Styles> {\n ;(globalThis as any).__styleCache__ = (globalThis as any).__styleCache__ || new WeakMap()\n return (globalThis as any).__styleCache__\n}\n\nexport function getComputedStyle(el: El): Styles {\n if (!el) return {} as Styles\n const cache = getStyleCache()\n let style: Styles | undefined = cache.get(el)\n if (!style) {\n const win = el?.ownerDocument.defaultView ?? window\n style = win.getComputedStyle(el) as Styles\n cache.set(el, style)\n }\n return style\n}\n\nexport function copyVisualStyles(fromEl: HTMLElement | null, toEl: HTMLElement) {\n if (!fromEl) return\n const el = getComputedStyle(fromEl)\n // prettier-ignore\n const cssText = 'box-sizing:' + el.boxSizing +\n ';border-left:' + el.borderLeftWidth + ' solid red' +\n ';border-right:' + el.borderRightWidth + ' solid red' +\n ';font-family:' + el.fontFamily +\n ';font-feature-settings:' + el.fontFeatureSettings +\n ';font-kerning:' + el.fontKerning +\n ';font-size:' + el.fontSize +\n ';font-stretch:' + el.fontStretch +\n ';font-style:' + el.fontStyle +\n ';font-variant:' + el.fontVariant +\n ';font-variant-caps:' + el.fontVariantCaps +\n ';font-variant-ligatures:' + el.fontVariantLigatures +\n ';font-variant-numeric:' + el.fontVariantNumeric +\n ';font-weight:' + el.fontWeight +\n ';letter-spacing:' + el.letterSpacing +\n ';margin-left:' + el.marginLeft +\n ';margin-right:' + el.marginRight +\n ';padding-left:' + el.paddingLeft +\n ';padding-right:' + el.paddingRight +\n ';text-indent:' + el.textIndent +\n ';text-transform:' + el.textTransform\n\n toEl.style.cssText += cssText\n}\n", "export function nextTick(fn: VoidFunction) {\n const set = new Set<VoidFunction>()\n function raf(fn: VoidFunction) {\n const id = globalThis.requestAnimationFrame(fn)\n set.add(() => globalThis.cancelAnimationFrame(id))\n }\n raf(() => raf(fn))\n return function cleanup() {\n set.forEach(function (fn) {\n fn()\n })\n }\n}\n\nexport function raf(fn: VoidFunction) {\n const id = globalThis.requestAnimationFrame(fn)\n return function cleanup() {\n globalThis.cancelAnimationFrame(id)\n }\n}\n\nexport function queueMicrotask(fn: VoidFunction) {\n if (typeof globalThis.queueMicrotask === \"function\") {\n globalThis.queueMicrotask(fn)\n } else {\n Promise.resolve().then(fn)\n }\n}\n", "import { copyVisualStyles } from \"./computed-style\"\nimport { raf } from \"./next-tick\"\n\nfunction createGhostElement(doc: Document) {\n var el = doc.createElement(\"div\")\n el.id = \"ghost\"\n el.style.cssText =\n \"display:inline-block;height:0;overflow:hidden;position:absolute;top:0;visibility:hidden;white-space:nowrap;\"\n doc.body.appendChild(el)\n return el\n}\n\nexport function autoResizeInput(input: HTMLInputElement | null) {\n if (!input) return\n const doc = input.ownerDocument ?? document\n const ghost = createGhostElement(doc)\n\n copyVisualStyles(input, ghost)\n\n function resize() {\n raf(() => {\n ghost.innerHTML = input!.value\n const rect = getComputedStyle(ghost)\n input?.style.setProperty(\"width\", rect.width)\n })\n }\n\n resize()\n\n input?.addEventListener(\"input\", resize)\n input?.addEventListener(\"change\", resize)\n\n return () => {\n doc.body.removeChild(ghost)\n input?.removeEventListener(\"input\", resize)\n input?.removeEventListener(\"change\", resize)\n }\n}\n", "export function toArray<T>(v: T | T[] | undefined | null): T[] {\n if (!v) return []\n return Array.isArray(v) ? v : [v]\n}\n\nexport const fromLength = (length: number) => Array.from(Array(length).keys())\n\nexport const first = <T>(v: T[]): T | undefined => v[0]\n\nexport const last = <T>(v: T[]): T | undefined => v[v.length - 1]\n\nexport const isEmpty = <T>(v: T[]): boolean => v.length === 0\n\nexport const has = <T>(v: T[], t: any): boolean => v.indexOf(t) !== -1\n\nexport const add = <T>(v: T[], ...items: T[]): T[] => v.concat(items)\n\nexport const remove = <T>(v: T[], item: T): T[] => removeAt(v, v.indexOf(item))\n\nexport const removeAt = <T>(v: T[], i: number): T[] => {\n if (i > -1) v.splice(i, 1)\n return v\n}\n\nexport function clear<T>(v: T[]): T[] {\n while (v.length > 0) v.pop()\n return v\n}\n\nexport type IndexOptions = {\n step?: number\n loop?: boolean\n}\n\nexport function nextIndex<T>(v: T[], idx: number, opts: IndexOptions = {}): number {\n const { step = 1, loop = true } = opts\n const next = idx + step\n const len = v.length\n const last = len - 1\n if (idx === -1) return step > 0 ? 0 : last\n if (next < 0) return loop ? last : 0\n if (next >= len) return loop ? 0 : idx > len ? len : idx\n return next\n}\n\nexport function next<T>(v: T[], idx: number, opts: IndexOptions = {}): T | undefined {\n return v[nextIndex(v, idx, opts)]\n}\n\nexport function prevIndex<T>(v: T[], idx: number, opts: IndexOptions = {}): number {\n const { step = 1, loop = true } = opts\n return nextIndex(v, idx, { step: -step, loop })\n}\n\nexport function prev<T>(v: T[], index: number, opts: IndexOptions = {}): T | undefined {\n return v[prevIndex(v, index, opts)]\n}\n\nexport const chunk = <T>(v: T[], size: number): T[][] => {\n const res: T[][] = []\n return v.reduce((rows, value, index) => {\n if (index % size === 0) rows.push([value])\n else last(rows)?.push(value)\n return rows\n }, res)\n}\n", "export const isDev = () => process.env.NODE_ENV !== \"production\"\nexport const isDom = () => typeof window !== \"undefined\"\n\nexport const isArray = (v: any): v is any[] => Array.isArray(v)\nexport const isBoolean = (v: any): v is boolean => v === true || v === false\nexport const isObject = (v: any): v is Record<string, any> => !(v == null || typeof v !== \"object\" || isArray(v))\nexport const isNumber = (v: any): v is number => typeof v === \"number\" && !Number.isNaN(v)\nexport const isString = (v: any): v is string => typeof v === \"string\"\nexport const isFunction = (v: any): v is Function => typeof v === \"function\"\n\nexport const hasProp = <T extends string>(obj: any, prop: T): obj is Record<T, any> =>\n Object.prototype.hasOwnProperty.call(obj, prop)\n", "import { isDom } from \"./guard\"\n\nexport function getPlatform() {\n const agent = (navigator as any).userAgentData\n return agent?.platform ?? navigator.platform\n}\n\nconst pt = (v: RegExp) => isDom() && v.test(getPlatform())\nconst ua = (v: RegExp) => isDom() && v.test(navigator.userAgent)\nconst vn = (v: RegExp) => isDom() && v.test(navigator.vendor)\n\nexport const isTouchDevice = isDom() && !!navigator.maxTouchPoints\nexport const isMac = () => pt(/^Mac/) && !isTouchDevice\nexport const isIPhone = () => pt(/^iPhone/)\nexport const isSafari = () => isApple() && vn(/apple/i)\nexport const isFirefox = () => ua(/firefox\\//i)\nexport const isApple = () => pt(/mac|iphone|ipad|ipod/i)\nexport const isIos = () => isApple() && !isMac()\n", "import { hasProp, isDom, isObject } from \"./guard\"\nimport { isMac } from \"./platform\"\n\nexport const supportsPointerEvent = () => isDom() && window.onpointerdown === null\nexport const supportsTouchEvent = () => isDom() && window.ontouchstart === null\nexport const supportsMouseEvent = () => isDom() && window.onmousedown === null\n\nexport const isMouseEvent = (v: any): v is MouseEvent => isObject(v) && hasProp(v, \"button\")\nexport const isTouchEvent = (v: any): v is TouchEvent => isObject(v) && hasProp(v, \"touches\")\nexport const isLeftClick = (v: { button: number }) => v.button === 0\nexport const isRightClick = (v: { button: number }) => v.button === 2\nexport const isModifiedEvent = (v: Pick<KeyboardEvent, \"ctrlKey\" | \"metaKey\" | \"altKey\">) =>\n v.ctrlKey || v.altKey || v.metaKey\n\nexport const isCtrlKey = (v: Pick<KeyboardEvent, \"ctrlKey\" | \"metaKey\">) =>\n isMac() ? v.metaKey && !v.ctrlKey : v.ctrlKey && !v.metaKey\n", "export const runIfFn = <T>(\n v: T | undefined,\n ...a: T extends (...a: any[]) => void ? Parameters<T> : never\n): T extends (...a: any[]) => void ? NonNullable<ReturnType<T>> : NonNullable<T> => {\n const res = typeof v === \"function\" ? v(...a) : v\n return res ?? undefined\n}\n\nexport const cast = <T>(v: unknown): T => v as T\n\nexport const noop = () => {}\n\nexport const pipe =\n <T>(...fns: Array<(a: T) => T>) =>\n (v: T) =>\n fns.reduce((a, b) => b(a), v)\n\nexport const callAll =\n <T extends (...a: any[]) => void>(...fns: (T | undefined)[]) =>\n (...a: Parameters<T>) => {\n fns.forEach(function (fn) {\n fn?.(...a)\n })\n }\n\nexport const uuid = /*#__PURE__*/ (() => {\n let id = 0\n return () => {\n id++\n return id.toString(36)\n }\n})()\n\nexport function merge<T, U>(origin: T, patch: U): T & U {\n if (!(typeof patch === \"object\")) return patch as any\n const result = !(typeof origin === \"object\") ? {} : Object.assign({}, origin)\n for (const key of Object.keys(patch)) {\n const value = patch[key]\n const src = result[key]\n if (value === null) delete result[key]\n else if (Array.isArray(value) || Array.isArray(src)) result[key] = (src || []).concat(value || [])\n else result[key] = merge(src, value)\n }\n return result as any\n}\n", "export function warn(m: string): void\nexport function warn(c: boolean, m: string): void\nexport function warn(...a: any[]): void {\n const m = a.length === 1 ? a[0] : a[1]\n const c = a.length === 2 ? a[0] : true\n if (c && process.env.NODE_ENV !== \"production\") {\n console.warn(m)\n }\n}\n\nexport function invariant(m: string): void\nexport function invariant(c: boolean, m: string): void\nexport function invariant(...a: any[]): void {\n const m = a.length === 1 ? a[0] : a[1]\n const c = a.length === 2 ? a[0] : true\n if (c && process.env.NODE_ENV !== \"production\") {\n throw new Error(m)\n }\n}\n", "import { noop } from \"@zag-js/utils\"\n\ntype El = HTMLElement | Document | VisualViewport | Window\ntype Handler = (event: Event) => void\ntype Group = Map<string, Set<Handler>>\ntype Option = boolean | AddEventListenerOptions\n\nfunction getListenerElements(): Map<El, Group> {\n ;(globalThis as any).__listenerElements__ = (globalThis as any).__listenerElements__ || new Map()\n return (globalThis as any).__listenerElements__\n}\n\nfunction getListenerCache(): Map<El, Map<string, Handler>> {\n ;(globalThis as any).__listenerCache__ = (globalThis as any).__listenerCache__ || new Map()\n return (globalThis as any).__listenerCache__\n}\n\n/**\n * The global event bus for managing event listeners attached to DOM elements.\n *\n * It's goal is to ensure that only one listener is attached to a DOM element for a given event,\n * regardless of the number of times `addEventListener` is called.\n */\n\nexport function addGlobalEventListener(node: El | null, type: string, handler: Handler, options?: Option) {\n if (!node) return noop\n\n // unique identifier for the event listener\n const hash = JSON.stringify({ type, options })\n\n // Subscribe pattern\n const listenerElements = getListenerElements()\n const listenerCache = getListenerCache()\n\n const group = listenerElements.get(node)\n\n if (!listenerElements.has(node)) {\n // create group of listeners per hash\n const group: Group = new Map([[hash, new Set([handler])]])\n listenerElements.set(node, group)\n } else if (group?.has(hash)) {\n group?.get(hash)?.add(handler)\n } else {\n group?.set(hash, new Set([handler]))\n }\n\n // add the event listener to the node or register it in the cache\n function attach(node: El) {\n // Publish pattern\n function listener(event: Event) {\n const group = listenerElements.get(node)\n group?.get(hash)?.forEach((fn) => fn(event))\n }\n\n if (!listenerCache?.has(node)) {\n listenerCache.set(node, new Map([[hash, listener]]))\n node.addEventListener(type, listener, options)\n return\n }\n\n if (!listenerCache?.get(node)?.has(hash)) {\n listenerCache.get(node)?.set(hash, listener)\n node.addEventListener(type, listener, options)\n }\n }\n\n attach(node)\n\n return function remove() {\n if (!listenerElements.has(node)) return\n\n const group = listenerElements.get(node)\n group?.get(hash)?.delete(handler)\n\n if (group?.get(hash)?.size === 0) {\n const listener = listenerCache.get(node)?.get(hash)!\n node.removeEventListener(type, listener, options)\n group?.delete(hash)\n listenerCache.get(node)?.delete(hash)\n\n if (group?.size === 0) {\n listenerElements.delete(node)\n listenerCache.delete(node)\n }\n }\n }\n}\n", "import {\n supportsMouseEvent,\n supportsPointerEvent,\n supportsTouchEvent,\n runIfFn,\n hasProp,\n isTouchEvent,\n} from \"@zag-js/utils\"\nimport { addGlobalEventListener } from \"./global-listener\"\nimport {\n AnyPointerEvent,\n DOMEventTarget,\n EventMap,\n PointerEventInfo,\n PointerNameMap,\n RefTarget,\n} from \"./listener.types\"\n\nconst isRef = (v: any): v is RefTarget => hasProp(v, \"current\")\n\nconst fallback = { pageX: 0, pageY: 0, clientX: 0, clientY: 0 }\n\nexport function extractInfo<T extends AnyPointerEvent = AnyPointerEvent>(event: T, type: \"page\" | \"client\" = \"page\") {\n const point = isTouchEvent(event) ? event.touches[0] || event.changedTouches[0] || fallback : event\n return {\n point: {\n x: point[`${type}X`],\n y: point[`${type}Y`],\n },\n }\n}\n\nexport function addDomEvent<K extends keyof EventMap>(\n target: DOMEventTarget,\n event: K,\n listener: (event: EventMap[K]) => void,\n options?: boolean | AddEventListenerOptions,\n) {\n const node = isRef(target) ? target.current : runIfFn(target)\n return addGlobalEventListener(node as HTMLElement | null, event, listener as any, options)\n}\n\nexport function addPointerEvent<K extends keyof EventMap>(\n target: DOMEventTarget,\n event: K,\n listener: (event: EventMap[K], info: PointerEventInfo) => void,\n options?: boolean | AddEventListenerOptions,\n) {\n const type = getEventName(event) ?? event\n return addDomEvent(target, type, wrapHandler(listener, event === \"pointerdown\"), options)\n}\n\nfunction wrapHandler<E extends EventMap[keyof EventMap]>(\n fn: (event: E, info: PointerEventInfo) => void,\n filter = false,\n) {\n const listener: EventListener = (event: any) => {\n fn(event, extractInfo(event))\n }\n return filter ? filterPrimaryPointer(listener) : listener\n}\n\nfunction filterPrimaryPointer(fn: EventListener): EventListener {\n return (event: Event) => {\n const win = ((event as UIEvent).view ?? window) as typeof window\n const isMouseEvent = event instanceof win.MouseEvent\n const isPrimary = !isMouseEvent || (isMouseEvent && (event as MouseEvent).button === 0)\n if (isPrimary) fn(event)\n }\n}\n\nexport function extractClientInfo(event: AnyPointerEvent) {\n return extractInfo(event, \"client\")\n}\n\nconst mouseEventNames: PointerNameMap = {\n pointerdown: \"mousedown\",\n pointermove: \"mousemove\",\n pointerup: \"mouseup\",\n pointercancel: \"mousecancel\",\n pointerover: \"mouseover\",\n pointerout: \"mouseout\",\n pointerenter: \"mouseenter\",\n pointerleave: \"mouseleave\",\n}\n\nconst touchEventNames: PointerNameMap = {\n pointerdown: \"touchstart\",\n pointermove: \"touchmove\",\n pointerup: \"touchend\",\n pointercancel: \"touchcancel\",\n}\n\nexport function getEventName(evt: keyof EventMap): keyof EventMap {\n if (supportsPointerEvent()) return evt\n if (supportsTouchEvent()) return touchEventNames[evt]\n if (supportsMouseEvent()) return mouseEventNames[evt]\n return evt\n}\n", "import { isLeftClick, pipe } from \"@zag-js/utils\"\nimport { addDomEvent } from \"./listener\"\nimport { nextTick } from \"./next-tick\"\n\nlet changeCount = 0\nlet originalBodyPointerEvents: string\n\ntype PointerEventOptions = {\n disabled: boolean\n document?: Document\n}\n\nexport function preventBodyPointerEvents(el: HTMLElement | null, opts: Partial<PointerEventOptions> = {}) {\n const { disabled = false, document: docProp } = opts\n const doc: Document = docProp || document\n\n let isTouchOrPenPressed = false\n let isLeftClickPressed = false\n\n function listen() {\n const onPointerDown = (event: PointerEvent) => {\n const isMouse = event.pointerType === \"mouse\"\n isTouchOrPenPressed = !isMouse\n isLeftClickPressed = isMouse && isLeftClick(event)\n }\n\n const onPointerUp = () => {\n isTouchOrPenPressed = false\n isLeftClickPressed = false\n }\n\n // prettier-ignore\n return pipe(\n addDomEvent(doc, \"pointerdown\", onPointerDown),\n addDomEvent(doc,\"pointerup\", onPointerUp)\n )\n }\n\n function reset() {\n changeCount--\n if (changeCount === 0) {\n doc.body.style.pointerEvents = originalBodyPointerEvents\n }\n if (el) {\n el.style.pointerEvents = \"\"\n }\n }\n\n function apply() {\n if (disabled) return\n\n if (changeCount === 0) {\n originalBodyPointerEvents = doc.body.style.pointerEvents\n }\n\n doc.body.style.pointerEvents = \"none\"\n if (el) {\n el.style.pointerEvents = \"auto\"\n }\n\n changeCount++\n\n return function () {\n if (isTouchOrPenPressed) {\n addDomEvent(doc, \"click\", reset, { once: true })\n } else if (isLeftClickPressed) {\n addDomEvent(doc, \"pointerup\", reset, { once: true })\n } else {\n reset()\n }\n }\n }\n\n const cleanups: Array<VoidFunction | undefined> = []\n cleanups.push(apply())\n nextTick(() => {\n cleanups.push(listen())\n })\n\n return function () {\n cleanups.forEach((cleanup) => cleanup?.())\n }\n}\n", "export const MAX_Z_INDEX = 2147483647\n", "export function isShadowRoot(el: any): el is ShadowRoot {\n return el?.toString() === \"[object ShadowRoot]\"\n}\n\nexport function isWindow(value: any): value is Window {\n return value?.toString() === \"[object Window]\"\n}\n\nexport const isWithinShadowRoot = (node: HTMLElement) => {\n return isShadowRoot(node.getRootNode())\n}\n\nexport function getOwnerDocument(el: Element | Window | null) {\n if (isWindow(el)) return el.document\n return el?.ownerDocument ?? document\n}\n\nexport function getOwnerWindow(el: HTMLElement) {\n return el?.ownerDocument.defaultView ?? window\n}\n\nexport function getDocumentElement(el: HTMLElement | Window): HTMLElement {\n return getOwnerDocument(el).documentElement\n}\n\nexport function getNodeName(node: HTMLElement | Window): string {\n return isWindow(node) ? \"\" : node ? node.localName || \"\" : \"\"\n}\n\nexport function getEventWindow(event: UIEvent) {\n if (event.view) return event.view\n let target = event.currentTarget\n if (target != null) return getOwnerWindow(target as HTMLElement)\n return window\n}\n\nexport function getEventTarget<T extends EventTarget>(event: Event): T | null {\n return (event.composedPath?.()[0] ?? event.target) as T | null\n}\n\nexport function getActiveElement(el: HTMLElement): HTMLElement | null {\n let activeElement = getOwnerDocument(el).activeElement as HTMLElement | null\n\n while (activeElement && activeElement.shadowRoot) {\n const el = activeElement.shadowRoot.activeElement as HTMLElement | null\n if (el === activeElement) break\n else activeElement = el\n }\n\n return activeElement\n}\n\nexport function getActiveDescendant(node: HTMLElement | null): HTMLElement | null {\n if (!node) return null\n const id = node.getAttribute(\"aria-activedescendant\")\n if (!id) return null\n return getOwnerDocument(node).getElementById(id)\n}\n\nexport function getParent(el: HTMLElement): HTMLElement {\n const doc = getOwnerDocument(el)\n if (getNodeName(el) === \"html\") return el\n return el.assignedSlot || el.parentElement || doc.documentElement\n}\n\nexport function contains(\n parent: HTMLElement | EventTarget | null | undefined,\n child: HTMLElement | EventTarget | null,\n) {\n if (!parent) return false\n return parent === child || (isHTMLElement(parent) && isHTMLElement(child) && parent.contains(child))\n}\n\nexport function isHTMLElement(v: any): v is HTMLElement {\n return typeof v === \"object\" && v?.nodeType === Node.ELEMENT_NODE && typeof v?.nodeName === \"string\"\n}\n\nexport const isDisabled = (el: HTMLElement | null): boolean => {\n return el?.getAttribute(\"disabled\") != null || !!el?.getAttribute(\"aria-disabled\") === true\n}\n\nexport function isElementEditable(el: HTMLElement | null) {\n if (el == null) return false\n try {\n return (\n (el instanceof getOwnerWindow(el).HTMLInputElement && el.selectionStart != null) ||\n /(textarea|select)/.test(el.localName) ||\n el.isContentEditable\n )\n } catch (error) {\n return false\n }\n}\n", "import { contains } from \"./query\"\n\nexport function isKeyboardClick(e: Pick<MouseEvent, \"detail\" | \"clientX\" | \"clientY\">) {\n return e.detail === 0 || (e.clientX === 0 && e.clientY === 0)\n}\n\nexport function isPrintableKey(e: Pick<KeyboardEvent, \"key\" | \"ctrlKey\" | \"metaKey\">): boolean {\n return e.key.length === 1 && !e.ctrlKey && !e.metaKey\n}\n\ntype NativeEvent<E> = React.ChangeEvent<any> extends E\n ? InputEvent\n : E extends React.SyntheticEvent<any, infer T>\n ? T\n : never\n\nexport function getNativeEvent<E>(e: E): NativeEvent<E> {\n return (e as any).nativeEvent ?? e\n}\n\nexport function queueBeforeEvent(el: Element, type: string, fn: VoidFunction) {\n const raf = requestAnimationFrame(() => {\n el.removeEventListener(type, invoke, true)\n fn()\n })\n\n const invoke = () => {\n cancelAnimationFrame(raf)\n fn()\n }\n\n el.addEventListener(type, invoke, { once: true, capture: true })\n\n return raf\n}\n\nexport function isPortalEvent(event: Pick<Event, \"currentTarget\" | \"target\">): boolean {\n return !contains(event.currentTarget, event.target)\n}\n\nexport function isSelfTarget(event: Pick<Event, \"target\" | \"currentTarget\">): boolean {\n return event.target === event.currentTarget\n}\n", "export function fireEvent(el: Element, type: string, init?: EventInit) {\n const event = new Event(type, init)\n return el.dispatchEvent(event)\n}\n\nexport function fireCustomEvent(el: Element, type: string, init?: CustomEventInit) {\n const event = new CustomEvent(type, init)\n return el.dispatchEvent(event)\n}\n\nexport function fireBlurEvent(el: Element, init?: FocusEventInit) {\n const event = new FocusEvent(\"blur\", init)\n const allowed = el.dispatchEvent(event)\n const bubbleInit = { ...init, bubbles: true }\n el.dispatchEvent(new FocusEvent(\"focusout\", bubbleInit))\n return allowed\n}\n\nexport function fireKeyboardEvent(el: Element, type: string, init?: KeyboardEventInit) {\n const event = new KeyboardEvent(type, init)\n return el.dispatchEvent(event)\n}\n\nexport function fireClickEvent(el: Element, init?: PointerEventInit) {\n const event = typeof PointerEvent !== \"undefined\" ? new PointerEvent(\"click\", init) : new MouseEvent(\"click\", init)\n return el.dispatchEvent(event)\n}\n", "/**\n * Determine if the blur event within an element is valid\n */\nexport function validateBlur(event: Event, opts: Options) {\n const exclude = Array.isArray(opts.exclude) ? opts.exclude : [opts.exclude]\n const relatedTarget = (event.relatedTarget ?? opts.fallback) as HTMLElement\n return exclude.every((el) => !el?.contains(relatedTarget))\n}\n\ntype MaybeArray<T> = T | T[]\n\ntype Options = {\n exclude: MaybeArray<HTMLElement | null>\n fallback?: HTMLElement | null\n}\n\ntype Event = Pick<FocusEvent, \"relatedTarget\">\n", "import { getComputedStyle } from \"./computed-style\"\nimport { isDisabled, isHTMLElement } from \"./query\"\n\nexport const focusableSelector = /*#__PURE__*/ [\n \"input:not([disabled]):not([type=hidden])\",\n \"select:not([disabled])\",\n \"textarea:not([disabled])\",\n \"button:not([disabled])\",\n \"embed\",\n \"iframe\",\n \"object\",\n \"a[href]\",\n \"area[href]\",\n \"[tabindex]\",\n \"audio[controls]\",\n \"video[controls]\",\n \"*[tabindex]:not([aria-disabled])\",\n \"[contenteditable]:not([contenteditable=false])\",\n \"details > summary:first-of-type\",\n].join(\",\")\n\nexport function isHidden(el: HTMLElement | null, until?: HTMLElement) {\n const style = getComputedStyle(el)\n if (!el || style.getPropertyValue(\"visibility\") === \"hidden\") return true\n while (el) {\n if (until != null && el === until) return false\n if (style.getPropertyValue(\"display\") === \"none\") return true\n el = el.parentElement\n }\n return false\n}\n\n/**\n * Returns the focusable elements within the element\n */\nexport const getFocusables = (el: HTMLElement | Document | null, includeContainer: boolean | \"if-empty\" = false) => {\n if (!el) return []\n let els = Array.from(el.querySelectorAll<HTMLElement>(focusableSelector))\n\n const shouldAddContainer = includeContainer == true || (includeContainer == \"if-empty\" && els.length === 0)\n\n if (shouldAddContainer && isHTMLElement(el)) {\n els.unshift(el)\n }\n\n return els.filter((el) => isFocusable(el) && !isHidden(el))\n}\n\n/**\n * Whether this element is focusable\n */\nexport const isFocusable = (el: HTMLElement | null) => {\n if (!isHTMLElement(el) || isHidden(el) || isDisabled(el)) return false\n return el?.matches(focusableSelector)\n}\n\n/**\n * Returns the tabbable elements within the element\n */\nexport const getTabbables = (el: HTMLElement | Document | null, includeContainer: boolean | \"if-empty\" = false) => {\n if (!el) return []\n return getFocusables(el, includeContainer).filter(isTabbable)\n}\n\n/**\n * Whether this element is tabbable\n */\nexport const isTabbable = (el: HTMLElement | null) => {\n return isFocusable(el) && !isDisabled(el) && !isHidden(el)\n}\n", "import { noop } from \"@zag-js/utils\"\n\ntype Callback = (v: MutationRecord) => void\n\nexport function observeAttributes(node: Element | null, attributes: string | string[], fn: Callback) {\n if (!node) return noop\n const attrs = Array.isArray(attributes) ? attributes : [attributes]\n const win = node.ownerDocument.defaultView || window\n const obs = new win.MutationObserver((changes) => {\n for (const change of changes) {\n if (change.type === \"attributes\" && change.attributeName && attrs.includes(change.attributeName)) {\n fn(change)\n }\n }\n })\n\n obs.observe(node, { attributes: true, attributeFilter: attrs })\n\n return () => obs.disconnect()\n}\n\nexport function observeChildren(node: Element | null, fn: Callback) {\n if (!node) return noop\n const win = node.ownerDocument.defaultView || window\n const obs = new win.MutationObserver((changes) => {\n for (const change of changes) {\n if (change.type === \"childList\") {\n fn(change)\n }\n }\n })\n\n obs.observe(node, { childList: true, subtree: true })\n\n return () => obs.disconnect()\n}\n", "import { observeAttributes } from \"./mutation-observer\"\n\nexport function getClosestForm(el: HTMLElement) {\n if (isFormElement(el)) return el.form\n else return el.closest(\"form\")\n}\n\nfunction isFormElement(el: HTMLElement): el is HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement {\n return el.matches(\"textarea, input, select, button\")\n}\n\nexport function trackFormReset(el: HTMLElement | null | undefined, callback: () => void) {\n if (!el) return\n const form = getClosestForm(el)\n form?.addEventListener(\"reset\", callback, { passive: true })\n return () => {\n form?.removeEventListener(\"reset\", callback)\n }\n}\n\nexport function trackFieldsetDisabled(el: HTMLElement | null | undefined, callback: (disabled: boolean) => void) {\n const fieldset = el?.closest(\"fieldset\")\n if (!fieldset) return\n callback(fieldset.disabled)\n return observeAttributes(fieldset, [\"disabled\"], () => callback(fieldset.disabled))\n}\n\nexport function isNativeDisabled(el: HTMLElement) {\n return el.matches(\":disabled\")\n}\n", "import { getOwnerWindow } from \"./query\"\n\ntype DescriptorOptions = {\n type: \"input\" | \"textarea\"\n property: \"value\" | \"checked\"\n}\n\nfunction getDescriptor(el: HTMLElement, options: DescriptorOptions) {\n const { type, property } = options\n const win = getOwnerWindow(el)\n const _type = type === \"input\" ? \"HTMLInputElement\" : \"HTMLTextAreaElement\"\n const proto = win[_type].prototype\n return Object.getOwnPropertyDescriptor(proto, property) ?? {}\n}\n\nexport function dispatchInputValueEvent(el: HTMLElement, value: string | number) {\n const win = getOwnerWindow(el)\n if (!(el instanceof win.HTMLInputElement)) return\n const desc = getDescriptor(el, { type: \"input\", property: \"value\" })\n desc.set?.call(el, value)\n const event = new win.Event(\"input\", { bubbles: true })\n el.dispatchEvent(event)\n}\n\nexport function dispatchInputCheckedEvent(el: HTMLElement, checked: boolean) {\n const win = getOwnerWindow(el)\n if (!(el instanceof win.HTMLInputElement)) return\n const desc = getDescriptor(el, { type: \"input\", property: \"checked\" })\n desc.set?.call(el, checked)\n const event = new win.Event(\"click\", { bubbles: true })\n el.dispatchEvent(event)\n}\n\nexport function trackInputPropertyMutation(\n el: HTMLInputElement | null,\n options: DescriptorOptions & { fn?: (value: string) => void },\n) {\n const { fn, property, type } = options\n\n if (!fn || !el) return\n\n const { get, set } = getDescriptor(el, { property, type })\n\n let run = true\n\n Object.defineProperty(el, property, {\n get() {\n return get?.call(this)\n },\n set(value: string) {\n if (run) fn(value)\n return set?.call(this, value)\n },\n })\n\n return () => {\n run = false\n }\n}\n", "import type { KeyboardEvent } from \"react\"\n\ntype EventKey =\n | \"ArrowDown\"\n | \"ArrowUp\"\n | \"ArrowLeft\"\n | \"ArrowRight\"\n | \"Space\"\n | \"Enter\"\n | \"Comma\"\n | \"Escape\"\n | \"Backspace\"\n | \"Delete\"\n | \"Home\"\n | \"End\"\n | \"Tab\"\n | \"PageUp\"\n | \"PageDown\"\n | (string & {})\n\nexport type EventKeyMap = Partial<Record<EventKey, (event: React.KeyboardEvent) => void>>\n\nconst rtlKeyMap = {\n ArrowLeft: \"ArrowRight\",\n ArrowRight: \"ArrowLeft\",\n Home: \"End\",\n End: \"Home\",\n}\n\nconst sameKeyMap = {\n Up: \"ArrowUp\",\n Down: \"ArrowDown\",\n Esc: \"Escape\",\n \" \": \"Space\",\n \",\": \"Comma\",\n Left: \"ArrowLeft\",\n Right: \"ArrowRight\",\n}\n\ntype EventKeyOptions = {\n dir?: \"ltr\" | \"rtl\"\n orientation?: \"horizontal\" | \"vertical\"\n}\n\n/**\n * Determine the event key based on text direction.\n */\nexport function getEventKey(event: KeyboardEvent, options: EventKeyOptions = {}) {\n const { dir = \"ltr\", orientation = \"horizontal\" } = options\n\n let { key } = event\n key = sameKeyMap[key] ?? key // normalize key\n\n const isRtl = dir === \"rtl\" && orientation === \"horizontal\"\n\n if (isRtl && key in rtlKeyMap) {\n key = rtlKeyMap[key]\n }\n\n return key\n}\n\nconst PAGE_KEYS = new Set([\"PageUp\", \"PageDown\"])\nconst ARROW_KEYS = new Set([\"ArrowUp\", \"ArrowDown\", \"ArrowLeft\", \"ArrowRight\"])\n\n/**\n * Determine the step factor for keyboard events\n */\nexport function getEventStep(event: KeyboardEvent) {\n if (event.ctrlKey || event.metaKey) {\n return 0.1\n } else {\n const isPageKey = PAGE_KEYS.has(event.key)\n const isSkipKey = isPageKey || (event.shiftKey && ARROW_KEYS.has(event.key))\n return isSkipKey ? 10 : 1\n }\n}\n", "export const visuallyHiddenStyle = {\n border: \"0\",\n clip: \"rect(0 0 0 0)\",\n height: \"1px\",\n margin: \"-1px\",\n overflow: \"hidden\",\n padding: \"0\",\n position: \"absolute\",\n width: \"1px\",\n whiteSpace: \"nowrap\",\n wordWrap: \"normal\",\n} as const\n\nexport function setVisuallyHidden(el: HTMLElement) {\n Object.assign(el.style, visuallyHiddenStyle)\n}\n", "import { setVisuallyHidden } from \"./visually-hidden\"\n\nexport type LiveRegionOptions = {\n level: \"polite\" | \"assertive\"\n document?: Document\n root?: HTMLElement | null\n delay?: number\n}\n\nexport type LiveRegion = ReturnType<typeof createLiveRegion>\n\nconst LIVE_REGION_ID = \"__live-region__\"\n\nexport function createLiveRegion(opts: Partial<LiveRegionOptions> = {}) {\n const { level = \"polite\", document: doc = document, root, delay: _delay = 0 } = opts\n\n const win = doc.defaultView ?? window\n const parent = root ?? doc.body\n\n function announce(message: string, delay?: number) {\n const oldRegion = doc.getElementById(LIVE_REGION_ID)\n\n // remove old region\n oldRegion?.remove()\n\n // Did an override level get set?\n delay = delay ?? _delay\n\n // create fresh region\n const region = doc.createElement(\"span\")\n region.id = LIVE_REGION_ID\n region.dataset.liveAnnouncer = \"true\"\n\n // Determine redundant role\n const role = level !== \"assertive\" ? \"status\" : \"alert\"\n\n // add role and attributes\n region.setAttribute(\"aria-live\", level)\n region.setAttribute(\"role\", role)\n\n // hide live region\n setVisuallyHidden(region)\n\n parent.appendChild(region)\n\n // populate region to trigger it\n win.setTimeout(() => {\n region.textContent = message\n }, delay)\n }\n\n function destroy() {\n const oldRegion = doc.getElementById(LIVE_REGION_ID)\n oldRegion?.remove()\n }\n\n return {\n announce,\n destroy,\n toJSON() {\n return LIVE_REGION_ID\n },\n }\n}\n", "type Root = Document | Element | null | undefined\n\nexport function queryAll<T extends HTMLElement = HTMLElement>(root: Root, selector: string) {\n return Array.from(root?.querySelectorAll<T>(selector) ?? [])\n}\n\nexport function query<T extends HTMLElement = HTMLElement>(root: Root, selector: string) {\n return root?.querySelector<T>(selector)\n}\n\nexport function itemById<T extends HTMLElement>(v: T[], id: string) {\n return v.find((node) => node.id === id)\n}\n\nexport function indexOfId<T extends HTMLElement>(v: T[], id: string) {\n const item = itemById(v, id)\n return item ? v.indexOf(item) : -1\n}\n\nexport function nextById<T extends HTMLElement>(v: T[], id: string, loop = true) {\n let idx = indexOfId(v, id)\n idx = loop ? (idx + 1) % v.length : Math.min(idx + 1, v.length - 1)\n return v[idx]\n}\n\nexport function prevById<T extends HTMLElement>(v: T[], id: string, loop = true) {\n let idx = indexOfId(v, id)\n if (idx === -1) return loop ? v[v.length - 1] : null\n idx = loop ? (idx - 1 + v.length) % v.length : Math.max(0, idx - 1)\n return v[idx]\n}\n\nconst getValueText = <T extends HTMLElement>(item: T) => item.dataset.valuetext ?? item.textContent ?? \"\"\n\nconst match = (valueText: string, query: string) => valueText.toLowerCase().startsWith(query.toLowerCase())\n\nconst wrap = <T>(v: T[], idx: number) => {\n return v.map((_, index) => v[(Math.max(idx, 0) + index) % v.length])\n}\n\nexport function findByText<T extends HTMLElement>(v: T[], text: string, currentId?: string | null) {\n const index = currentId ? indexOfId(v, currentId) : -1\n let items = currentId ? wrap(v, index) : v\n\n const isSingleKey = text.length === 1\n\n if (isSingleKey) {\n items = items.filter((item) => item.id !== currentId)\n }\n\n return items.find((item) => match(getValueText(item), text))\n}\n\nexport function sortByTreeOrder<T extends HTMLElement>(v: T[]) {\n return v.sort((a, b) => (a.compareDocumentPosition(b) & 2 ? 1 : -1))\n}\n", "// Credits: https://github.com/adobe/react-spectrum/blob/e81cfec20056338c7987c513826dc45df32f3db4/packages/%40react-aria/interactions/src/textSelection.ts\nimport { isIos } from \"@zag-js/utils\"\nimport { nextTick } from \"./next-tick\"\n\ntype State = \"default\" | \"disabled\" | \"restoring\"\n\nlet state: State = \"default\"\nlet savedUserSelect = \"\"\nlet modifiedElementMap = new WeakMap<HTMLElement, string>()\n\nexport function disableTextSelection({ target, doc }: { target?: HTMLElement; doc?: Document } = {}) {\n const _document = doc ?? document\n\n if (isIos()) {\n if (state === \"default\") {\n savedUserSelect = _document.documentElement.style.webkitUserSelect\n _document.documentElement.style.webkitUserSelect = \"none\"\n }\n\n state = \"disabled\"\n } else if (target) {\n modifiedElementMap.set(target, target.style.userSelect)\n target.style.userSelect = \"none\"\n }\n\n return () => restoreTextSelection({ target, doc: _document })\n}\n\nexport function restoreTextSelection({ target, doc }: { target?: HTMLElement; doc?: Document } = {}) {\n const _document = doc ?? document\n\n if (isIos()) {\n if (state !== \"disabled\") return\n state = \"restoring\"\n\n setTimeout(() => {\n nextTick(() => {\n if (state === \"restoring\") {\n if (_document.documentElement.style.webkitUserSelect === \"none\") {\n _document.documentElement.style.webkitUserSelect = savedUserSelect || \"\"\n }\n\n savedUserSelect = \"\"\n state = \"default\"\n }\n })\n }, 300)\n } else {\n if (target && modifiedElementMap.has(target)) {\n let targetOldUserSelect = modifiedElementMap.get(target)\n\n if (target.style.userSelect === \"none\") {\n target.style.userSelect = targetOldUserSelect ?? \"\"\n }\n\n if (target.getAttribute(\"style\") === \"\") {\n target.removeAttribute(\"style\")\n }\n modifiedElementMap.delete(target)\n }\n }\n}\n", "import { isLeftClick, isMouseEvent, pipe } from \"@zag-js/utils\"\nimport { addDomEvent, addPointerEvent } from \"./listener\"\nimport type { AnyPointerEvent, EventListenerWithPointInfo as Listener, PointerEventInfo } from \"./listener.types\"\nimport { disableTextSelection } from \"./text-selection\"\n\nexport function trackPointerDown(doc: Document, onPointerDown: (el: HTMLElement) => void) {\n const win = doc.defaultView ?? window\n const fn = (event: PointerEvent) => {\n if (event.target instanceof win.HTMLElement) {\n onPointerDown(event.target)\n }\n }\n return addDomEvent(doc, \"pointerdown\", fn)\n}\n\ntype TrackPointerMoveOptions = {\n ctx: { doc?: Document; threshold?: number }\n onPointerUp: VoidFunction\n onPointerMove: (info: PointerEventInfo, event: AnyPointerEvent) => void\n}\n\nexport function trackPointerMove(opts: TrackPointerMoveOptions) {\n const { onPointerMove, onPointerUp, ctx } = opts\n const { doc = document, threshold = 5 } = ctx\n\n const handlePointerMove: Listener = (event, info) => {\n const { point: p } = info\n const distance = Math.sqrt(p.x ** 2 + p.y ** 2)\n if (distance < threshold) return\n\n // Because Safari doesn't trigger mouseup events when it's above a `<select>`\n if (isMouseEvent(event) && isLeftClick(event)) {\n onPointerUp()\n return\n }\n\n onPointerMove(info, event)\n }\n\n return pipe(\n addPointerEvent(doc, \"pointermove\", handlePointerMove, false),\n addPointerEvent(doc, \"pointerup\", onPointerUp, false),\n addPointerEvent(doc, \"pointercancel\", onPointerUp, false),\n addPointerEvent(doc, \"contextmenu\", onPointerUp, false),\n disableTextSelection({ doc }),\n )\n}\n", "import { pipe } from \"@zag-js/utils\"\nimport { addDomEvent } from \"./listener\"\n\ntype PointerLockHandlers = {\n onPointerLock?: VoidFunction\n onPointerUnlock?: VoidFunction\n}\n\nexport function addPointerlockChangeListener(doc: Document, fn: VoidFunction) {\n return addDomEvent(doc, \"pointerlockchange\", fn, false)\n}\n\nexport function addPointerlockErrorListener(doc: Document, fn: (e: Event) => void) {\n doc.addEventListener(\"pointerlockerror\", fn, false)\n return function cleanup() {\n doc.removeEventListener(\"pointerlockerror\", fn, false)\n }\n}\n\nexport function requestPointerLock(doc: Document, handlers: PointerLockHandlers = {}) {\n const { onPointerLock, onPointerUnlock } = handlers\n const body = doc.body\n\n const supported = \"pointerLockElement\" in doc || \"mozPointerLockElement\" in doc\n const locked = !!doc.pointerLockElement\n\n function onPointerChange() {\n if (locked) onPointerLock?.()\n else onPointerUnlock?.()\n }\n\n function onPointerError(event: Event) {\n if (locked) onPointerUnlock?.()\n console.error(\"PointerLock error occured:\", event)\n exit()\n }\n\n function exit() {\n doc.exitPointerLock()\n }\n\n if (!supported) return\n\n body.requestPointerLock()\n\n const cleanup = pipe(\n addPointerlockChangeListener(doc, onPointerChange),\n addPointerlockErrorListener(doc, onPointerError),\n )\n\n return function dispose() {\n if (!supported) return\n cleanup()\n exit()\n }\n}\n", "// Credit goes to the radix-ui team for this utility:\n// https://github.com/radix-ui/primitives/blob/main/packages/core/rect/src/observeElementRect.ts\n\ntype Fn = (rect: DOMRect) => void\ntype ObservedData = { rect: DOMRect; callbacks: Fn[] }\nexport type Measurable = { getBoundingClientRect(): DOMRect }\n\nfunction getObservedElements(): Map<Measurable, ObservedData> {\n ;(globalThis as any).__rectObserverMap__ = (globalThis as any).__rectObserverMap__ || new Map()\n return (globalThis as any).__rectObserverMap__\n}\n\nexport function observeElementRect(el: Measurable, fn: Fn) {\n const observedElements = getObservedElements()\n\n const data = observedElements.get(el)\n\n if (!data) {\n observedElements.set(el, { rect: {} as DOMRect, callbacks: [fn] })\n\n if (observedElements.size === 1) {\n rafId = requestAnimationFrame(runLoop)\n }\n } else {\n data.callbacks.push(fn)\n fn(el.getBoundingClientRect())\n }\n\n return function unobserve() {\n const data = observedElements.get(el)\n if (!data) return\n\n const index = data.callbacks.indexOf(fn)\n if (index > -1) {\n data.callbacks.splice(index, 1)\n }\n\n if (data.callbacks.length === 0) {\n observedElements.delete(el)\n\n if (observedElements.size === 0) {\n cancelAnimationFrame(rafId)\n }\n }\n }\n}\n\nlet rafId: number\n\nfunction runLoop() {\n const observedElements = getObservedElements()\n\n const changedRectsData: Array<ObservedData> = []\n\n observedElements.forEach((data, element) => {\n const newRect = element.getBoundingClientRect()\n\n if (!isEqual(data.rect, newRect)) {\n data.rect = newRect\n changedRectsData.push(data)\n }\n })\n\n changedRectsData.forEach((data) => {\n data.callbacks.forEach((callback) => callback(data.rect))\n })\n\n rafId = requestAnimationFrame(runLoop)\n}\n\nfunction isEqual(rect1: DOMRect, rect2: DOMRect) {\n return (\n rect1.width === rect2.width &&\n rect1.height === rect2.height &&\n rect1.top === rect2.top &&\n rect1.right === rect2.right &&\n rect1.bottom === rect2.bottom &&\n rect1.left === rect2.left\n )\n}\n", "import { getComputedStyle } from \"./computed-style\"\nimport { getNodeName, getOwnerDocument, getOwnerWindow, getParent, isHTMLElement, isWindow } from \"./query\"\n\nexport function isScrollParent(el: HTMLElement): boolean {\n const { overflow, overflowX, overflowY } = getComputedStyle(el)\n return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX)\n}\n\nexport function getScrollParent(el: HTMLElement): HTMLElement {\n if ([\"html\", \"body\", \"#document\"].includes(getNodeName(el))) {\n return getOwnerDocument(el).body\n }\n\n if (isHTMLElement(el) && isScrollParent(el)) {\n return el\n }\n\n return getScrollParent(getParent(el))\n}\n\ntype Target = Array<VisualViewport | Window | HTMLElement>\n\nexport function getScrollParents(el: HTMLElement, list: Target = []): Target {\n const scrollParent = getScrollParent(el)\n const isBody = scrollParent === getOwnerDocument(el).body\n const win = getOwnerWindow(scrollParent)\n\n const target = isBody\n ? ([win] as Target).concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : [])\n : scrollParent\n\n const parents = list.concat(target)\n if (isBody) return parents\n\n return parents.concat(getScrollParents(getParent(<HTMLElement>target)))\n}\n\nexport function getScrollOffset(el: HTMLElement) {\n if (isWindow(el)) {\n return { scrollLeft: el.scrollX, scrollTop: el.scrollY }\n }\n\n return { scrollLeft: el.scrollLeft, scrollTop: el.scrollTop }\n}\n", "import { findByText } from \"./nodelist\"\n\nexport type TypeaheadState = {\n keysSoFar: string\n timer: number\n}\n\nexport type TypeaheadOptions = {\n state: TypeaheadState\n activeId: string | null\n key: string\n timeout?: number\n}\n\nfunction findByTypeaheadImpl<T extends HTMLElement>(_items: T[], options: TypeaheadOptions) {\n const { state, activeId, key, timeout = 350 } = options\n\n const search = state.keysSoFar + key\n const isRepeated = search.length > 1 && Array.from(search).every((char) => char === search[0])\n\n const query = isRepeated ? search[0] : search\n\n let items = _items.slice()\n\n const next = findByText(items, query, activeId)\n\n function cleanup() {\n clearTimeout(state.timer)\n state.timer = -1\n }\n\n function update(value: string) {\n state.keysSoFar = value\n cleanup()\n\n if (value !== \"\") {\n state.timer = +setTimeout(() => {\n update(\"\")\n cleanup()\n }, timeout)\n }\n }\n\n update(search)\n\n return next\n}\nexport const findByTypeahead = /*#__PURE__*/ Object.assign(findByTypeaheadImpl, {\n defaultOptions: {\n keysSoFar: \"\",\n timer: -1,\n },\n})\n", "import { cast } from \"@zag-js/utils\"\nimport { addDomEvent } from \"./listener\"\n\nexport function trackDocumentVisibility(_doc: Document, callback: (hidden: boolean) => void) {\n const doc = cast(_doc) as Document & { msHidden?: boolean; webkitHidden?: boolean }\n return addDomEvent(doc, \"visibilitychange\", () => {\n const hidden = doc.hidden || doc.msHidden || doc.webkitHidden\n callback(!!hidden)\n })\n}\n", "import { addDomEvent } from \"./listener\"\n\ntype ViewportSize = {\n width: number\n height: number\n}\n\ntype Options = {\n document?: Document\n resolve?(data: ViewportSize): void\n}\n\nexport function trackVisualViewport(options: Options) {\n const { document: doc, resolve } = options\n const win = doc?.defaultView || window\n resolve?.(getViewportSize(win))\n const onResize = () => resolve?.(getViewportSize(win))\n return addDomEvent(win.visualViewport ?? win, \"resize\", onResize)\n}\n\nfunction getViewportSize(win: Window): ViewportSize {\n return {\n width: win.visualViewport?.width || win.innerWidth,\n height: win.visualViewport?.height || win.innerHeight,\n }\n}\n", "export function waitFor<T>(predicate: () => T): Promise<T> {\n let value = predicate()\n if (!!value) return Promise.resolve(value)\n return new Promise((resolve) => {\n const id = globalThis.setInterval(function () {\n let value = predicate()\n if (value) {\n globalThis.clearInterval(id)\n resolve(value)\n }\n }, 0)\n })\n}\n\nexport function waitForEvent(el: HTMLElement, eventName: string) {\n return new Promise<void>((resolve) => {\n function done(event: Event) {\n if (event.target === el) {\n el.removeEventListener(eventName, done)\n resolve()\n }\n }\n\n el.addEventListener(eventName, done)\n })\n}\n", "import { RectEdge, RectValue } from \"./types\"\n\nconst point = (x: number, y: number) => ({ x, y })\n\nexport class Rect {\n static create(v: RectValue) {\n return new Rect(v)\n }\n protected constructor(private v: RectValue) {}\n set(n: Partial<RectValue>) {\n return new Rect(Object.assign({}, this.v, n))\n }\n clone() {\n return new Rect(this.v)\n }\n get x() {\n return this.v.x\n }\n get y() {\n return this.v.y\n }\n get width() {\n return this.v.width\n }\n get height() {\n return this.v.height\n }\n get minX() {\n return this.v.x\n }\n get midX() {\n return this.v.x + this.v.width / 2\n }\n get maxX() {\n return this.v.x + this.v.width\n }\n get minY() {\n return this.v.y\n }\n get midY() {\n return this.v.y + this.v.height / 2\n }\n get maxY() {\n return this.v.y + this.v.height\n }\n get center() {\n return point(this.midX, this.midY)\n }\n get centers() {\n const top = point(this.midX, this.minY)\n const right = point(this.maxX, this.midY)\n const bottom = point(this.midX, this.maxY)\n const left = point(this.minX, this.midY)\n return { top, right, bottom, left }\n }\n get corners() {\n const top = point(this.minX, this.minY)\n const right = point(this.maxX, this.minY)\n const bottom = point(this.maxX, this.maxY)\n const left = point(this.minX, this.maxY)\n return { top, right, bottom, left }\n }\n\n get edges() {\n const c = this.corners\n const top: RectEdge = [c.top, c.right]\n const right: RectEdge = [c.right, c.bottom]\n const bottom: RectEdge = [c.left, c.bottom]\n const left: RectEdge = [c.top, c.left]\n return { top, right, bottom, left }\n }\n}\n", "type Key = keyof CSSStyleDeclaration | (string & {})\ntype Styles = Record<Key, any>\ntype El = HTMLElement | null | undefined\n\nconst styleCache: WeakMap<HTMLElement, Styles> = new WeakMap()\n\nexport function getComputedStyle(el: El): Styles {\n if (!el) return {} as Styles\n let style: Styles | undefined = styleCache.get(el)\n if (!style) {\n const win = el?.ownerDocument.defaultView ?? window\n style = win.getComputedStyle(el) as Styles\n styleCache.set(el, style)\n }\n return style\n}\n", "import { Rect } from \"./rect\"\nimport { getComputedStyle } from \"./computed-style\"\n\nexport function getElementRect(el: HTMLElement, opts: ElementRectOptions = {}): Rect {\n return Rect.create(getClientRect(el, opts))\n}\n\nexport type ElementRectOptions = {\n /**\n * Whether to exclude the element's scrollbar size from the calculation.\n */\n excludeScrollbar?: boolean\n /**\n * Whether to exclude the element's borders from the calculation.\n */\n excludeBorders?: boolean\n}\n\nfunction getClientRect(el: HTMLElement, opts: ElementRectOptions = {}) {\n const { excludeScrollbar = false, excludeBorders = false } = opts\n\n const { x, y, width, height } = el.getBoundingClientRect()\n const r = { x, y, width, height }\n\n const style = getComputedStyle(el)\n\n const { borderLeftWidth, borderTopWidth, borderRightWidth, borderBottomWidth } = style\n\n const borderXWidth = sum(borderLeftWidth, borderRightWidth)\n const borderYWidth = sum(borderTopWidth, borderBottomWidth)\n\n if (excludeBorders) {\n r.width -= borderXWidth\n r.height -= borderYWidth\n r.x += px(borderLeftWidth)\n r.y += px(borderTopWidth)\n }\n\n if (excludeScrollbar) {\n const scrollbarWidth = el.offsetWidth - el.clientWidth - borderXWidth\n const scrollbarHeight = el.offsetHeight - el.clientHeight - borderYWidth\n r.width -= scrollbarWidth\n r.height -= scrollbarHeight\n }\n\n return r\n}\n\nconst px = (v: string) => parseFloat(v.replace(\"px\", \"\"))\n\nconst sum = (...vals: string[]) => vals.reduce((sum, v) => sum + (v ? px(v) : 0), 0)\n", "export function toArray<T>(v: T | T[] | undefined | null): T[] {\n if (!v) return []\n return Array.isArray(v) ? v : [v]\n}\n\nexport const fromLength = (length: number) => Array.from(Array(length).keys())\n\nexport const first = <T>(v: T[]): T | undefined => v[0]\n\nexport const last = <T>(v: T[]): T | undefined => v[v.length - 1]\n\nexport const isEmpty = <T>(v: T[]): boolean => v.length === 0\n\nexport const has = <T>(v: T[], t: any): boolean => v.indexOf(t) !== -1\n\nexport const add = <T>(v: T[], ...items: T[]): T[] => v.concat(items)\n\nexport const remove = <T>(v: T[], item: T): T[] => removeAt(v, v.indexOf(item))\n\nexport const removeAt = <T>(v: T[], i: number): T[] => {\n if (i > -1) v.splice(i, 1)\n return v\n}\n\nexport function clear<T>(v: T[]): T[] {\n while (v.length > 0) v.pop()\n return v\n}\n\nexport type IndexOptions = {\n step?: number\n loop?: boolean\n}\n\nexport function nextIndex<T>(v: T[], idx: number, opts: IndexOptions = {}): number {\n const { step = 1, loop = true } = opts\n const next = idx + step\n const len = v.length\n const last = len - 1\n if (idx === -1) return step > 0 ? 0 : last\n if (next < 0) return loop ? last : 0\n if (next >= len) return loop ? 0 : idx > len ? len : idx\n return next\n}\n\nexport function next<T>(v: T[], idx: number, opts: IndexOptions = {}): T | undefined {\n return v[nextIndex(v, idx, opts)]\n}\n\nexport function prevIndex<T>(v: T[], idx: number, opts: IndexOptions = {}): number {\n const { step = 1, loop = true } = opts\n return nextIndex(v, idx, { step: -step, loop })\n}\n\nexport function prev<T>(v: T[], index: number, opts: IndexOptions = {}): T | undefined {\n return v[prevIndex(v, index, opts)]\n}\n\nexport const chunk = <T>(v: T[], size: number): T[][] => {\n const res: T[][] = []\n return v.reduce((rows, value, index) => {\n if (index % size === 0) rows.push([value])\n else last(rows)?.push(value)\n return rows\n }, res)\n}\n", "export const isDev = () => process.env.NODE_ENV !== \"production\"\nexport const isDom = () => typeof window !== \"undefined\"\n\nexport const isArray = (v: any): v is any[] => Array.isArray(v)\nexport const isBoolean = (v: any): v is boolean => v === true || v === false\nexport const isObject = (v: any): v is Record<string, any> => !(v == null || typeof v !== \"object\" || isArray(v))\nexport const isNumber = (v: any): v is number => typeof v === \"number\" && !Number.isNaN(v)\nexport const isString = (v: any): v is string => typeof v === \"string\"\nexport const isFunction = (v: any): v is Function => typeof v === \"function\"\n\nexport const hasProp = <T extends string>(obj: any, prop: T): obj is Record<T, any> =>\n Object.prototype.hasOwnProperty.call(obj, prop)\n", "import { isDom } from \"./guard\"\n\nexport function getPlatform() {\n const agent = (navigator as any).userAgentData\n return agent?.platform ?? navigator.platform\n}\n\nconst pt = (v: RegExp) => isDom() && v.test(getPlatform())\nconst ua = (v: RegExp) => isDom() && v.test(navigator.userAgent)\nconst vn = (v: RegExp) => isDom() && v.test(navigator.vendor)\n\nexport const isTouchDevice = isDom() && !!navigator.maxTouchPoints\nexport const isMac = () => pt(/^Mac/) && !isTouchDevice\nexport const isIPhone = () => pt(/^iPhone/)\nexport const isSafari = () => isApple() && vn(/apple/i)\nexport const isFirefox = () => ua(/firefox\\//i)\nexport const isApple = () => pt(/mac|iphone|ipad|ipod/i)\nexport const isIos = () => isApple() && !isMac()\n", "import { hasProp, isDom, isObject } from \"./guard\"\nimport { isMac } from \"./platform\"\n\nexport const supportsPointerEvent = () => isDom() && window.onpointerdown === null\nexport const supportsTouchEvent = () => isDom() && window.ontouchstart === null\nexport const supportsMouseEvent = () => isDom() && window.onmousedown === null\n\nexport const isMouseEvent = (v: any): v is MouseEvent => isObject(v) && hasProp(v, \"button\")\nexport const isTouchEvent = (v: any): v is TouchEvent => isObject(v) && hasProp(v, \"touches\")\nexport const isLeftClick = (v: { button: number }) => v.button === 0\nexport const isRightClick = (v: { button: number }) => v.button === 2\nexport const isModifiedEvent = (v: Pick<KeyboardEvent, \"ctrlKey\" | \"metaKey\" | \"altKey\">) =>\n v.ctrlKey || v.altKey || v.metaKey\n\nexport const isCtrlKey = (v: Pick<KeyboardEvent, \"ctrlKey\" | \"metaKey\">) =>\n isMac() ? v.metaKey && !v.ctrlKey : v.ctrlKey && !v.metaKey\n", "export const runIfFn = <T>(\n v: T | undefined,\n ...a: T extends (...a: any[]) => void ? Parameters<T> : never\n): T extends (...a: any[]) => void ? NonNullable<ReturnType<T>> : NonNullable<T> => {\n const res = typeof v === \"function\" ? v(...a) : v\n return res ?? undefined\n}\n\nexport const cast = <T>(v: unknown): T => v as T\n\nexport const noop = () => {}\n\nexport const pipe =\n <T>(...fns: Array<(a: T) => T>) =>\n (v: T) =>\n fns.reduce((a, b) => b(a), v)\n\nexport const callAll =\n <T extends (...a: any[]) => void>(...fns: (T | undefined)[]) =>\n (...a: Parameters<T>) => {\n fns.forEach(function (fn) {\n fn?.(...a)\n })\n }\n\nexport const uuid = /*#__PURE__*/ (() => {\n let id = 0\n return () => {\n id++\n return id.toString(36)\n }\n})()\n\nexport function merge<T, U>(origin: T, patch: U): T & U {\n if (!(typeof patch === \"object\")) return patch as any\n const result = !(typeof origin === \"object\") ? {} : Object.assign({}, origin)\n for (const key of Object.keys(patch)) {\n const value = patch[key]\n const src = result[key]\n if (value === null) delete result[key]\n else if (Array.isArray(value) || Array.isArray(src)) result[key] = (src || []).concat(value || [])\n else result[key] = merge(src, value)\n }\n return result as any\n}\n", "export function warn(m: string): void\nexport function warn(c: boolean, m: string): void\nexport function warn(...a: any[]): void {\n const m = a.length === 1 ? a[0] : a[1]\n const c = a.length === 2 ? a[0] : true\n if (c && process.env.NODE_ENV !== \"production\") {\n console.warn(m)\n }\n}\n\nexport function invariant(m: string): void\nexport function invariant(c: boolean, m: string): void\nexport function invariant(...a: any[]): void {\n const m = a.length === 1 ? a[0] : a[1]\n const c = a.length === 2 ? a[0] : true\n if (c && process.env.NODE_ENV !== \"production\") {\n throw new Error(m)\n }\n}\n", "import { isTouchEvent } from \"@zag-js/utils\"\nimport { Point } from \"./types\"\n\nexport function distance(a: Point, b: Point = { x: 0, y: 0 }): number {\n return Math.sqrt(Math.pow(a.x - b.x, 2) + Math.pow(a.y - b.y, 2))\n}\n\nexport function closest(...pts: Point[]) {\n return (a: Point): Point => {\n const ds = pts.map((b) => distance(b, a))\n const c = Math.min.apply(Math, ds)\n return pts[ds.indexOf(c)]\n }\n}\n\nconst fallback = { pageX: 0, pageY: 0, clientX: 0, clientY: 0 }\n\nexport function getEventPoint(e: AnyPointerEvent, t: PointType = \"page\"): Point {\n const p = isTouchEvent(e) ? e.touches[0] || e.changedTouches[0] || fallback : e\n return { x: p[`${t}X`], y: p[`${t}Y`] }\n}\n\nexport function relativeToNode(p: Point, el: HTMLElement): RelativeValue {\n const dx = p.x - el.offsetLeft - el.clientLeft + el.scrollLeft\n const dy = p.y - el.offsetTop - el.clientTop + el.scrollTop\n return {\n point: { x: dx, y: dy },\n progress: { x: dx / el.offsetWidth, y: dy / el.offsetHeight },\n }\n}\n\ntype AnyPointerEvent = MouseEvent | TouchEvent | PointerEvent\n\ntype RelativeValue = {\n point: Point\n progress: { x: number; y: number }\n}\n\ntype PointType = \"page\" | \"client\"\n", "import { Rect } from \"./rect\"\nimport type { Point, RectInset, SymmetricRectInset } from \"./types\"\n\nexport const isSymmetric = (v: any): v is SymmetricRectInset => \"dx\" in v || \"dy\" in v\n\nexport function inset(r: Rect, i: RectInset | SymmetricRectInset): Rect {\n const v = isSymmetric(i) ? { left: i.dx, right: i.dx, top: i.dy, bottom: i.dy } : i\n const { top = 0, right = 0, bottom = 0, left = 0 } = v\n return Rect.create({ x: r.x + left, y: r.y + top, width: r.width - left - right, height: r.height - top - bottom })\n}\n\nexport function expand(r: Rect, v: number | SymmetricRectInset): Rect {\n const value = typeof v === \"number\" ? { dx: -v, dy: -v } : v\n return inset(r, value)\n}\n\nexport function shrink(r: Rect, v: number | SymmetricRectInset): Rect {\n const value = typeof v === \"number\" ? { dx: -v, dy: -v } : v\n return inset(r, value)\n}\n\nexport function shift(r: Rect, o: Partial<Point>): Rect {\n const { x = 0, y = 0 } = o\n return Rect.create({ x: r.x + x, y: r.y + y, width: r.width, height: r.height })\n}\n", "import { Point } from \"./types\"\n\nexport function withinPolygon(polygon: Point[], point: Point) {\n const { x, y } = point\n let c = false\n\n for (let i = 0, j = polygon.length - 1; i < polygon.length; j = i++) {\n const xi = polygon[i].x\n const yi = polygon[i].y\n const xj = polygon[j].x\n const yj = polygon[j].y\n\n if (yi > y !== yj > y && x < ((xj - xi) * (y - yi)) / (yj - yi) + xi) {\n c = !c\n }\n }\n return c\n}\n\nfunction createPolygonElement() {\n const id = \"debug-polygon\"\n const existingPolygon = document.getElementById(id)\n if (existingPolygon) {\n return existingPolygon\n }\n const svg = document.createElementNS(\"http://www.w3.org/2000/svg\", \"svg\")\n Object.assign(svg.style, {\n top: \"0\",\n left: \"0\",\n width: \"100%\",\n height: \"100%\",\n opacity: \"0.15\",\n position: \"fixed\",\n pointerEvents: \"none\",\n })\n\n const polygon = document.createElementNS(\"http://www.w3.org/2000/svg\", \"polygon\")\n polygon.setAttribute(\"id\", id)\n polygon.setAttribute(\"points\", \"0,0 0,0\")\n svg.appendChild(polygon)\n document.body.appendChild(svg)\n return polygon\n}\n\nexport function debugPolygon(polygon: Point[]) {\n const el = createPolygonElement()\n const points = polygon.map((point) => `${point.x},${point.y}`).join(\" \")\n el.setAttribute(\"points\", points)\n}\n", "export type Num<T extends string> = Record<T, number>\n\nexport function wrap(num: number, max: number): number {\n return ((num % max) + max) % max\n}\n\nexport function round(v: number | string, t?: number) {\n let num = valueOf(v)\n const p = 10 ** (t ?? 10)\n num = Math.round(num * p) / p\n return t ? num.toFixed(t) : v.toString()\n}\n\nexport function roundToDevicePixel(num: number) {\n if (typeof window === \"undefined\") return Math.round(num)\n const dp = window.devicePixelRatio\n return Math.floor(num * dp + 0.5) / dp\n}\n\nexport const valueToPercent = (v: number | string, r: Num<\"step\" | \"min\" | \"max\">) =>\n ((valueOf(v) - r.min) * 100) / (r.max - r.min)\n\nexport const percentToValue = (v: number | string, r: Num<\"min\" | \"max\">) => r.min + (r.max - r.min) * valueOf(v)\n\nexport function clamp(v: number | string, o: Num<\"min\" | \"max\">) {\n return Math.min(Math.max(valueOf(v), o.min), o.max)\n}\n\nexport function countDecimals(value: number) {\n if (!Number.isFinite(value)) return 0\n let e = 1,\n p = 0\n while (Math.round(value * e) / e !== value) {\n e *= 10\n p += 1\n }\n return p\n}\n\nexport const increment = (v: number | string, s: number) => decimalOperation(valueOf(v), \"+\", s)\n\nexport const decrement = (v: number | string, s: number) => decimalOperation(valueOf(v), \"-\", s)\n\nexport function snapToStep(value: number | string, step: number) {\n const num = valueOf(value)\n const p = countDecimals(step)\n const v = Math.round(num / step) * step\n return round(v, p)\n}\n\nexport function valueOf(v: string | number) {\n if (typeof v === \"number\") return v\n const num = parseFloat(v.toString().replace(/[^\\w.-]+/g, \"\"))\n return !Number.isNaN(num) ? num : 0\n}\n\nexport type FormatDecimalOptions = {\n /**\n * The minimum number of fraction digits to use. Possible values are from 0 to 20\n */\n minFractionDigits?: number\n /**\n * The maximum number of fraction digits to use. Possible values are from 0 to 20;\n */\n maxFractionDigits?: number\n}\n\nexport function formatDecimal(v: number | string, o: Omit<FormatDecimalOptions, \"value\">) {\n return new Intl.NumberFormat(\"en-US\", {\n useGrouping: false,\n style: \"decimal\",\n minimumFractionDigits: o.minFractionDigits,\n maximumFractionDigits: o.maxFractionDigits,\n }).format(valueOf(v))\n}\n\nexport function isAtMax(v: number | string, o: Num<\"max\">) {\n const val = valueOf(v)\n return val >= o.max\n}\n\nexport function isAtMin(v: number | string, o: Num<\"min\">) {\n const val = valueOf(v)\n return val <= o.min\n}\n\nexport function isWithinRange(v: number | string, o: Num<\"min\" | \"max\">) {\n const val = valueOf(v)\n return val >= o.min && val <= o.max\n}\n\nfunction decimalOperation(a: number, op: \"-\" | \"+\", b: number): number {\n let result = op === \"+\" ? a + b : a - b\n\n // Check if we have decimals\n if (a % 1 !== 0 || b % 1 !== 0) {\n const multiplier = 10 ** Math.max(countDecimals(a), countDecimals(b))\n\n // Transform the decimals to integers based on the precision\n a = Math.round(a * multiplier)\n b = Math.round(b * multiplier)\n\n // Perform the operation on integers values to make sure we don't get a fancy decimal value\n result = op === \"+\" ? a + b : a - b\n\n // Transform the integer result back to decimal\n result /= multiplier\n }\n\n return result\n}\n", "import {\n clamp,\n decrement,\n increment,\n isAtMax,\n isAtMin,\n isWithinRange,\n Num,\n percentToValue,\n FormatDecimalOptions,\n formatDecimal,\n snapToStep,\n valueOf,\n valueToPercent,\n} from \"./number\"\n\nexport type RangeOptions<T = string | number> = Num<\"min\" | \"max\"> &\n FormatDecimalOptions & {\n value: T\n step: number\n }\n\nexport function rangy(o: RangeOptions) {\n const wrap = (v: string | number) => rangy({ ...o, value: v })\n return {\n isInRange: isWithinRange(o.value, o),\n isAtMax: isAtMax(o.value, o),\n isAtMin: isAtMin(o.value, o),\n percent: valueToPercent(o.value, o),\n valueAsNumber: valueOf(o.value),\n value: formatDecimal(o.value, o),\n snapToStep: () => wrap(snapToStep(o.value, o.step)),\n increment: (s?: number) => wrap(increment(o.value, s || o.step)),\n decrement: (s?: number) => wrap(decrement(o.value, s || o.step)),\n toMax: () => wrap(o.max),\n toMin: () => wrap(o.min),\n fromPercent: (p: number) => wrap(percentToValue(p, o)),\n clamp: () => wrap(clamp(o.value, o)),\n }\n}\n", "export const nf = new Intl.NumberFormat(\"en-US\", { style: \"decimal\", maximumFractionDigits: 20 })\n\nexport function formatter(n: number) {\n return parseFloat(nf.format(n))\n}\n", "import { formatter } from \"./number-format\"\n\ntype Num<T extends string> = Record<T, number>\n\nexport const transform = (a: [number, number], b: [number, number]) => {\n const i = { min: a[0], max: a[1] }\n const o = { min: b[0], max: b[1] }\n return (v: number) => {\n if (i.min === i.max || o.min === o.max) return o.min\n const ratio = (o.max - o.min) / (i.max - i.min)\n return o.min + ratio * (v - i.min)\n }\n}\n\nexport function toRanges(o: Num<\"min\" | \"max\"> & { value: number[]; spacing: number }) {\n const spacing = o.spacing ?? 0\n return o.value.map((v, i) => {\n const min = i === 0 ? o.min : o.value[i - 1] + spacing\n const max = i === o.value.length - 1 ? o.max : o.value[i + 1] - spacing\n return { min, max, value: v }\n })\n}\n\nexport function toRangeArray(o: Num<\"min\" | \"max\" | \"step\">): number[] {\n let i = o.min\n const range: number[] = []\n while (i <= o.max) {\n range.push(i)\n i = formatter(i + o.step)\n }\n return range\n}\n", "import { transform, valueToPercent } from \"@zag-js/number-utils\"\nimport type { Style } from \"@zag-js/types\"\nimport type { MachineContext as Ctx, SharedContext } from \"./slider.types\"\n\n/* -----------------------------------------------------------------------------\n * Thumb style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getVerticalThumbOffset(ctx: SharedContext) {\n const { height = 0 } = ctx.thumbSize ?? {}\n const getValue = transform([ctx.min, ctx.max], [-height / 2, height / 2])\n return parseFloat(getValue(ctx.value).toFixed(2))\n}\n\nfunction getHorizontalThumbOffset(ctx: SharedContext) {\n const { width = 0 } = ctx.thumbSize ?? {}\n\n if (ctx.isRtl) {\n const getValue = transform([ctx.max, ctx.min], [-width * 1.5, -width / 2])\n return -1 * parseFloat(getValue(ctx.value).toFixed(2))\n }\n\n const getValue = transform([ctx.min, ctx.max], [-width / 2, width / 2])\n return parseFloat(getValue(ctx.value).toFixed(2))\n}\n\nfunction getThumbOffset(ctx: SharedContext) {\n const percent = valueToPercent(ctx.value, ctx)\n const offset = ctx.isVertical ? getVerticalThumbOffset(ctx) : getHorizontalThumbOffset(ctx)\n return `calc(${percent}% - ${offset}px)`\n}\n\nfunction getThumbStyle(ctx: SharedContext): Style {\n const placementProp = ctx.isVertical ? \"bottom\" : ctx.isRtl ? \"right\" : \"left\"\n return {\n visibility: ctx.hasMeasuredThumbSize ? \"visible\" : \"hidden\",\n position: \"absolute\",\n transform: \"var(--slider-thumb-transform)\",\n [placementProp]: \"var(--slider-thumb-offset)\",\n }\n}\n\n/* -----------------------------------------------------------------------------\n * Range style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getRangeOffsets(ctx: Ctx) {\n const percent = valueToPercent(ctx.value, ctx)\n\n let start = \"0%\"\n let end = `${100 - percent}%`\n\n if (ctx.origin === \"center\") {\n const isNegative = percent < 50\n start = isNegative ? `${percent}%` : \"50%\"\n end = isNegative ? \"50%\" : end\n }\n\n return { start, end }\n}\n\nfunction getRangeStyle(ctx: Pick<SharedContext, \"isVertical\" | \"isRtl\">): Style {\n if (ctx.isVertical) {\n return {\n position: \"absolute\",\n bottom: \"var(--slider-range-start)\",\n top: \"var(--slider-range-end)\",\n }\n }\n\n return {\n position: \"absolute\",\n [ctx.isRtl ? \"right\" : \"left\"]: \"var(--slider-range-start)\",\n [ctx.isRtl ? \"left\" : \"right\"]: \"var(--slider-range-end)\",\n }\n}\n\n/* -----------------------------------------------------------------------------\n * Control style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getControlStyle(): Style {\n return {\n touchAction: \"none\",\n userSelect: \"none\",\n position: \"relative\",\n }\n}\n\n/* -----------------------------------------------------------------------------\n * Root style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getRootStyle(ctx: Ctx): Style {\n const range = getRangeOffsets(ctx)\n return {\n \"--slider-thumb-transform\": ctx.isVertical ? \"translateY(50%)\" : \"translateX(-50%)\",\n \"--slider-thumb-offset\": getThumbOffset(ctx),\n \"--slider-range-start\": range.start,\n \"--slider-range-end\": range.end,\n }\n}\n\n/* -----------------------------------------------------------------------------\n * Marker style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getMarkerStyle(ctx: Pick<SharedContext, \"isHorizontal\" | \"isRtl\">, percent: number): Style {\n return {\n position: \"absolute\",\n pointerEvents: \"none\",\n [ctx.isHorizontal ? \"left\" : \"bottom\"]: `${ctx.isRtl ? 100 - percent : percent}%`,\n }\n}\n\n/* -----------------------------------------------------------------------------\n * Label style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getLabelStyle(): Style {\n return { userSelect: \"none\" }\n}\n\n/* -----------------------------------------------------------------------------\n * Label style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getTrackStyle(): Style {\n return { position: \"relative\" }\n}\n\n/* -----------------------------------------------------------------------------\n * Label style calculations\n * -----------------------------------------------------------------------------*/\n\nfunction getMarkerGroupStyle(): Style {\n return {\n userSelect: \"none\",\n pointerEvents: \"none\",\n position: \"relative\",\n }\n}\n\nexport const styles = {\n getThumbOffset,\n getControlStyle,\n getThumbStyle,\n getRangeStyle,\n getRootStyle,\n getMarkerStyle,\n getLabelStyle,\n getTrackStyle,\n getMarkerGroupStyle,\n}\n", "import { clamp, decrement, increment, percentToValue, snapToStep } from \"@zag-js/number-utils\"\nimport { MachineContext as Ctx } from \"./slider.types\"\n\nexport const utils = {\n fromPercent(ctx: Ctx, percent: number) {\n percent = clamp(percent, { min: 0, max: 1 })\n return parseFloat(snapToStep(percentToValue(percent, ctx), ctx.step))\n },\n clamp(ctx: Ctx, value: number) {\n return clamp(value, ctx)\n },\n convert(ctx: Ctx, value: number) {\n return clamp(parseFloat(snapToStep(value, ctx.step)), ctx)\n },\n decrement(ctx: Ctx, step?: number) {\n let value = decrement(ctx.value, step ?? ctx.step)\n return utils.convert(ctx, value)\n },\n increment(ctx: Ctx, step?: number) {\n let value = increment(ctx.value, step ?? ctx.step)\n return utils.convert(ctx, value)\n },\n}\n", "import { dispatchInputValueEvent } from \"@zag-js/dom-utils\"\nimport type { Point } from \"@zag-js/rect-utils\"\nimport { relativeToNode } from \"@zag-js/rect-utils\"\nimport { styles } from \"./slider.style\"\nimport type { MachineContext as Ctx } from \"./slider.types\"\nimport { utils } from \"./slider.utils\"\n\nexport const dom = {\n ...styles,\n getDoc: (ctx: Ctx) => ctx.doc ?? document,\n getRootNode: (ctx: Ctx) => ctx.rootNode ?? dom.getDoc(ctx),\n\n getRootId: (ctx: Ctx) => ctx.ids?.root ?? `slider:${ctx.uid}`,\n getThumbId: (ctx: Ctx) => ctx.ids?.thumb ?? `slider:${ctx.uid}:thumb`,\n getControlId: (ctx: Ctx) => ctx.ids?.control ?? `slider:${ctx.uid}:control`,\n getInputId: (ctx: Ctx) => `slider:${ctx.uid}:input`,\n getOutputId: (ctx: Ctx) => ctx.ids?.output ?? `slider:${ctx.uid}:output`,\n getTrackId: (ctx: Ctx) => ctx.ids?.track ?? `slider:${ctx.uid}track`,\n getRangeId: (ctx: Ctx) => ctx.ids?.track ?? `slider:${ctx.uid}:range`,\n getLabelId: (ctx: Ctx) => ctx.ids?.label ?? `slider:${ctx.uid}:label`,\n getMarkerId: (ctx: Ctx, value: number) => `slider:${ctx.uid}:marker:${value}`,\n\n getRootEl: (ctx: Ctx) => dom.getRootNode(ctx).getElementById(dom.getRootId(ctx)),\n getThumbEl: (ctx: Ctx) => dom.getRootNode(ctx).getElementById(dom.getThumbId(ctx)),\n getControlEl: (ctx: Ctx) => dom.getRootNode(ctx).getElementById(dom.getControlId(ctx)),\n getInputEl: (ctx: Ctx) => dom.getRootNode(ctx).getElementById(dom.getInputId(ctx)) as HTMLInputElement | null,\n\n getValueFromPoint(ctx: Ctx, point: Point): number | undefined {\n // get the slider root element\n const control = dom.getControlEl(ctx)\n if (!control) return\n\n // get the position/progress % of the point relative to the root's width/height\n const { progress } = relativeToNode(point, control)\n\n // get the progress % depending on the orientation\n let percent: number\n\n if (ctx.isHorizontal) {\n percent = ctx.isRtl ? 1 - progress.x : progress.x\n } else {\n percent = 1 - progress.y\n }\n\n return utils.fromPercent(ctx, percent)\n },\n\n dispatchChangeEvent(ctx: Ctx) {\n const input = dom.getInputEl(ctx)\n if (!input) return\n dispatchInputValueEvent(input, ctx.value)\n },\n}\n", "import type * as React from \"react\"\n\ntype Dict<T = any> = Record<string, T>\n\ntype Booleanish = boolean | \"true\" | \"false\"\n\ntype Omit<T, K extends keyof T> = { [P in Exclude<keyof T, K>]?: T[P] }\n\ntype WithStyle<T extends { style?: any }> = Omit<T, \"style\"> & {\n style?: T[\"style\"] & {\n [prop: string]: string | number | undefined\n }\n}\n\ntype DataAttr = {\n \"data-uid\"?: string\n \"data-name\"?: string\n \"data-ownedby\"?: string\n \"data-selected\"?: Booleanish\n \"data-expanded\"?: Booleanish\n \"data-highlighted\"?: Booleanish\n \"data-readonly\"?: Booleanish\n \"data-invalid\"?: Booleanish\n \"data-hover\"?: Booleanish\n \"data-active\"?: Booleanish\n \"data-focus\"?: Booleanish\n \"data-disabled\"?: Booleanish\n \"data-type\"?: string\n \"data-value\"?: string | number\n \"data-valuetext\"?: string\n \"data-open\"?: Booleanish\n \"data-placement\"?: string\n \"data-orientation\"?: \"horizontal\" | \"vertical\"\n \"data-label\"?: string\n \"data-checked\"?: Booleanish\n \"data-pressed\"?: Booleanish\n \"data-state\"?: string | null\n \"data-half\"?: Booleanish\n \"data-count\"?: number\n \"data-controls\"?: string\n \"data-part\"?: string\n \"data-index\"?: number\n \"data-complete\"?: Booleanish\n \"data-empty\"?: Booleanish\n \"data-placeholder-shown\"?: Booleanish\n}\n\ntype JSXElementAttributes = DataAttr & React.HTMLAttributes<HTMLElement>\ntype JSXButtonAttributes = DataAttr & React.ButtonHTMLAttributes<HTMLButtonElement>\ntype JSXInputAttributes = DataAttr & React.InputHTMLAttributes<HTMLInputElement>\ntype JSXLabelAttributes = DataAttr & React.LabelHTMLAttributes<HTMLLabelElement>\ntype JSXOutputAttributes = DataAttr & React.OutputHTMLAttributes<HTMLOutputElement>\n\nexport type PropTypes = Record<\"button\" | \"label\" | \"input\" | \"output\" | \"element\", Dict>\n\nexport type ReactPropTypes = {\n button: JSXButtonAttributes\n label: JSXLabelAttributes\n input: JSXInputAttributes\n output: JSXOutputAttributes\n element: JSXElementAttributes\n}\n\nexport type NormalizeProps = {\n button<T extends PropTypes>(props: WithStyle<JSXButtonAttributes>): T[\"button\"]\n label<T extends PropTypes>(props: WithStyle<JSXLabelAttributes>): T[\"label\"]\n input<T extends PropTypes>(props: WithStyle<JSXInputAttributes>): T[\"input\"]\n output<T extends PropTypes>(props: WithStyle<JSXOutputAttributes>): T[\"output\"]\n element<T extends PropTypes>(props: WithStyle<JSXElementAttributes>): T[\"element\"]\n}\n\nexport function createNormalizer(fn: (props: Dict) => Dict): NormalizeProps {\n return new Proxy({} as any, {\n get() {\n return fn\n },\n })\n}\n\nexport const normalizeProp = createNormalizer((v) => v)\n", "export type ControlProp =\n | { type: \"boolean\"; label?: string; defaultValue: boolean }\n | { type: \"string\"; label?: string; defaultValue: string; placeholder?: string }\n | { type: \"select\"; options: readonly string[]; defaultValue: string; label?: string }\n | { type: \"multiselect\"; options: readonly string[]; defaultValue: string[]; label?: string }\n | { type: \"number\"; label?: string; defaultValue: number; min?: number; max?: number }\n\nexport type ControlRecord = Record<string, ControlProp>\n\nexport type ControlValue<T extends ControlRecord> = {\n [K in keyof T]: T[K] extends { type: \"boolean\" }\n ? boolean\n : T[K] extends { type: \"string\" }\n ? string\n : T[K] extends { type: \"select\" }\n ? T[K][\"options\"][number]\n : T[K] extends { type: \"multiselect\" }\n ? T[K][\"options\"][number][]\n : T[K] extends { type: \"number\" }\n ? number\n : never\n}\n\nexport function defineControls<T extends ControlRecord>(config: T) {\n return config\n}\n", "export function toArray<T>(v: T | T[] | undefined | null): T[] {\n if (!v) return []\n return Array.isArray(v) ? v : [v]\n}\n\nexport const fromLength = (length: number) => Array.from(Array(length).keys())\n\nexport const first = <T>(v: T[]): T | undefined => v[0]\n\nexport const last = <T>(v: T[]): T | undefined => v[v.length - 1]\n\nexport const isEmpty = <T>(v: T[]): boolean => v.length === 0\n\nexport const has = <T>(v: T[], t: any): boolean => v.indexOf(t) !== -1\n\nexport const add = <T>(v: T[], ...items: T[]): T[] => v.concat(items)\n\nexport const remove = <T>(v: T[], item: T): T[] => removeAt(v, v.indexOf(item))\n\nexport const removeAt = <T>(v: T[], i: number): T[] => {\n if (i > -1) v.splice(i, 1)\n return v\n}\n\nexport function clear<T>(v: T[]): T[] {\n while (v.length > 0) v.pop()\n return v\n}\n\nexport type IndexOptions = {\n step?: number\n loop?: boolean\n}\n\nexport function nextIndex<T>(v: T[], idx: number, opts: IndexOptions = {}): number {\n const { step = 1, loop = true } = opts\n const next = idx + step\n const len = v.length\n const last = len - 1\n if (idx === -1) return step > 0 ? 0 : last\n if (next < 0) return loop ? last : 0\n if (next >= len) return loop ? 0 : idx > len ? len : idx\n return next\n}\n\nexport function next<T>(v: T[], idx: number, opts: IndexOptions = {}): T | undefined {\n return v[nextIndex(v, idx, opts)]\n}\n\nexport function prevIndex<T>(v: T[], idx: number, opts: IndexOptions = {}): number {\n const { step = 1, loop = true } = opts\n return nextIndex(v, idx, { step: -step, loop })\n}\n\nexport function prev<T>(v: T[], index: number, opts: IndexOptions = {}): T | undefined {\n return v[prevIndex(v, index, opts)]\n}\n\nexport const chunk = <T>(v: T[], size: number): T[][] => {\n const res: T[][] = []\n return v.reduce((rows, value, index) => {\n if (index % size === 0) rows.push([value])\n else last(rows)?.push(value)\n return rows\n }, res)\n}\n", "export const isDev = () => process.env.NODE_ENV !== \"production\"\nexport const isDom = () => typeof window !== \"undefined\"\n\nexport const isArray = (v: any): v is any[] => Array.isArray(v)\nexport const isBoolean = (v: any): v is boolean => v === true || v === false\nexport const isObject = (v: any): v is Record<string, any> => !(v == null || typeof v !== \"object\" || isArray(v))\nexport const isNumber = (v: any): v is number => typeof v === \"number\" && !Number.isNaN(v)\nexport const isString = (v: any): v is string => typeof v === \"string\"\nexport const isFunction = (v: any): v is Function => typeof v === \"function\"\n\nexport const hasProp = <T extends string>(obj: any, prop: T): obj is Record<T, any> =>\n Object.prototype.hasOwnProperty.call(obj, prop)\n", "import { isDom } from \"./guard\"\n\nexport function getPlatform() {\n const agent = (navigator as any).userAgentData\n return agent?.platform ?? navigator.platform\n}\n\nconst pt = (v: RegExp) => isDom() && v.test(getPlatform())\nconst ua = (v: RegExp) => isDom() && v.test(navigator.userAgent)\nconst vn = (v: RegExp) => isDom() && v.test(navigator.vendor)\n\nexport const isTouchDevice = isDom() && !!navigator.maxTouchPoints\nexport const isMac = () => pt(/^Mac/) && !isTouchDevice\nexport const isIPhone = () => pt(/^iPhone/)\nexport const isSafari = () => isApple() && vn(/apple/i)\nexport const isFirefox = () => ua(/firefox\\//i)\nexport const isApple = () => pt(/mac|iphone|ipad|ipod/i)\nexport const isIos = () => isApple() && !isMac()\n", "import { hasProp, isDom, isObject } from \"./guard\"\nimport { isMac } from \"./platform\"\n\nexport const supportsPointerEvent = () => isDom() && window.onpointerdown === null\nexport const supportsTouchEvent = () => isDom() && window.ontouchstart === null\nexport const supportsMouseEvent = () => isDom() && window.onmousedown === null\n\nexport const isMouseEvent = (v: any): v is MouseEvent => isObject(v) && hasProp(v, \"button\")\nexport const isTouchEvent = (v: any): v is TouchEvent => isObject(v) && hasProp(v, \"touches\")\nexport const isLeftClick = (v: { button: number }) => v.button === 0\nexport const isRightClick = (v: { button: number }) => v.button === 2\nexport const isModifiedEvent = (v: Pick<KeyboardEvent, \"ctrlKey\" | \"metaKey\" | \"altKey\">) =>\n v.ctrlKey || v.altKey || v.metaKey\n\nexport const isCtrlKey = (v: Pick<KeyboardEvent, \"ctrlKey\" | \"metaKey\">) =>\n isMac() ? v.metaKey && !v.ctrlKey : v.ctrlKey && !v.metaKey\n", "export const runIfFn = <T>(\n v: T | undefined,\n ...a: T extends (...a: any[]) => void ? Parameters<T> : never\n): T extends (...a: any[]) => void ? NonNullable<ReturnType<T>> : NonNullable<T> => {\n const res = typeof v === \"function\" ? v(...a) : v\n return res ?? undefined\n}\n\nexport const cast = <T>(v: unknown): T => v as T\n\nexport const noop = () => {}\n\nexport const pipe =\n <T>(...fns: Array<(a: T) => T>) =>\n (v: T) =>\n fns.reduce((a, b) => b(a), v)\n\nexport const callAll =\n <T extends (...a: any[]) => void>(...fns: (T | undefined)[]) =>\n (...a: Parameters<T>) => {\n fns.forEach(function (fn) {\n fn?.(...a)\n })\n }\n\nexport const uuid = /*#__PURE__*/ (() => {\n let id = 0\n return () => {\n id++\n return id.toString(36)\n }\n})()\n\nexport function merge<T, U>(origin: T, patch: U): T & U {\n if (!(typeof patch === \"object\")) return patch as any\n const result = !(typeof origin === \"object\") ? {} : Object.assign({}, origin)\n for (const key of Object.keys(patch)) {\n const value = patch[key]\n const src = result[key]\n if (value === null) delete result[key]\n else if (Array.isArray(value) || Array.isArray(src)) result[key] = (src || []).concat(value || [])\n else result[key] = merge(src, value)\n }\n return result as any\n}\n", "export function warn(m: string): void\nexport function warn(c: boolean, m: string): void\nexport function warn(...a: any[]): void {\n const m = a.length === 1 ? a[0] : a[1]\n const c = a.length === 2 ? a[0] : true\n if (c && process.env.NODE_ENV !== \"production\") {\n console.warn(m)\n }\n}\n\nexport function invariant(m: string): void\nexport function invariant(c: boolean, m: string): void\nexport function invariant(...a: any[]): void {\n const m = a.length === 1 ? a[0] : a[1]\n const c = a.length === 2 ? a[0] : true\n if (c && process.env.NODE_ENV !== \"production\") {\n throw new Error(m)\n }\n}\n", "import { dataAttr, EventKeyMap, getEventKey, getEventStep, getNativeEvent } from \"@zag-js/dom-utils\"\nimport { percentToValue, valueToPercent } from \"@zag-js/number-utils\"\nimport { getEventPoint } from \"@zag-js/rect-utils\"\nimport { normalizeProp, PropTypes, ReactPropTypes } from \"@zag-js/types\"\nimport { isLeftClick, isModifiedEvent } from \"@zag-js/utils\"\nimport { dom } from \"./slider.dom\"\nimport type { Send, State } from \"./slider.types\"\n\nexport function connect<T extends PropTypes = ReactPropTypes>(state: State, send: Send, normalize = normalizeProp) {\n const ariaLabel = state.context[\"aria-label\"]\n const ariaLabelledBy = state.context[\"aria-labelledby\"]\n const ariaValueText = state.context.getAriaValueText?.(state.context.value)\n\n const isFocused = state.matches(\"focus\")\n const isDragging = state.matches(\"dragging\")\n const isDisabled = state.context.disabled\n const isInteractive = state.context.isInteractive\n const isInvalid = state.context.invalid\n\n return {\n isFocused,\n isDragging,\n value: state.context.value,\n percent: valueToPercent(state.context.value, state.context),\n setValue(value: number) {\n send({ type: \"SET_VALUE\", value })\n },\n getPercentValue(percent: number) {\n return percentToValue(percent, state.context)\n },\n focus() {\n dom.getThumbEl(state.context)?.focus()\n },\n increment() {\n send(\"INCREMENT\")\n },\n decrement() {\n send(\"DECREMENT\")\n },\n\n rootProps: normalize.element<T>({\n \"data-part\": \"root\",\n \"data-disabled\": dataAttr(isDisabled),\n \"data-orientation\": state.context.orientation,\n id: dom.getRootId(state.context),\n dir: state.context.dir,\n style: dom.getRootStyle(state.context),\n }),\n\n labelProps: normalize.label<T>({\n \"data-part\": \"label\",\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n id: dom.getLabelId(state.context),\n htmlFor: dom.getInputId(state.context),\n onClick(event) {\n if (!isInteractive) return\n event.preventDefault()\n dom.getThumbEl(state.context)?.focus()\n },\n style: dom.getLabelStyle(),\n }),\n\n thumbProps: normalize.element<T>({\n \"data-part\": \"thumb\",\n id: dom.getThumbId(state.context),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-orientation\": state.context.orientation,\n \"data-focus\": dataAttr(isFocused),\n draggable: false,\n \"aria-invalid\": isInvalid || undefined,\n \"data-invalid\": dataAttr(isInvalid),\n \"aria-disabled\": isDisabled || undefined,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabel ? undefined : ariaLabelledBy ?? dom.getLabelId(state.context),\n \"aria-orientation\": state.context.orientation,\n \"aria-valuemax\": state.context.max,\n \"aria-valuemin\": state.context.min,\n \"aria-valuenow\": state.context.value,\n \"aria-valuetext\": ariaValueText,\n role: \"slider\",\n tabIndex: isDisabled ? undefined : 0,\n onBlur() {\n if (!isInteractive) return\n send(\"BLUR\")\n },\n onFocus() {\n if (!isInteractive) return\n send(\"FOCUS\")\n },\n onKeyDown(event) {\n if (!isInteractive) return\n const step = getEventStep(event) * state.context.step\n let prevent = true\n const keyMap: EventKeyMap = {\n ArrowUp() {\n send({ type: \"ARROW_UP\", step })\n prevent = state.context.isVertical\n },\n ArrowDown() {\n send({ type: \"ARROW_DOWN\", step })\n prevent = state.context.isVertical\n },\n ArrowLeft() {\n send({ type: \"ARROW_LEFT\", step })\n prevent = state.context.isHorizontal\n },\n ArrowRight() {\n send({ type: \"ARROW_RIGHT\", step })\n prevent = state.context.isHorizontal\n },\n PageUp() {\n send({ type: \"PAGE_UP\", step })\n },\n PageDown() {\n send({ type: \"PAGE_DOWN\", step })\n },\n Home() {\n send(\"HOME\")\n },\n End() {\n send(\"END\")\n },\n }\n\n const key = getEventKey(event, state.context)\n const exec = keyMap[key]\n\n if (!exec) return\n exec(event)\n\n if (prevent) {\n event.preventDefault()\n }\n },\n style: dom.getThumbStyle(state.context),\n }),\n\n inputProps: normalize.input<T>({\n \"data-part\": \"input\",\n type: \"text\",\n defaultValue: state.context.value,\n name: state.context.name,\n id: dom.getInputId(state.context),\n hidden: true,\n }),\n\n outputProps: normalize.output<T>({\n \"data-part\": \"output\",\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n id: dom.getOutputId(state.context),\n htmlFor: dom.getInputId(state.context),\n \"aria-live\": \"off\",\n }),\n\n trackProps: normalize.element<T>({\n \"data-part\": \"track\",\n id: dom.getTrackId(state.context),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n \"data-orientation\": state.context.orientation,\n \"data-focus\": dataAttr(isFocused),\n style: dom.getTrackStyle(),\n }),\n\n rangeProps: normalize.element<T>({\n \"data-part\": \"range\",\n id: dom.getRangeId(state.context),\n \"data-invalid\": dataAttr(isInvalid),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-orientation\": state.context.orientation,\n style: dom.getRangeStyle(state.context),\n }),\n\n controlProps: normalize.element<T>({\n \"data-part\": \"control\",\n id: dom.getControlId(state.context),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n \"data-orientation\": state.context.orientation,\n \"data-focus\": dataAttr(isFocused),\n onPointerDown(event) {\n if (!isInteractive) return\n\n const evt = getNativeEvent(event)\n if (!isLeftClick(evt) || isModifiedEvent(evt)) return\n\n const point = getEventPoint(evt)\n send({ type: \"POINTER_DOWN\", point })\n\n event.preventDefault()\n event.stopPropagation()\n },\n style: dom.getControlStyle(),\n }),\n\n markerGroupProps: normalize.element<T>({\n \"data-part\": \"marker-group\",\n role: \"presentation\",\n \"aria-hidden\": true,\n \"data-orientation\": state.context.orientation,\n style: dom.getMarkerGroupStyle(),\n }),\n\n getMarkerProps({ value }: { value: number }) {\n const percent = valueToPercent(value, state.context)\n const style = dom.getMarkerStyle(state.context, percent)\n const markerState =\n value > state.context.value ? \"over-value\" : value < state.context.value ? \"under-value\" : \"at-value\"\n\n return normalize.element<T>({\n \"data-part\": \"marker\",\n \"data-orientation\": state.context.orientation,\n id: dom.getMarkerId(state.context, value),\n \"data-value\": value,\n \"data-disabled\": dataAttr(isDisabled),\n \"data-state\": markerState,\n style,\n })\n },\n }\n}\n", "import { createMachine, ref } from \"@zag-js/core\"\nimport { nextTick, raf, trackFieldsetDisabled, trackFormReset, trackPointerMove } from \"@zag-js/dom-utils\"\nimport { dom } from \"./slider.dom\"\nimport { MachineContext, MachineState, UserDefinedContext } from \"./slider.types\"\nimport { utils } from \"./slider.utils\"\n\nexport function machine(ctx: UserDefinedContext = {}) {\n return createMachine<MachineContext, MachineState>(\n {\n id: \"slider\",\n initial: \"unknown\",\n context: {\n thumbSize: null,\n uid: \"\",\n disabled: false,\n threshold: 5,\n dir: \"ltr\",\n origin: \"start\",\n orientation: \"horizontal\",\n initialValue: null,\n value: 0,\n step: 1,\n min: 0,\n max: 100,\n ...ctx,\n },\n\n computed: {\n isHorizontal: (ctx) => ctx.orientation === \"horizontal\",\n isVertical: (ctx) => ctx.orientation === \"vertical\",\n isRtl: (ctx) => ctx.orientation === \"horizontal\" && ctx.dir === \"rtl\",\n isInteractive: (ctx) => !(ctx.disabled || ctx.readonly),\n hasMeasuredThumbSize: (ctx) => ctx.thumbSize !== null,\n },\n\n watch: {\n value: [\"invokeOnChange\", \"dispatchChangeEvent\"],\n },\n\n activities: [\"trackFormReset\", \"trackFieldsetDisabled\"],\n\n on: {\n SET_VALUE: {\n actions: \"setValue\",\n },\n INCREMENT: {\n actions: \"increment\",\n },\n DECREMENT: {\n actions: \"decrement\",\n },\n },\n\n states: {\n unknown: {\n on: {\n SETUP: {\n target: \"idle\",\n actions: [\"setupDocument\", \"setThumbSize\", \"checkValue\"],\n },\n },\n },\n\n idle: {\n on: {\n POINTER_DOWN: {\n target: \"dragging\",\n actions: [\"setPointerValue\", \"invokeOnChangeStart\", \"focusThumb\"],\n },\n FOCUS: \"focus\",\n },\n },\n\n focus: {\n entry: \"focusThumb\",\n on: {\n POINTER_DOWN: {\n target: \"dragging\",\n actions: [\"setPointerValue\", \"invokeOnChangeStart\", \"focusThumb\"],\n },\n ARROW_LEFT: {\n guard: \"isHorizontal\",\n actions: \"decrement\",\n },\n ARROW_RIGHT: {\n guard: \"isHorizontal\",\n actions: \"increment\",\n },\n ARROW_UP: {\n guard: \"isVertical\",\n actions: \"increment\",\n },\n ARROW_DOWN: {\n guard: \"isVertical\",\n actions: \"decrement\",\n },\n PAGE_UP: {\n actions: \"increment\",\n },\n PAGE_DOWN: {\n actions: \"decrement\",\n },\n HOME: {\n actions: \"setToMin\",\n },\n END: {\n actions: \"setToMax\",\n },\n BLUR: \"idle\",\n },\n },\n\n dragging: {\n entry: \"focusThumb\",\n activities: \"trackPointerMove\",\n on: {\n POINTER_UP: {\n target: \"focus\",\n actions: \"invokeOnChangeEnd\",\n },\n POINTER_MOVE: {\n actions: \"setPointerValue\",\n },\n },\n },\n },\n },\n {\n guards: {\n isHorizontal: (ctx) => ctx.isHorizontal,\n isVertical: (ctx) => ctx.isVertical,\n },\n\n activities: {\n trackFieldsetDisabled(ctx) {\n let cleanup: VoidFunction | undefined\n nextTick(() => {\n cleanup = trackFieldsetDisabled(dom.getRootEl(ctx), (disabled) => {\n if (disabled != ctx.disabled) {\n ctx.disabled = disabled\n }\n })\n })\n return () => cleanup?.()\n },\n trackFormReset(ctx) {\n let cleanup: VoidFunction | undefined\n nextTick(() => {\n cleanup = trackFormReset(dom.getInputEl(ctx), () => {\n if (ctx.initialValue != null) {\n ctx.value = ctx.initialValue\n }\n })\n })\n return () => cleanup?.()\n },\n trackPointerMove(ctx, _evt, { send }) {\n return trackPointerMove({\n ctx,\n onPointerMove(info) {\n send({ type: \"POINTER_MOVE\", point: info.point })\n },\n onPointerUp() {\n send(\"POINTER_UP\")\n },\n })\n },\n },\n\n actions: {\n setupDocument(ctx, evt) {\n if (evt.doc) ctx.doc = ref(evt.doc)\n if (evt.root) ctx.rootNode = ref(evt.root)\n ctx.uid = evt.id\n },\n checkValue(ctx) {\n const value = utils.convert(ctx, ctx.value)\n Object.assign(ctx, { value, initialValue: value })\n },\n invokeOnChangeStart(ctx) {\n ctx.onChangeStart?.({ value: ctx.value })\n },\n invokeOnChangeEnd(ctx) {\n ctx.onChangeEnd?.({ value: ctx.value })\n },\n invokeOnChange(ctx) {\n ctx.onChange?.({ value: ctx.value })\n },\n dispatchChangeEvent(ctx) {\n dom.dispatchChangeEvent(ctx)\n },\n setThumbSize(ctx) {\n raf(() => {\n const el = dom.getThumbEl(ctx)\n if (!el) return\n ctx.thumbSize = { width: el.offsetWidth, height: el.offsetHeight }\n })\n },\n setPointerValue(ctx, evt) {\n const value = dom.getValueFromPoint(ctx, evt.point)\n if (value == null) return\n ctx.value = utils.clamp(ctx, value)\n },\n focusThumb(ctx) {\n raf(() => dom.getThumbEl(ctx)?.focus())\n },\n decrement(ctx, evt) {\n ctx.value = utils.decrement(ctx, evt.step)\n },\n increment(ctx, evt) {\n ctx.value = utils.increment(ctx, evt.step)\n },\n setToMin(ctx) {\n ctx.value = ctx.min\n },\n setToMax(ctx) {\n ctx.value = ctx.max\n },\n setValue(ctx, evt) {\n ctx.value = utils.convert(ctx, evt.value)\n },\n },\n },\n )\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"slider.connect.d.ts","sourceRoot":"","sources":["../src/slider.connect.ts"],"names":[],"mappings":"AAGA,OAAO,EAAiB,SAAS,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAGxE,OAAO,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AAEjD,wBAAgB,OAAO,CAAC,CAAC,SAAS,SAAS,GAAG,cAAc,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,yCAAgB;;;;;oBAgB7F,MAAM;6BAGG,MAAM;;;;;;;;;;;;;;eAkLI,MAAM;;EAiB5C"}
|
package/dist/slider.dom.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"slider.dom.d.ts","sourceRoot":"","sources":["../src/slider.dom.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAA;AAG/C,OAAO,KAAK,EAAE,cAAc,IAAI,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAG3D,eAAO,MAAM,GAAG;kBAEA,GAAG;uBACE,GAAG;qBAEL,GAAG;sBACF,GAAG;wBACD,GAAG;sBACL,GAAG;uBACF,GAAG;sBACJ,GAAG;sBACH,GAAG;sBACH,GAAG;uBACF,GAAG,SAAS,MAAM;qBAEpB,GAAG;sBACF,GAAG;wBACD,GAAG;sBACL,GAAG;2BAEE,GAAG,SAAS,KAAK,GAAG,MAAM,GAAG,SAAS;6BAoBpC,GAAG;;;;;;;;;;CAK7B,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"slider.machine.d.ts","sourceRoot":"","sources":["../src/slider.machine.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AAGjF,wBAAgB,OAAO,CAAC,GAAG,GAAE,kBAAuB,oHA0NnD"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"slider.style.d.ts","sourceRoot":"","sources":["../src/slider.style.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAC1C,OAAO,KAAK,EAAE,cAAc,IAAI,GAAG,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAA;AAwB1E,iBAAS,cAAc,CAAC,GAAG,EAAE,aAAa,UAIzC;AAED,iBAAS,aAAa,CAAC,GAAG,EAAE,aAAa,GAAG,KAAK,CAQhD;AAqBD,iBAAS,aAAa,CAAC,GAAG,EAAE,IAAI,CAAC,aAAa,EAAE,YAAY,GAAG,OAAO,CAAC,GAAG,KAAK,CAc9E;AAMD,iBAAS,eAAe,IAAI,KAAK,CAMhC;AAMD,iBAAS,YAAY,CAAC,GAAG,EAAE,GAAG,GAAG,KAAK,CAQrC;AAMD,iBAAS,cAAc,CAAC,GAAG,EAAE,IAAI,CAAC,aAAa,EAAE,cAAc,GAAG,OAAO,CAAC,EAAE,OAAO,EAAE,MAAM,GAAG,KAAK,CAMlG;AAMD,iBAAS,aAAa,IAAI,KAAK,CAE9B;AAMD,iBAAS,aAAa,IAAI,KAAK,CAE9B;AAMD,iBAAS,mBAAmB,IAAI,KAAK,CAMpC;AAED,eAAO,MAAM,MAAM;;;;;;;;;;CAUlB,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"slider.types.d.ts","sourceRoot":"","sources":["../src/slider.types.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"slider.utils.d.ts","sourceRoot":"","sources":["../src/slider.utils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,IAAI,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAEtD,eAAO,MAAM,KAAK;qBACC,GAAG,WAAW,MAAM;eAI1B,GAAG,SAAS,MAAM;iBAGhB,GAAG,SAAS,MAAM;mBAGhB,GAAG,SAAS,MAAM;mBAIlB,GAAG,SAAS,MAAM;CAIlC,CAAA"}
|