@hyunsdev/ui 0.1.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 (340) hide show
  1. package/LICENSE +674 -0
  2. package/README.md +89 -0
  3. package/SKILL.md +38 -0
  4. package/dist/WindowContext-DybYtZJa.d.ts +50 -0
  5. package/dist/_styles-BbTx89aX.d.ts +3 -0
  6. package/dist/chunk-23KUNTRD.js +49 -0
  7. package/dist/chunk-23KUNTRD.js.map +1 -0
  8. package/dist/chunk-3RTSANKB.js +51 -0
  9. package/dist/chunk-3RTSANKB.js.map +1 -0
  10. package/dist/chunk-4QIWBOF4.js +129 -0
  11. package/dist/chunk-4QIWBOF4.js.map +1 -0
  12. package/dist/chunk-5JCWC7IU.js +293 -0
  13. package/dist/chunk-5JCWC7IU.js.map +1 -0
  14. package/dist/chunk-6ANDNGHD.js +33 -0
  15. package/dist/chunk-6ANDNGHD.js.map +1 -0
  16. package/dist/chunk-7W7QZHEZ.js +42 -0
  17. package/dist/chunk-7W7QZHEZ.js.map +1 -0
  18. package/dist/chunk-BHO4WT2N.js +51 -0
  19. package/dist/chunk-BHO4WT2N.js.map +1 -0
  20. package/dist/chunk-BI3KKBIC.js +11 -0
  21. package/dist/chunk-BI3KKBIC.js.map +1 -0
  22. package/dist/chunk-D3SP7GL3.js +55 -0
  23. package/dist/chunk-D3SP7GL3.js.map +1 -0
  24. package/dist/chunk-D7W4RSQX.js +115 -0
  25. package/dist/chunk-D7W4RSQX.js.map +1 -0
  26. package/dist/chunk-DN2AEEA2.js +11 -0
  27. package/dist/chunk-DN2AEEA2.js.map +1 -0
  28. package/dist/chunk-ETTKFCO6.js +84 -0
  29. package/dist/chunk-ETTKFCO6.js.map +1 -0
  30. package/dist/chunk-GJT7TDBS.js +66 -0
  31. package/dist/chunk-GJT7TDBS.js.map +1 -0
  32. package/dist/chunk-HZT6RQYZ.js +109 -0
  33. package/dist/chunk-HZT6RQYZ.js.map +1 -0
  34. package/dist/chunk-JB2QZV7K.js +60 -0
  35. package/dist/chunk-JB2QZV7K.js.map +1 -0
  36. package/dist/chunk-KJJB2PVC.js +21 -0
  37. package/dist/chunk-KJJB2PVC.js.map +1 -0
  38. package/dist/chunk-NE3IVPMO.js +31 -0
  39. package/dist/chunk-NE3IVPMO.js.map +1 -0
  40. package/dist/chunk-O2BG2KSY.js +23 -0
  41. package/dist/chunk-O2BG2KSY.js.map +1 -0
  42. package/dist/chunk-OUFGNJ3V.js +1726 -0
  43. package/dist/chunk-OUFGNJ3V.js.map +1 -0
  44. package/dist/chunk-PLZMCJSL.js +351 -0
  45. package/dist/chunk-PLZMCJSL.js.map +1 -0
  46. package/dist/chunk-POG5DZBT.js +104 -0
  47. package/dist/chunk-POG5DZBT.js.map +1 -0
  48. package/dist/chunk-SECZM6JE.js +170 -0
  49. package/dist/chunk-SECZM6JE.js.map +1 -0
  50. package/dist/chunk-T64WPXSC.js +48 -0
  51. package/dist/chunk-T64WPXSC.js.map +1 -0
  52. package/dist/chunk-TU5CYBB4.js +90 -0
  53. package/dist/chunk-TU5CYBB4.js.map +1 -0
  54. package/dist/chunk-UVAI2U6X.js +153 -0
  55. package/dist/chunk-UVAI2U6X.js.map +1 -0
  56. package/dist/chunk-UXCBLYG6.js +142 -0
  57. package/dist/chunk-UXCBLYG6.js.map +1 -0
  58. package/dist/chunk-VUR4MQMH.js +53 -0
  59. package/dist/chunk-VUR4MQMH.js.map +1 -0
  60. package/dist/chunk-WIEKNG4S.js +26 -0
  61. package/dist/chunk-WIEKNG4S.js.map +1 -0
  62. package/dist/chunk-WIZ4OLOB.js +23 -0
  63. package/dist/chunk-WIZ4OLOB.js.map +1 -0
  64. package/dist/chunk-WJRJBMFN.js +21 -0
  65. package/dist/chunk-WJRJBMFN.js.map +1 -0
  66. package/dist/chunk-YUPLJP3F.js +33 -0
  67. package/dist/chunk-YUPLJP3F.js.map +1 -0
  68. package/dist/chunk-Z7ITPSUF.js +184 -0
  69. package/dist/chunk-Z7ITPSUF.js.map +1 -0
  70. package/dist/chunk-ZC76ALSI.js +75 -0
  71. package/dist/chunk-ZC76ALSI.js.map +1 -0
  72. package/dist/code-block-core-xkE94Rk5.d.ts +30 -0
  73. package/dist/components/accordion.d.ts +9 -0
  74. package/dist/components/accordion.js +98 -0
  75. package/dist/components/accordion.js.map +1 -0
  76. package/dist/components/alert-dialog.d.ts +26 -0
  77. package/dist/components/alert-dialog.js +341 -0
  78. package/dist/components/alert-dialog.js.map +1 -0
  79. package/dist/components/alert.d.ts +13 -0
  80. package/dist/components/alert.js +76 -0
  81. package/dist/components/alert.js.map +1 -0
  82. package/dist/components/aspect-ratio.d.ts +6 -0
  83. package/dist/components/aspect-ratio.js +12 -0
  84. package/dist/components/aspect-ratio.js.map +1 -0
  85. package/dist/components/avatar.d.ts +13 -0
  86. package/dist/components/avatar.js +19 -0
  87. package/dist/components/avatar.js.map +1 -0
  88. package/dist/components/badge.d.ts +12 -0
  89. package/dist/components/badge.js +11 -0
  90. package/dist/components/badge.js.map +1 -0
  91. package/dist/components/breadcrumb.d.ts +13 -0
  92. package/dist/components/breadcrumb.js +102 -0
  93. package/dist/components/breadcrumb.js.map +1 -0
  94. package/dist/components/button-group.d.ts +16 -0
  95. package/dist/components/button-group.js +15 -0
  96. package/dist/components/button-group.js.map +1 -0
  97. package/dist/components/button.d.ts +14 -0
  98. package/dist/components/button.js +11 -0
  99. package/dist/components/button.js.map +1 -0
  100. package/dist/components/calendar.d.ts +14 -0
  101. package/dist/components/calendar.js +13 -0
  102. package/dist/components/calendar.js.map +1 -0
  103. package/dist/components/card.d.ts +13 -0
  104. package/dist/components/card.js +21 -0
  105. package/dist/components/card.js.map +1 -0
  106. package/dist/components/carousel.d.ts +32 -0
  107. package/dist/components/carousel.js +196 -0
  108. package/dist/components/carousel.js.map +1 -0
  109. package/dist/components/chart.d.ts +46 -0
  110. package/dist/components/chart.js +254 -0
  111. package/dist/components/chart.js.map +1 -0
  112. package/dist/components/checkbox.d.ts +6 -0
  113. package/dist/components/checkbox.js +41 -0
  114. package/dist/components/checkbox.js.map +1 -0
  115. package/dist/components/code-block-core.d.ts +3 -0
  116. package/dist/components/code-block-core.js +13 -0
  117. package/dist/components/code-block-core.js.map +1 -0
  118. package/dist/components/code-block-custom.d.ts +20 -0
  119. package/dist/components/code-block-custom.js +16 -0
  120. package/dist/components/code-block-custom.js.map +1 -0
  121. package/dist/components/code-block-shiki.d.ts +13 -0
  122. package/dist/components/code-block-shiki.js +15 -0
  123. package/dist/components/code-block-shiki.js.map +1 -0
  124. package/dist/components/code-block.d.ts +5 -0
  125. package/dist/components/code-block.js +14 -0
  126. package/dist/components/code-block.js.map +1 -0
  127. package/dist/components/collapsible.d.ts +8 -0
  128. package/dist/components/collapsible.js +24 -0
  129. package/dist/components/collapsible.js.map +1 -0
  130. package/dist/components/collection.d.ts +63 -0
  131. package/dist/components/collection.js +598 -0
  132. package/dist/components/collection.js.map +1 -0
  133. package/dist/components/color-dot.d.ts +19 -0
  134. package/dist/components/color-dot.js +41 -0
  135. package/dist/components/color-dot.js.map +1 -0
  136. package/dist/components/color-picker.d.ts +12 -0
  137. package/dist/components/color-picker.js +142 -0
  138. package/dist/components/color-picker.js.map +1 -0
  139. package/dist/components/combobox.d.ts +74 -0
  140. package/dist/components/combobox.js +610 -0
  141. package/dist/components/combobox.js.map +1 -0
  142. package/dist/components/command.d.ts +21 -0
  143. package/dist/components/command.js +31 -0
  144. package/dist/components/command.js.map +1 -0
  145. package/dist/components/date-picker.d.ts +43 -0
  146. package/dist/components/date-picker.js +235 -0
  147. package/dist/components/date-picker.js.map +1 -0
  148. package/dist/components/dialog.d.ts +25 -0
  149. package/dist/components/dialog.js +31 -0
  150. package/dist/components/dialog.js.map +1 -0
  151. package/dist/components/drawer.d.ts +15 -0
  152. package/dist/components/drawer.js +124 -0
  153. package/dist/components/drawer.js.map +1 -0
  154. package/dist/components/dropdown-menu.d.ts +34 -0
  155. package/dist/components/dropdown-menu.js +248 -0
  156. package/dist/components/dropdown-menu.js.map +1 -0
  157. package/dist/components/empty.d.ts +15 -0
  158. package/dist/components/empty.js +104 -0
  159. package/dist/components/empty.js.map +1 -0
  160. package/dist/components/field.d.ts +29 -0
  161. package/dist/components/field.js +214 -0
  162. package/dist/components/field.js.map +1 -0
  163. package/dist/components/format-bytes.d.ts +12 -0
  164. package/dist/components/format-bytes.js +30 -0
  165. package/dist/components/format-bytes.js.map +1 -0
  166. package/dist/components/format-number.d.ts +12 -0
  167. package/dist/components/format-number.js +30 -0
  168. package/dist/components/format-number.js.map +1 -0
  169. package/dist/components/gauge.d.ts +11 -0
  170. package/dist/components/gauge.js +82 -0
  171. package/dist/components/gauge.js.map +1 -0
  172. package/dist/components/hover-card.d.ts +8 -0
  173. package/dist/components/hover-card.js +45 -0
  174. package/dist/components/hover-card.js.map +1 -0
  175. package/dist/components/input-group.d.ts +24 -0
  176. package/dist/components/input-group.js +23 -0
  177. package/dist/components/input-group.js.map +1 -0
  178. package/dist/components/input-otp.d.ts +20 -0
  179. package/dist/components/input-otp.js +95 -0
  180. package/dist/components/input-otp.js.map +1 -0
  181. package/dist/components/input.d.ts +9 -0
  182. package/dist/components/input.js +9 -0
  183. package/dist/components/input.js.map +1 -0
  184. package/dist/components/item.d.ts +27 -0
  185. package/dist/components/item.js +182 -0
  186. package/dist/components/item.js.map +1 -0
  187. package/dist/components/kbd.d.ts +6 -0
  188. package/dist/components/kbd.js +34 -0
  189. package/dist/components/kbd.js.map +1 -0
  190. package/dist/components/label.d.ts +6 -0
  191. package/dist/components/label.js +9 -0
  192. package/dist/components/label.js.map +1 -0
  193. package/dist/components/loading-bar.d.ts +8 -0
  194. package/dist/components/loading-bar.js +127 -0
  195. package/dist/components/loading-bar.js.map +1 -0
  196. package/dist/components/loading-dots.d.ts +5 -0
  197. package/dist/components/loading-dots.js +45 -0
  198. package/dist/components/loading-dots.js.map +1 -0
  199. package/dist/components/main-provider.d.ts +7 -0
  200. package/dist/components/main-provider.js +12 -0
  201. package/dist/components/main-provider.js.map +1 -0
  202. package/dist/components/mark.d.ts +11 -0
  203. package/dist/components/mark.js +44 -0
  204. package/dist/components/mark.js.map +1 -0
  205. package/dist/components/pagination.d.ts +21 -0
  206. package/dist/components/pagination.js +114 -0
  207. package/dist/components/pagination.js.map +1 -0
  208. package/dist/components/popover.d.ts +12 -0
  209. package/dist/components/popover.js +22 -0
  210. package/dist/components/popover.js.map +1 -0
  211. package/dist/components/prev-next-navigation.d.ts +15 -0
  212. package/dist/components/prev-next-navigation.js +85 -0
  213. package/dist/components/prev-next-navigation.js.map +1 -0
  214. package/dist/components/progress.d.ts +6 -0
  215. package/dist/components/progress.js +38 -0
  216. package/dist/components/progress.js.map +1 -0
  217. package/dist/components/radio-group.d.ts +7 -0
  218. package/dist/components/radio-group.js +57 -0
  219. package/dist/components/radio-group.js.map +1 -0
  220. package/dist/components/relative-time.d.ts +16 -0
  221. package/dist/components/relative-time.js +75 -0
  222. package/dist/components/relative-time.js.map +1 -0
  223. package/dist/components/resizable.d.ts +10 -0
  224. package/dist/components/resizable.js +45 -0
  225. package/dist/components/resizable.js.map +1 -0
  226. package/dist/components/scroll-area.d.ts +7 -0
  227. package/dist/components/scroll-area.js +11 -0
  228. package/dist/components/scroll-area.js.map +1 -0
  229. package/dist/components/select.d.ts +20 -0
  230. package/dist/components/select.js +189 -0
  231. package/dist/components/select.js.map +1 -0
  232. package/dist/components/separator.d.ts +6 -0
  233. package/dist/components/separator.js +9 -0
  234. package/dist/components/separator.js.map +1 -0
  235. package/dist/components/sheet.d.ts +16 -0
  236. package/dist/components/sheet.js +25 -0
  237. package/dist/components/sheet.js.map +1 -0
  238. package/dist/components/show-more.d.ts +15 -0
  239. package/dist/components/show-more.js +79 -0
  240. package/dist/components/show-more.js.map +1 -0
  241. package/dist/components/skeleton.d.ts +5 -0
  242. package/dist/components/skeleton.js +8 -0
  243. package/dist/components/skeleton.js.map +1 -0
  244. package/dist/components/slider.d.ts +6 -0
  245. package/dist/components/slider.js +65 -0
  246. package/dist/components/slider.js.map +1 -0
  247. package/dist/components/snippet.d.ts +13 -0
  248. package/dist/components/snippet.js +135 -0
  249. package/dist/components/snippet.js.map +1 -0
  250. package/dist/components/sonner.d.ts +6 -0
  251. package/dist/components/sonner.js +10 -0
  252. package/dist/components/sonner.js.map +1 -0
  253. package/dist/components/spinner.d.ts +5 -0
  254. package/dist/components/spinner.js +8 -0
  255. package/dist/components/spinner.js.map +1 -0
  256. package/dist/components/stat.d.ts +17 -0
  257. package/dist/components/stat.js +71 -0
  258. package/dist/components/stat.js.map +1 -0
  259. package/dist/components/steps.d.ts +17 -0
  260. package/dist/components/steps.js +133 -0
  261. package/dist/components/steps.js.map +1 -0
  262. package/dist/components/switch.d.ts +8 -0
  263. package/dist/components/switch.js +44 -0
  264. package/dist/components/switch.js.map +1 -0
  265. package/dist/components/table.d.ts +12 -0
  266. package/dist/components/table.js +101 -0
  267. package/dist/components/table.js.map +1 -0
  268. package/dist/components/tabs.d.ts +14 -0
  269. package/dist/components/tabs.js +88 -0
  270. package/dist/components/tabs.js.map +1 -0
  271. package/dist/components/textarea.d.ts +5 -0
  272. package/dist/components/textarea.js +9 -0
  273. package/dist/components/textarea.js.map +1 -0
  274. package/dist/components/theme-provider.d.ts +10 -0
  275. package/dist/components/theme-provider.js +14 -0
  276. package/dist/components/theme-provider.js.map +1 -0
  277. package/dist/components/time-picker.d.ts +17 -0
  278. package/dist/components/time-picker.js +219 -0
  279. package/dist/components/time-picker.js.map +1 -0
  280. package/dist/components/timeline.d.ts +17 -0
  281. package/dist/components/timeline.js +138 -0
  282. package/dist/components/timeline.js.map +1 -0
  283. package/dist/components/toggle-group.d.ts +14 -0
  284. package/dist/components/toggle-group.js +82 -0
  285. package/dist/components/toggle-group.js.map +1 -0
  286. package/dist/components/toggle.d.ts +12 -0
  287. package/dist/components/toggle.js +11 -0
  288. package/dist/components/toggle.js.map +1 -0
  289. package/dist/components/tooltip.d.ts +9 -0
  290. package/dist/components/tooltip.js +15 -0
  291. package/dist/components/tooltip.js.map +1 -0
  292. package/dist/components/typography.d.ts +17 -0
  293. package/dist/components/typography.js +91 -0
  294. package/dist/components/typography.js.map +1 -0
  295. package/dist/hooks/use-mobile.d.ts +3 -0
  296. package/dist/hooks/use-mobile.js +7 -0
  297. package/dist/hooks/use-mobile.js.map +1 -0
  298. package/dist/hooks/use-theme.d.ts +3 -0
  299. package/dist/hooks/use-theme.js +8 -0
  300. package/dist/hooks/use-theme.js.map +1 -0
  301. package/dist/index.d.ts +7 -0
  302. package/dist/index.js +27 -0
  303. package/dist/index.js.map +1 -0
  304. package/dist/layouts/center/index.d.ts +18 -0
  305. package/dist/layouts/center/index.js +73 -0
  306. package/dist/layouts/center/index.js.map +1 -0
  307. package/dist/layouts/chat/index.d.ts +42 -0
  308. package/dist/layouts/chat/index.js +191 -0
  309. package/dist/layouts/chat/index.js.map +1 -0
  310. package/dist/layouts/command/index.d.ts +2 -0
  311. package/dist/layouts/command/index.js +1 -0
  312. package/dist/layouts/command/index.js.map +1 -0
  313. package/dist/layouts/panel/index.d.ts +55 -0
  314. package/dist/layouts/panel/index.js +513 -0
  315. package/dist/layouts/panel/index.js.map +1 -0
  316. package/dist/layouts/presentation/index.d.ts +14 -0
  317. package/dist/layouts/presentation/index.js +100 -0
  318. package/dist/layouts/presentation/index.js.map +1 -0
  319. package/dist/layouts/site/index.d.ts +17 -0
  320. package/dist/layouts/site/index.js +82 -0
  321. package/dist/layouts/site/index.js.map +1 -0
  322. package/dist/layouts/window/index.d.ts +223 -0
  323. package/dist/layouts/window/index.js +127 -0
  324. package/dist/layouts/window/index.js.map +1 -0
  325. package/dist/layouts/workbench/index.d.ts +281 -0
  326. package/dist/layouts/workbench/index.js +2457 -0
  327. package/dist/layouts/workbench/index.js.map +1 -0
  328. package/dist/lib/format.d.ts +15 -0
  329. package/dist/lib/format.js +9 -0
  330. package/dist/lib/format.js.map +1 -0
  331. package/dist/lib/theme.d.ts +22 -0
  332. package/dist/lib/theme.js +25 -0
  333. package/dist/lib/theme.js.map +1 -0
  334. package/dist/lib/utils.d.ts +5 -0
  335. package/dist/lib/utils.js +7 -0
  336. package/dist/lib/utils.js.map +1 -0
  337. package/dist/styles/fonts.css +1 -0
  338. package/dist/styles/globals.css +717 -0
  339. package/dist/styles/tokens.css +693 -0
  340. package/package.json +137 -0
