@n3wth/ui 0.8.0 → 0.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/atoms/AnimatedText/AnimatedText.js +65 -0
- package/dist/atoms/AnimatedText/AnimatedText.js.map +1 -0
- package/dist/atoms/Avatar/Avatar.js +55 -0
- package/dist/atoms/Avatar/Avatar.js.map +1 -0
- package/dist/atoms/Badge/Badge.js +57 -0
- package/dist/atoms/Badge/Badge.js.map +1 -0
- package/dist/atoms/Button/Button.js +92 -0
- package/dist/atoms/Button/Button.js.map +1 -0
- package/dist/atoms/Character/Character.js +155 -0
- package/dist/atoms/Character/Character.js.map +1 -0
- package/dist/atoms/CodeBlock/CodeBlock.js +75 -0
- package/dist/atoms/CodeBlock/CodeBlock.js.map +1 -0
- package/dist/atoms/HamburgerIcon/HamburgerIcon.js +50 -0
- package/dist/atoms/HamburgerIcon/HamburgerIcon.js.map +1 -0
- package/dist/atoms/Icon/Icon.js +199 -0
- package/dist/atoms/Icon/Icon.js.map +1 -0
- package/dist/atoms/Input/Input.js +80 -0
- package/dist/atoms/Input/Input.js.map +1 -0
- package/dist/atoms/Label/Label.js +32 -0
- package/dist/atoms/Label/Label.js.map +1 -0
- package/dist/atoms/NoiseOverlay/NoiseOverlay.js +32 -0
- package/dist/atoms/NoiseOverlay/NoiseOverlay.js.map +1 -0
- package/dist/atoms/Progress/Progress.js +63 -0
- package/dist/atoms/Progress/Progress.js.map +1 -0
- package/dist/atoms/ScrollIndicator/ScrollIndicator.js +51 -0
- package/dist/atoms/ScrollIndicator/ScrollIndicator.js.map +1 -0
- package/dist/atoms/Separator/Separator.js +28 -0
- package/dist/atoms/Separator/Separator.js.map +1 -0
- package/dist/atoms/Shape/Shape.js +110 -0
- package/dist/atoms/Shape/Shape.js.map +1 -0
- package/dist/atoms/Shape/patterns.js +66 -0
- package/dist/atoms/Shape/patterns.js.map +1 -0
- package/dist/atoms/Skeleton/Skeleton.js +77 -0
- package/dist/atoms/Skeleton/Skeleton.js.map +1 -0
- package/dist/atoms/SpeechBubble/SpeechBubble.js +98 -0
- package/dist/atoms/SpeechBubble/SpeechBubble.js.map +1 -0
- package/dist/atoms/Switch/Switch.js +78 -0
- package/dist/atoms/Switch/Switch.js.map +1 -0
- package/dist/atoms/Textarea/Textarea.js +40 -0
- package/dist/atoms/Textarea/Textarea.js.map +1 -0
- package/dist/atoms/Tooltip/Tooltip.js +153 -0
- package/dist/atoms/Tooltip/Tooltip.js.map +1 -0
- package/dist/hooks/useButtonPulse.js +43 -0
- package/dist/hooks/useButtonPulse.js.map +1 -0
- package/dist/hooks/useCountUp.js +52 -0
- package/dist/hooks/useCountUp.js.map +1 -0
- package/dist/hooks/useKeyboardShortcuts.js +37 -0
- package/dist/hooks/useKeyboardShortcuts.js.map +1 -0
- package/dist/hooks/useMediaQuery.js +59 -0
- package/dist/hooks/useMediaQuery.js.map +1 -0
- package/dist/hooks/usePageTransition.js +39 -0
- package/dist/hooks/usePageTransition.js.map +1 -0
- package/dist/hooks/useReducedMotion.js +57 -0
- package/dist/hooks/useReducedMotion.js.map +1 -0
- package/dist/hooks/useScrollReveal.js +61 -0
- package/dist/hooks/useScrollReveal.js.map +1 -0
- package/dist/hooks/useStaggerList.js +54 -0
- package/dist/hooks/useStaggerList.js.map +1 -0
- package/dist/hooks/useTextReveal.js +59 -0
- package/dist/hooks/useTextReveal.js.map +1 -0
- package/dist/hooks/useTheme.js +37 -0
- package/dist/hooks/useTheme.js.map +1 -0
- package/dist/hooks/useToast.js +84 -0
- package/dist/hooks/useToast.js.map +1 -0
- package/dist/index.js +147 -7925
- package/dist/index.js.map +1 -1
- package/dist/molecules/Accordion/Accordion.js +178 -0
- package/dist/molecules/Accordion/Accordion.js.map +1 -0
- package/dist/molecules/Card/Card.js +104 -0
- package/dist/molecules/Card/Card.js.map +1 -0
- package/dist/molecules/CommandBox/CommandBox.js +65 -0
- package/dist/molecules/CommandBox/CommandBox.js.map +1 -0
- package/dist/molecules/CompositeShape/CompositeShape.js +69 -0
- package/dist/molecules/CompositeShape/CompositeShape.js.map +1 -0
- package/dist/molecules/CompositeShape/presets.js +71 -0
- package/dist/molecules/CompositeShape/presets.js.map +1 -0
- package/dist/molecules/Dropdown/Dropdown.d.ts.map +1 -1
- package/dist/molecules/Dropdown/Dropdown.js +530 -0
- package/dist/molecules/Dropdown/Dropdown.js.map +1 -0
- package/dist/molecules/ErrorBoundary/ErrorBoundary.js +128 -0
- package/dist/molecules/ErrorBoundary/ErrorBoundary.js.map +1 -0
- package/dist/molecules/MobileDrawer/MobileDrawer.js +78 -0
- package/dist/molecules/MobileDrawer/MobileDrawer.js.map +1 -0
- package/dist/molecules/Modal/Modal.js +262 -0
- package/dist/molecules/Modal/Modal.js.map +1 -0
- package/dist/molecules/NavLink/NavLink.js +38 -0
- package/dist/molecules/NavLink/NavLink.js.map +1 -0
- package/dist/molecules/Tabs/Tabs.js +188 -0
- package/dist/molecules/Tabs/Tabs.js.map +1 -0
- package/dist/molecules/ThemeToggle/ThemeToggle.js +48 -0
- package/dist/molecules/ThemeToggle/ThemeToggle.js.map +1 -0
- package/dist/molecules/Toast/Toast.js +156 -0
- package/dist/molecules/Toast/Toast.js.map +1 -0
- package/dist/node_modules/clsx/dist/clsx.js +17 -0
- package/dist/node_modules/clsx/dist/clsx.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/IconoirContext.js +6 -0
- package/dist/node_modules/iconoir-react/dist/esm/IconoirContext.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowDown.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowDown.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowLeft.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowLeft.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowRight.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowRight.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowUp.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowUp.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowUpRight.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowUpRight.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Bell.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Bell.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Calendar.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Calendar.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Check.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Check.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/CheckCircle.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/CheckCircle.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Clock.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Clock.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Code.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Code.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Copy.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Copy.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Download.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Download.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/EditPencil.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/EditPencil.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Eye.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Eye.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/EyeClosed.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/EyeClosed.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Filter.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Filter.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Folder.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Folder.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Github.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Github.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/HalfMoon.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/HalfMoon.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Heart.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Heart.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Home.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Home.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/InfoCircle.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/InfoCircle.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Link.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Link.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/List.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/List.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Lock.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Lock.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/LockSlash.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/LockSlash.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Mail.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Mail.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Menu.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Menu.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Minus.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Minus.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/MoreHoriz.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/MoreHoriz.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/MoreVert.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/MoreVert.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowDown.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowDown.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowLeft.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowLeft.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowRight.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowRight.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowUp.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowUp.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/OpenInWindow.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/OpenInWindow.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Page.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Page.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Plus.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Plus.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/RefreshDouble.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/RefreshDouble.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Search.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Search.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Settings.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Settings.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/SortDown.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/SortDown.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Sparks.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Sparks.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Star.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Star.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/SunLight.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/SunLight.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Terminal.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Terminal.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Trash.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Trash.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Upload.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Upload.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/User.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/User.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/ViewGrid.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/ViewGrid.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/WarningTriangle.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/WarningTriangle.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Xmark.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/Xmark.js.map +1 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/XmarkCircle.js +17 -0
- package/dist/node_modules/iconoir-react/dist/esm/regular/XmarkCircle.js.map +1 -0
- package/dist/node_modules/tailwind-merge/dist/bundle-mjs.js +2996 -0
- package/dist/node_modules/tailwind-merge/dist/bundle-mjs.js.map +1 -0
- package/dist/organisms/Footer/Footer.js +108 -0
- package/dist/organisms/Footer/Footer.js.map +1 -0
- package/dist/organisms/Hero/Hero.d.ts.map +1 -1
- package/dist/organisms/Hero/Hero.js +101 -0
- package/dist/organisms/Hero/Hero.js.map +1 -0
- package/dist/organisms/Nav/Nav.js +177 -0
- package/dist/organisms/Nav/Nav.js.map +1 -0
- package/dist/organisms/Section/Section.js +57 -0
- package/dist/organisms/Section/Section.js.map +1 -0
- package/dist/tokens/colors.js +105 -0
- package/dist/tokens/colors.js.map +1 -0
- package/dist/tokens/effects.js +26 -0
- package/dist/tokens/effects.js.map +1 -0
- package/dist/tokens/motion.js +25 -0
- package/dist/tokens/motion.js.map +1 -0
- package/dist/tokens/spacing.js +31 -0
- package/dist/tokens/spacing.js.map +1 -0
- package/dist/tokens/typography.js +63 -0
- package/dist/tokens/typography.js.map +1 -0
- package/dist/utils/cn.js +9 -0
- package/dist/utils/cn.js.map +1 -0
- package/package.json +5 -3
|
@@ -0,0 +1,530 @@
|
|
|
1
|
+
import { jsx as o, jsxs as C } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef as R, useId as ye, useState as N, useMemo as V, useRef as O, useCallback as A, useEffect as z, createContext as De, useContext as Ie } from "react";
|
|
3
|
+
import { createPortal as Ce } from "react-dom";
|
|
4
|
+
import { cn as y } from "../../utils/cn.js";
|
|
5
|
+
const ae = De(null);
|
|
6
|
+
function T() {
|
|
7
|
+
const r = Ie(ae);
|
|
8
|
+
if (!r) throw new Error("Dropdown compound components must be used within <Dropdown>");
|
|
9
|
+
return r;
|
|
10
|
+
}
|
|
11
|
+
function Ne(r, l) {
|
|
12
|
+
z(() => {
|
|
13
|
+
function u(p) {
|
|
14
|
+
const c = p.target;
|
|
15
|
+
r.every((i) => i.current && !i.current.contains(c)) && l();
|
|
16
|
+
}
|
|
17
|
+
return document.addEventListener("pointerdown", u), () => document.removeEventListener("pointerdown", u);
|
|
18
|
+
}, [r, l]);
|
|
19
|
+
}
|
|
20
|
+
function Le(r, l) {
|
|
21
|
+
const [u, p] = N({});
|
|
22
|
+
return z(() => {
|
|
23
|
+
if (!l || !r.current) return;
|
|
24
|
+
let c, i = null;
|
|
25
|
+
function x() {
|
|
26
|
+
const h = r.current;
|
|
27
|
+
if (!h) return;
|
|
28
|
+
const D = h.getBoundingClientRect();
|
|
29
|
+
p({
|
|
30
|
+
position: "fixed",
|
|
31
|
+
top: D.bottom + 4,
|
|
32
|
+
left: D.left,
|
|
33
|
+
width: D.width,
|
|
34
|
+
zIndex: 9999
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
x(), typeof ResizeObserver < "u" && (i = new ResizeObserver(() => {
|
|
38
|
+
cancelAnimationFrame(c), c = requestAnimationFrame(x);
|
|
39
|
+
}), i.observe(r.current));
|
|
40
|
+
const s = () => {
|
|
41
|
+
cancelAnimationFrame(c), c = requestAnimationFrame(x);
|
|
42
|
+
};
|
|
43
|
+
return window.addEventListener("scroll", s, { passive: !0, capture: !1 }), () => {
|
|
44
|
+
cancelAnimationFrame(c), window.removeEventListener("scroll", s), i && i.disconnect();
|
|
45
|
+
};
|
|
46
|
+
}, [l, r]), u;
|
|
47
|
+
}
|
|
48
|
+
const se = R(
|
|
49
|
+
({ children: r, className: l, onClick: u, ...p }, c) => {
|
|
50
|
+
const i = T(), x = (s) => {
|
|
51
|
+
u?.(s), i.toggle();
|
|
52
|
+
};
|
|
53
|
+
return /* @__PURE__ */ o(
|
|
54
|
+
"button",
|
|
55
|
+
{
|
|
56
|
+
ref: c,
|
|
57
|
+
id: i.triggerId,
|
|
58
|
+
type: "button",
|
|
59
|
+
role: "combobox",
|
|
60
|
+
"aria-expanded": i.isOpen,
|
|
61
|
+
"aria-haspopup": "listbox",
|
|
62
|
+
"aria-controls": i.isOpen ? i.listboxId : void 0,
|
|
63
|
+
className: l,
|
|
64
|
+
onClick: x,
|
|
65
|
+
...p,
|
|
66
|
+
children: r
|
|
67
|
+
}
|
|
68
|
+
);
|
|
69
|
+
}
|
|
70
|
+
);
|
|
71
|
+
se.displayName = "Dropdown.Trigger";
|
|
72
|
+
const le = R(
|
|
73
|
+
({ children: r, className: l, ...u }, p) => {
|
|
74
|
+
const c = T();
|
|
75
|
+
return c.isOpen ? /* @__PURE__ */ o(
|
|
76
|
+
"ul",
|
|
77
|
+
{
|
|
78
|
+
ref: p,
|
|
79
|
+
id: c.listboxId,
|
|
80
|
+
role: "listbox",
|
|
81
|
+
"aria-multiselectable": c.multi || void 0,
|
|
82
|
+
tabIndex: -1,
|
|
83
|
+
className: l,
|
|
84
|
+
...u,
|
|
85
|
+
children: r
|
|
86
|
+
}
|
|
87
|
+
) : null;
|
|
88
|
+
}
|
|
89
|
+
);
|
|
90
|
+
le.displayName = "Dropdown.Menu";
|
|
91
|
+
const ie = R(
|
|
92
|
+
({ value: r, disabled: l = !1, children: u, className: p, onClick: c, ...i }, x) => {
|
|
93
|
+
const s = T(), h = s.selectedValues.has(r);
|
|
94
|
+
return /* @__PURE__ */ o(
|
|
95
|
+
"li",
|
|
96
|
+
{
|
|
97
|
+
ref: x,
|
|
98
|
+
role: "option",
|
|
99
|
+
"aria-selected": h,
|
|
100
|
+
"aria-disabled": l || void 0,
|
|
101
|
+
"data-value": r,
|
|
102
|
+
className: p,
|
|
103
|
+
onClick: (K) => {
|
|
104
|
+
l || (c?.(K), s.select(r));
|
|
105
|
+
},
|
|
106
|
+
...i,
|
|
107
|
+
children: u ?? r
|
|
108
|
+
}
|
|
109
|
+
);
|
|
110
|
+
}
|
|
111
|
+
);
|
|
112
|
+
ie.displayName = "Dropdown.Item";
|
|
113
|
+
function Se({ open: r, className: l }) {
|
|
114
|
+
return /* @__PURE__ */ o(
|
|
115
|
+
"svg",
|
|
116
|
+
{
|
|
117
|
+
width: "16",
|
|
118
|
+
height: "16",
|
|
119
|
+
viewBox: "0 0 16 16",
|
|
120
|
+
fill: "none",
|
|
121
|
+
className: y(
|
|
122
|
+
"transition-transform duration-200 shrink-0",
|
|
123
|
+
r && "rotate-180",
|
|
124
|
+
l
|
|
125
|
+
),
|
|
126
|
+
"aria-hidden": "true",
|
|
127
|
+
children: /* @__PURE__ */ o(
|
|
128
|
+
"path",
|
|
129
|
+
{
|
|
130
|
+
d: "M4 6L8 10L12 6",
|
|
131
|
+
stroke: "currentColor",
|
|
132
|
+
strokeWidth: "1.5",
|
|
133
|
+
strokeLinecap: "round",
|
|
134
|
+
strokeLinejoin: "round"
|
|
135
|
+
}
|
|
136
|
+
)
|
|
137
|
+
}
|
|
138
|
+
);
|
|
139
|
+
}
|
|
140
|
+
function Ee() {
|
|
141
|
+
return /* @__PURE__ */ C(
|
|
142
|
+
"svg",
|
|
143
|
+
{
|
|
144
|
+
width: "14",
|
|
145
|
+
height: "14",
|
|
146
|
+
viewBox: "0 0 16 16",
|
|
147
|
+
fill: "none",
|
|
148
|
+
className: "shrink-0",
|
|
149
|
+
"aria-hidden": "true",
|
|
150
|
+
children: [
|
|
151
|
+
/* @__PURE__ */ o("circle", { cx: "7", cy: "7", r: "5", stroke: "currentColor", strokeWidth: "1.5" }),
|
|
152
|
+
/* @__PURE__ */ o("path", { d: "M11 11L14 14", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round" })
|
|
153
|
+
]
|
|
154
|
+
}
|
|
155
|
+
);
|
|
156
|
+
}
|
|
157
|
+
function oe() {
|
|
158
|
+
return /* @__PURE__ */ o(
|
|
159
|
+
"svg",
|
|
160
|
+
{
|
|
161
|
+
width: "14",
|
|
162
|
+
height: "14",
|
|
163
|
+
viewBox: "0 0 16 16",
|
|
164
|
+
fill: "none",
|
|
165
|
+
className: "shrink-0",
|
|
166
|
+
"aria-hidden": "true",
|
|
167
|
+
children: /* @__PURE__ */ o(
|
|
168
|
+
"path",
|
|
169
|
+
{
|
|
170
|
+
d: "M3.5 8.5L6.5 11.5L12.5 4.5",
|
|
171
|
+
stroke: "currentColor",
|
|
172
|
+
strokeWidth: "1.5",
|
|
173
|
+
strokeLinecap: "round",
|
|
174
|
+
strokeLinejoin: "round"
|
|
175
|
+
}
|
|
176
|
+
)
|
|
177
|
+
}
|
|
178
|
+
);
|
|
179
|
+
}
|
|
180
|
+
const Ve = Object.assign(
|
|
181
|
+
R(
|
|
182
|
+
({
|
|
183
|
+
options: r = [],
|
|
184
|
+
value: l,
|
|
185
|
+
values: u,
|
|
186
|
+
defaultValue: p,
|
|
187
|
+
defaultValues: c,
|
|
188
|
+
onChange: i,
|
|
189
|
+
onMultiChange: x,
|
|
190
|
+
multi: s = !1,
|
|
191
|
+
searchable: h = !1,
|
|
192
|
+
placeholder: D = "Select...",
|
|
193
|
+
searchPlaceholder: K = "Search...",
|
|
194
|
+
disabled: L = !1,
|
|
195
|
+
size: H = "md",
|
|
196
|
+
variant: ce = "default",
|
|
197
|
+
className: de,
|
|
198
|
+
menuClassName: ue,
|
|
199
|
+
portal: W = !1,
|
|
200
|
+
children: U
|
|
201
|
+
}, S) => {
|
|
202
|
+
const G = ye(), J = `dropdown-trigger-${G}`, E = `dropdown-listbox-${G}`, [a, I] = N(!1), [M, q] = N(""), [f, b] = N(-1), [Q, fe] = N(p), [X, be] = N(c ?? []), v = s ? u !== void 0 : l !== void 0, w = V(
|
|
203
|
+
() => v ? l : Q,
|
|
204
|
+
[v, l, Q]
|
|
205
|
+
), m = V(
|
|
206
|
+
() => v ? u ?? [] : X,
|
|
207
|
+
[v, u, X]
|
|
208
|
+
), $ = V(
|
|
209
|
+
() => new Set(s ? m : w ? [w] : []),
|
|
210
|
+
[s, m, w]
|
|
211
|
+
), B = O(null), j = O(null), P = O(null), Y = O(null), pe = O(/* @__PURE__ */ new Map()), d = V(() => {
|
|
212
|
+
if (!M) return r;
|
|
213
|
+
const e = M.toLowerCase();
|
|
214
|
+
return r.filter((t) => t.label.toLowerCase().includes(e));
|
|
215
|
+
}, [r, M]), he = Le(B, a && W), k = A(() => {
|
|
216
|
+
I(!1), q(""), b(-1), B.current?.focus();
|
|
217
|
+
}, []), Z = A(() => {
|
|
218
|
+
L || I((e) => (e && (q(""), b(-1)), !e));
|
|
219
|
+
}, [L]), F = A(
|
|
220
|
+
(e) => {
|
|
221
|
+
if (s) {
|
|
222
|
+
const t = $.has(e) ? m.filter((n) => n !== e) : [...m, e];
|
|
223
|
+
v || be(t), x?.(t);
|
|
224
|
+
} else
|
|
225
|
+
v || fe(e), i?.(e), k();
|
|
226
|
+
},
|
|
227
|
+
[s, $, m, v, i, x, k]
|
|
228
|
+
), ge = A((e, t) => {
|
|
229
|
+
pe.current.set(t, e);
|
|
230
|
+
}, []);
|
|
231
|
+
Ne([Y, j], () => {
|
|
232
|
+
a && k();
|
|
233
|
+
}), z(() => {
|
|
234
|
+
a && h && requestAnimationFrame(() => P.current?.focus());
|
|
235
|
+
}, [a, h]);
|
|
236
|
+
const _ = A(
|
|
237
|
+
(e) => {
|
|
238
|
+
if (!L)
|
|
239
|
+
switch (e.key) {
|
|
240
|
+
case "ArrowDown": {
|
|
241
|
+
if (e.preventDefault(), !a) {
|
|
242
|
+
I(!0), b(0);
|
|
243
|
+
return;
|
|
244
|
+
}
|
|
245
|
+
b((t) => {
|
|
246
|
+
const n = d.length - 1;
|
|
247
|
+
let g = t + 1;
|
|
248
|
+
for (; g <= n && d[g]?.disabled; ) g++;
|
|
249
|
+
return g > n ? t : g;
|
|
250
|
+
});
|
|
251
|
+
break;
|
|
252
|
+
}
|
|
253
|
+
case "ArrowUp": {
|
|
254
|
+
if (e.preventDefault(), !a) {
|
|
255
|
+
I(!0), b(d.length - 1);
|
|
256
|
+
return;
|
|
257
|
+
}
|
|
258
|
+
b((t) => {
|
|
259
|
+
let n = t - 1;
|
|
260
|
+
for (; n >= 0 && d[n]?.disabled; ) n--;
|
|
261
|
+
return n < 0 ? t : n;
|
|
262
|
+
});
|
|
263
|
+
break;
|
|
264
|
+
}
|
|
265
|
+
case "Enter":
|
|
266
|
+
case " ": {
|
|
267
|
+
if (!a) {
|
|
268
|
+
e.preventDefault(), I(!0), b(0);
|
|
269
|
+
return;
|
|
270
|
+
}
|
|
271
|
+
if (e.key === " " && h && document.activeElement === P.current)
|
|
272
|
+
return;
|
|
273
|
+
e.preventDefault(), f >= 0 && d[f] && !d[f].disabled && F(d[f].value);
|
|
274
|
+
break;
|
|
275
|
+
}
|
|
276
|
+
case "Escape": {
|
|
277
|
+
e.preventDefault(), k();
|
|
278
|
+
break;
|
|
279
|
+
}
|
|
280
|
+
case "Home": {
|
|
281
|
+
if (a) {
|
|
282
|
+
e.preventDefault();
|
|
283
|
+
const t = d.findIndex((n) => !n.disabled);
|
|
284
|
+
t >= 0 && b(t);
|
|
285
|
+
}
|
|
286
|
+
break;
|
|
287
|
+
}
|
|
288
|
+
case "End": {
|
|
289
|
+
if (a) {
|
|
290
|
+
e.preventDefault();
|
|
291
|
+
for (let t = d.length - 1; t >= 0; t--)
|
|
292
|
+
if (!d[t].disabled) {
|
|
293
|
+
b(t);
|
|
294
|
+
break;
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
break;
|
|
298
|
+
}
|
|
299
|
+
case "Tab": {
|
|
300
|
+
a && k();
|
|
301
|
+
break;
|
|
302
|
+
}
|
|
303
|
+
default:
|
|
304
|
+
if (!h && e.key.length === 1 && !e.ctrlKey && !e.metaKey && !e.altKey) {
|
|
305
|
+
e.preventDefault(), a || I(!0);
|
|
306
|
+
const t = e.key.toLowerCase(), n = f + 1, re = [
|
|
307
|
+
...d.slice(n),
|
|
308
|
+
...d.slice(0, n)
|
|
309
|
+
].findIndex(
|
|
310
|
+
(ne) => !ne.disabled && ne.label.toLowerCase().startsWith(t)
|
|
311
|
+
);
|
|
312
|
+
re >= 0 && b((re + n) % d.length);
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
},
|
|
316
|
+
[L, a, d, f, h, F, k]
|
|
317
|
+
);
|
|
318
|
+
z(() => {
|
|
319
|
+
if (!a || f < 0 || !j.current) return;
|
|
320
|
+
j.current.querySelector(`[data-index="${f}"]`)?.scrollIntoView({ block: "nearest" });
|
|
321
|
+
}, [a, f]);
|
|
322
|
+
const xe = {
|
|
323
|
+
sm: "h-8 px-3 text-xs",
|
|
324
|
+
md: "h-10 px-4 text-sm",
|
|
325
|
+
lg: "h-12 px-5 text-base"
|
|
326
|
+
}, me = {
|
|
327
|
+
sm: "px-3 py-1.5 text-xs",
|
|
328
|
+
md: "px-4 py-2 text-sm",
|
|
329
|
+
lg: "px-5 py-2.5 text-base"
|
|
330
|
+
}, ve = {
|
|
331
|
+
default: [
|
|
332
|
+
"bg-transparent",
|
|
333
|
+
"border-[var(--glass-border)]",
|
|
334
|
+
"hover:border-[var(--glass-highlight)]"
|
|
335
|
+
],
|
|
336
|
+
glass: [
|
|
337
|
+
"bg-[var(--glass-bg)]",
|
|
338
|
+
"backdrop-blur-lg",
|
|
339
|
+
"border-[var(--glass-border)]",
|
|
340
|
+
"hover:bg-[rgba(255,255,255,0.08)]"
|
|
341
|
+
]
|
|
342
|
+
}, ee = V(() => {
|
|
343
|
+
if (s) {
|
|
344
|
+
if (m.length === 0) return null;
|
|
345
|
+
const e = m.map((t) => r.find((n) => n.value === t)?.label ?? t);
|
|
346
|
+
return e.length <= 2 ? e.join(", ") : `${e[0]}, ${e[1]} +${e.length - 2}`;
|
|
347
|
+
}
|
|
348
|
+
return w ? r.find((e) => e.value === w)?.label ?? w : null;
|
|
349
|
+
}, [s, m, w, r]), we = a && f >= 0 ? `${E}-option-${f}` : void 0, ke = {
|
|
350
|
+
isOpen: a,
|
|
351
|
+
activeIndex: f,
|
|
352
|
+
selectedValues: $,
|
|
353
|
+
multi: s,
|
|
354
|
+
listboxId: E,
|
|
355
|
+
triggerId: J,
|
|
356
|
+
toggle: Z,
|
|
357
|
+
close: k,
|
|
358
|
+
select: F,
|
|
359
|
+
setActiveIndex: b,
|
|
360
|
+
registerItem: ge
|
|
361
|
+
};
|
|
362
|
+
if (U)
|
|
363
|
+
return /* @__PURE__ */ o(ae.Provider, { value: ke, children: /* @__PURE__ */ o("div", { ref: S, onKeyDown: _, children: U }) });
|
|
364
|
+
const te = /* @__PURE__ */ C(
|
|
365
|
+
"ul",
|
|
366
|
+
{
|
|
367
|
+
ref: j,
|
|
368
|
+
id: E,
|
|
369
|
+
role: "listbox",
|
|
370
|
+
"aria-multiselectable": s || void 0,
|
|
371
|
+
"aria-label": "Options",
|
|
372
|
+
tabIndex: -1,
|
|
373
|
+
className: y(
|
|
374
|
+
"py-1 max-h-60 overflow-y-auto",
|
|
375
|
+
"bg-[var(--glass-bg)] backdrop-blur-xl",
|
|
376
|
+
"border border-[var(--glass-border)]",
|
|
377
|
+
"rounded-xl",
|
|
378
|
+
"scrollbar-hidden",
|
|
379
|
+
"animate-in",
|
|
380
|
+
ue
|
|
381
|
+
),
|
|
382
|
+
style: W ? he : void 0,
|
|
383
|
+
children: [
|
|
384
|
+
h && /* @__PURE__ */ o("li", { role: "presentation", className: "px-2 py-1.5 sticky top-0 bg-[var(--glass-bg)] backdrop-blur-xl z-10", children: /* @__PURE__ */ C("div", { className: "flex items-center gap-2 px-2 py-1.5 rounded-lg border border-[var(--glass-border)] bg-transparent", children: [
|
|
385
|
+
/* @__PURE__ */ o("span", { className: "text-[var(--color-grey-400)]", children: /* @__PURE__ */ o(Ee, {}) }),
|
|
386
|
+
/* @__PURE__ */ o(
|
|
387
|
+
"input",
|
|
388
|
+
{
|
|
389
|
+
ref: P,
|
|
390
|
+
type: "text",
|
|
391
|
+
role: "searchbox",
|
|
392
|
+
"aria-label": "Filter options",
|
|
393
|
+
value: M,
|
|
394
|
+
onChange: (e) => {
|
|
395
|
+
q(e.target.value), b(0);
|
|
396
|
+
},
|
|
397
|
+
placeholder: K,
|
|
398
|
+
className: y(
|
|
399
|
+
"w-full bg-transparent",
|
|
400
|
+
"text-[var(--color-white)]",
|
|
401
|
+
"placeholder:text-[var(--color-grey-600)]",
|
|
402
|
+
"focus:outline-none",
|
|
403
|
+
"text-xs"
|
|
404
|
+
)
|
|
405
|
+
}
|
|
406
|
+
)
|
|
407
|
+
] }) }),
|
|
408
|
+
d.length === 0 && /* @__PURE__ */ o(
|
|
409
|
+
"li",
|
|
410
|
+
{
|
|
411
|
+
role: "presentation",
|
|
412
|
+
className: "px-4 py-3 text-center text-xs text-[var(--color-grey-600)]",
|
|
413
|
+
children: "No options found"
|
|
414
|
+
}
|
|
415
|
+
),
|
|
416
|
+
d.map((e, t) => {
|
|
417
|
+
const n = $.has(e.value), g = t === f;
|
|
418
|
+
return /* @__PURE__ */ C(
|
|
419
|
+
"li",
|
|
420
|
+
{
|
|
421
|
+
id: `${E}-option-${t}`,
|
|
422
|
+
role: "option",
|
|
423
|
+
"aria-selected": n,
|
|
424
|
+
"aria-disabled": e.disabled || void 0,
|
|
425
|
+
"data-index": t,
|
|
426
|
+
"data-value": e.value,
|
|
427
|
+
className: y(
|
|
428
|
+
"flex items-center gap-2 cursor-pointer",
|
|
429
|
+
"transition-[background-color,color] duration-150",
|
|
430
|
+
me[H],
|
|
431
|
+
g && "bg-[var(--glass-highlight)]",
|
|
432
|
+
n && !g && "text-[var(--color-white)]",
|
|
433
|
+
!n && !g && "text-[var(--color-grey-300)]",
|
|
434
|
+
e.disabled && "opacity-40 cursor-not-allowed pointer-events-none",
|
|
435
|
+
!e.disabled && !g && "hover:bg-[var(--glass-bg)]"
|
|
436
|
+
),
|
|
437
|
+
onClick: () => {
|
|
438
|
+
e.disabled || F(e.value);
|
|
439
|
+
},
|
|
440
|
+
onMouseEnter: () => b(t),
|
|
441
|
+
children: [
|
|
442
|
+
s && /* @__PURE__ */ o(
|
|
443
|
+
"span",
|
|
444
|
+
{
|
|
445
|
+
className: y(
|
|
446
|
+
"w-4 h-4 rounded border flex items-center justify-center shrink-0",
|
|
447
|
+
"transition-[background-color,border-color] duration-150",
|
|
448
|
+
n ? "bg-[var(--color-white)] border-[var(--color-white)] text-[var(--color-bg)]" : "border-[var(--glass-border)]"
|
|
449
|
+
),
|
|
450
|
+
children: n && /* @__PURE__ */ o(oe, {})
|
|
451
|
+
}
|
|
452
|
+
),
|
|
453
|
+
/* @__PURE__ */ o("span", { className: "truncate", children: e.label }),
|
|
454
|
+
!s && n && /* @__PURE__ */ o("span", { className: "ml-auto text-[var(--color-white)]", children: /* @__PURE__ */ o(oe, {}) })
|
|
455
|
+
]
|
|
456
|
+
},
|
|
457
|
+
e.value
|
|
458
|
+
);
|
|
459
|
+
})
|
|
460
|
+
]
|
|
461
|
+
}
|
|
462
|
+
);
|
|
463
|
+
return /* @__PURE__ */ C(
|
|
464
|
+
"div",
|
|
465
|
+
{
|
|
466
|
+
ref: (e) => {
|
|
467
|
+
Y.current = e, typeof S == "function" ? S(e) : S && (S.current = e);
|
|
468
|
+
},
|
|
469
|
+
className: "relative inline-block w-full",
|
|
470
|
+
onKeyDown: _,
|
|
471
|
+
children: [
|
|
472
|
+
/* @__PURE__ */ C(
|
|
473
|
+
"button",
|
|
474
|
+
{
|
|
475
|
+
ref: B,
|
|
476
|
+
id: J,
|
|
477
|
+
type: "button",
|
|
478
|
+
role: "combobox",
|
|
479
|
+
"aria-expanded": a,
|
|
480
|
+
"aria-haspopup": "listbox",
|
|
481
|
+
"aria-controls": a ? E : void 0,
|
|
482
|
+
"aria-activedescendant": we,
|
|
483
|
+
disabled: L,
|
|
484
|
+
className: y(
|
|
485
|
+
"w-full inline-flex items-center justify-between gap-2",
|
|
486
|
+
"border rounded-xl",
|
|
487
|
+
"transition-[border-color,background-color] duration-200",
|
|
488
|
+
"focus-ring",
|
|
489
|
+
"disabled:opacity-50 disabled:cursor-not-allowed",
|
|
490
|
+
xe[H],
|
|
491
|
+
ve[ce],
|
|
492
|
+
a && "border-[var(--color-white)]",
|
|
493
|
+
de
|
|
494
|
+
),
|
|
495
|
+
onClick: Z,
|
|
496
|
+
children: [
|
|
497
|
+
/* @__PURE__ */ o(
|
|
498
|
+
"span",
|
|
499
|
+
{
|
|
500
|
+
className: y(
|
|
501
|
+
"truncate text-left",
|
|
502
|
+
ee ? "text-[var(--color-white)]" : "text-[var(--color-grey-600)]"
|
|
503
|
+
),
|
|
504
|
+
children: ee ?? D
|
|
505
|
+
}
|
|
506
|
+
),
|
|
507
|
+
/* @__PURE__ */ o(Se, { open: a, className: "text-[var(--color-grey-400)]" })
|
|
508
|
+
]
|
|
509
|
+
}
|
|
510
|
+
),
|
|
511
|
+
a && (W ? Ce(te, document.body) : /* @__PURE__ */ o("div", { className: "absolute left-0 right-0 mt-1 z-50", children: te }))
|
|
512
|
+
]
|
|
513
|
+
}
|
|
514
|
+
);
|
|
515
|
+
}
|
|
516
|
+
),
|
|
517
|
+
{
|
|
518
|
+
Trigger: se,
|
|
519
|
+
Menu: le,
|
|
520
|
+
Item: ie
|
|
521
|
+
}
|
|
522
|
+
);
|
|
523
|
+
Ve.displayName = "Dropdown";
|
|
524
|
+
export {
|
|
525
|
+
Ve as Dropdown,
|
|
526
|
+
ie as DropdownItem,
|
|
527
|
+
le as DropdownMenu,
|
|
528
|
+
se as DropdownTrigger
|
|
529
|
+
};
|
|
530
|
+
//# sourceMappingURL=Dropdown.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Dropdown.js","sources":["../../../src/molecules/Dropdown/Dropdown.tsx"],"sourcesContent":["import {\n forwardRef,\n useState,\n useRef,\n useEffect,\n useCallback,\n useMemo,\n useId,\n createContext,\n useContext,\n type ReactNode,\n type HTMLAttributes,\n type KeyboardEvent,\n type MouseEvent,\n} from 'react'\nimport { createPortal } from 'react-dom'\nimport { cn } from '../../utils/cn'\n\n/* ------------------------------------------------------------------\n Types\n ------------------------------------------------------------------ */\n\nexport interface DropdownOption {\n value: string\n label: string\n disabled?: boolean\n}\n\nexport interface DropdownProps {\n /** Options to display */\n options: DropdownOption[]\n /** Controlled value (single-select) */\n value?: string\n /** Controlled values (multi-select) */\n values?: string[]\n /** Default value for uncontrolled single-select */\n defaultValue?: string\n /** Default values for uncontrolled multi-select */\n defaultValues?: string[]\n /** Called when selection changes (single-select) */\n onChange?: (value: string) => void\n /** Called when selection changes (multi-select) */\n onMultiChange?: (values: string[]) => void\n /** Enable multi-select mode */\n multi?: boolean\n /** Enable search/filter input */\n searchable?: boolean\n /** Placeholder text when nothing is selected */\n placeholder?: string\n /** Search input placeholder */\n searchPlaceholder?: string\n /** Disabled state */\n disabled?: boolean\n /** Size variant */\n size?: 'sm' | 'md' | 'lg'\n /** Visual variant */\n variant?: 'default' | 'glass'\n /** Additional class names for the trigger */\n className?: string\n /** Additional class names for the menu */\n menuClassName?: string\n /** Use portal rendering for overflow contexts */\n portal?: boolean\n /** Children for compound API (overrides options-based rendering) */\n children?: ReactNode\n}\n\n/* ------------------------------------------------------------------\n Context for compound API\n ------------------------------------------------------------------ */\n\ninterface DropdownContextValue {\n isOpen: boolean\n activeIndex: number\n selectedValues: Set<string>\n multi: boolean\n listboxId: string\n triggerId: string\n toggle: () => void\n close: () => void\n select: (value: string) => void\n setActiveIndex: (index: number) => void\n registerItem: (value: string, index: number) => void\n}\n\nconst DropdownContext = createContext<DropdownContextValue | null>(null)\n\nfunction useDropdownContext() {\n const ctx = useContext(DropdownContext)\n if (!ctx) throw new Error('Dropdown compound components must be used within <Dropdown>')\n return ctx\n}\n\n/* ------------------------------------------------------------------\n Hooks\n ------------------------------------------------------------------ */\n\nfunction useClickOutside(\n refs: React.RefObject<HTMLElement | null>[],\n handler: () => void\n) {\n useEffect(() => {\n function onPointerDown(e: PointerEvent) {\n const target = e.target as Node\n if (refs.every((r) => r.current && !r.current.contains(target))) {\n handler()\n }\n }\n document.addEventListener('pointerdown', onPointerDown)\n return () => document.removeEventListener('pointerdown', onPointerDown)\n }, [refs, handler])\n}\n\nfunction usePositioning(\n triggerRef: React.RefObject<HTMLElement | null>,\n isOpen: boolean\n) {\n const [style, setStyle] = useState<React.CSSProperties>({})\n\n useEffect(() => {\n if (!isOpen || !triggerRef.current) return\n\n let animationFrameId: number\n let resizeObserver: ResizeObserver | null = null\n\n function update() {\n const trigger = triggerRef.current\n if (!trigger) return\n const rect = trigger.getBoundingClientRect()\n setStyle({\n position: 'fixed',\n top: rect.bottom + 4,\n left: rect.left,\n width: rect.width,\n zIndex: 9999,\n })\n }\n\n // Initial position\n update()\n\n // ResizeObserver for reliable updates when the trigger resizes\n if (typeof ResizeObserver !== 'undefined') {\n resizeObserver = new ResizeObserver(() => {\n cancelAnimationFrame(animationFrameId)\n animationFrameId = requestAnimationFrame(update)\n })\n resizeObserver.observe(triggerRef.current)\n }\n\n // Passive, rAF-throttled scroll listener for smoother updates\n const handleScroll = () => {\n cancelAnimationFrame(animationFrameId)\n animationFrameId = requestAnimationFrame(update)\n }\n window.addEventListener('scroll', handleScroll, { passive: true, capture: false })\n\n return () => {\n cancelAnimationFrame(animationFrameId)\n window.removeEventListener('scroll', handleScroll)\n if (resizeObserver) resizeObserver.disconnect()\n }\n }, [isOpen, triggerRef])\n\n return style\n}\n\n/* ------------------------------------------------------------------\n Sub-components\n ------------------------------------------------------------------ */\n\nexport interface DropdownTriggerProps extends HTMLAttributes<HTMLButtonElement> {\n children?: ReactNode\n}\n\nexport const DropdownTrigger = forwardRef<HTMLButtonElement, DropdownTriggerProps>(\n ({ children, className, onClick, ...props }, ref) => {\n const ctx = useDropdownContext()\n\n const handleClick = (e: MouseEvent<HTMLButtonElement>) => {\n onClick?.(e)\n ctx.toggle()\n }\n\n return (\n <button\n ref={ref}\n id={ctx.triggerId}\n type=\"button\"\n role=\"combobox\"\n aria-expanded={ctx.isOpen}\n aria-haspopup=\"listbox\"\n aria-controls={ctx.isOpen ? ctx.listboxId : undefined}\n className={className}\n onClick={handleClick}\n {...props}\n >\n {children}\n </button>\n )\n }\n)\nDropdownTrigger.displayName = 'Dropdown.Trigger'\n\nexport interface DropdownMenuProps extends HTMLAttributes<HTMLUListElement> {\n children?: ReactNode\n}\n\nexport const DropdownMenu = forwardRef<HTMLUListElement, DropdownMenuProps>(\n ({ children, className, ...props }, ref) => {\n const ctx = useDropdownContext()\n\n if (!ctx.isOpen) return null\n\n return (\n <ul\n ref={ref}\n id={ctx.listboxId}\n role=\"listbox\"\n aria-multiselectable={ctx.multi || undefined}\n tabIndex={-1}\n className={className}\n {...props}\n >\n {children}\n </ul>\n )\n }\n)\nDropdownMenu.displayName = 'Dropdown.Menu'\n\nexport interface DropdownItemProps extends HTMLAttributes<HTMLLIElement> {\n value: string\n disabled?: boolean\n children?: ReactNode\n}\n\nexport const DropdownItem = forwardRef<HTMLLIElement, DropdownItemProps>(\n ({ value, disabled = false, children, className, onClick, ...props }, ref) => {\n const ctx = useDropdownContext()\n const isSelected = ctx.selectedValues.has(value)\n\n const handleClick = (e: MouseEvent<HTMLLIElement>) => {\n if (disabled) return\n onClick?.(e)\n ctx.select(value)\n }\n\n return (\n <li\n ref={ref}\n role=\"option\"\n aria-selected={isSelected}\n aria-disabled={disabled || undefined}\n data-value={value}\n className={className}\n onClick={handleClick}\n {...props}\n >\n {children ?? value}\n </li>\n )\n }\n)\nDropdownItem.displayName = 'Dropdown.Item'\n\n/* ------------------------------------------------------------------\n Chevron icon (inline SVG to avoid dependency)\n ------------------------------------------------------------------ */\n\nfunction ChevronIcon({ open, className }: { open: boolean; className?: string }) {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n className={cn(\n 'transition-transform duration-200 shrink-0',\n open && 'rotate-180',\n className\n )}\n aria-hidden=\"true\"\n >\n <path\n d=\"M4 6L8 10L12 6\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n )\n}\n\nfunction SearchIcon() {\n return (\n <svg\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n className=\"shrink-0\"\n aria-hidden=\"true\"\n >\n <circle cx=\"7\" cy=\"7\" r=\"5\" stroke=\"currentColor\" strokeWidth=\"1.5\" />\n <path d=\"M11 11L14 14\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" />\n </svg>\n )\n}\n\nfunction CheckIcon() {\n return (\n <svg\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n className=\"shrink-0\"\n aria-hidden=\"true\"\n >\n <path\n d=\"M3.5 8.5L6.5 11.5L12.5 4.5\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n )\n}\n\n/* ------------------------------------------------------------------\n Main Dropdown component\n ------------------------------------------------------------------ */\n\nexport const Dropdown = Object.assign(\n forwardRef<HTMLDivElement, DropdownProps>(\n (\n {\n options = [],\n value,\n values,\n defaultValue,\n defaultValues,\n onChange,\n onMultiChange,\n multi = false,\n searchable = false,\n placeholder = 'Select...',\n searchPlaceholder = 'Search...',\n disabled = false,\n size = 'md',\n variant = 'default',\n className,\n menuClassName,\n portal = false,\n children,\n },\n ref\n ) => {\n const uid = useId()\n const triggerId = `dropdown-trigger-${uid}`\n const listboxId = `dropdown-listbox-${uid}`\n\n // State\n const [isOpen, setIsOpen] = useState(false)\n const [search, setSearch] = useState('')\n const [activeIndex, setActiveIndex] = useState(-1)\n\n // Selection state (controlled or uncontrolled)\n const [internalValue, setInternalValue] = useState<string | undefined>(defaultValue)\n const [internalValues, setInternalValues] = useState<string[]>(defaultValues ?? [])\n\n const isControlled = multi ? values !== undefined : value !== undefined\n const selectedValue = useMemo(\n () => (isControlled ? value : internalValue),\n [isControlled, value, internalValue]\n )\n const selectedMultiValues = useMemo(\n () => (isControlled ? (values ?? []) : internalValues),\n [isControlled, values, internalValues]\n )\n const selectedSet = useMemo(\n () => new Set(multi ? selectedMultiValues : selectedValue ? [selectedValue] : []),\n [multi, selectedMultiValues, selectedValue]\n )\n\n // Refs\n const triggerRef = useRef<HTMLButtonElement>(null)\n const menuRef = useRef<HTMLUListElement>(null)\n const searchRef = useRef<HTMLInputElement>(null)\n const containerRef = useRef<HTMLDivElement>(null)\n const itemMapRef = useRef<Map<number, string>>(new Map())\n\n // Filtered options\n const filteredOptions = useMemo(() => {\n if (!search) return options\n const lower = search.toLowerCase()\n return options.filter((o) => o.label.toLowerCase().includes(lower))\n }, [options, search])\n\n // Position for portal mode\n const portalStyle = usePositioning(triggerRef, isOpen && portal)\n\n // Close handler\n const close = useCallback(() => {\n setIsOpen(false)\n setSearch('')\n setActiveIndex(-1)\n triggerRef.current?.focus()\n }, [])\n\n // Toggle\n const toggle = useCallback(() => {\n if (disabled) return\n setIsOpen((prev) => {\n if (prev) {\n setSearch('')\n setActiveIndex(-1)\n }\n return !prev\n })\n }, [disabled])\n\n // Selection\n const select = useCallback(\n (val: string) => {\n if (multi) {\n const next = selectedSet.has(val)\n ? selectedMultiValues.filter((v) => v !== val)\n : [...selectedMultiValues, val]\n if (!isControlled) setInternalValues(next)\n onMultiChange?.(next)\n } else {\n if (!isControlled) setInternalValue(val)\n onChange?.(val)\n close()\n }\n },\n [multi, selectedSet, selectedMultiValues, isControlled, onChange, onMultiChange, close]\n )\n\n // Register item (for compound API)\n const registerItem = useCallback((val: string, index: number) => {\n itemMapRef.current.set(index, val)\n }, [])\n\n // Click outside\n useClickOutside([containerRef, menuRef], () => {\n if (isOpen) close()\n })\n\n // Focus search input when menu opens\n useEffect(() => {\n if (isOpen && searchable) {\n requestAnimationFrame(() => searchRef.current?.focus())\n }\n }, [isOpen, searchable])\n\n // Keyboard handler\n const handleKeyDown = useCallback(\n (e: KeyboardEvent<HTMLDivElement>) => {\n if (disabled) return\n\n switch (e.key) {\n case 'ArrowDown': {\n e.preventDefault()\n if (!isOpen) {\n setIsOpen(true)\n setActiveIndex(0)\n return\n }\n setActiveIndex((prev) => {\n const max = filteredOptions.length - 1\n let next = prev + 1\n while (next <= max && filteredOptions[next]?.disabled) next++\n return next > max ? prev : next\n })\n break\n }\n case 'ArrowUp': {\n e.preventDefault()\n if (!isOpen) {\n setIsOpen(true)\n setActiveIndex(filteredOptions.length - 1)\n return\n }\n setActiveIndex((prev) => {\n let next = prev - 1\n while (next >= 0 && filteredOptions[next]?.disabled) next--\n return next < 0 ? prev : next\n })\n break\n }\n case 'Enter':\n case ' ': {\n if (!isOpen) {\n e.preventDefault()\n setIsOpen(true)\n setActiveIndex(0)\n return\n }\n // Allow space in search input\n if (e.key === ' ' && searchable && document.activeElement === searchRef.current) {\n return\n }\n e.preventDefault()\n if (activeIndex >= 0 && filteredOptions[activeIndex] && !filteredOptions[activeIndex].disabled) {\n select(filteredOptions[activeIndex].value)\n }\n break\n }\n case 'Escape': {\n e.preventDefault()\n close()\n break\n }\n case 'Home': {\n if (isOpen) {\n e.preventDefault()\n const first = filteredOptions.findIndex((o) => !o.disabled)\n if (first >= 0) setActiveIndex(first)\n }\n break\n }\n case 'End': {\n if (isOpen) {\n e.preventDefault()\n for (let i = filteredOptions.length - 1; i >= 0; i--) {\n if (!filteredOptions[i].disabled) {\n setActiveIndex(i)\n break\n }\n }\n }\n break\n }\n case 'Tab': {\n if (isOpen) close()\n break\n }\n default: {\n // Type-ahead: single character jumps to matching option\n if (!searchable && e.key.length === 1 && !e.ctrlKey && !e.metaKey && !e.altKey) {\n e.preventDefault()\n if (!isOpen) setIsOpen(true)\n const char = e.key.toLowerCase()\n const startIndex = activeIndex + 1\n const reordered = [\n ...filteredOptions.slice(startIndex),\n ...filteredOptions.slice(0, startIndex),\n ]\n const match = reordered.findIndex(\n (o) => !o.disabled && o.label.toLowerCase().startsWith(char)\n )\n if (match >= 0) {\n setActiveIndex((match + startIndex) % filteredOptions.length)\n }\n }\n }\n }\n },\n [disabled, isOpen, filteredOptions, activeIndex, searchable, select, close]\n )\n\n // Scroll active item into view\n useEffect(() => {\n if (!isOpen || activeIndex < 0 || !menuRef.current) return\n const activeEl = menuRef.current.querySelector(`[data-index=\"${activeIndex}\"]`)\n activeEl?.scrollIntoView({ block: 'nearest' })\n }, [isOpen, activeIndex])\n\n // Size styles\n const triggerSizes = {\n sm: 'h-8 px-3 text-xs',\n md: 'h-10 px-4 text-sm',\n lg: 'h-12 px-5 text-base',\n }\n\n const itemSizes = {\n sm: 'px-3 py-1.5 text-xs',\n md: 'px-4 py-2 text-sm',\n lg: 'px-5 py-2.5 text-base',\n }\n\n // Variant styles\n const triggerVariants = {\n default: [\n 'bg-transparent',\n 'border-[var(--glass-border)]',\n 'hover:border-[var(--glass-highlight)]',\n ],\n glass: [\n 'bg-[var(--glass-bg)]',\n 'backdrop-blur-lg',\n 'border-[var(--glass-border)]',\n 'hover:bg-[rgba(255,255,255,0.08)]',\n ],\n }\n\n // Display value\n const displayValue = useMemo(() => {\n if (multi) {\n if (selectedMultiValues.length === 0) return null\n const labels = selectedMultiValues\n .map((v) => options.find((o) => o.value === v)?.label ?? v)\n if (labels.length <= 2) return labels.join(', ')\n return `${labels[0]}, ${labels[1]} +${labels.length - 2}`\n }\n if (!selectedValue) return null\n return options.find((o) => o.value === selectedValue)?.label ?? selectedValue\n }, [multi, selectedMultiValues, selectedValue, options])\n\n // Active descendant\n const activeDescendant =\n isOpen && activeIndex >= 0\n ? `${listboxId}-option-${activeIndex}`\n : undefined\n\n // Context value\n const contextValue: DropdownContextValue = {\n isOpen,\n activeIndex,\n selectedValues: selectedSet,\n multi,\n listboxId,\n triggerId,\n toggle,\n close,\n select,\n setActiveIndex,\n registerItem,\n }\n\n // If children are provided, use compound API\n if (children) {\n return (\n <DropdownContext.Provider value={contextValue}>\n <div ref={ref} onKeyDown={handleKeyDown}>\n {children}\n </div>\n </DropdownContext.Provider>\n )\n }\n\n // Options-based rendering\n const menuContent = (\n <ul\n ref={menuRef}\n id={listboxId}\n role=\"listbox\"\n aria-multiselectable={multi || undefined}\n aria-label=\"Options\"\n tabIndex={-1}\n className={cn(\n 'py-1 max-h-60 overflow-y-auto',\n 'bg-[var(--glass-bg)] backdrop-blur-xl',\n 'border border-[var(--glass-border)]',\n 'rounded-xl',\n 'scrollbar-hidden',\n 'animate-in',\n menuClassName\n )}\n style={portal ? portalStyle : undefined}\n >\n {searchable && (\n <li role=\"presentation\" className=\"px-2 py-1.5 sticky top-0 bg-[var(--glass-bg)] backdrop-blur-xl z-10\">\n <div className=\"flex items-center gap-2 px-2 py-1.5 rounded-lg border border-[var(--glass-border)] bg-transparent\">\n <span className=\"text-[var(--color-grey-400)]\">\n <SearchIcon />\n </span>\n <input\n ref={searchRef}\n type=\"text\"\n role=\"searchbox\"\n aria-label=\"Filter options\"\n value={search}\n onChange={(e) => {\n setSearch(e.target.value)\n setActiveIndex(0)\n }}\n placeholder={searchPlaceholder}\n className={cn(\n 'w-full bg-transparent',\n 'text-[var(--color-white)]',\n 'placeholder:text-[var(--color-grey-600)]',\n 'focus:outline-none',\n 'text-xs'\n )}\n />\n </div>\n </li>\n )}\n {filteredOptions.length === 0 && (\n <li\n role=\"presentation\"\n className=\"px-4 py-3 text-center text-xs text-[var(--color-grey-600)]\"\n >\n No options found\n </li>\n )}\n {filteredOptions.map((option, index) => {\n const isSelected = selectedSet.has(option.value)\n const isActive = index === activeIndex\n\n return (\n <li\n key={option.value}\n id={`${listboxId}-option-${index}`}\n role=\"option\"\n aria-selected={isSelected}\n aria-disabled={option.disabled || undefined}\n data-index={index}\n data-value={option.value}\n className={cn(\n 'flex items-center gap-2 cursor-pointer',\n 'transition-[background-color,color] duration-150',\n itemSizes[size],\n isActive && 'bg-[var(--glass-highlight)]',\n isSelected && !isActive && 'text-[var(--color-white)]',\n !isSelected && !isActive && 'text-[var(--color-grey-300)]',\n option.disabled && 'opacity-40 cursor-not-allowed pointer-events-none',\n !option.disabled && !isActive && 'hover:bg-[var(--glass-bg)]'\n )}\n onClick={() => {\n if (!option.disabled) select(option.value)\n }}\n onMouseEnter={() => setActiveIndex(index)}\n >\n {multi && (\n <span\n className={cn(\n 'w-4 h-4 rounded border flex items-center justify-center shrink-0',\n 'transition-[background-color,border-color] duration-150',\n isSelected\n ? 'bg-[var(--color-white)] border-[var(--color-white)] text-[var(--color-bg)]'\n : 'border-[var(--glass-border)]'\n )}\n >\n {isSelected && <CheckIcon />}\n </span>\n )}\n <span className=\"truncate\">{option.label}</span>\n {!multi && isSelected && (\n <span className=\"ml-auto text-[var(--color-white)]\">\n <CheckIcon />\n </span>\n )}\n </li>\n )\n })}\n </ul>\n )\n\n return (\n <div\n ref={(node) => {\n // Merge refs\n ;(containerRef as React.MutableRefObject<HTMLDivElement | null>).current = node\n if (typeof ref === 'function') ref(node)\n else if (ref) (ref as React.MutableRefObject<HTMLDivElement | null>).current = node\n }}\n className=\"relative inline-block w-full\"\n onKeyDown={handleKeyDown}\n >\n {/* Trigger */}\n <button\n ref={triggerRef}\n id={triggerId}\n type=\"button\"\n role=\"combobox\"\n aria-expanded={isOpen}\n aria-haspopup=\"listbox\"\n aria-controls={isOpen ? listboxId : undefined}\n aria-activedescendant={activeDescendant}\n disabled={disabled}\n className={cn(\n 'w-full inline-flex items-center justify-between gap-2',\n 'border rounded-xl',\n 'transition-[border-color,background-color] duration-200',\n 'focus-ring',\n 'disabled:opacity-50 disabled:cursor-not-allowed',\n triggerSizes[size],\n triggerVariants[variant],\n isOpen && 'border-[var(--color-white)]',\n className\n )}\n onClick={toggle}\n >\n <span\n className={cn(\n 'truncate text-left',\n displayValue\n ? 'text-[var(--color-white)]'\n : 'text-[var(--color-grey-600)]'\n )}\n >\n {displayValue ?? placeholder}\n </span>\n <ChevronIcon open={isOpen} className=\"text-[var(--color-grey-400)]\" />\n </button>\n\n {/* Menu */}\n {isOpen && (\n portal\n ? createPortal(menuContent, document.body)\n : <div className=\"absolute left-0 right-0 mt-1 z-50\">{menuContent}</div>\n )}\n </div>\n )\n }\n ),\n {\n Trigger: DropdownTrigger,\n Menu: DropdownMenu,\n Item: DropdownItem,\n }\n)\n\nDropdown.displayName = 'Dropdown'\n"],"names":["DropdownContext","createContext","useDropdownContext","ctx","useContext","useClickOutside","refs","handler","useEffect","onPointerDown","e","target","r","usePositioning","triggerRef","isOpen","style","setStyle","useState","animationFrameId","resizeObserver","update","trigger","rect","handleScroll","DropdownTrigger","forwardRef","children","className","onClick","props","ref","handleClick","jsx","DropdownMenu","DropdownItem","value","disabled","isSelected","ChevronIcon","open","cn","SearchIcon","jsxs","CheckIcon","Dropdown","options","values","defaultValue","defaultValues","onChange","onMultiChange","multi","searchable","placeholder","searchPlaceholder","size","variant","menuClassName","portal","uid","useId","triggerId","listboxId","setIsOpen","search","setSearch","activeIndex","setActiveIndex","internalValue","setInternalValue","internalValues","setInternalValues","isControlled","selectedValue","useMemo","selectedMultiValues","selectedSet","useRef","menuRef","searchRef","containerRef","itemMapRef","filteredOptions","lower","o","portalStyle","close","useCallback","toggle","prev","select","val","next","v","registerItem","index","handleKeyDown","max","first","i","char","startIndex","match","triggerSizes","itemSizes","triggerVariants","displayValue","labels","activeDescendant","contextValue","menuContent","option","isActive","node","createPortal"],"mappings":";;;;AAqFA,MAAMA,KAAkBC,GAA2C,IAAI;AAEvE,SAASC,IAAqB;AAC5B,QAAMC,IAAMC,GAAWJ,EAAe;AACtC,MAAI,CAACG,EAAK,OAAM,IAAI,MAAM,6DAA6D;AACvF,SAAOA;AACT;AAMA,SAASE,GACPC,GACAC,GACA;AACA,EAAAC,EAAU,MAAM;AACd,aAASC,EAAcC,GAAiB;AACtC,YAAMC,IAASD,EAAE;AACjB,MAAIJ,EAAK,MAAM,CAACM,MAAMA,EAAE,WAAW,CAACA,EAAE,QAAQ,SAASD,CAAM,CAAC,KAC5DJ,EAAA;AAAA,IAEJ;AACA,oBAAS,iBAAiB,eAAeE,CAAa,GAC/C,MAAM,SAAS,oBAAoB,eAAeA,CAAa;AAAA,EACxE,GAAG,CAACH,GAAMC,CAAO,CAAC;AACpB;AAEA,SAASM,GACPC,GACAC,GACA;AACA,QAAM,CAACC,GAAOC,CAAQ,IAAIC,EAA8B,CAAA,CAAE;AAE1D,SAAAV,EAAU,MAAM;AACd,QAAI,CAACO,KAAU,CAACD,EAAW,QAAS;AAEpC,QAAIK,GACAC,IAAwC;AAE5C,aAASC,IAAS;AAChB,YAAMC,IAAUR,EAAW;AAC3B,UAAI,CAACQ,EAAS;AACd,YAAMC,IAAOD,EAAQ,sBAAA;AACrB,MAAAL,EAAS;AAAA,QACP,UAAU;AAAA,QACV,KAAKM,EAAK,SAAS;AAAA,QACnB,MAAMA,EAAK;AAAA,QACX,OAAOA,EAAK;AAAA,QACZ,QAAQ;AAAA,MAAA,CACT;AAAA,IACH;AAGA,IAAAF,EAAA,GAGI,OAAO,iBAAmB,QAC5BD,IAAiB,IAAI,eAAe,MAAM;AACxC,2BAAqBD,CAAgB,GACrCA,IAAmB,sBAAsBE,CAAM;AAAA,IACjD,CAAC,GACDD,EAAe,QAAQN,EAAW,OAAO;AAI3C,UAAMU,IAAe,MAAM;AACzB,2BAAqBL,CAAgB,GACrCA,IAAmB,sBAAsBE,CAAM;AAAA,IACjD;AACA,kBAAO,iBAAiB,UAAUG,GAAc,EAAE,SAAS,IAAM,SAAS,IAAO,GAE1E,MAAM;AACX,2BAAqBL,CAAgB,GACrC,OAAO,oBAAoB,UAAUK,CAAY,GAC7CJ,OAA+B,WAAA;AAAA,IACrC;AAAA,EACF,GAAG,CAACL,GAAQD,CAAU,CAAC,GAEhBE;AACT;AAUO,MAAMS,KAAkBC;AAAA,EAC7B,CAAC,EAAE,UAAAC,GAAU,WAAAC,GAAW,SAAAC,GAAS,GAAGC,EAAA,GAASC,MAAQ;AACnD,UAAM5B,IAAMD,EAAA,GAEN8B,IAAc,CAACtB,MAAqC;AACxD,MAAAmB,IAAUnB,CAAC,GACXP,EAAI,OAAA;AAAA,IACN;AAEA,WACE,gBAAA8B;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,KAAAF;AAAA,QACA,IAAI5B,EAAI;AAAA,QACR,MAAK;AAAA,QACL,MAAK;AAAA,QACL,iBAAeA,EAAI;AAAA,QACnB,iBAAc;AAAA,QACd,iBAAeA,EAAI,SAASA,EAAI,YAAY;AAAA,QAC5C,WAAAyB;AAAA,QACA,SAASI;AAAA,QACR,GAAGF;AAAA,QAEH,UAAAH;AAAA,MAAA;AAAA,IAAA;AAAA,EAGP;AACF;AACAF,GAAgB,cAAc;AAMvB,MAAMS,KAAeR;AAAA,EAC1B,CAAC,EAAE,UAAAC,GAAU,WAAAC,GAAW,GAAGE,EAAA,GAASC,MAAQ;AAC1C,UAAM5B,IAAMD,EAAA;AAEZ,WAAKC,EAAI,SAGP,gBAAA8B;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,KAAAF;AAAA,QACA,IAAI5B,EAAI;AAAA,QACR,MAAK;AAAA,QACL,wBAAsBA,EAAI,SAAS;AAAA,QACnC,UAAU;AAAA,QACV,WAAAyB;AAAA,QACC,GAAGE;AAAA,QAEH,UAAAH;AAAA,MAAA;AAAA,IAAA,IAZmB;AAAA,EAe1B;AACF;AACAO,GAAa,cAAc;AAQpB,MAAMC,KAAeT;AAAA,EAC1B,CAAC,EAAE,OAAAU,GAAO,UAAAC,IAAW,IAAO,UAAAV,GAAU,WAAAC,GAAW,SAAAC,GAAS,GAAGC,EAAA,GAASC,MAAQ;AAC5E,UAAM5B,IAAMD,EAAA,GACNoC,IAAanC,EAAI,eAAe,IAAIiC,CAAK;AAQ/C,WACE,gBAAAH;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,KAAAF;AAAA,QACA,MAAK;AAAA,QACL,iBAAeO;AAAA,QACf,iBAAeD,KAAY;AAAA,QAC3B,cAAYD;AAAA,QACZ,WAAAR;AAAA,QACA,SAdgB,CAAClB,MAAiC;AACpD,UAAI2B,MACJR,IAAUnB,CAAC,GACXP,EAAI,OAAOiC,CAAK;AAAA,QAClB;AAAA,QAWK,GAAGN;AAAA,QAEH,UAAAH,KAAYS;AAAA,MAAA;AAAA,IAAA;AAAA,EAGnB;AACF;AACAD,GAAa,cAAc;AAM3B,SAASI,GAAY,EAAE,MAAAC,GAAM,WAAAZ,KAAoD;AAC/E,SACE,gBAAAK;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,OAAM;AAAA,MACN,QAAO;AAAA,MACP,SAAQ;AAAA,MACR,MAAK;AAAA,MACL,WAAWQ;AAAA,QACT;AAAA,QACAD,KAAQ;AAAA,QACRZ;AAAA,MAAA;AAAA,MAEF,eAAY;AAAA,MAEZ,UAAA,gBAAAK;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,GAAE;AAAA,UACF,QAAO;AAAA,UACP,aAAY;AAAA,UACZ,eAAc;AAAA,UACd,gBAAe;AAAA,QAAA;AAAA,MAAA;AAAA,IACjB;AAAA,EAAA;AAGN;AAEA,SAASS,KAAa;AACpB,SACE,gBAAAC;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,OAAM;AAAA,MACN,QAAO;AAAA,MACP,SAAQ;AAAA,MACR,MAAK;AAAA,MACL,WAAU;AAAA,MACV,eAAY;AAAA,MAEZ,UAAA;AAAA,QAAA,gBAAAV,EAAC,UAAA,EAAO,IAAG,KAAI,IAAG,KAAI,GAAE,KAAI,QAAO,gBAAe,aAAY,MAAA,CAAM;AAAA,QACpE,gBAAAA,EAAC,UAAK,GAAE,gBAAe,QAAO,gBAAe,aAAY,OAAM,eAAc,QAAA,CAAQ;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAG3F;AAEA,SAASW,KAAY;AACnB,SACE,gBAAAX;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,OAAM;AAAA,MACN,QAAO;AAAA,MACP,SAAQ;AAAA,MACR,MAAK;AAAA,MACL,WAAU;AAAA,MACV,eAAY;AAAA,MAEZ,UAAA,gBAAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,GAAE;AAAA,UACF,QAAO;AAAA,UACP,aAAY;AAAA,UACZ,eAAc;AAAA,UACd,gBAAe;AAAA,QAAA;AAAA,MAAA;AAAA,IACjB;AAAA,EAAA;AAGN;AAMO,MAAMY,KAAW,OAAO;AAAA,EAC7BnB;AAAA,IACE,CACE;AAAA,MACE,SAAAoB,IAAU,CAAA;AAAA,MACV,OAAAV;AAAA,MACA,QAAAW;AAAA,MACA,cAAAC;AAAA,MACA,eAAAC;AAAA,MACA,UAAAC;AAAA,MACA,eAAAC;AAAA,MACA,OAAAC,IAAQ;AAAA,MACR,YAAAC,IAAa;AAAA,MACb,aAAAC,IAAc;AAAA,MACd,mBAAAC,IAAoB;AAAA,MACpB,UAAAlB,IAAW;AAAA,MACX,MAAAmB,IAAO;AAAA,MACP,SAAAC,KAAU;AAAA,MACV,WAAA7B;AAAA,MACA,eAAA8B;AAAA,MACA,QAAAC,IAAS;AAAA,MACT,UAAAhC;AAAA,IAAA,GAEFI,MACG;AACH,YAAM6B,IAAMC,GAAA,GACNC,IAAY,oBAAoBF,CAAG,IACnCG,IAAY,oBAAoBH,CAAG,IAGnC,CAAC7C,GAAQiD,CAAS,IAAI9C,EAAS,EAAK,GACpC,CAAC+C,GAAQC,CAAS,IAAIhD,EAAS,EAAE,GACjC,CAACiD,GAAaC,CAAc,IAAIlD,EAAS,EAAE,GAG3C,CAACmD,GAAeC,EAAgB,IAAIpD,EAA6B8B,CAAY,GAC7E,CAACuB,GAAgBC,EAAiB,IAAItD,EAAmB+B,KAAiB,CAAA,CAAE,GAE5EwB,IAAerB,IAAQL,MAAW,SAAYX,MAAU,QACxDsC,IAAgBC;AAAA,QACpB,MAAOF,IAAerC,IAAQiC;AAAA,QAC9B,CAACI,GAAcrC,GAAOiC,CAAa;AAAA,MAAA,GAE/BO,IAAsBD;AAAA,QAC1B,MAAOF,IAAgB1B,KAAU,CAAA,IAAMwB;AAAA,QACvC,CAACE,GAAc1B,GAAQwB,CAAc;AAAA,MAAA,GAEjCM,IAAcF;AAAA,QAClB,MAAM,IAAI,IAAIvB,IAAQwB,IAAsBF,IAAgB,CAACA,CAAa,IAAI,EAAE;AAAA,QAChF,CAACtB,GAAOwB,GAAqBF,CAAa;AAAA,MAAA,GAItC5D,IAAagE,EAA0B,IAAI,GAC3CC,IAAUD,EAAyB,IAAI,GACvCE,IAAYF,EAAyB,IAAI,GACzCG,IAAeH,EAAuB,IAAI,GAC1CI,KAAaJ,EAA4B,oBAAI,KAAK,GAGlDK,IAAkBR,EAAQ,MAAM;AACpC,YAAI,CAACV,EAAQ,QAAOnB;AACpB,cAAMsC,IAAQnB,EAAO,YAAA;AACrB,eAAOnB,EAAQ,OAAO,CAACuC,MAAMA,EAAE,MAAM,YAAA,EAAc,SAASD,CAAK,CAAC;AAAA,MACpE,GAAG,CAACtC,GAASmB,CAAM,CAAC,GAGdqB,KAAczE,GAAeC,GAAYC,KAAU4C,CAAM,GAGzD4B,IAAQC,EAAY,MAAM;AAC9B,QAAAxB,EAAU,EAAK,GACfE,EAAU,EAAE,GACZE,EAAe,EAAE,GACjBtD,EAAW,SAAS,MAAA;AAAA,MACtB,GAAG,CAAA,CAAE,GAGC2E,IAASD,EAAY,MAAM;AAC/B,QAAInD,KACJ2B,EAAU,CAAC0B,OACLA,MACFxB,EAAU,EAAE,GACZE,EAAe,EAAE,IAEZ,CAACsB,EACT;AAAA,MACH,GAAG,CAACrD,CAAQ,CAAC,GAGPsD,IAASH;AAAA,QACb,CAACI,MAAgB;AACf,cAAIxC,GAAO;AACT,kBAAMyC,IAAOhB,EAAY,IAAIe,CAAG,IAC5BhB,EAAoB,OAAO,CAACkB,MAAMA,MAAMF,CAAG,IAC3C,CAAC,GAAGhB,GAAqBgB,CAAG;AAChC,YAAKnB,KAAcD,GAAkBqB,CAAI,GACzC1C,IAAgB0C,CAAI;AAAA,UACtB;AACE,YAAKpB,KAAcH,GAAiBsB,CAAG,GACvC1C,IAAW0C,CAAG,GACdL,EAAA;AAAA,QAEJ;AAAA,QACA,CAACnC,GAAOyB,GAAaD,GAAqBH,GAAcvB,GAAUC,GAAeoC,CAAK;AAAA,MAAA,GAIlFQ,KAAeP,EAAY,CAACI,GAAaI,MAAkB;AAC/D,QAAAd,GAAW,QAAQ,IAAIc,GAAOJ,CAAG;AAAA,MACnC,GAAG,CAAA,CAAE;AAGL,MAAAvF,GAAgB,CAAC4E,GAAcF,CAAO,GAAG,MAAM;AAC7C,QAAIhE,KAAQwE,EAAA;AAAA,MACd,CAAC,GAGD/E,EAAU,MAAM;AACd,QAAIO,KAAUsC,KACZ,sBAAsB,MAAM2B,EAAU,SAAS,MAAA,CAAO;AAAA,MAE1D,GAAG,CAACjE,GAAQsC,CAAU,CAAC;AAGvB,YAAM4C,IAAgBT;AAAA,QACpB,CAAC,MAAqC;AACpC,cAAI,CAAAnD;AAEJ,oBAAQ,EAAE,KAAA;AAAA,cACR,KAAK,aAAa;AAEhB,oBADA,EAAE,eAAA,GACE,CAACtB,GAAQ;AACX,kBAAAiD,EAAU,EAAI,GACdI,EAAe,CAAC;AAChB;AAAA,gBACF;AACA,gBAAAA,EAAe,CAACsB,MAAS;AACvB,wBAAMQ,IAAMf,EAAgB,SAAS;AACrC,sBAAIU,IAAOH,IAAO;AAClB,yBAAOG,KAAQK,KAAOf,EAAgBU,CAAI,GAAG,WAAU,CAAAA;AACvD,yBAAOA,IAAOK,IAAMR,IAAOG;AAAA,gBAC7B,CAAC;AACD;AAAA,cACF;AAAA,cACA,KAAK,WAAW;AAEd,oBADA,EAAE,eAAA,GACE,CAAC9E,GAAQ;AACX,kBAAAiD,EAAU,EAAI,GACdI,EAAee,EAAgB,SAAS,CAAC;AACzC;AAAA,gBACF;AACA,gBAAAf,EAAe,CAACsB,MAAS;AACvB,sBAAIG,IAAOH,IAAO;AAClB,yBAAOG,KAAQ,KAAKV,EAAgBU,CAAI,GAAG,WAAU,CAAAA;AACrD,yBAAOA,IAAO,IAAIH,IAAOG;AAAA,gBAC3B,CAAC;AACD;AAAA,cACF;AAAA,cACA,KAAK;AAAA,cACL,KAAK,KAAK;AACR,oBAAI,CAAC9E,GAAQ;AACX,oBAAE,eAAA,GACFiD,EAAU,EAAI,GACdI,EAAe,CAAC;AAChB;AAAA,gBACF;AAEA,oBAAI,EAAE,QAAQ,OAAOf,KAAc,SAAS,kBAAkB2B,EAAU;AACtE;AAEF,kBAAE,eAAA,GACEb,KAAe,KAAKgB,EAAgBhB,CAAW,KAAK,CAACgB,EAAgBhB,CAAW,EAAE,YACpFwB,EAAOR,EAAgBhB,CAAW,EAAE,KAAK;AAE3C;AAAA,cACF;AAAA,cACA,KAAK,UAAU;AACb,kBAAE,eAAA,GACFoB,EAAA;AACA;AAAA,cACF;AAAA,cACA,KAAK,QAAQ;AACX,oBAAIxE,GAAQ;AACV,oBAAE,eAAA;AACF,wBAAMoF,IAAQhB,EAAgB,UAAU,CAACE,MAAM,CAACA,EAAE,QAAQ;AAC1D,kBAAIc,KAAS,KAAG/B,EAAe+B,CAAK;AAAA,gBACtC;AACA;AAAA,cACF;AAAA,cACA,KAAK,OAAO;AACV,oBAAIpF,GAAQ;AACV,oBAAE,eAAA;AACF,2BAASqF,IAAIjB,EAAgB,SAAS,GAAGiB,KAAK,GAAGA;AAC/C,wBAAI,CAACjB,EAAgBiB,CAAC,EAAE,UAAU;AAChC,sBAAAhC,EAAegC,CAAC;AAChB;AAAA,oBACF;AAAA,gBAEJ;AACA;AAAA,cACF;AAAA,cACA,KAAK,OAAO;AACV,gBAAIrF,KAAQwE,EAAA;AACZ;AAAA,cACF;AAAA,cACA;AAEE,oBAAI,CAAClC,KAAc,EAAE,IAAI,WAAW,KAAK,CAAC,EAAE,WAAW,CAAC,EAAE,WAAW,CAAC,EAAE,QAAQ;AAC9E,oBAAE,eAAA,GACGtC,KAAQiD,EAAU,EAAI;AAC3B,wBAAMqC,IAAO,EAAE,IAAI,YAAA,GACbC,IAAanC,IAAc,GAK3BoC,KAJY;AAAA,oBAChB,GAAGpB,EAAgB,MAAMmB,CAAU;AAAA,oBACnC,GAAGnB,EAAgB,MAAM,GAAGmB,CAAU;AAAA,kBAAA,EAEhB;AAAA,oBACtB,CAACjB,OAAM,CAACA,GAAE,YAAYA,GAAE,MAAM,cAAc,WAAWgB,CAAI;AAAA,kBAAA;AAE7D,kBAAIE,MAAS,KACXnC,GAAgBmC,KAAQD,KAAcnB,EAAgB,MAAM;AAAA,gBAEhE;AAAA,YACF;AAAA,QAEJ;AAAA,QACA,CAAC9C,GAAUtB,GAAQoE,GAAiBhB,GAAad,GAAYsC,GAAQJ,CAAK;AAAA,MAAA;AAI5E,MAAA/E,EAAU,MAAM;AACd,YAAI,CAACO,KAAUoD,IAAc,KAAK,CAACY,EAAQ,QAAS;AAEpD,QADiBA,EAAQ,QAAQ,cAAc,gBAAgBZ,CAAW,IAAI,GACpE,eAAe,EAAE,OAAO,UAAA,CAAW;AAAA,MAC/C,GAAG,CAACpD,GAAQoD,CAAW,CAAC;AAGxB,YAAMqC,KAAe;AAAA,QACnB,IAAI;AAAA,QACJ,IAAI;AAAA,QACJ,IAAI;AAAA,MAAA,GAGAC,KAAY;AAAA,QAChB,IAAI;AAAA,QACJ,IAAI;AAAA,QACJ,IAAI;AAAA,MAAA,GAIAC,KAAkB;AAAA,QACtB,SAAS;AAAA,UACP;AAAA,UACA;AAAA,UACA;AAAA,QAAA;AAAA,QAEF,OAAO;AAAA,UACL;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QAAA;AAAA,MACF,GAIIC,KAAehC,EAAQ,MAAM;AACjC,YAAIvB,GAAO;AACT,cAAIwB,EAAoB,WAAW,EAAG,QAAO;AAC7C,gBAAMgC,IAAShC,EACZ,IAAI,CAACkB,MAAMhD,EAAQ,KAAK,CAACuC,MAAMA,EAAE,UAAUS,CAAC,GAAG,SAASA,CAAC;AAC5D,iBAAIc,EAAO,UAAU,IAAUA,EAAO,KAAK,IAAI,IACxC,GAAGA,EAAO,CAAC,CAAC,KAAKA,EAAO,CAAC,CAAC,KAAKA,EAAO,SAAS,CAAC;AAAA,QACzD;AACA,eAAKlC,IACE5B,EAAQ,KAAK,CAACuC,MAAMA,EAAE,UAAUX,CAAa,GAAG,SAASA,IADrC;AAAA,MAE7B,GAAG,CAACtB,GAAOwB,GAAqBF,GAAe5B,CAAO,CAAC,GAGjD+D,KACJ9F,KAAUoD,KAAe,IACrB,GAAGJ,CAAS,WAAWI,CAAW,KAClC,QAGA2C,KAAqC;AAAA,QACzC,QAAA/F;AAAA,QACA,aAAAoD;AAAA,QACA,gBAAgBU;AAAA,QAChB,OAAAzB;AAAA,QACA,WAAAW;AAAA,QACA,WAAAD;AAAA,QACA,QAAA2B;AAAA,QACA,OAAAF;AAAA,QACA,QAAAI;AAAA,QACA,gBAAAvB;AAAA,QACA,cAAA2B;AAAA,MAAA;AAIF,UAAIpE;AACF,eACE,gBAAAM,EAACjC,GAAgB,UAAhB,EAAyB,OAAO8G,IAC/B,UAAA,gBAAA7E,EAAC,OAAA,EAAI,KAAAF,GAAU,WAAWkE,GACvB,UAAAtE,EAAA,CACH,GACF;AAKJ,YAAMoF,KACJ,gBAAApE;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,KAAKoC;AAAA,UACL,IAAIhB;AAAA,UACJ,MAAK;AAAA,UACL,wBAAsBX,KAAS;AAAA,UAC/B,cAAW;AAAA,UACX,UAAU;AAAA,UACV,WAAWX;AAAA,YACT;AAAA,YACA;AAAA,YACA;AAAA,YACA;AAAA,YACA;AAAA,YACA;AAAA,YACAiB;AAAA,UAAA;AAAA,UAEF,OAAOC,IAAS2B,KAAc;AAAA,UAE7B,UAAA;AAAA,YAAAjC,KACC,gBAAApB,EAAC,QAAG,MAAK,gBAAe,WAAU,uEAChC,UAAA,gBAAAU,EAAC,OAAA,EAAI,WAAU,qGACb,UAAA;AAAA,cAAA,gBAAAV,EAAC,QAAA,EAAK,WAAU,gCACd,UAAA,gBAAAA,EAACS,MAAW,GACd;AAAA,cACA,gBAAAT;AAAA,gBAAC;AAAA,gBAAA;AAAA,kBACC,KAAK+C;AAAA,kBACL,MAAK;AAAA,kBACL,MAAK;AAAA,kBACL,cAAW;AAAA,kBACX,OAAOf;AAAA,kBACP,UAAU,CAAC,MAAM;AACf,oBAAAC,EAAU,EAAE,OAAO,KAAK,GACxBE,EAAe,CAAC;AAAA,kBAClB;AAAA,kBACA,aAAab;AAAA,kBACb,WAAWd;AAAA,oBACT;AAAA,oBACA;AAAA,oBACA;AAAA,oBACA;AAAA,oBACA;AAAA,kBAAA;AAAA,gBACF;AAAA,cAAA;AAAA,YACF,EAAA,CACF,EAAA,CACF;AAAA,YAED0C,EAAgB,WAAW,KAC1B,gBAAAlD;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,MAAK;AAAA,gBACL,WAAU;AAAA,gBACX,UAAA;AAAA,cAAA;AAAA,YAAA;AAAA,YAIFkD,EAAgB,IAAI,CAAC6B,GAAQhB,MAAU;AACtC,oBAAM1D,IAAauC,EAAY,IAAImC,EAAO,KAAK,GACzCC,IAAWjB,MAAU7B;AAE3B,qBACE,gBAAAxB;AAAA,gBAAC;AAAA,gBAAA;AAAA,kBAEC,IAAI,GAAGoB,CAAS,WAAWiC,CAAK;AAAA,kBAChC,MAAK;AAAA,kBACL,iBAAe1D;AAAA,kBACf,iBAAe0E,EAAO,YAAY;AAAA,kBAClC,cAAYhB;AAAA,kBACZ,cAAYgB,EAAO;AAAA,kBACnB,WAAWvE;AAAA,oBACT;AAAA,oBACA;AAAA,oBACAgE,GAAUjD,CAAI;AAAA,oBACdyD,KAAY;AAAA,oBACZ3E,KAAc,CAAC2E,KAAY;AAAA,oBAC3B,CAAC3E,KAAc,CAAC2E,KAAY;AAAA,oBAC5BD,EAAO,YAAY;AAAA,oBACnB,CAACA,EAAO,YAAY,CAACC,KAAY;AAAA,kBAAA;AAAA,kBAEnC,SAAS,MAAM;AACb,oBAAKD,EAAO,YAAUrB,EAAOqB,EAAO,KAAK;AAAA,kBAC3C;AAAA,kBACA,cAAc,MAAM5C,EAAe4B,CAAK;AAAA,kBAEvC,UAAA;AAAA,oBAAA5C,KACC,gBAAAnB;AAAA,sBAAC;AAAA,sBAAA;AAAA,wBACC,WAAWQ;AAAA,0BACT;AAAA,0BACA;AAAA,0BACAH,IACI,+EACA;AAAA,wBAAA;AAAA,wBAGL,UAAAA,uBAAeM,IAAA,CAAA,CAAU;AAAA,sBAAA;AAAA,oBAAA;AAAA,oBAG9B,gBAAAX,EAAC,QAAA,EAAK,WAAU,YAAY,YAAO,OAAM;AAAA,oBACxC,CAACmB,KAASd,KACT,gBAAAL,EAAC,UAAK,WAAU,qCACd,UAAA,gBAAAA,EAACW,IAAA,CAAA,CAAU,EAAA,CACb;AAAA,kBAAA;AAAA,gBAAA;AAAA,gBAvCGoE,EAAO;AAAA,cAAA;AAAA,YA2ClB,CAAC;AAAA,UAAA;AAAA,QAAA;AAAA,MAAA;AAIL,aACE,gBAAArE;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,KAAK,CAACuE,MAAS;AAEX,YAAAjC,EAA+D,UAAUiC,GACvE,OAAOnF,KAAQ,aAAYA,EAAImF,CAAI,IAC9BnF,MAAMA,EAAsD,UAAUmF;AAAA,UACjF;AAAA,UACA,WAAU;AAAA,UACV,WAAWjB;AAAA,UAGX,UAAA;AAAA,YAAA,gBAAAtD;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,KAAK7B;AAAA,gBACL,IAAIgD;AAAA,gBACJ,MAAK;AAAA,gBACL,MAAK;AAAA,gBACL,iBAAe/C;AAAA,gBACf,iBAAc;AAAA,gBACd,iBAAeA,IAASgD,IAAY;AAAA,gBACpC,yBAAuB8C;AAAA,gBACvB,UAAAxE;AAAA,gBACA,WAAWI;AAAA,kBACT;AAAA,kBACA;AAAA,kBACA;AAAA,kBACA;AAAA,kBACA;AAAA,kBACA+D,GAAahD,CAAI;AAAA,kBACjBkD,GAAgBjD,EAAO;AAAA,kBACvB1C,KAAU;AAAA,kBACVa;AAAA,gBAAA;AAAA,gBAEF,SAAS6D;AAAA,gBAET,UAAA;AAAA,kBAAA,gBAAAxD;AAAA,oBAAC;AAAA,oBAAA;AAAA,sBACC,WAAWQ;AAAA,wBACT;AAAA,wBACAkE,KACI,8BACA;AAAA,sBAAA;AAAA,sBAGL,UAAAA,MAAgBrD;AAAA,oBAAA;AAAA,kBAAA;AAAA,kBAEnB,gBAAArB,EAACM,IAAA,EAAY,MAAMxB,GAAQ,WAAU,+BAAA,CAA+B;AAAA,gBAAA;AAAA,cAAA;AAAA,YAAA;AAAA,YAIrEA,MACC4C,IACIwD,GAAaJ,IAAa,SAAS,IAAI,IACvC,gBAAA9E,EAAC,OAAA,EAAI,WAAU,qCAAqC,UAAA8E,GAAA,CAAY;AAAA,UAAA;AAAA,QAAA;AAAA,MAAA;AAAA,IAI5E;AAAA,EAAA;AAAA,EAEF;AAAA,IACE,SAAStF;AAAA,IACT,MAAMS;AAAA,IACN,MAAMC;AAAA,EAAA;AAEV;AAEAU,GAAS,cAAc;"}
|