@mdigital_ui/ui 0.3.8 → 0.3.9

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 (299) hide show
  1. package/dist/accordion/index.d.ts.map +1 -1
  2. package/dist/accordion/index.js +2 -2
  3. package/dist/badge/index.d.ts +1 -1
  4. package/dist/badge/index.d.ts.map +1 -1
  5. package/dist/badge/index.js +2 -2
  6. package/dist/breadcrumbs/index.js +5 -4
  7. package/dist/button/index.d.ts +9 -0
  8. package/dist/button/index.d.ts.map +1 -1
  9. package/dist/button/index.js +4 -3
  10. package/dist/button/types.d.ts +18 -0
  11. package/dist/button/types.d.ts.map +1 -1
  12. package/dist/card/index.d.ts +14 -14
  13. package/dist/card/index.d.ts.map +1 -1
  14. package/dist/card/index.js +2 -2
  15. package/dist/carousel/index.d.ts +1 -1
  16. package/dist/carousel/index.d.ts.map +1 -1
  17. package/dist/carousel/index.js +1 -1
  18. package/dist/cascader/index.js +2 -2
  19. package/dist/checkbox/index.js +2 -2
  20. package/dist/{chunk-7P3Q6H2V.js → chunk-2F5MMMVP.js} +4 -4
  21. package/dist/{chunk-7P3Q6H2V.js.map → chunk-2F5MMMVP.js.map} +1 -1
  22. package/dist/chunk-2TLOWZE4.js +689 -0
  23. package/dist/chunk-2TLOWZE4.js.map +1 -0
  24. package/dist/{chunk-ITCXCSUS.js → chunk-3BZE6BBJ.js} +9 -4
  25. package/dist/chunk-3BZE6BBJ.js.map +1 -0
  26. package/dist/{chunk-6QZFWSN7.js → chunk-3PWILVOE.js} +13 -6
  27. package/dist/chunk-3PWILVOE.js.map +1 -0
  28. package/dist/{chunk-M3AALH7G.js → chunk-4F7U5UPY.js} +16 -8
  29. package/dist/chunk-4F7U5UPY.js.map +1 -0
  30. package/dist/{chunk-QKSDVYKF.js → chunk-4FFVNUTK.js} +5 -8
  31. package/dist/chunk-4FFVNUTK.js.map +1 -0
  32. package/dist/{chunk-OV6K6GML.js → chunk-5QQH5LYU.js} +8 -8
  33. package/dist/chunk-5QQH5LYU.js.map +1 -0
  34. package/dist/{chunk-FCODTRKL.js → chunk-6BAP6QUT.js} +3 -3
  35. package/dist/{chunk-FCODTRKL.js.map → chunk-6BAP6QUT.js.map} +1 -1
  36. package/dist/chunk-6G3BMY4N.js +349 -0
  37. package/dist/chunk-6G3BMY4N.js.map +1 -0
  38. package/dist/{chunk-WMTEAMPB.js → chunk-6LYRMQOI.js} +83 -9
  39. package/dist/chunk-6LYRMQOI.js.map +1 -0
  40. package/dist/{chunk-DUNER5Q3.js → chunk-6YOOKE6C.js} +11 -6
  41. package/dist/chunk-6YOOKE6C.js.map +1 -0
  42. package/dist/chunk-764UKE6X.js +359 -0
  43. package/dist/chunk-764UKE6X.js.map +1 -0
  44. package/dist/{chunk-EGNF7BRT.js → chunk-C4SHFLFR.js} +3 -3
  45. package/dist/{chunk-EGNF7BRT.js.map → chunk-C4SHFLFR.js.map} +1 -1
  46. package/dist/{chunk-ZQTJBYKO.js → chunk-C5IGZLIT.js} +3 -3
  47. package/dist/{chunk-ZQTJBYKO.js.map → chunk-C5IGZLIT.js.map} +1 -1
  48. package/dist/{chunk-SX5UNM6C.js → chunk-CH3YMDCF.js} +6 -6
  49. package/dist/chunk-CH3YMDCF.js.map +1 -0
  50. package/dist/{chunk-I75ZSXD6.js → chunk-DUIL5BYS.js} +3 -3
  51. package/dist/{chunk-I75ZSXD6.js.map → chunk-DUIL5BYS.js.map} +1 -1
  52. package/dist/{chunk-ZPVBIQ2R.js → chunk-EHWXPH76.js} +3 -3
  53. package/dist/chunk-EHWXPH76.js.map +1 -0
  54. package/dist/{chunk-ZSS6E4T2.js → chunk-EPE3OODP.js} +31 -7
  55. package/dist/chunk-EPE3OODP.js.map +1 -0
  56. package/dist/{chunk-E222IQHF.js → chunk-ERRZ2CSG.js} +16 -8
  57. package/dist/chunk-ERRZ2CSG.js.map +1 -0
  58. package/dist/{chunk-GVEEUHM2.js → chunk-FAD45WRP.js} +7 -6
  59. package/dist/chunk-FAD45WRP.js.map +1 -0
  60. package/dist/{chunk-YPHVSPWM.js → chunk-FZSCLZF6.js} +5 -5
  61. package/dist/{chunk-YPHVSPWM.js.map → chunk-FZSCLZF6.js.map} +1 -1
  62. package/dist/{chunk-S2DZXTRN.js → chunk-GJPZOMFE.js} +8 -8
  63. package/dist/{chunk-S2DZXTRN.js.map → chunk-GJPZOMFE.js.map} +1 -1
  64. package/dist/{chunk-SB3JGUGE.js → chunk-GOLARX5K.js} +3 -3
  65. package/dist/{chunk-SB3JGUGE.js.map → chunk-GOLARX5K.js.map} +1 -1
  66. package/dist/{chunk-OR4GO5XL.js → chunk-GVVP5TZM.js} +71 -233
  67. package/dist/chunk-GVVP5TZM.js.map +1 -0
  68. package/dist/{chunk-WIR52JXZ.js → chunk-H6G4BUPA.js} +98 -237
  69. package/dist/chunk-H6G4BUPA.js.map +1 -0
  70. package/dist/{chunk-MOQDO4XZ.js → chunk-HCOTO5WX.js} +3 -3
  71. package/dist/{chunk-MOQDO4XZ.js.map → chunk-HCOTO5WX.js.map} +1 -1
  72. package/dist/chunk-HECAAILV.js +94 -0
  73. package/dist/chunk-HECAAILV.js.map +1 -0
  74. package/dist/{chunk-OKCKLIFP.js → chunk-HK3NJMSY.js} +8 -6
  75. package/dist/chunk-HK3NJMSY.js.map +1 -0
  76. package/dist/{chunk-GGDDE7LC.js → chunk-HQLHE5RX.js} +3 -9
  77. package/dist/chunk-HQLHE5RX.js.map +1 -0
  78. package/dist/{chunk-56BHCAPI.js → chunk-I32ZQUYY.js} +6 -6
  79. package/dist/chunk-I32ZQUYY.js.map +1 -0
  80. package/dist/{chunk-D53OQERO.js → chunk-JWTWPZ32.js} +14 -6
  81. package/dist/chunk-JWTWPZ32.js.map +1 -0
  82. package/dist/{chunk-KYDQJSSW.js → chunk-KH577UDI.js} +46 -82
  83. package/dist/chunk-KH577UDI.js.map +1 -0
  84. package/dist/{chunk-XOIX5WIL.js → chunk-KJTMZJ7V.js} +6 -6
  85. package/dist/{chunk-XOIX5WIL.js.map → chunk-KJTMZJ7V.js.map} +1 -1
  86. package/dist/{chunk-XHDUO3UW.js → chunk-L5UYN5LX.js} +3 -3
  87. package/dist/{chunk-XHDUO3UW.js.map → chunk-L5UYN5LX.js.map} +1 -1
  88. package/dist/{chunk-DRCT6VZ7.js → chunk-N2WHJ3FI.js} +3 -3
  89. package/dist/{chunk-DRCT6VZ7.js.map → chunk-N2WHJ3FI.js.map} +1 -1
  90. package/dist/{chunk-ZHPYJTWP.js → chunk-O3V3BTIJ.js} +16 -6
  91. package/dist/chunk-O3V3BTIJ.js.map +1 -0
  92. package/dist/chunk-OFUPJH35.js +74 -0
  93. package/dist/chunk-OFUPJH35.js.map +1 -0
  94. package/dist/{chunk-6YVT3AL2.js → chunk-OLTQAMV2.js} +4 -5
  95. package/dist/chunk-OLTQAMV2.js.map +1 -0
  96. package/dist/chunk-ONGJXAYQ.js +144 -0
  97. package/dist/chunk-ONGJXAYQ.js.map +1 -0
  98. package/dist/{chunk-KJRKPYYZ.js → chunk-OQFYIKWR.js} +27 -25
  99. package/dist/chunk-OQFYIKWR.js.map +1 -0
  100. package/dist/{chunk-X5XIBIEF.js → chunk-PMA4VCAH.js} +3 -3
  101. package/dist/{chunk-X5XIBIEF.js.map → chunk-PMA4VCAH.js.map} +1 -1
  102. package/dist/chunk-POLVJ36Y.js +210 -0
  103. package/dist/chunk-POLVJ36Y.js.map +1 -0
  104. package/dist/{chunk-LK4EPTNG.js → chunk-POXI7JJ4.js} +27 -121
  105. package/dist/chunk-POXI7JJ4.js.map +1 -0
  106. package/dist/{chunk-L76WWJGR.js → chunk-R3TLU26W.js} +21 -33
  107. package/dist/chunk-R3TLU26W.js.map +1 -0
  108. package/dist/chunk-RFHTC6AH.js +250 -0
  109. package/dist/chunk-RFHTC6AH.js.map +1 -0
  110. package/dist/{chunk-IAQDQN6W.js → chunk-RPWYIGD3.js} +15 -36
  111. package/dist/chunk-RPWYIGD3.js.map +1 -0
  112. package/dist/{chunk-HXPMYGSR.js → chunk-T7RWQLUB.js} +4 -10
  113. package/dist/chunk-T7RWQLUB.js.map +1 -0
  114. package/dist/chunk-WRSG7WU5.js +278 -0
  115. package/dist/chunk-WRSG7WU5.js.map +1 -0
  116. package/dist/{chunk-ZYWDJMHF.js → chunk-X3YNHX77.js} +4 -4
  117. package/dist/{chunk-ZYWDJMHF.js.map → chunk-X3YNHX77.js.map} +1 -1
  118. package/dist/chunk-Y4XAXZHB.js +42 -0
  119. package/dist/chunk-Y4XAXZHB.js.map +1 -0
  120. package/dist/{chunk-JZ5F6XDO.js → chunk-YS5AIY4A.js} +3 -3
  121. package/dist/{chunk-JZ5F6XDO.js.map → chunk-YS5AIY4A.js.map} +1 -1
  122. package/dist/chunk-ZIYA7TGX.js +141 -0
  123. package/dist/chunk-ZIYA7TGX.js.map +1 -0
  124. package/dist/{chunk-QLUGKHAA.js → chunk-ZKEDJ536.js} +4 -4
  125. package/dist/{chunk-QLUGKHAA.js.map → chunk-ZKEDJ536.js.map} +1 -1
  126. package/dist/clipboard/index.d.ts.map +1 -1
  127. package/dist/clipboard/index.js +3 -2
  128. package/dist/collapse/index.js +2 -2
  129. package/dist/command/index.js +1 -1
  130. package/dist/context-menu/index.d.ts.map +1 -1
  131. package/dist/context-menu/index.js +2 -1
  132. package/dist/date-picker/index.d.ts.map +1 -1
  133. package/dist/date-picker/index.js +3 -3
  134. package/dist/date-picker/types.d.ts +0 -2
  135. package/dist/date-picker/types.d.ts.map +1 -1
  136. package/dist/dropdown/index.d.ts.map +1 -1
  137. package/dist/dropdown/index.js +4 -3
  138. package/dist/fetching-overlay/index.d.ts +1 -1
  139. package/dist/fetching-overlay/index.d.ts.map +1 -1
  140. package/dist/fetching-overlay/index.js +3 -3
  141. package/dist/float-input/index.js +3 -3
  142. package/dist/grid/index.d.ts +1 -1
  143. package/dist/grid/index.d.ts.map +1 -1
  144. package/dist/grid/index.js +1 -1
  145. package/dist/hooks/index.d.ts +6 -0
  146. package/dist/hooks/index.d.ts.map +1 -0
  147. package/dist/hooks/useControllable.d.ts +6 -0
  148. package/dist/hooks/useControllable.d.ts.map +1 -0
  149. package/dist/hooks/useDebounce.d.ts +2 -0
  150. package/dist/hooks/useDebounce.d.ts.map +1 -0
  151. package/dist/hooks/useMediaQuery.d.ts +2 -0
  152. package/dist/hooks/useMediaQuery.d.ts.map +1 -0
  153. package/dist/hooks/useRipple.d.ts +29 -0
  154. package/dist/hooks/useRipple.d.ts.map +1 -0
  155. package/dist/hooks/useThrottle.d.ts +2 -0
  156. package/dist/hooks/useThrottle.d.ts.map +1 -0
  157. package/dist/image/index.d.ts.map +1 -1
  158. package/dist/image/index.js +1 -1
  159. package/dist/image/types.d.ts +4 -0
  160. package/dist/image/types.d.ts.map +1 -1
  161. package/dist/index.d.ts +10 -7
  162. package/dist/index.d.ts.map +1 -1
  163. package/dist/index.js +114 -56
  164. package/dist/index.js.map +1 -1
  165. package/dist/input/index.d.ts.map +1 -1
  166. package/dist/input/index.js +3 -3
  167. package/dist/input-otp/index.js +1 -1
  168. package/dist/input-password/index.js +4 -4
  169. package/dist/kbd/index.js +2 -2
  170. package/dist/link/index.d.ts +1 -1
  171. package/dist/link/index.d.ts.map +1 -1
  172. package/dist/link/index.js +1 -1
  173. package/dist/menubar/index.js +3 -3
  174. package/dist/multi-select/index.d.ts.map +1 -1
  175. package/dist/multi-select/index.js +5 -3
  176. package/dist/multi-select/utils.d.ts.map +1 -1
  177. package/dist/navigation-menu/index.js +1 -1
  178. package/dist/notification/index.js +2 -2
  179. package/dist/number-input/index.d.ts.map +1 -1
  180. package/dist/number-input/index.js +4 -3
  181. package/dist/pagination/index.d.ts.map +1 -1
  182. package/dist/pagination/index.js +2 -1
  183. package/dist/popover/index.js +2 -2
  184. package/dist/progress/index.d.ts.map +1 -1
  185. package/dist/progress/index.js +1 -1
  186. package/dist/progress/styles.d.ts +39 -0
  187. package/dist/progress/styles.d.ts.map +1 -0
  188. package/dist/radio/index.d.ts.map +1 -1
  189. package/dist/radio/index.js +2 -2
  190. package/dist/select/index.d.ts.map +1 -1
  191. package/dist/select/index.js +5 -4
  192. package/dist/shared/useSelectBase.d.ts +56 -0
  193. package/dist/shared/useSelectBase.d.ts.map +1 -0
  194. package/dist/skeleton/index.js +2 -2
  195. package/dist/slider/index.d.ts.map +1 -1
  196. package/dist/slider/index.js +1 -1
  197. package/dist/spinner/index.d.ts +1 -1
  198. package/dist/spinner/index.d.ts.map +1 -1
  199. package/dist/spinner/index.js +2 -2
  200. package/dist/stepper/index.js +1 -1
  201. package/dist/switch/index.d.ts.map +1 -1
  202. package/dist/switch/index.js +2 -2
  203. package/dist/table/index.d.ts.map +1 -1
  204. package/dist/table/index.js +10 -9
  205. package/dist/table/variants.d.ts +0 -4
  206. package/dist/table/variants.d.ts.map +1 -1
  207. package/dist/tabs/index.d.ts.map +1 -1
  208. package/dist/tabs/index.js +2 -2
  209. package/dist/tabs/types.d.ts +4 -0
  210. package/dist/tabs/types.d.ts.map +1 -1
  211. package/dist/tag/index.d.ts +1 -1
  212. package/dist/tag/index.d.ts.map +1 -1
  213. package/dist/tag/index.js +2 -2
  214. package/dist/timeline/index.d.ts.map +1 -1
  215. package/dist/timeline/index.js +1 -1
  216. package/dist/toast/index.d.ts.map +1 -1
  217. package/dist/toast/index.js +2 -2
  218. package/dist/toggle/index.d.ts.map +1 -1
  219. package/dist/toggle/index.js +2 -1
  220. package/dist/toggle-group/index.d.ts.map +1 -1
  221. package/dist/toggle-group/index.js +2 -1
  222. package/dist/tooltip/index.js +2 -2
  223. package/dist/transfer/index.d.ts +0 -1
  224. package/dist/transfer/index.d.ts.map +1 -1
  225. package/dist/transfer/index.js +3 -3
  226. package/dist/tree/index.d.ts.map +1 -1
  227. package/dist/tree/index.js +1 -1
  228. package/dist/tree-select/index.js +4 -4
  229. package/dist/upload/index.d.ts.map +1 -1
  230. package/dist/upload/index.js +2 -1
  231. package/dist/variants.d.ts +44 -163
  232. package/dist/variants.d.ts.map +1 -1
  233. package/package.json +44 -231
  234. package/styles/global.css +327 -220
  235. package/styles/themes/dark.css +57 -44
  236. package/styles/themes/light.css +3 -3
  237. package/styles/themes/presets/corporate.css +32 -30
  238. package/styles/themes/presets/minimal.css +32 -30
  239. package/styles/themes/presets/vibrant.css +38 -36
  240. package/dist/chunk-2K7MDR7K.js +0 -212
  241. package/dist/chunk-2K7MDR7K.js.map +0 -1
  242. package/dist/chunk-2SYAIIJE.js +0 -143
  243. package/dist/chunk-2SYAIIJE.js.map +0 -1
  244. package/dist/chunk-56BHCAPI.js.map +0 -1
  245. package/dist/chunk-6QZFWSN7.js.map +0 -1
  246. package/dist/chunk-6YVT3AL2.js.map +0 -1
  247. package/dist/chunk-D53OQERO.js.map +0 -1
  248. package/dist/chunk-DRL4CJMI.js +0 -147
  249. package/dist/chunk-DRL4CJMI.js.map +0 -1
  250. package/dist/chunk-DUNER5Q3.js.map +0 -1
  251. package/dist/chunk-E222IQHF.js.map +0 -1
  252. package/dist/chunk-FVTMKQUE.js +0 -67
  253. package/dist/chunk-FVTMKQUE.js.map +0 -1
  254. package/dist/chunk-GGDDE7LC.js.map +0 -1
  255. package/dist/chunk-GVEEUHM2.js.map +0 -1
  256. package/dist/chunk-HQVTIFXN.js +0 -494
  257. package/dist/chunk-HQVTIFXN.js.map +0 -1
  258. package/dist/chunk-HXPMYGSR.js.map +0 -1
  259. package/dist/chunk-IAQDQN6W.js.map +0 -1
  260. package/dist/chunk-ITCXCSUS.js.map +0 -1
  261. package/dist/chunk-KJRKPYYZ.js.map +0 -1
  262. package/dist/chunk-KYDQJSSW.js.map +0 -1
  263. package/dist/chunk-L76WWJGR.js.map +0 -1
  264. package/dist/chunk-LK4EPTNG.js.map +0 -1
  265. package/dist/chunk-M3AALH7G.js.map +0 -1
  266. package/dist/chunk-MBAZ7OW5.js +0 -607
  267. package/dist/chunk-MBAZ7OW5.js.map +0 -1
  268. package/dist/chunk-MGKFJWQU.js +0 -194
  269. package/dist/chunk-MGKFJWQU.js.map +0 -1
  270. package/dist/chunk-OKCKLIFP.js.map +0 -1
  271. package/dist/chunk-OR4GO5XL.js.map +0 -1
  272. package/dist/chunk-OV6K6GML.js.map +0 -1
  273. package/dist/chunk-PHQOHVG3.js +0 -45
  274. package/dist/chunk-PHQOHVG3.js.map +0 -1
  275. package/dist/chunk-QKSDVYKF.js.map +0 -1
  276. package/dist/chunk-SJHNFRXG.js +0 -276
  277. package/dist/chunk-SJHNFRXG.js.map +0 -1
  278. package/dist/chunk-SX5UNM6C.js.map +0 -1
  279. package/dist/chunk-T4MGK3WE.js +0 -143
  280. package/dist/chunk-T4MGK3WE.js.map +0 -1
  281. package/dist/chunk-WAPZ4QAN.js +0 -76
  282. package/dist/chunk-WAPZ4QAN.js.map +0 -1
  283. package/dist/chunk-WIR52JXZ.js.map +0 -1
  284. package/dist/chunk-WMTEAMPB.js.map +0 -1
  285. package/dist/chunk-ZHPYJTWP.js.map +0 -1
  286. package/dist/chunk-ZPVBIQ2R.js.map +0 -1
  287. package/dist/chunk-ZSS6E4T2.js.map +0 -1
  288. package/dist/form/index.d.ts +0 -31
  289. package/dist/form/index.d.ts.map +0 -1
  290. package/dist/form/index.js +0 -4
  291. package/dist/form/index.js.map +0 -1
  292. package/dist/form/types.d.ts +0 -45
  293. package/dist/form/types.d.ts.map +0 -1
  294. package/dist/ribbon/index.d.ts +0 -6
  295. package/dist/ribbon/index.d.ts.map +0 -1
  296. package/dist/ribbon/index.js +0 -4
  297. package/dist/ribbon/index.js.map +0 -1
  298. package/dist/ribbon/types.d.ts +0 -26
  299. package/dist/ribbon/types.d.ts.map +0 -1