@@ -0,0 +1,610 @@
1
+ "use client";
2
+ import {
3
+ Command,
4
+ CommandGroup,
5
+ CommandItem,
6
+ CommandList
7
+ } from "../chunk-Z7ITPSUF.js";
8
+ import {
9
+ Popover,
10
+ PopoverAnchor,
11
+ PopoverContent
12
+ } from "../chunk-ZC76ALSI.js";
13
+ import "../chunk-PLZMCJSL.js";
14
+ import "../chunk-UVAI2U6X.js";
15
+ import "../chunk-NE3IVPMO.js";
16
+ import "../chunk-YUPLJP3F.js";
17
+ import "../chunk-TU5CYBB4.js";
18
+ import {
19
+ Badge
20
+ } from "../chunk-VUR4MQMH.js";
21
+ import {
22
+ fieldInvalidClass
23
+ } from "../chunk-O2BG2KSY.js";
24
+ import {
25
+ cn
26
+ } from "../chunk-DN2AEEA2.js";
27
+
28
+ // src/components/combobox.tsx
29
+ import * as React from "react";
30
+ import { Command as CommandPrimitive } from "cmdk";
31
+ import { CheckIcon, ChevronDownIcon, LoaderCircleIcon, SearchIcon, XIcon } from "lucide-react";
32
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
33
+ var ComboboxContext = React.createContext(null);
34
+ function useControllableState({
35
+ value,
36
+ defaultValue,
37
+ onChange
38
+ }) {
39
+ const [internalValue, setInternalValue] = React.useState(defaultValue);
40
+ const isControlled = value !== void 0;
41
+ const currentValue = isControlled ? value : internalValue;
42
+ const setValue = React.useCallback(
43
+ (nextValue) => {
44
+ if (!isControlled) {
45
+ setInternalValue(nextValue);
46
+ }
47
+ onChange?.(nextValue);
48
+ },
49
+ [isControlled, onChange]
50
+ );
51
+ return [currentValue, setValue];
52
+ }
53
+ function useComboboxContext(componentName) {
54
+ const context = React.useContext(ComboboxContext);
55
+ if (!context) {
56
+ throw new Error(`${componentName} must be used within <Combobox>.`);
57
+ }
58
+ return context;
59
+ }
60
+ function Combobox(props) {
61
+ const {
62
+ options,
63
+ query: queryProp,
64
+ defaultQuery = "",
65
+ onQueryChange,
66
+ open: openProp,
67
+ defaultOpen = false,
68
+ onOpenChange,
69
+ creatable = false,
70
+ loading = false,
71
+ disabled = false,
72
+ invalid = false,
73
+ placeholder = "Search\u2026",
74
+ emptyMessage = "No results found.",
75
+ loadingMessage = "Loading\u2026",
76
+ createLabel = (query2) => `Create "${query2}"`,
77
+ onCreateOption,
78
+ id,
79
+ className,
80
+ children,
81
+ multiple: multipleProp,
82
+ ...divProps
83
+ } = props;
84
+ const inputId = React.useId();
85
+ const listId = React.useId();
86
+ const multiple = multipleProp === true;
87
+ const singleValueProp = props.multiple === true ? void 0 : props.value;
88
+ const singleDefaultValue = props.multiple === true ? void 0 : props.defaultValue;
89
+ const singleOnValueChange = props.multiple === true ? void 0 : props.onValueChange;
90
+ const multiValueProp = props.multiple === true ? props.value : void 0;
91
+ const multiDefaultValue = props.multiple === true ? props.defaultValue ?? [] : [];
92
+ const multiOnValueChange = props.multiple === true ? props.onValueChange : void 0;
93
+ const [open = defaultOpen, setOpenState] = useControllableState({
94
+ value: openProp,
95
+ defaultValue: defaultOpen,
96
+ onChange: onOpenChange
97
+ });
98
+ const [query = defaultQuery, setQueryState] = useControllableState({
99
+ value: queryProp,
100
+ defaultValue: defaultQuery,
101
+ onChange: onQueryChange
102
+ });
103
+ const [singleValue = singleDefaultValue, setSingleValue] = useControllableState({
104
+ value: singleValueProp,
105
+ defaultValue: singleDefaultValue,
106
+ onChange: singleOnValueChange
107
+ });
108
+ const [multiValue = multiDefaultValue, setMultiValue] = useControllableState({
109
+ value: multiValueProp,
110
+ defaultValue: multiDefaultValue,
111
+ onChange: multiOnValueChange
112
+ });
113
+ const triggerRef = React.useRef(null);
114
+ const inputRef = React.useRef(null);
115
+ const [contentWidth, setContentWidth] = React.useState();
116
+ const [createdOptions, setCreatedOptions] = React.useState([]);
117
+ React.useEffect(() => {
118
+ const trigger = triggerRef.current;
119
+ if (!trigger) {
120
+ return;
121
+ }
122
+ const update = () => {
123
+ setContentWidth(trigger.offsetWidth);
124
+ };
125
+ update();
126
+ const observer = new ResizeObserver(update);
127
+ observer.observe(trigger);
128
+ return () => observer.disconnect();
129
+ }, []);
130
+ const allOptions = React.useMemo(() => {
131
+ const map = /* @__PURE__ */ new Map();
132
+ createdOptions.forEach((option) => {
133
+ map.set(option.value, option);
134
+ });
135
+ options.forEach((option) => {
136
+ map.set(option.value, option);
137
+ });
138
+ return Array.from(map.values());
139
+ }, [createdOptions, options]);
140
+ const selectedValues = React.useMemo(
141
+ () => multiple ? multiValue : singleValue ? [singleValue] : [],
142
+ [multiple, multiValue, singleValue]
143
+ );
144
+ const normalizedQuery = query.trim().toLowerCase();
145
+ const filteredOptions = React.useMemo(() => {
146
+ if (!normalizedQuery) {
147
+ return allOptions;
148
+ }
149
+ return allOptions.filter((option) => {
150
+ const terms = [option.label, option.value, ...option.keywords ?? []];
151
+ return terms.some((term) => term.toLowerCase().includes(normalizedQuery));
152
+ });
153
+ }, [allOptions, normalizedQuery]);
154
+ const filteredGroups = React.useMemo(() => {
155
+ const groups = /* @__PURE__ */ new Map();
156
+ filteredOptions.forEach((option) => {
157
+ const groupKey = option.group ?? "";
158
+ const existingGroup = groups.get(groupKey);
159
+ if (existingGroup) {
160
+ existingGroup.options.push(option);
161
+ return;
162
+ }
163
+ groups.set(groupKey, {
164
+ group: option.group,
165
+ options: [option]
166
+ });
167
+ });
168
+ return Array.from(groups.values());
169
+ }, [filteredOptions]);
170
+ const selectedOptions = React.useMemo(() => {
171
+ const optionMap = new Map(allOptions.map((option) => [option.value, option]));
172
+ return selectedValues.map((value) => optionMap.get(value) ?? { value, label: value });
173
+ }, [allOptions, selectedValues]);
174
+ const selectedSingleLabel = !multiple ? selectedOptions[0]?.label : void 0;
175
+ const inputValue = multiple ? query : open ? query : query || selectedSingleLabel || "";
176
+ const hasSelection = selectedValues.length > 0;
177
+ const hasQuery = query.trim().length > 0;
178
+ const hasExactOption = React.useMemo(
179
+ () => allOptions.some((option) => {
180
+ const optionValue = option.value.trim().toLowerCase();
181
+ const optionLabel = option.label.trim().toLowerCase();
182
+ return optionValue === normalizedQuery || optionLabel === normalizedQuery;
183
+ }),
184
+ [allOptions, normalizedQuery]
185
+ );
186
+ const showCreateOption = creatable && hasQuery && !hasExactOption && !loading;
187
+ const createOptionLabel = hasQuery ? createLabel(query.trim()) : null;
188
+ const setOpen = React.useCallback(
189
+ (nextOpen) => {
190
+ setOpenState(nextOpen);
191
+ if (!nextOpen) {
192
+ setQueryState("");
193
+ }
194
+ },
195
+ [setOpenState, setQueryState]
196
+ );
197
+ const setQuery = React.useCallback(
198
+ (nextQuery) => {
199
+ if (disabled) {
200
+ return;
201
+ }
202
+ if (!open) {
203
+ setOpenState(true);
204
+ }
205
+ setQueryState(nextQuery);
206
+ },
207
+ [disabled, open, setOpenState, setQueryState]
208
+ );
209
+ const removeValue = React.useCallback(
210
+ (valueToRemove) => {
211
+ if (disabled) {
212
+ return;
213
+ }
214
+ if (multiple) {
215
+ setMultiValue(selectedValues.filter((value) => value !== valueToRemove));
216
+ return;
217
+ }
218
+ if (singleValue === valueToRemove) {
219
+ setSingleValue(void 0);
220
+ }
221
+ },
222
+ [disabled, multiple, selectedValues, setMultiValue, setSingleValue, singleValue]
223
+ );
224
+ const clear = React.useCallback(() => {
225
+ if (disabled) {
226
+ return;
227
+ }
228
+ setQueryState("");
229
+ if (multiple) {
230
+ setMultiValue([]);
231
+ return;
232
+ }
233
+ setSingleValue(void 0);
234
+ }, [disabled, multiple, setMultiValue, setQueryState, setSingleValue]);
235
+ const selectOption = React.useCallback(
236
+ (option) => {
237
+ if (disabled || option.disabled) {
238
+ return;
239
+ }
240
+ if (multiple) {
241
+ const nextValues = selectedValues.includes(option.value) ? selectedValues.filter((value) => value !== option.value) : [...selectedValues, option.value];
242
+ setMultiValue(nextValues);
243
+ setQueryState("");
244
+ setOpenState(true);
245
+ inputRef.current?.focus();
246
+ return;
247
+ }
248
+ setSingleValue(option.value);
249
+ setQueryState("");
250
+ setOpenState(false);
251
+ },
252
+ [
253
+ disabled,
254
+ multiple,
255
+ selectedValues,
256
+ setMultiValue,
257
+ setOpenState,
258
+ setQueryState,
259
+ setSingleValue
260
+ ]
261
+ );
262
+ const createOption = React.useCallback(() => {
263
+ const nextValue = query.trim();
264
+ if (!nextValue || disabled) {
265
+ return;
266
+ }
267
+ const createdOption = {
268
+ value: nextValue,
269
+ label: nextValue
270
+ };
271
+ setCreatedOptions((currentOptions) => {
272
+ if (currentOptions.some((option) => option.value === nextValue)) {
273
+ return currentOptions;
274
+ }
275
+ return [...currentOptions, createdOption];
276
+ });
277
+ onCreateOption?.(nextValue);
278
+ selectOption(createdOption);
279
+ }, [disabled, onCreateOption, query, selectOption]);
280
+ const onInputKeyDown = React.useCallback(
281
+ (event) => {
282
+ if (disabled) {
283
+ return;
284
+ }
285
+ if (event.key === "Backspace" && !query && multiple && selectedValues.length > 0) {
286
+ event.preventDefault();
287
+ const lastValue = selectedValues[selectedValues.length - 1];
288
+ if (lastValue) {
289
+ removeValue(lastValue);
290
+ }
291
+ }
292
+ if (event.key === "Escape") {
293
+ event.preventDefault();
294
+ setOpen(false);
295
+ }
296
+ },
297
+ [disabled, multiple, query, removeValue, selectedValues, setOpen]
298
+ );
299
+ const contextValue = {
300
+ inputId: id ?? inputId,
301
+ listId,
302
+ open,
303
+ setOpen,
304
+ query,
305
+ setQuery,
306
+ inputValue,
307
+ multiple,
308
+ creatable,
309
+ disabled,
310
+ invalid,
311
+ loading,
312
+ placeholder,
313
+ emptyMessage,
314
+ loadingMessage,
315
+ createOptionLabel,
316
+ showCreateOption,
317
+ selectedValues,
318
+ selectedOptions,
319
+ filteredGroups,
320
+ hasSelection,
321
+ hasQuery,
322
+ triggerRef,
323
+ inputRef,
324
+ contentWidth,
325
+ clear,
326
+ removeValue,
327
+ selectOption,
328
+ createOption,
329
+ onInputKeyDown
330
+ };
331
+ return /* @__PURE__ */ jsx(ComboboxContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsx(
332
+ Command,
333
+ {
334
+ shouldFilter: false,
335
+ loop: true,
336
+ className: cn("overflow-visible rounded-none bg-transparent p-0", className),
337
+ children: /* @__PURE__ */ jsx(Popover, { open, onOpenChange: setOpen, children: /* @__PURE__ */ jsx("div", { "data-slot": "combobox", ...divProps, children: children ?? /* @__PURE__ */ jsxs(Fragment, { children: [
338
+ /* @__PURE__ */ jsxs(ComboboxTrigger, { children: [
339
+ /* @__PURE__ */ jsx(ComboboxTags, {}),
340
+ /* @__PURE__ */ jsx(ComboboxInput, {}),
341
+ /* @__PURE__ */ jsx(ComboboxClear, {})
342
+ ] }),
343
+ /* @__PURE__ */ jsx(ComboboxContent, { children: /* @__PURE__ */ jsx(ComboboxList, {}) })
344
+ ] }) }) })
345
+ }
346
+ ) });
347
+ }
348
+ function ComboboxTrigger({
349
+ className,
350
+ children,
351
+ leadingIcon = /* @__PURE__ */ jsx(SearchIcon, { className: "text-field-placeholder size-4 shrink-0" }),
352
+ ...props
353
+ }) {
354
+ const context = useComboboxContext("ComboboxTrigger");
355
+ return /* @__PURE__ */ jsx(PopoverAnchor, { asChild: true, children: /* @__PURE__ */ jsxs(
356
+ "div",
357
+ {
358
+ ref: context.triggerRef,
359
+ "data-slot": "combobox-trigger",
360
+ "aria-disabled": context.disabled || void 0,
361
+ "aria-invalid": context.invalid || void 0,
362
+ className: cn(
363
+ "border-field-border bg-field-background text-field-text focus-within:border-field-border-focus focus-within:ring-focus-ring aria-disabled:bg-field-background-disabled flex min-h-8 w-full cursor-text items-center gap-1 rounded-lg border px-2 py-1 transition-colors focus-within:ring-3 aria-disabled:cursor-not-allowed aria-disabled:opacity-50",
364
+ fieldInvalidClass,
365
+ className
366
+ ),
367
+ onMouseDown: (event) => {
368
+ if (context.disabled) {
369
+ return;
370
+ }
371
+ if (event.target instanceof HTMLElement && event.target.closest("[data-combobox-interactive]")) {
372
+ return;
373
+ }
374
+ event.preventDefault();
375
+ context.setOpen(true);
376
+ context.inputRef.current?.focus();
377
+ },
378
+ ...props,
379
+ children: [
380
+ leadingIcon,
381
+ children,
382
+ /* @__PURE__ */ jsx(ChevronDownIcon, { className: "text-field-placeholder ml-auto size-4 shrink-0" })
383
+ ]
384
+ }
385
+ ) });
386
+ }
387
+ function ComboboxInput({
388
+ className,
389
+ onFocus,
390
+ onKeyDown,
391
+ ...props
392
+ }) {
393
+ const context = useComboboxContext("ComboboxInput");
394
+ return /* @__PURE__ */ jsx(
395
+ CommandPrimitive.Input,
396
+ {
397
+ ref: context.inputRef,
398
+ id: context.inputId,
399
+ "data-slot": "combobox-input",
400
+ "aria-controls": context.listId,
401
+ "aria-expanded": context.open,
402
+ "aria-autocomplete": "list",
403
+ "aria-invalid": context.invalid || void 0,
404
+ disabled: context.disabled,
405
+ placeholder: !context.multiple && context.selectedOptions[0] && !context.open ? void 0 : context.placeholder,
406
+ value: context.inputValue,
407
+ onFocus: (event) => {
408
+ context.setOpen(true);
409
+ onFocus?.(event);
410
+ },
411
+ onValueChange: context.setQuery,
412
+ onKeyDown: (event) => {
413
+ context.onInputKeyDown(event);
414
+ onKeyDown?.(event);
415
+ },
416
+ className: cn(
417
+ "placeholder:text-field-placeholder min-w-[4ch] flex-1 bg-transparent text-sm outline-none disabled:cursor-not-allowed",
418
+ className
419
+ ),
420
+ ...props
421
+ }
422
+ );
423
+ }
424
+ function ComboboxContent({
425
+ className,
426
+ style,
427
+ children,
428
+ onOpenAutoFocus,
429
+ ...props
430
+ }) {
431
+ const context = useComboboxContext("ComboboxContent");
432
+ return /* @__PURE__ */ jsx(
433
+ PopoverContent,
434
+ {
435
+ "data-slot": "combobox-content",
436
+ align: "start",
437
+ sideOffset: 4,
438
+ className: cn("gap-0 p-1", className),
439
+ style: {
440
+ width: context.contentWidth ? `${context.contentWidth}px` : void 0,
441
+ ...style
442
+ },
443
+ onOpenAutoFocus: (event) => {
444
+ event.preventDefault();
445
+ onOpenAutoFocus?.(event);
446
+ },
447
+ ...props,
448
+ children
449
+ }
450
+ );
451
+ }
452
+ function ComboboxList({
453
+ className,
454
+ children,
455
+ ...props
456
+ }) {
457
+ const context = useComboboxContext("ComboboxList");
458
+ return /* @__PURE__ */ jsx(CommandList, { id: context.listId, className: cn("max-h-64", className), ...props, children: children ? children : context.loading ? /* @__PURE__ */ jsx(ComboboxLoading, {}) : context.filteredGroups.length > 0 ? /* @__PURE__ */ jsxs(Fragment, { children: [
459
+ context.filteredGroups.map(
460
+ (group) => group.group ? /* @__PURE__ */ jsx(ComboboxGroup, { heading: group.group, children: group.options.map((option) => /* @__PURE__ */ jsx(ComboboxItem, { option }, option.value)) }, group.group) : group.options.map((option) => /* @__PURE__ */ jsx(ComboboxItem, { option }, option.value))
461
+ ),
462
+ context.showCreateOption ? /* @__PURE__ */ jsx(
463
+ CommandItem,
464
+ {
465
+ value: `__create__${context.query}`,
466
+ onSelect: context.createOption,
467
+ className: "mt-1",
468
+ children: context.createOptionLabel
469
+ }
470
+ ) : null
471
+ ] }) : context.showCreateOption ? /* @__PURE__ */ jsx(CommandItem, { value: `__create__${context.query}`, onSelect: context.createOption, children: context.createOptionLabel }) : /* @__PURE__ */ jsx(ComboboxEmpty, {}) });
472
+ }
473
+ function ComboboxGroup({
474
+ className,
475
+ children,
476
+ ...props
477
+ }) {
478
+ return /* @__PURE__ */ jsx(CommandGroup, { className: cn("overflow-hidden", className), ...props, children });
479
+ }
480
+ function ComboboxItem({
481
+ option,
482
+ className,
483
+ children,
484
+ ...props
485
+ }) {
486
+ const context = useComboboxContext("ComboboxItem");
487
+ const isSelected = context.selectedValues.includes(option.value);
488
+ return /* @__PURE__ */ jsxs(
489
+ CommandItem,
490
+ {
491
+ "data-checked": isSelected || void 0,
492
+ value: option.value,
493
+ ...context.disabled || option.disabled ? { disabled: true } : {},
494
+ onSelect: () => context.selectOption(option),
495
+ className,
496
+ ...props,
497
+ children: [
498
+ /* @__PURE__ */ jsx("span", { className: "truncate", children: children ?? option.label }),
499
+ !isSelected ? /* @__PURE__ */ jsx(CheckIcon, { className: "ml-auto size-4 opacity-0" }) : null
500
+ ]
501
+ }
502
+ );
503
+ }
504
+ function ComboboxEmpty({ className, children, ...props }) {
505
+ const context = useComboboxContext("ComboboxEmpty");
506
+ return /* @__PURE__ */ jsx(
507
+ "div",
508
+ {
509
+ "data-slot": "combobox-empty",
510
+ className: cn("text-text-muted py-6 text-center text-sm", className),
511
+ ...props,
512
+ children: children ?? context.emptyMessage
513
+ }
514
+ );
515
+ }
516
+ function ComboboxLoading({ className, children, ...props }) {
517
+ const context = useComboboxContext("ComboboxLoading");
518
+ return /* @__PURE__ */ jsxs(
519
+ "div",
520
+ {
521
+ "data-slot": "combobox-loading",
522
+ className: cn("text-text-muted flex items-center gap-2 px-2 py-3 text-sm", className),
523
+ ...props,
524
+ children: [
525
+ /* @__PURE__ */ jsx(LoaderCircleIcon, { className: "size-4 animate-spin" }),
526
+ /* @__PURE__ */ jsx("span", { children: children ?? context.loadingMessage })
527
+ ]
528
+ }
529
+ );
530
+ }
531
+ function ComboboxTags({ className, children, ...props }) {
532
+ const context = useComboboxContext("ComboboxTags");
533
+ if (!context.multiple || context.selectedOptions.length === 0) {
534
+ return children ? /* @__PURE__ */ jsx("div", { "data-slot": "combobox-tags", className, ...props, children }) : null;
535
+ }
536
+ return /* @__PURE__ */ jsx(
537
+ "div",
538
+ {
539
+ "data-slot": "combobox-tags",
540
+ className: cn("flex flex-wrap items-center gap-1", className),
541
+ ...props,
542
+ children: children ?? context.selectedOptions.map((option) => /* @__PURE__ */ jsx(ComboboxTag, { option }, option.value))
543
+ }
544
+ );
545
+ }
546
+ function ComboboxTag({
547
+ option,
548
+ className,
549
+ children,
550
+ ...props
551
+ }) {
552
+ const context = useComboboxContext("ComboboxTag");
553
+ return /* @__PURE__ */ jsxs(Badge, { variant: "normal", className: cn("gap-1 pr-1", className), ...props, children: [
554
+ /* @__PURE__ */ jsx("span", { className: "truncate", children: children ?? option.label }),
555
+ /* @__PURE__ */ jsx(
556
+ "button",
557
+ {
558
+ type: "button",
559
+ "data-combobox-interactive": true,
560
+ className: "hover:bg-background-modifier-hover rounded-full p-0.5 transition-colors",
561
+ onMouseDown: (event) => event.preventDefault(),
562
+ onClick: () => context.removeValue(option.value),
563
+ "aria-label": `Remove ${option.label}`,
564
+ children: /* @__PURE__ */ jsx(XIcon, { className: "size-3" })
565
+ }
566
+ )
567
+ ] });
568
+ }
569
+ function ComboboxClear({
570
+ className,
571
+ children,
572
+ ...props
573
+ }) {
574
+ const context = useComboboxContext("ComboboxClear");
575
+ if (!context.hasSelection && !context.hasQuery) {
576
+ return null;
577
+ }
578
+ return /* @__PURE__ */ jsx(
579
+ "button",
580
+ {
581
+ type: "button",
582
+ "data-slot": "combobox-clear",
583
+ "data-combobox-interactive": true,
584
+ className: cn(
585
+ "text-field-placeholder hover:bg-background-modifier-hover hover:text-text-normal ml-1 inline-flex size-5 shrink-0 items-center justify-center rounded-full transition-colors",
586
+ className
587
+ ),
588
+ onMouseDown: (event) => event.preventDefault(),
589
+ onClick: context.clear,
590
+ "aria-label": "Clear selection",
591
+ ...props,
592
+ children: children ?? /* @__PURE__ */ jsx(XIcon, { className: "size-3.5" })
593
+ }
594
+ );
595
+ }
596
+ export {
597
+ Combobox,
598
+ ComboboxClear,
599
+ ComboboxContent,
600
+ ComboboxEmpty,
601
+ ComboboxGroup,
602
+ ComboboxInput,
603
+ ComboboxItem,
604
+ ComboboxList,
605
+ ComboboxLoading,
606
+ ComboboxTag,
607
+ ComboboxTags,
608
+ ComboboxTrigger
609
+ };
610
+ //# sourceMappingURL=combobox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/components/combobox.tsx"],"sourcesContent":["\"use client\"\n\nimport * as React from \"react\"\n\nimport { Command as CommandPrimitive } from \"cmdk\"\nimport { CheckIcon, ChevronDownIcon, LoaderCircleIcon, SearchIcon, XIcon } from \"lucide-react\"\n\nimport { Badge } from \"@hyunsdev/ui/components/badge\"\nimport {\n Command as CommandRoot,\n CommandGroup as CommandGroupPrimitive,\n CommandItem as CommandItemPrimitive,\n CommandList as CommandListPrimitive,\n} from \"@hyunsdev/ui/components/command\"\nimport { Popover, PopoverAnchor, PopoverContent } from \"@hyunsdev/ui/components/popover\"\nimport { cn } from \"@hyunsdev/ui/lib/utils\"\n\nimport { fieldInvalidClass } from \"./_styles\"\n\nexport type ComboboxOption = {\n value: string\n label: string\n keywords?: readonly string[]\n disabled?: boolean\n group?: string | undefined\n}\n\ntype ComboboxSharedProps = {\n options: readonly ComboboxOption[]\n query?: string | undefined\n defaultQuery?: string | undefined\n onQueryChange?: (query: string) => void\n open?: boolean | undefined\n defaultOpen?: boolean | undefined\n onOpenChange?: (open: boolean) => void\n creatable?: boolean\n loading?: boolean\n disabled?: boolean\n invalid?: boolean\n placeholder?: string\n emptyMessage?: React.ReactNode\n loadingMessage?: React.ReactNode\n createLabel?: (query: string) => React.ReactNode\n onCreateOption?: (query: string) => void\n id?: string\n className?: string\n children?: React.ReactNode\n}\n\ntype SingleComboboxProps = ComboboxSharedProps & {\n multiple?: false\n value?: string | undefined\n defaultValue?: string | undefined\n onValueChange?: (value: string | undefined) => void\n}\n\ntype MultiComboboxProps = ComboboxSharedProps & {\n multiple: true\n value?: string[] | undefined\n defaultValue?: string[] | undefined\n onValueChange?: (value: string[]) => void\n}\n\nexport type ComboboxProps = SingleComboboxProps | MultiComboboxProps\n\ntype ComboboxContextValue = {\n inputId: string\n listId: string\n open: boolean\n setOpen: (open: boolean) => void\n query: string\n setQuery: (query: string) => void\n inputValue: string\n multiple: boolean\n creatable: boolean\n disabled: boolean\n invalid: boolean\n loading: boolean\n placeholder?: string\n emptyMessage: React.ReactNode\n loadingMessage: React.ReactNode\n createOptionLabel: React.ReactNode\n showCreateOption: boolean\n selectedValues: string[]\n selectedOptions: ComboboxOption[]\n filteredGroups: Array<{ group?: string | undefined; options: ComboboxOption[] }>\n hasSelection: boolean\n hasQuery: boolean\n triggerRef: React.RefObject<HTMLDivElement | null>\n inputRef: React.RefObject<HTMLInputElement | null>\n contentWidth?: number | undefined\n clear: () => void\n removeValue: (value: string) => void\n selectOption: (option: ComboboxOption) => void\n createOption: () => void\n onInputKeyDown: (event: React.KeyboardEvent<HTMLInputElement>) => void\n}\n\nconst ComboboxContext = React.createContext<ComboboxContextValue | null>(null)\n\nfunction useControllableState<T>({\n value,\n defaultValue,\n onChange,\n}: {\n value: T | undefined\n defaultValue: T\n onChange?: ((value: T) => void) | undefined\n}) {\n const [internalValue, setInternalValue] = React.useState(defaultValue)\n const isControlled = value !== undefined\n const currentValue = isControlled ? value : internalValue\n\n const setValue = React.useCallback(\n (nextValue: T) => {\n if (!isControlled) {\n setInternalValue(nextValue)\n }\n\n onChange?.(nextValue)\n },\n [isControlled, onChange],\n )\n\n return [currentValue, setValue] as const\n}\n\nfunction useComboboxContext(componentName: string) {\n const context = React.useContext(ComboboxContext)\n\n if (!context) {\n throw new Error(`${componentName} must be used within <Combobox>.`)\n }\n\n return context\n}\n\nfunction Combobox(props: ComboboxProps & Omit<React.ComponentProps<\"div\">, keyof ComboboxProps>) {\n const {\n options,\n query: queryProp,\n defaultQuery = \"\",\n onQueryChange,\n open: openProp,\n defaultOpen = false,\n onOpenChange,\n creatable = false,\n loading = false,\n disabled = false,\n invalid = false,\n placeholder = \"Search…\",\n emptyMessage = \"No results found.\",\n loadingMessage = \"Loading…\",\n createLabel = (query) => `Create \"${query}\"`,\n onCreateOption,\n id,\n className,\n children,\n multiple: multipleProp,\n ...divProps\n } = props\n const inputId = React.useId()\n const listId = React.useId()\n const multiple = multipleProp === true\n const singleValueProp = props.multiple === true ? undefined : props.value\n const singleDefaultValue = props.multiple === true ? undefined : props.defaultValue\n const singleOnValueChange = props.multiple === true ? undefined : props.onValueChange\n const multiValueProp = props.multiple === true ? props.value : undefined\n const multiDefaultValue = props.multiple === true ? (props.defaultValue ?? []) : []\n const multiOnValueChange = props.multiple === true ? props.onValueChange : undefined\n const [open = defaultOpen, setOpenState] = useControllableState<boolean>({\n value: openProp,\n defaultValue: defaultOpen,\n onChange: onOpenChange,\n })\n const [query = defaultQuery, setQueryState] = useControllableState<string>({\n value: queryProp,\n defaultValue: defaultQuery,\n onChange: onQueryChange,\n })\n\n const [singleValue = singleDefaultValue, setSingleValue] = useControllableState<\n string | undefined\n >({\n value: singleValueProp,\n defaultValue: singleDefaultValue,\n onChange: singleOnValueChange,\n })\n const [multiValue = multiDefaultValue, setMultiValue] = useControllableState<string[]>({\n value: multiValueProp,\n defaultValue: multiDefaultValue,\n onChange: multiOnValueChange,\n })\n\n const triggerRef = React.useRef<HTMLDivElement>(null)\n const inputRef = React.useRef<HTMLInputElement>(null)\n const [contentWidth, setContentWidth] = React.useState<number>()\n const [createdOptions, setCreatedOptions] = React.useState<ComboboxOption[]>([])\n\n React.useEffect(() => {\n const trigger = triggerRef.current\n\n if (!trigger) {\n return\n }\n\n const update = () => {\n setContentWidth(trigger.offsetWidth)\n }\n\n update()\n\n const observer = new ResizeObserver(update)\n observer.observe(trigger)\n\n return () => observer.disconnect()\n }, [])\n\n const allOptions = React.useMemo(() => {\n const map = new Map<string, ComboboxOption>()\n\n createdOptions.forEach((option) => {\n map.set(option.value, option)\n })\n\n options.forEach((option) => {\n map.set(option.value, option)\n })\n\n return Array.from(map.values())\n }, [createdOptions, options])\n\n const selectedValues = React.useMemo(\n () => (multiple ? multiValue : singleValue ? [singleValue] : []),\n [multiple, multiValue, singleValue],\n )\n const normalizedQuery = query.trim().toLowerCase()\n const filteredOptions = React.useMemo(() => {\n if (!normalizedQuery) {\n return allOptions\n }\n\n return allOptions.filter((option) => {\n const terms = [option.label, option.value, ...(option.keywords ?? [])]\n\n return terms.some((term) => term.toLowerCase().includes(normalizedQuery))\n })\n }, [allOptions, normalizedQuery])\n\n const filteredGroups = React.useMemo(() => {\n const groups = new Map<string, { group?: string | undefined; options: ComboboxOption[] }>()\n\n filteredOptions.forEach((option) => {\n const groupKey = option.group ?? \"\"\n const existingGroup = groups.get(groupKey)\n\n if (existingGroup) {\n existingGroup.options.push(option)\n return\n }\n\n groups.set(groupKey, {\n group: option.group,\n options: [option],\n })\n })\n\n return Array.from(groups.values())\n }, [filteredOptions])\n\n const selectedOptions = React.useMemo(() => {\n const optionMap = new Map(allOptions.map((option) => [option.value, option] as const))\n\n return selectedValues.map((value) => optionMap.get(value) ?? { value, label: value })\n }, [allOptions, selectedValues])\n\n const selectedSingleLabel = !multiple ? selectedOptions[0]?.label : undefined\n const inputValue = multiple ? query : open ? query : query || selectedSingleLabel || \"\"\n const hasSelection = selectedValues.length > 0\n const hasQuery = query.trim().length > 0\n\n const hasExactOption = React.useMemo(\n () =>\n allOptions.some((option) => {\n const optionValue = option.value.trim().toLowerCase()\n const optionLabel = option.label.trim().toLowerCase()\n\n return optionValue === normalizedQuery || optionLabel === normalizedQuery\n }),\n [allOptions, normalizedQuery],\n )\n\n const showCreateOption = creatable && hasQuery && !hasExactOption && !loading\n const createOptionLabel = hasQuery ? createLabel(query.trim()) : null\n\n const setOpen = React.useCallback(\n (nextOpen: boolean) => {\n setOpenState(nextOpen)\n\n if (!nextOpen) {\n setQueryState(\"\")\n }\n },\n [setOpenState, setQueryState],\n )\n\n const setQuery = React.useCallback(\n (nextQuery: string) => {\n if (disabled) {\n return\n }\n\n if (!open) {\n setOpenState(true)\n }\n\n setQueryState(nextQuery)\n },\n [disabled, open, setOpenState, setQueryState],\n )\n\n const removeValue = React.useCallback(\n (valueToRemove: string) => {\n if (disabled) {\n return\n }\n\n if (multiple) {\n setMultiValue(selectedValues.filter((value) => value !== valueToRemove))\n return\n }\n\n if (singleValue === valueToRemove) {\n setSingleValue(undefined)\n }\n },\n [disabled, multiple, selectedValues, setMultiValue, setSingleValue, singleValue],\n )\n\n const clear = React.useCallback(() => {\n if (disabled) {\n return\n }\n\n setQueryState(\"\")\n\n if (multiple) {\n setMultiValue([])\n return\n }\n\n setSingleValue(undefined)\n }, [disabled, multiple, setMultiValue, setQueryState, setSingleValue])\n\n const selectOption = React.useCallback(\n (option: ComboboxOption) => {\n if (disabled || option.disabled) {\n return\n }\n\n if (multiple) {\n const nextValues = selectedValues.includes(option.value)\n ? selectedValues.filter((value) => value !== option.value)\n : [...selectedValues, option.value]\n\n setMultiValue(nextValues)\n setQueryState(\"\")\n setOpenState(true)\n inputRef.current?.focus()\n return\n }\n\n setSingleValue(option.value)\n setQueryState(\"\")\n setOpenState(false)\n },\n [\n disabled,\n multiple,\n selectedValues,\n setMultiValue,\n setOpenState,\n setQueryState,\n setSingleValue,\n ],\n )\n\n const createOption = React.useCallback(() => {\n const nextValue = query.trim()\n\n if (!nextValue || disabled) {\n return\n }\n\n const createdOption: ComboboxOption = {\n value: nextValue,\n label: nextValue,\n }\n\n setCreatedOptions((currentOptions) => {\n if (currentOptions.some((option) => option.value === nextValue)) {\n return currentOptions\n }\n\n return [...currentOptions, createdOption]\n })\n\n onCreateOption?.(nextValue)\n selectOption(createdOption)\n }, [disabled, onCreateOption, query, selectOption])\n\n const onInputKeyDown = React.useCallback(\n (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (disabled) {\n return\n }\n\n if (event.key === \"Backspace\" && !query && multiple && selectedValues.length > 0) {\n event.preventDefault()\n const lastValue = selectedValues[selectedValues.length - 1]\n\n if (lastValue) {\n removeValue(lastValue)\n }\n }\n\n if (event.key === \"Escape\") {\n event.preventDefault()\n setOpen(false)\n }\n },\n [disabled, multiple, query, removeValue, selectedValues, setOpen],\n )\n\n const contextValue: ComboboxContextValue = {\n inputId: id ?? inputId,\n listId,\n open,\n setOpen,\n query,\n setQuery,\n inputValue,\n multiple,\n creatable,\n disabled,\n invalid,\n loading,\n placeholder,\n emptyMessage,\n loadingMessage,\n createOptionLabel,\n showCreateOption,\n selectedValues,\n selectedOptions,\n filteredGroups,\n hasSelection,\n hasQuery,\n triggerRef,\n inputRef,\n contentWidth,\n clear,\n removeValue,\n selectOption,\n createOption,\n onInputKeyDown,\n }\n\n return (\n <ComboboxContext.Provider value={contextValue}>\n <CommandRoot\n shouldFilter={false}\n loop\n className={cn(\"overflow-visible rounded-none bg-transparent p-0\", className)}\n >\n <Popover open={open} onOpenChange={setOpen}>\n <div data-slot=\"combobox\" {...divProps}>\n {children ?? (\n <>\n <ComboboxTrigger>\n <ComboboxTags />\n <ComboboxInput />\n <ComboboxClear />\n </ComboboxTrigger>\n <ComboboxContent>\n <ComboboxList />\n </ComboboxContent>\n </>\n )}\n </div>\n </Popover>\n </CommandRoot>\n </ComboboxContext.Provider>\n )\n}\n\nfunction ComboboxTrigger({\n className,\n children,\n leadingIcon = <SearchIcon className=\"text-field-placeholder size-4 shrink-0\" />,\n ...props\n}: React.ComponentProps<\"div\"> & { leadingIcon?: React.ReactNode }) {\n const context = useComboboxContext(\"ComboboxTrigger\")\n\n return (\n <PopoverAnchor asChild>\n <div\n ref={context.triggerRef}\n data-slot=\"combobox-trigger\"\n aria-disabled={context.disabled || undefined}\n aria-invalid={context.invalid || undefined}\n className={cn(\n \"border-field-border bg-field-background text-field-text focus-within:border-field-border-focus focus-within:ring-focus-ring aria-disabled:bg-field-background-disabled flex min-h-8 w-full cursor-text items-center gap-1 rounded-lg border px-2 py-1 transition-colors focus-within:ring-3 aria-disabled:cursor-not-allowed aria-disabled:opacity-50\",\n fieldInvalidClass,\n className,\n )}\n onMouseDown={(event) => {\n if (context.disabled) {\n return\n }\n\n if (\n event.target instanceof HTMLElement &&\n event.target.closest(\"[data-combobox-interactive]\")\n ) {\n return\n }\n\n event.preventDefault()\n context.setOpen(true)\n context.inputRef.current?.focus()\n }}\n {...props}\n >\n {leadingIcon}\n {children}\n <ChevronDownIcon className=\"text-field-placeholder ml-auto size-4 shrink-0\" />\n </div>\n </PopoverAnchor>\n )\n}\n\nfunction ComboboxInput({\n className,\n onFocus,\n onKeyDown,\n ...props\n}: Omit<\n React.ComponentProps<typeof CommandPrimitive.Input>,\n \"value\" | \"onValueChange\" | \"disabled\" | \"placeholder\"\n>) {\n const context = useComboboxContext(\"ComboboxInput\")\n\n return (\n <CommandPrimitive.Input\n ref={context.inputRef}\n id={context.inputId}\n data-slot=\"combobox-input\"\n aria-controls={context.listId}\n aria-expanded={context.open}\n aria-autocomplete=\"list\"\n aria-invalid={context.invalid || undefined}\n disabled={context.disabled}\n placeholder={\n !context.multiple && context.selectedOptions[0] && !context.open\n ? undefined\n : context.placeholder\n }\n value={context.inputValue}\n onFocus={(event) => {\n context.setOpen(true)\n onFocus?.(event)\n }}\n onValueChange={context.setQuery}\n onKeyDown={(event) => {\n context.onInputKeyDown(event)\n onKeyDown?.(event)\n }}\n className={cn(\n \"placeholder:text-field-placeholder min-w-[4ch] flex-1 bg-transparent text-sm outline-none disabled:cursor-not-allowed\",\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction ComboboxContent({\n className,\n style,\n children,\n onOpenAutoFocus,\n ...props\n}: React.ComponentProps<typeof PopoverContent>) {\n const context = useComboboxContext(\"ComboboxContent\")\n\n return (\n <PopoverContent\n data-slot=\"combobox-content\"\n align=\"start\"\n sideOffset={4}\n className={cn(\"gap-0 p-1\", className)}\n style={{\n width: context.contentWidth ? `${context.contentWidth}px` : undefined,\n ...style,\n }}\n onOpenAutoFocus={(event) => {\n event.preventDefault()\n onOpenAutoFocus?.(event)\n }}\n {...props}\n >\n {children}\n </PopoverContent>\n )\n}\n\nfunction ComboboxList({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof CommandListPrimitive>) {\n const context = useComboboxContext(\"ComboboxList\")\n\n return (\n <CommandListPrimitive id={context.listId} className={cn(\"max-h-64\", className)} {...props}>\n {children ? (\n children\n ) : context.loading ? (\n <ComboboxLoading />\n ) : context.filteredGroups.length > 0 ? (\n <>\n {context.filteredGroups.map((group) =>\n group.group ? (\n <ComboboxGroup key={group.group} heading={group.group}>\n {group.options.map((option) => (\n <ComboboxItem key={option.value} option={option} />\n ))}\n </ComboboxGroup>\n ) : (\n group.options.map((option) => <ComboboxItem key={option.value} option={option} />)\n ),\n )}\n {context.showCreateOption ? (\n <CommandItemPrimitive\n value={`__create__${context.query}`}\n onSelect={context.createOption}\n className=\"mt-1\"\n >\n {context.createOptionLabel}\n </CommandItemPrimitive>\n ) : null}\n </>\n ) : context.showCreateOption ? (\n <CommandItemPrimitive value={`__create__${context.query}`} onSelect={context.createOption}>\n {context.createOptionLabel}\n </CommandItemPrimitive>\n ) : (\n <ComboboxEmpty />\n )}\n </CommandListPrimitive>\n )\n}\n\nfunction ComboboxGroup({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof CommandGroupPrimitive>) {\n return (\n <CommandGroupPrimitive className={cn(\"overflow-hidden\", className)} {...props}>\n {children}\n </CommandGroupPrimitive>\n )\n}\n\nfunction ComboboxItem({\n option,\n className,\n children,\n ...props\n}: Omit<React.ComponentProps<typeof CommandItemPrimitive>, \"value\" | \"onSelect\"> & {\n option: ComboboxOption\n}) {\n const context = useComboboxContext(\"ComboboxItem\")\n const isSelected = context.selectedValues.includes(option.value)\n\n return (\n <CommandItemPrimitive\n data-checked={isSelected || undefined}\n value={option.value}\n {...(context.disabled || option.disabled ? { disabled: true } : {})}\n onSelect={() => context.selectOption(option)}\n className={className}\n {...props}\n >\n <span className=\"truncate\">{children ?? option.label}</span>\n {!isSelected ? <CheckIcon className=\"ml-auto size-4 opacity-0\" /> : null}\n </CommandItemPrimitive>\n )\n}\n\nfunction ComboboxEmpty({ className, children, ...props }: React.ComponentProps<\"div\">) {\n const context = useComboboxContext(\"ComboboxEmpty\")\n\n return (\n <div\n data-slot=\"combobox-empty\"\n className={cn(\"text-text-muted py-6 text-center text-sm\", className)}\n {...props}\n >\n {children ?? context.emptyMessage}\n </div>\n )\n}\n\nfunction ComboboxLoading({ className, children, ...props }: React.ComponentProps<\"div\">) {\n const context = useComboboxContext(\"ComboboxLoading\")\n\n return (\n <div\n data-slot=\"combobox-loading\"\n className={cn(\"text-text-muted flex items-center gap-2 px-2 py-3 text-sm\", className)}\n {...props}\n >\n <LoaderCircleIcon className=\"size-4 animate-spin\" />\n <span>{children ?? context.loadingMessage}</span>\n </div>\n )\n}\n\nfunction ComboboxTags({ className, children, ...props }: React.ComponentProps<\"div\">) {\n const context = useComboboxContext(\"ComboboxTags\")\n\n if (!context.multiple || context.selectedOptions.length === 0) {\n return children ? (\n <div data-slot=\"combobox-tags\" className={className} {...props}>\n {children}\n </div>\n ) : null\n }\n\n return (\n <div\n data-slot=\"combobox-tags\"\n className={cn(\"flex flex-wrap items-center gap-1\", className)}\n {...props}\n >\n {children ??\n context.selectedOptions.map((option) => <ComboboxTag key={option.value} option={option} />)}\n </div>\n )\n}\n\nfunction ComboboxTag({\n option,\n className,\n children,\n ...props\n}: React.ComponentProps<typeof Badge> & {\n option: ComboboxOption\n}) {\n const context = useComboboxContext(\"ComboboxTag\")\n\n return (\n <Badge variant=\"normal\" className={cn(\"gap-1 pr-1\", className)} {...props}>\n <span className=\"truncate\">{children ?? option.label}</span>\n <button\n type=\"button\"\n data-combobox-interactive\n className=\"hover:bg-background-modifier-hover rounded-full p-0.5 transition-colors\"\n onMouseDown={(event) => event.preventDefault()}\n onClick={() => context.removeValue(option.value)}\n aria-label={`Remove ${option.label}`}\n >\n <XIcon className=\"size-3\" />\n </button>\n </Badge>\n )\n}\n\nfunction ComboboxClear({\n className,\n children,\n ...props\n}: Omit<React.ComponentProps<\"button\">, \"children\"> & { children?: React.ReactNode }) {\n const context = useComboboxContext(\"ComboboxClear\")\n\n if (!context.hasSelection && !context.hasQuery) {\n return null\n }\n\n return (\n <button\n type=\"button\"\n data-slot=\"combobox-clear\"\n data-combobox-interactive\n className={cn(\n \"text-field-placeholder hover:bg-background-modifier-hover hover:text-text-normal ml-1 inline-flex size-5 shrink-0 items-center justify-center rounded-full transition-colors\",\n className,\n )}\n onMouseDown={(event) => event.preventDefault()}\n onClick={context.clear}\n aria-label=\"Clear selection\"\n {...props}\n >\n {children ?? <XIcon className=\"size-3.5\" />}\n </button>\n )\n}\n\nexport {\n Combobox,\n ComboboxTrigger,\n ComboboxInput,\n ComboboxContent,\n ComboboxList,\n ComboboxGroup,\n ComboboxItem,\n ComboboxEmpty,\n ComboboxLoading,\n ComboboxTag,\n ComboboxTags,\n ComboboxClear,\n}\n"],"mappings":"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","names":["query"]}