@n3wth/ui 0.7.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.
Files changed (230) hide show
  1. package/dist/atoms/AnimatedText/AnimatedText.js +65 -0
  2. package/dist/atoms/AnimatedText/AnimatedText.js.map +1 -0
  3. package/dist/atoms/Avatar/Avatar.js +55 -0
  4. package/dist/atoms/Avatar/Avatar.js.map +1 -0
  5. package/dist/atoms/Badge/Badge.js +57 -0
  6. package/dist/atoms/Badge/Badge.js.map +1 -0
  7. package/dist/atoms/Button/Button.js +92 -0
  8. package/dist/atoms/Button/Button.js.map +1 -0
  9. package/dist/atoms/Character/Character.js +155 -0
  10. package/dist/atoms/Character/Character.js.map +1 -0
  11. package/dist/atoms/CodeBlock/CodeBlock.js +75 -0
  12. package/dist/atoms/CodeBlock/CodeBlock.js.map +1 -0
  13. package/dist/atoms/HamburgerIcon/HamburgerIcon.js +50 -0
  14. package/dist/atoms/HamburgerIcon/HamburgerIcon.js.map +1 -0
  15. package/dist/atoms/Icon/Icon.js +199 -0
  16. package/dist/atoms/Icon/Icon.js.map +1 -0
  17. package/dist/atoms/Input/Input.js +80 -0
  18. package/dist/atoms/Input/Input.js.map +1 -0
  19. package/dist/atoms/Label/Label.js +32 -0
  20. package/dist/atoms/Label/Label.js.map +1 -0
  21. package/dist/atoms/NoiseOverlay/NoiseOverlay.js +32 -0
  22. package/dist/atoms/NoiseOverlay/NoiseOverlay.js.map +1 -0
  23. package/dist/atoms/Progress/Progress.js +63 -0
  24. package/dist/atoms/Progress/Progress.js.map +1 -0
  25. package/dist/atoms/ScrollIndicator/ScrollIndicator.js +51 -0
  26. package/dist/atoms/ScrollIndicator/ScrollIndicator.js.map +1 -0
  27. package/dist/atoms/Separator/Separator.js +28 -0
  28. package/dist/atoms/Separator/Separator.js.map +1 -0
  29. package/dist/atoms/Shape/Shape.js +110 -0
  30. package/dist/atoms/Shape/Shape.js.map +1 -0
  31. package/dist/atoms/Shape/patterns.js +66 -0
  32. package/dist/atoms/Shape/patterns.js.map +1 -0
  33. package/dist/atoms/Skeleton/Skeleton.js +77 -0
  34. package/dist/atoms/Skeleton/Skeleton.js.map +1 -0
  35. package/dist/atoms/SpeechBubble/SpeechBubble.js +98 -0
  36. package/dist/atoms/SpeechBubble/SpeechBubble.js.map +1 -0
  37. package/dist/atoms/Switch/Switch.js +78 -0
  38. package/dist/atoms/Switch/Switch.js.map +1 -0
  39. package/dist/atoms/Textarea/Textarea.js +40 -0
  40. package/dist/atoms/Textarea/Textarea.js.map +1 -0
  41. package/dist/atoms/Tooltip/Tooltip.js +153 -0
  42. package/dist/atoms/Tooltip/Tooltip.js.map +1 -0
  43. package/dist/hooks/useButtonPulse.js +43 -0
  44. package/dist/hooks/useButtonPulse.js.map +1 -0
  45. package/dist/hooks/useCountUp.js +52 -0
  46. package/dist/hooks/useCountUp.js.map +1 -0
  47. package/dist/hooks/useKeyboardShortcuts.js +37 -0
  48. package/dist/hooks/useKeyboardShortcuts.js.map +1 -0
  49. package/dist/hooks/useMediaQuery.js +59 -0
  50. package/dist/hooks/useMediaQuery.js.map +1 -0
  51. package/dist/hooks/usePageTransition.js +39 -0
  52. package/dist/hooks/usePageTransition.js.map +1 -0
  53. package/dist/hooks/useReducedMotion.js +57 -0
  54. package/dist/hooks/useReducedMotion.js.map +1 -0
  55. package/dist/hooks/useScrollReveal.js +61 -0
  56. package/dist/hooks/useScrollReveal.js.map +1 -0
  57. package/dist/hooks/useStaggerList.js +54 -0
  58. package/dist/hooks/useStaggerList.js.map +1 -0
  59. package/dist/hooks/useTextReveal.js +59 -0
  60. package/dist/hooks/useTextReveal.js.map +1 -0
  61. package/dist/hooks/useTheme.js +37 -0
  62. package/dist/hooks/useTheme.js.map +1 -0
  63. package/dist/hooks/useToast.js +84 -0
  64. package/dist/hooks/useToast.js.map +1 -0
  65. package/dist/index.js +147 -7925
  66. package/dist/index.js.map +1 -1
  67. package/dist/molecules/Accordion/Accordion.js +178 -0
  68. package/dist/molecules/Accordion/Accordion.js.map +1 -0
  69. package/dist/molecules/Card/Card.js +104 -0
  70. package/dist/molecules/Card/Card.js.map +1 -0
  71. package/dist/molecules/CommandBox/CommandBox.js +65 -0
  72. package/dist/molecules/CommandBox/CommandBox.js.map +1 -0
  73. package/dist/molecules/CompositeShape/CompositeShape.js +69 -0
  74. package/dist/molecules/CompositeShape/CompositeShape.js.map +1 -0
  75. package/dist/molecules/CompositeShape/presets.js +71 -0
  76. package/dist/molecules/CompositeShape/presets.js.map +1 -0
  77. package/dist/molecules/Dropdown/Dropdown.d.ts.map +1 -1
  78. package/dist/molecules/Dropdown/Dropdown.js +530 -0
  79. package/dist/molecules/Dropdown/Dropdown.js.map +1 -0
  80. package/dist/molecules/ErrorBoundary/ErrorBoundary.js +128 -0
  81. package/dist/molecules/ErrorBoundary/ErrorBoundary.js.map +1 -0
  82. package/dist/molecules/MobileDrawer/MobileDrawer.js +78 -0
  83. package/dist/molecules/MobileDrawer/MobileDrawer.js.map +1 -0
  84. package/dist/molecules/Modal/Modal.js +262 -0
  85. package/dist/molecules/Modal/Modal.js.map +1 -0
  86. package/dist/molecules/NavLink/NavLink.js +38 -0
  87. package/dist/molecules/NavLink/NavLink.js.map +1 -0
  88. package/dist/molecules/Tabs/Tabs.js +188 -0
  89. package/dist/molecules/Tabs/Tabs.js.map +1 -0
  90. package/dist/molecules/ThemeToggle/ThemeToggle.js +48 -0
  91. package/dist/molecules/ThemeToggle/ThemeToggle.js.map +1 -0
  92. package/dist/molecules/Toast/Toast.js +156 -0
  93. package/dist/molecules/Toast/Toast.js.map +1 -0
  94. package/dist/node_modules/clsx/dist/clsx.js +17 -0
  95. package/dist/node_modules/clsx/dist/clsx.js.map +1 -0
  96. package/dist/node_modules/iconoir-react/dist/esm/IconoirContext.js +6 -0
  97. package/dist/node_modules/iconoir-react/dist/esm/IconoirContext.js.map +1 -0
  98. package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowDown.js +17 -0
  99. package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowDown.js.map +1 -0
  100. package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowLeft.js +17 -0
  101. package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowLeft.js.map +1 -0
  102. package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowRight.js +17 -0
  103. package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowRight.js.map +1 -0
  104. package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowUp.js +17 -0
  105. package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowUp.js.map +1 -0
  106. package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowUpRight.js +17 -0
  107. package/dist/node_modules/iconoir-react/dist/esm/regular/ArrowUpRight.js.map +1 -0
  108. package/dist/node_modules/iconoir-react/dist/esm/regular/Bell.js +17 -0
  109. package/dist/node_modules/iconoir-react/dist/esm/regular/Bell.js.map +1 -0
  110. package/dist/node_modules/iconoir-react/dist/esm/regular/Calendar.js +17 -0
  111. package/dist/node_modules/iconoir-react/dist/esm/regular/Calendar.js.map +1 -0
  112. package/dist/node_modules/iconoir-react/dist/esm/regular/Check.js +17 -0
  113. package/dist/node_modules/iconoir-react/dist/esm/regular/Check.js.map +1 -0
  114. package/dist/node_modules/iconoir-react/dist/esm/regular/CheckCircle.js +17 -0
  115. package/dist/node_modules/iconoir-react/dist/esm/regular/CheckCircle.js.map +1 -0
  116. package/dist/node_modules/iconoir-react/dist/esm/regular/Clock.js +17 -0
  117. package/dist/node_modules/iconoir-react/dist/esm/regular/Clock.js.map +1 -0
  118. package/dist/node_modules/iconoir-react/dist/esm/regular/Code.js +17 -0
  119. package/dist/node_modules/iconoir-react/dist/esm/regular/Code.js.map +1 -0
  120. package/dist/node_modules/iconoir-react/dist/esm/regular/Copy.js +17 -0
  121. package/dist/node_modules/iconoir-react/dist/esm/regular/Copy.js.map +1 -0
  122. package/dist/node_modules/iconoir-react/dist/esm/regular/Download.js +17 -0
  123. package/dist/node_modules/iconoir-react/dist/esm/regular/Download.js.map +1 -0
  124. package/dist/node_modules/iconoir-react/dist/esm/regular/EditPencil.js +17 -0
  125. package/dist/node_modules/iconoir-react/dist/esm/regular/EditPencil.js.map +1 -0
  126. package/dist/node_modules/iconoir-react/dist/esm/regular/Eye.js +17 -0
  127. package/dist/node_modules/iconoir-react/dist/esm/regular/Eye.js.map +1 -0
  128. package/dist/node_modules/iconoir-react/dist/esm/regular/EyeClosed.js +17 -0
  129. package/dist/node_modules/iconoir-react/dist/esm/regular/EyeClosed.js.map +1 -0
  130. package/dist/node_modules/iconoir-react/dist/esm/regular/Filter.js +17 -0
  131. package/dist/node_modules/iconoir-react/dist/esm/regular/Filter.js.map +1 -0
  132. package/dist/node_modules/iconoir-react/dist/esm/regular/Folder.js +17 -0
  133. package/dist/node_modules/iconoir-react/dist/esm/regular/Folder.js.map +1 -0
  134. package/dist/node_modules/iconoir-react/dist/esm/regular/Github.js +17 -0
  135. package/dist/node_modules/iconoir-react/dist/esm/regular/Github.js.map +1 -0
  136. package/dist/node_modules/iconoir-react/dist/esm/regular/HalfMoon.js +17 -0
  137. package/dist/node_modules/iconoir-react/dist/esm/regular/HalfMoon.js.map +1 -0
  138. package/dist/node_modules/iconoir-react/dist/esm/regular/Heart.js +17 -0
  139. package/dist/node_modules/iconoir-react/dist/esm/regular/Heart.js.map +1 -0
  140. package/dist/node_modules/iconoir-react/dist/esm/regular/Home.js +17 -0
  141. package/dist/node_modules/iconoir-react/dist/esm/regular/Home.js.map +1 -0
  142. package/dist/node_modules/iconoir-react/dist/esm/regular/InfoCircle.js +17 -0
  143. package/dist/node_modules/iconoir-react/dist/esm/regular/InfoCircle.js.map +1 -0
  144. package/dist/node_modules/iconoir-react/dist/esm/regular/Link.js +17 -0
  145. package/dist/node_modules/iconoir-react/dist/esm/regular/Link.js.map +1 -0
  146. package/dist/node_modules/iconoir-react/dist/esm/regular/List.js +17 -0
  147. package/dist/node_modules/iconoir-react/dist/esm/regular/List.js.map +1 -0
  148. package/dist/node_modules/iconoir-react/dist/esm/regular/Lock.js +17 -0
  149. package/dist/node_modules/iconoir-react/dist/esm/regular/Lock.js.map +1 -0
  150. package/dist/node_modules/iconoir-react/dist/esm/regular/LockSlash.js +17 -0
  151. package/dist/node_modules/iconoir-react/dist/esm/regular/LockSlash.js.map +1 -0
  152. package/dist/node_modules/iconoir-react/dist/esm/regular/Mail.js +17 -0
  153. package/dist/node_modules/iconoir-react/dist/esm/regular/Mail.js.map +1 -0
  154. package/dist/node_modules/iconoir-react/dist/esm/regular/Menu.js +17 -0
  155. package/dist/node_modules/iconoir-react/dist/esm/regular/Menu.js.map +1 -0
  156. package/dist/node_modules/iconoir-react/dist/esm/regular/Minus.js +17 -0
  157. package/dist/node_modules/iconoir-react/dist/esm/regular/Minus.js.map +1 -0
  158. package/dist/node_modules/iconoir-react/dist/esm/regular/MoreHoriz.js +17 -0
  159. package/dist/node_modules/iconoir-react/dist/esm/regular/MoreHoriz.js.map +1 -0
  160. package/dist/node_modules/iconoir-react/dist/esm/regular/MoreVert.js +17 -0
  161. package/dist/node_modules/iconoir-react/dist/esm/regular/MoreVert.js.map +1 -0
  162. package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowDown.js +17 -0
  163. package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowDown.js.map +1 -0
  164. package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowLeft.js +17 -0
  165. package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowLeft.js.map +1 -0
  166. package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowRight.js +17 -0
  167. package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowRight.js.map +1 -0
  168. package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowUp.js +17 -0
  169. package/dist/node_modules/iconoir-react/dist/esm/regular/NavArrowUp.js.map +1 -0
  170. package/dist/node_modules/iconoir-react/dist/esm/regular/OpenInWindow.js +17 -0
  171. package/dist/node_modules/iconoir-react/dist/esm/regular/OpenInWindow.js.map +1 -0
  172. package/dist/node_modules/iconoir-react/dist/esm/regular/Page.js +17 -0
  173. package/dist/node_modules/iconoir-react/dist/esm/regular/Page.js.map +1 -0
  174. package/dist/node_modules/iconoir-react/dist/esm/regular/Plus.js +17 -0
  175. package/dist/node_modules/iconoir-react/dist/esm/regular/Plus.js.map +1 -0
  176. package/dist/node_modules/iconoir-react/dist/esm/regular/RefreshDouble.js +17 -0
  177. package/dist/node_modules/iconoir-react/dist/esm/regular/RefreshDouble.js.map +1 -0
  178. package/dist/node_modules/iconoir-react/dist/esm/regular/Search.js +17 -0
  179. package/dist/node_modules/iconoir-react/dist/esm/regular/Search.js.map +1 -0
  180. package/dist/node_modules/iconoir-react/dist/esm/regular/Settings.js +17 -0
  181. package/dist/node_modules/iconoir-react/dist/esm/regular/Settings.js.map +1 -0
  182. package/dist/node_modules/iconoir-react/dist/esm/regular/SortDown.js +17 -0
  183. package/dist/node_modules/iconoir-react/dist/esm/regular/SortDown.js.map +1 -0
  184. package/dist/node_modules/iconoir-react/dist/esm/regular/Sparks.js +17 -0
  185. package/dist/node_modules/iconoir-react/dist/esm/regular/Sparks.js.map +1 -0
  186. package/dist/node_modules/iconoir-react/dist/esm/regular/Star.js +17 -0
  187. package/dist/node_modules/iconoir-react/dist/esm/regular/Star.js.map +1 -0
  188. package/dist/node_modules/iconoir-react/dist/esm/regular/SunLight.js +17 -0
  189. package/dist/node_modules/iconoir-react/dist/esm/regular/SunLight.js.map +1 -0
  190. package/dist/node_modules/iconoir-react/dist/esm/regular/Terminal.js +17 -0
  191. package/dist/node_modules/iconoir-react/dist/esm/regular/Terminal.js.map +1 -0
  192. package/dist/node_modules/iconoir-react/dist/esm/regular/Trash.js +17 -0
  193. package/dist/node_modules/iconoir-react/dist/esm/regular/Trash.js.map +1 -0
  194. package/dist/node_modules/iconoir-react/dist/esm/regular/Upload.js +17 -0
  195. package/dist/node_modules/iconoir-react/dist/esm/regular/Upload.js.map +1 -0
  196. package/dist/node_modules/iconoir-react/dist/esm/regular/User.js +17 -0
  197. package/dist/node_modules/iconoir-react/dist/esm/regular/User.js.map +1 -0
  198. package/dist/node_modules/iconoir-react/dist/esm/regular/ViewGrid.js +17 -0
  199. package/dist/node_modules/iconoir-react/dist/esm/regular/ViewGrid.js.map +1 -0
  200. package/dist/node_modules/iconoir-react/dist/esm/regular/WarningTriangle.js +17 -0
  201. package/dist/node_modules/iconoir-react/dist/esm/regular/WarningTriangle.js.map +1 -0
  202. package/dist/node_modules/iconoir-react/dist/esm/regular/Xmark.js +17 -0
  203. package/dist/node_modules/iconoir-react/dist/esm/regular/Xmark.js.map +1 -0
  204. package/dist/node_modules/iconoir-react/dist/esm/regular/XmarkCircle.js +17 -0
  205. package/dist/node_modules/iconoir-react/dist/esm/regular/XmarkCircle.js.map +1 -0
  206. package/dist/node_modules/tailwind-merge/dist/bundle-mjs.js +2996 -0
  207. package/dist/node_modules/tailwind-merge/dist/bundle-mjs.js.map +1 -0
  208. package/dist/organisms/Footer/Footer.js +108 -0
  209. package/dist/organisms/Footer/Footer.js.map +1 -0
  210. package/dist/organisms/Hero/Hero.d.ts.map +1 -1
  211. package/dist/organisms/Hero/Hero.js +101 -0
  212. package/dist/organisms/Hero/Hero.js.map +1 -0
  213. package/dist/organisms/Nav/Nav.js +177 -0
  214. package/dist/organisms/Nav/Nav.js.map +1 -0
  215. package/dist/organisms/Section/Section.js +57 -0
  216. package/dist/organisms/Section/Section.js.map +1 -0
  217. package/dist/theme.css +86 -0
  218. package/dist/tokens/colors.js +105 -0
  219. package/dist/tokens/colors.js.map +1 -0
  220. package/dist/tokens/effects.js +26 -0
  221. package/dist/tokens/effects.js.map +1 -0
  222. package/dist/tokens/motion.js +25 -0
  223. package/dist/tokens/motion.js.map +1 -0
  224. package/dist/tokens/spacing.js +31 -0
  225. package/dist/tokens/spacing.js.map +1 -0
  226. package/dist/tokens/typography.js +63 -0
  227. package/dist/tokens/typography.js.map +1 -0
  228. package/dist/utils/cn.js +9 -0
  229. package/dist/utils/cn.js.map +1 -0
  230. package/package.json +8 -5
@@ -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":"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"}