@@ -1,8 +1,9 @@
1
- import { Popover, PopoverTrigger, PopoverContent } from './chunk-ZQTJBYKO.js';
2
- import { getValidationStatus, cn, iconSizes } from './chunk-NGYLRX6F.js';
3
- import { useVirtualizer } from '@tanstack/react-virtual';
4
- import { X, Loader2, Search, ChevronDown, ChevronUp, Check } from 'lucide-react';
5
- import React, { useId, useCallback } from 'react';
1
+ import { useSelectBase } from './chunk-WRSG7WU5.js';
2
+ import { Popover, PopoverTrigger, PopoverContent } from './chunk-C5IGZLIT.js';
3
+ import { spinner_default } from './chunk-Y4XAXZHB.js';
4
+ import { cn, iconSizes } from './chunk-NGYLRX6F.js';
5
+ import { X, Search, ChevronDown, ChevronUp, Check } from 'lucide-react';
6
+ import React from 'react';
6
7
  import { cva } from 'class-variance-authority';
7
8
  import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
8
9
 
@@ -18,10 +19,10 @@ var multiSelectTriggerVariants = cva(
18
19
  success: "border-success"
19
20
  },
20
21
  size: {
21
- xs: "h-(--select-height-xs) pl-(--select-padding-x-xs) pr-[calc(var(--select-padding-x-xs)*2)] text-xs",
22
- sm: "h-(--select-height-sm) pl-(--select-padding-x-sm) pr-[calc(var(--select-padding-x-sm)*2)] text-sm",
23
- md: "h-(--select-height-md) pl-(--select-padding-x-md) pr-[calc(var(--select-padding-x-md)*2)] text-base",
24
- lg: "h-(--select-height-lg) pl-(--select-padding-x-lg) pr-[calc(var(--select-padding-x-lg)*2)] text-lg"
22
+ xs: "h-(--select-height-xs) px-(--select-padding-x-xs) text-xs",
23
+ sm: "h-(--select-height-sm) px-(--select-padding-x-sm) text-sm",
24
+ md: "h-(--select-height-md) px-(--select-padding-x-md) text-base",
25
+ lg: "h-(--select-height-lg) px-(--select-padding-x-lg) text-lg"
25
26
  },
26
27
  fullWidth: {
27
28
  true: "w-full",
@@ -87,89 +88,11 @@ var MultiSelect = React.memo(
87
88
  ref,
88
89
  ...props
89
90
  }) => {
90
- const uniqueId = useId();
91
- const labelId = `multiselect-label-${uniqueId}`;
92
- const [isOpen, setIsOpen] = React.useState(false);
93
91
  const [internalValue, setInternalValue] = React.useState(
94
- defaultValue || []
92
+ defaultValue ?? []
95
93
  );
96
- const [parentNode, setParentNode] = React.useState(
97
- null
98
- );
99
- const [searchQuery, setSearchQuery] = React.useState("");
100
- const [highlightedIndex, setHighlightedIndex] = React.useState(-1);
101
94
  const [visibleChipsCount, setVisibleChipsCount] = React.useState(maxChipsVisible);
102
- const [showTopArrow, setShowTopArrow] = React.useState(false);
103
- const [showBottomArrow, setShowBottomArrow] = React.useState(false);
104
- const triggerRef = React.useRef(null);
105
- const inputRef = React.useRef(null);
106
- const scrollContainerRef = React.useRef(null);
107
95
  const currentValue = value !== void 0 ? value : internalValue;
108
- const { status, message: helperMessage } = getValidationStatus({
109
- error,
110
- warning,
111
- info,
112
- success,
113
- helperText
114
- });
115
- const groupedOptions = React.useMemo(() => {
116
- const groups = {};
117
- const ungrouped = [];
118
- options.forEach((option) => {
119
- if (option.group) {
120
- if (!groups[option.group]) {
121
- groups[option.group] = [];
122
- }
123
- groups[option.group].push(option);
124
- } else {
125
- ungrouped.push(option);
126
- }
127
- });
128
- return { groups, ungrouped };
129
- }, [options]);
130
- const flattenedOptions = React.useMemo(() => {
131
- const items = [];
132
- groupedOptions.ungrouped.forEach((option) => {
133
- items.push({ type: "option", data: option });
134
- });
135
- Object.entries(groupedOptions.groups).forEach(
136
- ([groupName, groupOptions]) => {
137
- items.push({ type: "group", data: groupName });
138
- groupOptions.forEach((option) => {
139
- items.push({ type: "option", data: option });
140
- });
141
- }
142
- );
143
- return items;
144
- }, [groupedOptions]);
145
- const filteredOptions = React.useMemo(() => {
146
- if (!searchQuery) return flattenedOptions;
147
- return flattenedOptions.filter((item) => {
148
- if (item.type === "group") return true;
149
- const option = item.data;
150
- return option.label.toLowerCase().includes(searchQuery.toLowerCase());
151
- });
152
- }, [flattenedOptions, searchQuery]);
153
- const shouldVirtualize = filteredOptions.length > virtualizeThreshold;
154
- const virtualizer = useVirtualizer({
155
- count: filteredOptions.length,
156
- getScrollElement: () => parentNode,
157
- estimateSize: () => 40,
158
- enabled: shouldVirtualize
159
- });
160
- const virtualizerRef = React.useRef(virtualizer);
161
- React.useEffect(() => {
162
- virtualizerRef.current = virtualizer;
163
- }, [virtualizer]);
164
- const refCallback = useCallback((node) => {
165
- if (node) {
166
- setParentNode(node);
167
- scrollContainerRef.current = node;
168
- }
169
- }, []);
170
- const selectedOptions = options.filter(
171
- (opt) => currentValue.includes(opt.value)
172
- );
173
96
  const handleSelect = React.useCallback(
174
97
  (optionValue) => {
175
98
  const newValue = currentValue.includes(optionValue) ? currentValue.filter((v) => v !== optionValue) : [...currentValue, optionValue];
@@ -181,6 +104,53 @@ var MultiSelect = React.memo(
181
104
  },
182
105
  [value, onChange, currentValue]
183
106
  );
107
+ const {
108
+ // State
109
+ isOpen,
110
+ setIsOpen,
111
+ searchQuery,
112
+ setSearchQuery: _setSearchQuery,
113
+ setHighlightedIndex,
114
+ highlightedIndex,
115
+ showTopArrow,
116
+ showBottomArrow,
117
+ // Refs
118
+ triggerRef,
119
+ inputRef,
120
+ scrollContainerRef,
121
+ // Computed
122
+ filteredOptions,
123
+ selectableOptions,
124
+ shouldVirtualize,
125
+ virtualizer,
126
+ // IDs & validation
127
+ labelId,
128
+ listboxId,
129
+ helperId,
130
+ status,
131
+ helperMessage,
132
+ // Handlers
133
+ handleInputChange,
134
+ handleInputClick,
135
+ handleScroll,
136
+ handleKeyDown,
137
+ refCallback
138
+ } = useSelectBase({
139
+ options,
140
+ onSelectOption: (option) => handleSelect(option.value),
141
+ virtualizeThreshold,
142
+ maxDropdownHeight,
143
+ label,
144
+ idPrefix: "multiselect",
145
+ error,
146
+ warning,
147
+ info,
148
+ success,
149
+ helperText
150
+ });
151
+ const selectedOptions = options.filter(
152
+ (opt) => currentValue.includes(opt.value)
153
+ );
184
154
  const handleRemoveChip = React.useCallback(
185
155
  (optionValue, e) => {
186
156
  e.stopPropagation();
@@ -202,105 +172,6 @@ var MultiSelect = React.memo(
202
172
  },
203
173
  [value, onChange]
204
174
  );
205
- const handleInputChange = React.useCallback(
206
- (e) => {
207
- setSearchQuery(e.target.value);
208
- if (!isOpen) setIsOpen(true);
209
- },
210
- [isOpen]
211
- );
212
- const handleInputClick = React.useCallback(
213
- (e) => {
214
- e.stopPropagation();
215
- if (!isOpen) setIsOpen(true);
216
- },
217
- [isOpen]
218
- );
219
- const handleKeyDown = React.useCallback(
220
- (e) => {
221
- if (!isOpen && e.key !== "Tab") {
222
- if (e.key === "Enter" || e.key === " " || e.key === "ArrowDown") {
223
- e.preventDefault();
224
- setIsOpen(true);
225
- }
226
- return;
227
- }
228
- const selectableOptions = filteredOptions.filter(
229
- (item) => item.type === "option" && !item.data.disabled
230
- );
231
- switch (e.key) {
232
- case "Escape":
233
- e.preventDefault();
234
- setIsOpen(false);
235
- setSearchQuery("");
236
- setHighlightedIndex(-1);
237
- inputRef.current?.blur();
238
- break;
239
- case "ArrowDown":
240
- e.preventDefault();
241
- setHighlightedIndex((prev) => {
242
- const nextIndex = Math.min(
243
- prev + 1,
244
- selectableOptions.length - 1
245
- );
246
- const option = selectableOptions[nextIndex];
247
- if (option && shouldVirtualize && virtualizerRef.current) {
248
- const optionIndex = filteredOptions.indexOf(option);
249
- virtualizerRef.current.scrollToIndex(optionIndex, {
250
- align: "auto"
251
- });
252
- }
253
- return nextIndex;
254
- });
255
- break;
256
- case "ArrowUp":
257
- e.preventDefault();
258
- setHighlightedIndex((prev) => {
259
- const nextIndex = Math.max(prev - 1, 0);
260
- const option = selectableOptions[nextIndex];
261
- if (option && shouldVirtualize && virtualizerRef.current) {
262
- const optionIndex = filteredOptions.indexOf(option);
263
- virtualizerRef.current.scrollToIndex(optionIndex, {
264
- align: "auto"
265
- });
266
- }
267
- return nextIndex;
268
- });
269
- break;
270
- case "Enter":
271
- e.preventDefault();
272
- if (highlightedIndex >= 0 && highlightedIndex < selectableOptions.length) {
273
- const item = selectableOptions[highlightedIndex];
274
- if (item) {
275
- const option = item.data;
276
- handleSelect(option.value);
277
- }
278
- }
279
- break;
280
- case "Home":
281
- e.preventDefault();
282
- setHighlightedIndex(0);
283
- if (shouldVirtualize && virtualizerRef.current) {
284
- virtualizerRef.current.scrollToIndex(0);
285
- }
286
- break;
287
- case "End":
288
- e.preventDefault();
289
- setHighlightedIndex(selectableOptions.length - 1);
290
- if (shouldVirtualize && virtualizerRef.current) {
291
- virtualizerRef.current.scrollToIndex(filteredOptions.length - 1);
292
- }
293
- break;
294
- }
295
- },
296
- [
297
- isOpen,
298
- filteredOptions,
299
- highlightedIndex,
300
- handleSelect,
301
- shouldVirtualize
302
- ]
303
- );
304
175
  const handleInputKeyDown = React.useCallback(
305
176
  (e) => {
306
177
  if (e.key === "Backspace" && !searchQuery && currentValue.length > 0) {
@@ -358,33 +229,7 @@ var MultiSelect = React.memo(
358
229
  clearTimeout(timeoutId);
359
230
  resizeObserver.disconnect();
360
231
  };
361
- }, [selectedOptions, size, maxChipsVisible]);
362
- const handleScroll = React.useCallback(
363
- (e) => {
364
- const element = e.currentTarget;
365
- const { scrollTop, scrollHeight, clientHeight } = element;
366
- setShowTopArrow(scrollTop > 0);
367
- setShowBottomArrow(scrollTop + clientHeight < scrollHeight - 1);
368
- },
369
- []
370
- );
371
- React.useEffect(() => {
372
- if (isOpen) {
373
- const timeoutId = setTimeout(() => {
374
- const element = scrollContainerRef.current;
375
- if (element) {
376
- const { scrollTop, scrollHeight, clientHeight } = element;
377
- setShowTopArrow(scrollTop > 0);
378
- setShowBottomArrow(scrollTop + clientHeight < scrollHeight - 1);
379
- }
380
- }, 50);
381
- return () => clearTimeout(timeoutId);
382
- } else {
383
- setShowTopArrow(false);
384
- setShowBottomArrow(false);
385
- return;
386
- }
387
- }, [isOpen, filteredOptions, shouldVirtualize]);
232
+ }, [selectedOptions, size, maxChipsVisible, triggerRef]);
388
233
  const renderOptionsList = () => /* @__PURE__ */ jsxs("div", { className: "relative", "data-slot": "multiSelect_dropdown", children: [
389
234
  showTopArrow && /* @__PURE__ */ jsx("div", { className: "flex items-center justify-center", children: /* @__PURE__ */ jsx(ChevronUp, { className: "h-4 w-4 text-text-primary" }) }),
390
235
  /* @__PURE__ */ jsx(
@@ -394,13 +239,17 @@ var MultiSelect = React.memo(
394
239
  className: cn("overflow-auto relative", classNames?.dropdown),
395
240
  style: { maxHeight: maxDropdownHeight },
396
241
  role: "listbox",
242
+ id: listboxId,
397
243
  "aria-multiselectable": "true",
398
244
  "aria-labelledby": label ? labelId : void 0,
399
245
  onScroll: handleScroll,
400
246
  children: filteredOptions.length === 0 ? /* @__PURE__ */ jsx(
401
247
  "div",
402
248
  {
403
- className: cn("multiSelect_empty px-3 py-4 text-center text-sm text-text-secondary", classNames?.empty),
249
+ className: cn(
250
+ "multiSelect_empty px-3 py-4 text-center text-sm text-text-secondary",
251
+ classNames?.empty
252
+ ),
404
253
  "data-slot": "multiSelect_empty",
405
254
  children: "No options found"
406
255
  }
@@ -443,11 +292,8 @@ var MultiSelect = React.memo(
443
292
  }
444
293
  const option = item?.data;
445
294
  const isSelected = currentValue.includes(option.value);
446
- const selectableOptions = filteredOptions.filter(
447
- (i) => i.type === "option" && !i.data.disabled
448
- );
449
- const selectableIndex = selectableOptions.findIndex(
450
- (i) => i === item
295
+ const selectableIndex = selectableOptions.indexOf(
296
+ item
451
297
  );
452
298
  const isHighlighted = selectableIndex === highlightedIndex;
453
299
  return /* @__PURE__ */ jsxs(
@@ -492,7 +338,7 @@ var MultiSelect = React.memo(
492
338
  }
493
339
  )
494
340
  }
495
- ) : /* @__PURE__ */ jsx("div", { className: "py-1", children: filteredOptions.map((item, index) => {
341
+ ) : /* @__PURE__ */ jsx("div", { children: filteredOptions.map((item, index) => {
496
342
  if (item.type === "group") {
497
343
  return /* @__PURE__ */ jsx(
498
344
  "div",
@@ -505,11 +351,8 @@ var MultiSelect = React.memo(
505
351
  }
506
352
  const option = item.data;
507
353
  const isSelected = currentValue.includes(option.value);
508
- const selectableOptions = filteredOptions.filter(
509
- (i) => i.type === "option" && !i.data.disabled
510
- );
511
- const selectableIndex = selectableOptions.findIndex(
512
- (i) => i === item
354
+ const selectableIndex = selectableOptions.indexOf(
355
+ item
513
356
  );
514
357
  const isHighlighted = selectableIndex === highlightedIndex;
515
358
  return /* @__PURE__ */ jsxs(
@@ -562,7 +405,9 @@ var MultiSelect = React.memo(
562
405
  disabled: disabled || loading,
563
406
  "aria-haspopup": "listbox",
564
407
  "aria-expanded": isOpen,
408
+ "aria-controls": listboxId,
565
409
  "aria-labelledby": label ? labelId : void 0,
410
+ "aria-describedby": helperMessage ? helperId : void 0,
566
411
  "data-slot": "multiSelect_trigger",
567
412
  children: [
568
413
  selectedOptions.length > 0 && /* @__PURE__ */ jsxs("div", { className: "flex gap-1 shrink-0", children: [
@@ -577,15 +422,23 @@ var MultiSelect = React.memo(
577
422
  children: [
578
423
  option.label,
579
424
  /* @__PURE__ */ jsx(
580
- "button",
425
+ "span",
581
426
  {
582
- type: "button",
427
+ role: "button",
428
+ tabIndex: disabled ? -1 : 0,
583
429
  onClick: (e) => handleRemoveChip(option.value, e),
430
+ onKeyDown: (e) => {
431
+ if (e.key === "Enter" || e.key === " ") {
432
+ e.preventDefault();
433
+ handleRemoveChip(option.value, e);
434
+ }
435
+ },
584
436
  className: cn(
585
- "multiSelect_tagRemove hover:text-error",
437
+ "multiSelect_tagRemove hover:text-error cursor-pointer",
438
+ disabled && "pointer-events-none",
586
439
  classNames?.tagRemove
587
440
  ),
588
- disabled,
441
+ "aria-disabled": disabled,
589
442
  "data-slot": "multiSelect_tagRemove",
590
443
  children: /* @__PURE__ */ jsx(X, { className: "h-3 w-3" })
591
444
  }
@@ -634,13 +487,20 @@ var MultiSelect = React.memo(
634
487
  tabIndex: -1
635
488
  }
636
489
  ),
637
- /* @__PURE__ */ jsx("div", { className: "flex items-center gap-1 text-text-secondary", children: loading ? /* @__PURE__ */ jsx(Loader2, { className: cn("animate-spin", iconSizes[size]) }) : /* @__PURE__ */ jsxs(Fragment, { children: [
490
+ /* @__PURE__ */ jsx("div", { className: "flex items-center gap-1 text-text-secondary", children: loading ? /* @__PURE__ */ jsx(spinner_default, {}) : /* @__PURE__ */ jsxs(Fragment, { children: [
638
491
  clearable && selectedOptions.length > 0 && !disabled && /* @__PURE__ */ jsx(
639
- "button",
492
+ "span",
640
493
  {
641
- type: "button",
494
+ role: "button",
495
+ tabIndex: 0,
642
496
  onClick: handleClear,
643
- className: "hover:text-text-primary transition-colors",
497
+ onKeyDown: (e) => {
498
+ if (e.key === "Enter" || e.key === " ") {
499
+ e.preventDefault();
500
+ handleClear(e);
501
+ }
502
+ },
503
+ className: "hover:text-text-primary transition-colors cursor-pointer",
644
504
  "aria-label": "Clear selection",
645
505
  children: /* @__PURE__ */ jsx(X, { className: iconSizes[size] })
646
506
  }
@@ -666,7 +526,7 @@ var MultiSelect = React.memo(
666
526
  /* @__PURE__ */ jsx(
667
527
  PopoverContent,
668
528
  {
669
- className: "p-0 w-[var(--radix-popover-trigger-width)]",
529
+ className: "p-0 w-(--radix-popover-trigger-width)",
670
530
  align: "start",
671
531
  sideOffset: 4,
672
532
  onOpenAutoFocus: (e) => {
@@ -699,6 +559,7 @@ var MultiSelect = React.memo(
699
559
  helperMessage && /* @__PURE__ */ jsx(
700
560
  "p",
701
561
  {
562
+ id: helperId,
702
563
  className: cn(
703
564
  "multiSelect_helper text-xs",
704
565
  status === "error" && "text-error",
@@ -721,5 +582,5 @@ MultiSelect.displayName = "MultiSelect";
721
582
  var multi_select_default = MultiSelect;
722
583
 
723
584
  export { multi_select_default };
724
- //# sourceMappingURL=chunk-WIR52JXZ.js.map
725
- //# sourceMappingURL=chunk-WIR52JXZ.js.map
585
+ //# sourceMappingURL=chunk-H6G4BUPA.js.map
586
+ //# sourceMappingURL=chunk-H6G4BUPA.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/multi-select/utils.ts","../src/multi-select/index.tsx"],"names":[],"mappings":"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","file":"chunk-H6G4BUPA.js","sourcesContent":["import { cva } from \"class-variance-authority\";\n\nexport const multiSelectTriggerVariants = cva(\n \"w-full flex items-center justify-between rounded-md bg-background text-text-primary border focus:border-primary outline-none disabled:opacity-50 disabled:cursor-not-allowed cursor-pointer gap-1\",\n {\n variants: {\n status: {\n default: \"border-border\",\n error: \"border-error\",\n warning: \"border-warning\",\n info: \"border-info\",\n success: \"border-success\",\n },\n size: {\n xs: \"h-(--select-height-xs) px-(--select-padding-x-xs) text-xs\",\n sm: \"h-(--select-height-sm) px-(--select-padding-x-sm) text-sm\",\n md: \"h-(--select-height-md) px-(--select-padding-x-md) text-base\",\n lg: \"h-(--select-height-lg) px-(--select-padding-x-lg) text-lg\",\n },\n fullWidth: {\n true: \"w-full\",\n false: \"max-w-full\",\n },\n },\n defaultVariants: {\n status: \"default\",\n size: \"md\",\n fullWidth: true,\n },\n },\n);\n\nexport const multiSelectDropdownVariants = cva(\n \"absolute z-50 mt-1 overflow-auto rounded-md border border-border bg-background\",\n);\n\nexport const multiSelectOptionVariants = cva(\n \"relative cursor-pointer select-none px-3 py-2 text-text-primary\",\n {\n variants: {\n selected: {\n true: \"bg-primary/10 text-primary font-medium\",\n false: \"hover:bg-surface\",\n },\n disabled: {\n true: \"opacity-50 cursor-not-allowed\",\n false: \"\",\n },\n },\n defaultVariants: {\n selected: false,\n disabled: false,\n },\n },\n);\n\nexport const multiSelectGroupVariants = cva(\n \"px-3 py-2 text-xs font-semibold text-text-secondary uppercase tracking-wider bg-surface\",\n);\n","\"use client\";\n\nimport { Check, ChevronDown, ChevronUp, Search, X } from \"lucide-react\";\nimport React from \"react\";\n\nimport { Popover, PopoverContent, PopoverTrigger } from \"../popover\";\nimport Spinner from \"../spinner\";\nimport { useSelectBase } from \"../shared/useSelectBase\";\nimport type { FlattenedItem } from \"../shared/useSelectBase\";\nimport { cn, iconSizes } from \"../utils\";\nimport type { MultiSelectOption, MultiSelectProps } from \"./types\";\nimport {\n multiSelectGroupVariants,\n multiSelectOptionVariants,\n multiSelectTriggerVariants,\n} from \"./utils\";\n\nconst MultiSelect = React.memo<MultiSelectProps>(\n ({\n size = \"md\",\n label,\n helperText,\n error,\n warning,\n info,\n success,\n options = [],\n placeholder = \"Select options\",\n loading = false,\n fullWidth = true,\n maxChipsVisible = 3,\n value,\n defaultValue,\n onChange,\n disabled,\n required,\n clearable = false,\n virtualizeThreshold = 50,\n maxDropdownHeight = 300,\n className,\n classNames,\n ref,\n ...props\n }) => {\n const [internalValue, setInternalValue] = React.useState<string[]>(\n defaultValue ?? [],\n );\n const [visibleChipsCount, setVisibleChipsCount] =\n React.useState(maxChipsVisible);\n\n const currentValue = value !== undefined ? value : internalValue;\n\n const handleSelect = React.useCallback(\n (optionValue: string) => {\n const newValue = currentValue.includes(optionValue)\n ? currentValue.filter((v) => v !== optionValue)\n : [...currentValue, optionValue];\n\n if (value === undefined) {\n setInternalValue(newValue);\n }\n onChange?.(newValue);\n setHighlightedIndex(-1);\n },\n [value, onChange, currentValue],\n );\n\n const {\n // State\n isOpen,\n setIsOpen,\n searchQuery,\n setSearchQuery: _setSearchQuery,\n setHighlightedIndex,\n highlightedIndex,\n showTopArrow,\n showBottomArrow,\n // Refs\n triggerRef,\n inputRef,\n scrollContainerRef,\n // Computed\n filteredOptions,\n selectableOptions,\n shouldVirtualize,\n virtualizer,\n // IDs & validation\n labelId,\n listboxId,\n helperId,\n status,\n helperMessage,\n // Handlers\n handleInputChange,\n handleInputClick,\n handleScroll,\n handleKeyDown,\n refCallback,\n } = useSelectBase<MultiSelectOption>({\n options,\n onSelectOption: (option) => handleSelect(option.value),\n virtualizeThreshold,\n maxDropdownHeight,\n label,\n idPrefix: \"multiselect\",\n error,\n warning,\n info,\n success,\n helperText,\n });\n\n const selectedOptions = options.filter((opt) =>\n currentValue.includes(opt.value),\n );\n\n const handleRemoveChip = React.useCallback(\n (optionValue: string, e: React.MouseEvent | React.KeyboardEvent) => {\n e.stopPropagation();\n const newValue = currentValue.filter((v) => v !== optionValue);\n\n if (value === undefined) {\n setInternalValue(newValue);\n }\n onChange?.(newValue);\n },\n [value, onChange, currentValue],\n );\n\n const handleClear = React.useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation();\n if (value === undefined) {\n setInternalValue([]);\n }\n onChange?.([]);\n },\n [value, onChange],\n );\n\n const handleInputKeyDown = React.useCallback(\n (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (e.key === \"Backspace\" && !searchQuery && currentValue.length > 0) {\n e.preventDefault();\n const lastValue = currentValue[currentValue.length - 1];\n handleRemoveChip(lastValue!, e);\n } else {\n handleKeyDown(e);\n }\n },\n [searchQuery, currentValue, handleRemoveChip, handleKeyDown],\n );\n\n React.useEffect(() => {\n if (selectedOptions.length === 0 || !triggerRef.current) {\n setVisibleChipsCount(maxChipsVisible);\n return;\n }\n\n const calculateVisibleChips = () => {\n const container = triggerRef.current;\n if (!container) return;\n\n const hiddenChips = container.querySelectorAll(\"[data-hidden-chip]\");\n if (hiddenChips.length === 0) return;\n\n const containerWidth = container.offsetWidth;\n const padding =\n size === \"sm\" ? 12 : size === \"md\" ? 16 : size === \"lg\" ? 20 : 24;\n const chevronWidth = 32;\n const gap = 4;\n const plusIndicatorWidth = 50;\n\n const availableWidth = containerWidth - padding * 2 - chevronWidth;\n let totalWidth = 0;\n let visibleCount = 0;\n\n for (let i = 0; i < hiddenChips.length; i++) {\n const chip = hiddenChips[i];\n if (!chip) continue;\n const chipWidth = chip.getBoundingClientRect().width;\n const requiredSpace =\n totalWidth + chipWidth + (visibleCount > 0 ? gap : 0);\n\n const needsPlusIndicator = i < hiddenChips.length - 1;\n const spaceWithIndicator =\n requiredSpace + (needsPlusIndicator ? gap + plusIndicatorWidth : 0);\n\n if (spaceWithIndicator <= availableWidth) {\n totalWidth = requiredSpace;\n visibleCount++;\n } else {\n break;\n }\n }\n\n setVisibleChipsCount(Math.max(1, visibleCount));\n };\n\n const timeoutId = setTimeout(calculateVisibleChips, 0);\n\n const resizeObserver = new ResizeObserver(() => {\n calculateVisibleChips();\n });\n\n if (triggerRef.current) {\n resizeObserver.observe(triggerRef.current);\n }\n\n return () => {\n clearTimeout(timeoutId);\n resizeObserver.disconnect();\n };\n }, [selectedOptions, size, maxChipsVisible, triggerRef]);\n\n const renderOptionsList = () => (\n <div className=\"relative\" data-slot=\"multiSelect_dropdown\">\n {/* Top scroll indicator */}\n {showTopArrow && (\n <div className=\"flex items-center justify-center\">\n <ChevronUp className=\"h-4 w-4 text-text-primary\" />\n </div>\n )}\n\n <div\n ref={scrollContainerRef}\n className={cn(\"overflow-auto relative\", classNames?.dropdown)}\n style={{ maxHeight: maxDropdownHeight }}\n role=\"listbox\"\n id={listboxId}\n aria-multiselectable=\"true\"\n aria-labelledby={label ? labelId : undefined}\n onScroll={handleScroll}\n >\n {filteredOptions.length === 0 ? (\n <div\n className={cn(\n \"multiSelect_empty px-3 py-4 text-center text-sm text-text-secondary\",\n classNames?.empty,\n )}\n data-slot=\"multiSelect_empty\"\n >\n No options found\n </div>\n ) : shouldVirtualize ? (\n <div\n ref={refCallback}\n style={{\n height: `${Math.min(virtualizer.getTotalSize(), maxDropdownHeight)}px`,\n overflow: \"auto\",\n }}\n onScroll={handleScroll}\n >\n <div\n style={{\n height: `${virtualizer.getTotalSize()}px`,\n width: \"100%\",\n position: \"relative\",\n }}\n >\n {virtualizer.getVirtualItems().map((virtualItem) => {\n const item = filteredOptions[virtualItem.index];\n\n if (item?.type === \"group\") {\n return (\n <div\n key={`group-${virtualItem.index}`}\n style={{\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"100%\",\n height: `${virtualItem.size}px`,\n transform: `translateY(${virtualItem.start}px)`,\n }}\n className={multiSelectGroupVariants()}\n >\n {item?.data as string}\n </div>\n );\n }\n\n const option = item?.data as MultiSelectOption;\n const isSelected = currentValue.includes(option.value);\n const selectableIndex = selectableOptions.indexOf(\n item as FlattenedItem<MultiSelectOption>,\n );\n const isHighlighted = selectableIndex === highlightedIndex;\n\n return (\n <div\n key={option.value}\n style={{\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"100%\",\n height: `${virtualItem.size}px`,\n transform: `translateY(${virtualItem.start}px)`,\n }}\n className={cn(\n \"multiSelect_option\",\n multiSelectOptionVariants({\n selected: isSelected,\n disabled: !!option.disabled,\n }),\n isHighlighted && \"bg-surface\",\n classNames?.option,\n isSelected && classNames?.optionSelected,\n )}\n onClick={() =>\n !option.disabled && handleSelect(option.value)\n }\n role=\"option\"\n aria-selected={isSelected}\n aria-disabled={option.disabled}\n data-slot=\"multiSelect_option\"\n >\n {option.label}\n {isSelected && (\n <span className=\"absolute right-3 top-1/2 -translate-y-1/2\">\n <Check\n className={cn(\"text-primary\", iconSizes[size])}\n />\n </span>\n )}\n </div>\n );\n })}\n </div>\n </div>\n ) : (\n <div>\n {filteredOptions.map((item, index) => {\n if (item.type === \"group\") {\n return (\n <div\n key={`group-${index}`}\n className={multiSelectGroupVariants()}\n >\n {item.data as string}\n </div>\n );\n }\n\n const option = item.data as MultiSelectOption;\n const isSelected = currentValue.includes(option.value);\n const selectableIndex = selectableOptions.indexOf(\n item as FlattenedItem<MultiSelectOption>,\n );\n const isHighlighted = selectableIndex === highlightedIndex;\n\n return (\n <div\n key={option.value}\n className={cn(\n \"multiSelect_option\",\n multiSelectOptionVariants({\n selected: isSelected,\n disabled: !!option.disabled,\n }),\n isHighlighted && \"bg-surface\",\n classNames?.option,\n isSelected && classNames?.optionSelected,\n )}\n onClick={() =>\n !option.disabled && handleSelect(option.value)\n }\n role=\"option\"\n aria-selected={isSelected}\n aria-disabled={option.disabled}\n data-slot=\"multiSelect_option\"\n >\n {option.label}\n {isSelected && (\n <span className=\"absolute right-3 top-1/2 -translate-y-1/2\">\n <Check\n className={cn(\"text-primary\", iconSizes[size])}\n />\n </span>\n )}\n </div>\n );\n })}\n </div>\n )}\n </div>\n\n {/* Bottom scroll indicator */}\n {showBottomArrow && (\n <div className=\"flex items-center justify-center\">\n <ChevronDown className=\"h-4 w-4 text-text-primary\" />\n </div>\n )}\n </div>\n );\n\n // Trigger button (used in both desktop and mobile)\n const triggerButton = (\n <button\n ref={triggerRef}\n type=\"button\"\n className={cn(\n \"multiSelect_trigger\",\n multiSelectTriggerVariants({ status, size, fullWidth }),\n loading && \"opacity-50\",\n classNames?.trigger,\n className,\n )}\n disabled={disabled || loading}\n aria-haspopup=\"listbox\"\n aria-expanded={isOpen}\n aria-controls={listboxId}\n aria-labelledby={label ? labelId : undefined}\n aria-describedby={helperMessage ? helperId : undefined}\n data-slot=\"multiSelect_trigger\"\n >\n {selectedOptions.length > 0 && (\n <div className=\"flex gap-1 shrink-0\">\n {selectedOptions.slice(0, visibleChipsCount).map((option) => (\n <span\n key={option.value}\n className={cn(\n \"multiSelect_tag inline-flex items-center gap-1 px-2 bg-primary/10 text-primary rounded text-sm whitespace-nowrap\",\n classNames?.tag,\n )}\n data-slot=\"multiSelect_tag\"\n >\n {option.label}\n <span\n role=\"button\"\n tabIndex={disabled ? -1 : 0}\n onClick={(e) => handleRemoveChip(option.value, e)}\n onKeyDown={(e) => { if (e.key === 'Enter' || e.key === ' ') { e.preventDefault(); handleRemoveChip(option.value, e as unknown as React.MouseEvent); } }}\n className={cn(\n \"multiSelect_tagRemove hover:text-error cursor-pointer\",\n disabled && \"pointer-events-none\",\n classNames?.tagRemove,\n )}\n aria-disabled={disabled}\n data-slot=\"multiSelect_tagRemove\"\n >\n <X className=\"h-3 w-3\" />\n </span>\n </span>\n ))}\n {selectedOptions.length > visibleChipsCount && (\n <span className=\"inline-flex items-center px-2 py-0.5 bg-surface text-text-secondary rounded text-sm whitespace-nowrap\">\n +{selectedOptions.length - visibleChipsCount}\n </span>\n )}\n </div>\n )}\n <div\n className=\"absolute opacity-0 pointer-events-none whitespace-nowrap\"\n aria-hidden=\"true\"\n >\n {selectedOptions.map((option) => (\n <span\n key={option.value}\n data-hidden-chip\n className=\"inline-flex items-center gap-1 px-2 py-0.5 bg-primary/10 text-primary rounded text-sm whitespace-nowrap\"\n >\n {option.label}\n <X className=\"h-3 w-3\" />\n </span>\n ))}\n </div>\n <input\n ref={inputRef}\n type=\"text\"\n className=\"bg-transparent outline-none cursor-pointer placeholder:text-text-secondary/50 flex-1 min-w-0 pointer-events-none\"\n placeholder={selectedOptions.length > 0 ? \"\" : placeholder}\n value={searchQuery}\n onChange={handleInputChange}\n onClick={handleInputClick}\n onKeyDown={handleInputKeyDown}\n disabled={disabled || loading}\n readOnly={!isOpen}\n tabIndex={-1}\n />\n <div className=\"flex items-center gap-1 text-text-secondary\">\n {loading ? (\n <Spinner />\n ) : (\n <>\n {clearable && selectedOptions.length > 0 && !disabled && (\n <span\n role=\"button\"\n tabIndex={0}\n onClick={handleClear}\n onKeyDown={(e) => { if (e.key === 'Enter' || e.key === ' ') { e.preventDefault(); handleClear(e as unknown as React.MouseEvent); } }}\n className=\"hover:text-text-primary transition-colors cursor-pointer\"\n aria-label=\"Clear selection\"\n >\n <X className={iconSizes[size]} />\n </span>\n )}\n {isOpen ? (\n <Search className={iconSizes[size]} />\n ) : (\n <ChevronDown className={iconSizes[size]} />\n )}\n </>\n )}\n </div>\n </button>\n );\n\n const selectElement = (\n <div\n className={cn(\n \"multiSelect_root relative group\",\n fullWidth ? \"w-full\" : \"inline-block\",\n classNames?.root,\n )}\n ref={ref}\n data-slot=\"multiSelect_root\"\n {...props}\n >\n <Popover open={isOpen} onOpenChange={setIsOpen}>\n <PopoverTrigger asChild>{triggerButton}</PopoverTrigger>\n\n <PopoverContent\n className=\"p-0 w-(--radix-popover-trigger-width)\"\n align=\"start\"\n sideOffset={4}\n onOpenAutoFocus={(e: Event) => {\n e.preventDefault();\n inputRef.current?.focus();\n }}\n >\n {renderOptionsList()}\n </PopoverContent>\n </Popover>\n </div>\n );\n\n return (\n <div className={cn(\"w-full flex flex-col\", !fullWidth && \"inline-block\")}>\n <div className=\"flex gap-2 items-center\">\n {label && (\n <label\n id={labelId}\n className={cn(\n \"multiSelect_label block mb-0.5\",\n classNames?.label,\n )}\n data-slot=\"multiSelect_label\"\n >\n <span className=\"text-sm font-medium text-text-secondary\">\n {label}\n {required && <span className=\"text-error ml-1\">*</span>}\n </span>\n </label>\n )}\n {helperMessage && (\n <p\n id={helperId}\n className={cn(\n \"multiSelect_helper text-xs\",\n status === \"error\" && \"text-error\",\n status === \"warning\" && \"text-warning\",\n status === \"info\" && \"text-info\",\n status === \"success\" && \"text-success\",\n status === \"default\" && \"text-text-secondary\",\n classNames?.helper,\n )}\n data-slot=\"multiSelect_helper\"\n >\n {helperMessage}\n </p>\n )}\n </div>\n {selectElement}\n </div>\n );\n },\n);\n\nMultiSelect.displayName = \"MultiSelect\";\n\nexport type * from \"./types\";\nexport default MultiSelect;\n"]}
@@ -1,4 +1,4 @@
1
- import { createTooltipSoftColorVariants, tooltipSolidColorClasses, componentColors } from './chunk-LK4EPTNG.js';
1
+ import { createTooltipSoftColorVariants, tooltipSolidColorClasses, componentColors } from './chunk-POXI7JJ4.js';
2
2
  import { cn } from './chunk-NGYLRX6F.js';
3
3
  import * as TooltipPrimitive from '@radix-ui/react-tooltip';
4
4
  import { cva } from 'class-variance-authority';
@@ -73,5 +73,5 @@ Tooltip.displayName = "Tooltip";
73
73
  var tooltip_default = Tooltip;
74
74
 
75
75
  export { TooltipProvider, tooltip_default };
76
- //# sourceMappingURL=chunk-MOQDO4XZ.js.map
77
- //# sourceMappingURL=chunk-MOQDO4XZ.js.map
76
+ //# sourceMappingURL=chunk-HCOTO5WX.js.map
77
+ //# sourceMappingURL=chunk-HCOTO5WX.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/tooltip/index.tsx"],"names":[],"mappings":";;;;;;;AAcA,IAAM,sBAAA,GAAyB,GAAA;AAAA,EAC7B,slBAAA;AAAA,EACA;AAAA,IACE,QAAA,EAAU;AAAA,MACR,IAAA,EAAM;AAAA,QACJ,EAAA,EAAI,mBAAA;AAAA,QACJ,EAAA,EAAI,qBAAA;AAAA,QACJ,EAAA,EAAI,uBAAA;AAAA,QACJ,EAAA,EAAI;AAAA,OACN;AAAA,MACA,KAAA,EAAO,wBAAA;AAAA,MACP,OAAA,EAAS;AAAA,QACP,KAAA,EAAO,EAAA;AAAA,QACP,IAAA,EAAM;AAAA;AACR,KACF;AAAA,IACA,gBAAA,EAAkB,+BAA+B,eAAe,CAAA;AAAA,IAChE,eAAA,EAAiB;AAAA,MACf,IAAA,EAAM,IAAA;AAAA,MACN,KAAA,EAAO,SAAA;AAAA,MACP,OAAA,EAAS;AAAA;AACX;AAEJ,CAAA;AAEO,IAAM,eAAA,GAAmC,gBAAA,CAAA;AAUhD,IAAM,UAAU,KAAA,CAAM,IAAA;AAAA,EACpB,CAAC;AAAA,IACC,OAAA;AAAA,IACA,QAAA;AAAA,IACA,KAAA,GAAQ,SAAA;AAAA,IACR,IAAA,GAAO,IAAA;AAAA,IACP,OAAA,GAAU,OAAA;AAAA,IACV,IAAA,GAAO,KAAA;AAAA,IACP,KAAA,GAAQ,QAAA;AAAA,IACR,aAAA,GAAgB,GAAA;AAAA,IAChB,QAAA,GAAW,KAAA;AAAA,IACX,SAAA;AAAA,IACA,UAAA;AAAA,IACA,GAAG;AAAA,GACL,KAAM;AACJ,IAAA,IAAI,QAAA,EAAU;AACZ,MAAA,uCAAU,QAAA,EAAS,CAAA;AAAA,IACrB;AAEA,IAAA,uBACE,IAAA,CAAkB,gBAAA,CAAA,IAAA,EAAjB,EAAsB,aAAA,EACrB,QAAA,EAAA;AAAA,sBAAA,GAAA,CAAkB,gBAAA,CAAA,OAAA,EAAjB,EAAyB,OAAA,EAAO,IAAA,EAAE,QAAA,EAAS,CAAA;AAAA,sBAC5C,GAAA,CAAkB,yBAAjB,EACC,QAAA,kBAAA,GAAA;AAAA,QAAkB,gBAAA,CAAA,OAAA;AAAA,QAAjB;AAAA,UACC,IAAA;AAAA,UACA,KAAA;AAAA,UACA,SAAA,EAAW,EAAA;AAAA,YACT,iBAAA;AAAA,YACA,sBAAA,CAAuB,EAAE,IAAA,EAAM,KAAA,EAAO,SAAS,CAAA;AAAA,YAC/C,SAAA;AAAA,YACA,UAAA,EAAY;AAAA,WACd;AAAA,UACA,UAAA,EAAY,CAAA;AAAA,UACX,GAAG,KAAA;AAAA,UAEH,QAAA,EAAA;AAAA;AAAA,OACH,EACF;AAAA,KAAA,EACF,CAAA;AAAA,EAEJ;AACF,CAAA;AAEA,OAAA,CAAQ,WAAA,GAAc,SAAA;AAGtB,IAAO,eAAA,GAAQ","file":"chunk-MOQDO4XZ.js","sourcesContent":["'use client'\n\nimport * as TooltipPrimitive from '@radix-ui/react-tooltip'\nimport { cva } from 'class-variance-authority'\nimport React from 'react'\n\nimport { cn } from '../utils'\nimport {\n componentColors,\n createTooltipSoftColorVariants,\n tooltipSolidColorClasses,\n} from '../variants'\nimport type { TooltipProps } from './types'\n\nconst tooltipContentVariants = cva(\n 'z-50 overflow-hidden rounded px-3 py-1.5 text-sm will-change-[transform,_opacity] animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 data-[state=closed]:data-[side=bottom]:slide-out-to-top-2 data-[state=closed]:data-[side=left]:slide-out-to-right-2 data-[state=closed]:data-[side=right]:slide-out-to-left-2 data-[state=closed]:data-[side=top]:slide-out-to-bottom-2',\n {\n variants: {\n size: {\n xs: 'text-xs px-2 py-1',\n sm: 'text-sm px-2.5 py-1',\n md: 'text-base px-3 py-1.5',\n lg: 'text-lg px-4 py-2',\n },\n color: tooltipSolidColorClasses,\n variant: {\n solid: '',\n soft: 'border',\n },\n },\n compoundVariants: createTooltipSoftColorVariants(componentColors),\n defaultVariants: {\n size: 'sm',\n color: 'default',\n variant: 'solid',\n },\n },\n)\n\nexport const TooltipProvider = TooltipPrimitive.Provider\n\nexport type {\n TooltipProps,\n TooltipProviderProps,\n TooltipColor,\n TooltipSize,\n TooltipVariant,\n} from './types'\n\nconst Tooltip = React.memo<TooltipProps>(\n ({\n content,\n children,\n color = 'default',\n size = 'sm',\n variant = 'solid',\n side = 'top',\n align = 'center',\n delayDuration = 200,\n disabled = false,\n className,\n classNames,\n ...props\n }) => {\n if (disabled) {\n return <>{children}</>\n }\n\n return (\n <TooltipPrimitive.Root delayDuration={delayDuration}>\n <TooltipPrimitive.Trigger asChild>{children}</TooltipPrimitive.Trigger>\n <TooltipPrimitive.Portal>\n <TooltipPrimitive.Content\n side={side}\n align={align}\n className={cn(\n 'tooltip_content',\n tooltipContentVariants({ size, color, variant }),\n className,\n classNames?.content,\n )}\n sideOffset={4}\n {...props}\n >\n {content}\n </TooltipPrimitive.Content>\n </TooltipPrimitive.Portal>\n </TooltipPrimitive.Root>\n )\n },\n)\n\nTooltip.displayName = 'Tooltip'\n\nexport type * from './types'\nexport default Tooltip\n"]}
1
+ {"version":3,"sources":["../src/tooltip/index.tsx"],"names":[],"mappings":";;;;;;;AAcA,IAAM,sBAAA,GAAyB,GAAA;AAAA,EAC7B,slBAAA;AAAA,EACA;AAAA,IACE,QAAA,EAAU;AAAA,MACR,IAAA,EAAM;AAAA,QACJ,EAAA,EAAI,mBAAA;AAAA,QACJ,EAAA,EAAI,qBAAA;AAAA,QACJ,EAAA,EAAI,uBAAA;AAAA,QACJ,EAAA,EAAI;AAAA,OACN;AAAA,MACA,KAAA,EAAO,wBAAA;AAAA,MACP,OAAA,EAAS;AAAA,QACP,KAAA,EAAO,EAAA;AAAA,QACP,IAAA,EAAM;AAAA;AACR,KACF;AAAA,IACA,gBAAA,EAAkB,+BAA+B,eAAe,CAAA;AAAA,IAChE,eAAA,EAAiB;AAAA,MACf,IAAA,EAAM,IAAA;AAAA,MACN,KAAA,EAAO,SAAA;AAAA,MACP,OAAA,EAAS;AAAA;AACX;AAEJ,CAAA;AAEO,IAAM,eAAA,GAAmC,gBAAA,CAAA;AAUhD,IAAM,UAAU,KAAA,CAAM,IAAA;AAAA,EACpB,CAAC;AAAA,IACC,OAAA;AAAA,IACA,QAAA;AAAA,IACA,KAAA,GAAQ,SAAA;AAAA,IACR,IAAA,GAAO,IAAA;AAAA,IACP,OAAA,GAAU,OAAA;AAAA,IACV,IAAA,GAAO,KAAA;AAAA,IACP,KAAA,GAAQ,QAAA;AAAA,IACR,aAAA,GAAgB,GAAA;AAAA,IAChB,QAAA,GAAW,KAAA;AAAA,IACX,SAAA;AAAA,IACA,UAAA;AAAA,IACA,GAAG;AAAA,GACL,KAAM;AACJ,IAAA,IAAI,QAAA,EAAU;AACZ,MAAA,uCAAU,QAAA,EAAS,CAAA;AAAA,IACrB;AAEA,IAAA,uBACE,IAAA,CAAkB,gBAAA,CAAA,IAAA,EAAjB,EAAsB,aAAA,EACrB,QAAA,EAAA;AAAA,sBAAA,GAAA,CAAkB,gBAAA,CAAA,OAAA,EAAjB,EAAyB,OAAA,EAAO,IAAA,EAAE,QAAA,EAAS,CAAA;AAAA,sBAC5C,GAAA,CAAkB,yBAAjB,EACC,QAAA,kBAAA,GAAA;AAAA,QAAkB,gBAAA,CAAA,OAAA;AAAA,QAAjB;AAAA,UACC,IAAA;AAAA,UACA,KAAA;AAAA,UACA,SAAA,EAAW,EAAA;AAAA,YACT,iBAAA;AAAA,YACA,sBAAA,CAAuB,EAAE,IAAA,EAAM,KAAA,EAAO,SAAS,CAAA;AAAA,YAC/C,SAAA;AAAA,YACA,UAAA,EAAY;AAAA,WACd;AAAA,UACA,UAAA,EAAY,CAAA;AAAA,UACX,GAAG,KAAA;AAAA,UAEH,QAAA,EAAA;AAAA;AAAA,OACH,EACF;AAAA,KAAA,EACF,CAAA;AAAA,EAEJ;AACF,CAAA;AAEA,OAAA,CAAQ,WAAA,GAAc,SAAA;AAGtB,IAAO,eAAA,GAAQ","file":"chunk-HCOTO5WX.js","sourcesContent":["'use client'\n\nimport * as TooltipPrimitive from '@radix-ui/react-tooltip'\nimport { cva } from 'class-variance-authority'\nimport React from 'react'\n\nimport { cn } from '../utils'\nimport {\n componentColors,\n createTooltipSoftColorVariants,\n tooltipSolidColorClasses,\n} from '../variants'\nimport type { TooltipProps } from './types'\n\nconst tooltipContentVariants = cva(\n 'z-50 overflow-hidden rounded px-3 py-1.5 text-sm will-change-[transform,_opacity] animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 data-[state=closed]:data-[side=bottom]:slide-out-to-top-2 data-[state=closed]:data-[side=left]:slide-out-to-right-2 data-[state=closed]:data-[side=right]:slide-out-to-left-2 data-[state=closed]:data-[side=top]:slide-out-to-bottom-2',\n {\n variants: {\n size: {\n xs: 'text-xs px-2 py-1',\n sm: 'text-sm px-2.5 py-1',\n md: 'text-base px-3 py-1.5',\n lg: 'text-lg px-4 py-2',\n },\n color: tooltipSolidColorClasses,\n variant: {\n solid: '',\n soft: 'border',\n },\n },\n compoundVariants: createTooltipSoftColorVariants(componentColors),\n defaultVariants: {\n size: 'sm',\n color: 'default',\n variant: 'solid',\n },\n },\n)\n\nexport const TooltipProvider = TooltipPrimitive.Provider\n\nexport type {\n TooltipProps,\n TooltipProviderProps,\n TooltipColor,\n TooltipSize,\n TooltipVariant,\n} from './types'\n\nconst Tooltip = React.memo<TooltipProps>(\n ({\n content,\n children,\n color = 'default',\n size = 'sm',\n variant = 'solid',\n side = 'top',\n align = 'center',\n delayDuration = 200,\n disabled = false,\n className,\n classNames,\n ...props\n }) => {\n if (disabled) {\n return <>{children}</>\n }\n\n return (\n <TooltipPrimitive.Root delayDuration={delayDuration}>\n <TooltipPrimitive.Trigger asChild>{children}</TooltipPrimitive.Trigger>\n <TooltipPrimitive.Portal>\n <TooltipPrimitive.Content\n side={side}\n align={align}\n className={cn(\n 'tooltip_content',\n tooltipContentVariants({ size, color, variant }),\n className,\n classNames?.content,\n )}\n sideOffset={4}\n {...props}\n >\n {content}\n </TooltipPrimitive.Content>\n </TooltipPrimitive.Portal>\n </TooltipPrimitive.Root>\n )\n },\n)\n\nTooltip.displayName = 'Tooltip'\n\nexport type * from './types'\nexport default Tooltip\n"]}