@mdigital_ui/ui 0.3.3 → 0.3.5

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 (341) hide show
  1. package/dist/checkbox/index.js +1 -1
  2. package/dist/{chunk-VKLDLJXG.js → chunk-F3OLZMGO.js} +12 -8
  3. package/dist/chunk-F3OLZMGO.js.map +1 -0
  4. package/dist/{chunk-GIWG6BCT.js → chunk-KYDQJSSW.js} +2 -3
  5. package/dist/chunk-KYDQJSSW.js.map +1 -0
  6. package/dist/{chunk-OSHJYIHC.js → chunk-NQACKYGF.js} +4 -4
  7. package/dist/{chunk-OSHJYIHC.js.map → chunk-NQACKYGF.js.map} +1 -1
  8. package/dist/{chunk-2REG4OUB.js → chunk-QNPE63O6.js} +92 -75
  9. package/dist/chunk-QNPE63O6.js.map +1 -0
  10. package/dist/{chunk-I7MESP7F.js → chunk-SB3JGUGE.js} +6 -6
  11. package/dist/chunk-SB3JGUGE.js.map +1 -0
  12. package/dist/{chunk-RLYGJN56.js → chunk-U5GAFTEM.js} +9 -4
  13. package/dist/chunk-U5GAFTEM.js.map +1 -0
  14. package/dist/{chunk-DHXVNO75.js → chunk-XR4UHTK3.js} +3 -3
  15. package/dist/{chunk-DHXVNO75.js.map → chunk-XR4UHTK3.js.map} +1 -1
  16. package/dist/{chunk-623OVNLC.js → chunk-XVRNFPBI.js} +3 -3
  17. package/dist/{chunk-623OVNLC.js.map → chunk-XVRNFPBI.js.map} +1 -1
  18. package/dist/{chunk-QC7XNMM7.js → chunk-ZESEEYEJ.js} +81 -39
  19. package/dist/chunk-ZESEEYEJ.js.map +1 -0
  20. package/dist/float-input/index.js +1 -1
  21. package/dist/index.js +12 -12
  22. package/dist/input/index.js +1 -1
  23. package/dist/input-password/index.js +2 -2
  24. package/dist/radio/index.js +1 -1
  25. package/dist/select/index.js +1 -1
  26. package/dist/switch/index.js +1 -1
  27. package/dist/table/index.js +3 -3
  28. package/dist/transfer/index.js +2 -2
  29. package/package.json +1 -1
  30. package/dist/accordion/index.d.ts +0 -6
  31. package/dist/accordion/index.d.ts.map +0 -1
  32. package/dist/accordion/types.d.ts +0 -125
  33. package/dist/accordion/types.d.ts.map +0 -1
  34. package/dist/avatar/index.d.ts +0 -14
  35. package/dist/avatar/index.d.ts.map +0 -1
  36. package/dist/avatar/types.d.ts +0 -147
  37. package/dist/avatar/types.d.ts.map +0 -1
  38. package/dist/badge/index.d.ts +0 -28
  39. package/dist/badge/index.d.ts.map +0 -1
  40. package/dist/badge/types.d.ts +0 -97
  41. package/dist/badge/types.d.ts.map +0 -1
  42. package/dist/breadcrumbs/index.d.ts +0 -13
  43. package/dist/breadcrumbs/index.d.ts.map +0 -1
  44. package/dist/breadcrumbs/types.d.ts +0 -118
  45. package/dist/breadcrumbs/types.d.ts.map +0 -1
  46. package/dist/button/index.d.ts +0 -6
  47. package/dist/button/index.d.ts.map +0 -1
  48. package/dist/button/types.d.ts +0 -86
  49. package/dist/button/types.d.ts.map +0 -1
  50. package/dist/button-group/index.d.ts +0 -34
  51. package/dist/button-group/index.d.ts.map +0 -1
  52. package/dist/button-group/types.d.ts +0 -75
  53. package/dist/button-group/types.d.ts.map +0 -1
  54. package/dist/card/index.d.ts +0 -71
  55. package/dist/card/index.d.ts.map +0 -1
  56. package/dist/card/types.d.ts +0 -136
  57. package/dist/card/types.d.ts.map +0 -1
  58. package/dist/carousel/carousel-navigation.d.ts +0 -9
  59. package/dist/carousel/carousel-navigation.d.ts.map +0 -1
  60. package/dist/carousel/index.d.ts +0 -50
  61. package/dist/carousel/index.d.ts.map +0 -1
  62. package/dist/cascader/index.d.ts +0 -27
  63. package/dist/cascader/index.d.ts.map +0 -1
  64. package/dist/cascader/types.d.ts +0 -220
  65. package/dist/cascader/types.d.ts.map +0 -1
  66. package/dist/checkbox/index.d.ts +0 -6
  67. package/dist/checkbox/index.d.ts.map +0 -1
  68. package/dist/checkbox/types.d.ts +0 -21
  69. package/dist/checkbox/types.d.ts.map +0 -1
  70. package/dist/checkbox-group/index.d.ts +0 -6
  71. package/dist/checkbox-group/index.d.ts.map +0 -1
  72. package/dist/checkbox-group/types.d.ts +0 -43
  73. package/dist/checkbox-group/types.d.ts.map +0 -1
  74. package/dist/chunk-2REG4OUB.js.map +0 -1
  75. package/dist/chunk-GIWG6BCT.js.map +0 -1
  76. package/dist/chunk-I7MESP7F.js.map +0 -1
  77. package/dist/chunk-QC7XNMM7.js.map +0 -1
  78. package/dist/chunk-RLYGJN56.js.map +0 -1
  79. package/dist/chunk-VKLDLJXG.js.map +0 -1
  80. package/dist/clipboard/index.d.ts +0 -6
  81. package/dist/clipboard/index.d.ts.map +0 -1
  82. package/dist/clipboard/types.d.ts +0 -65
  83. package/dist/clipboard/types.d.ts.map +0 -1
  84. package/dist/collapse/index.d.ts +0 -6
  85. package/dist/collapse/index.d.ts.map +0 -1
  86. package/dist/collapse/types.d.ts +0 -60
  87. package/dist/collapse/types.d.ts.map +0 -1
  88. package/dist/command/index.d.ts +0 -74
  89. package/dist/command/index.d.ts.map +0 -1
  90. package/dist/command/types.d.ts +0 -24
  91. package/dist/command/types.d.ts.map +0 -1
  92. package/dist/context-menu/index.d.ts +0 -63
  93. package/dist/context-menu/index.d.ts.map +0 -1
  94. package/dist/context-menu/types.d.ts +0 -109
  95. package/dist/context-menu/types.d.ts.map +0 -1
  96. package/dist/date-picker/index.d.ts +0 -12
  97. package/dist/date-picker/index.d.ts.map +0 -1
  98. package/dist/date-picker/types.d.ts +0 -66
  99. package/dist/date-picker/types.d.ts.map +0 -1
  100. package/dist/date-picker/utils.d.ts +0 -10
  101. package/dist/date-picker/utils.d.ts.map +0 -1
  102. package/dist/descriptions/index.d.ts +0 -6
  103. package/dist/descriptions/index.d.ts.map +0 -1
  104. package/dist/descriptions/types.d.ts +0 -34
  105. package/dist/descriptions/types.d.ts.map +0 -1
  106. package/dist/divider/index.d.ts +0 -39
  107. package/dist/divider/index.d.ts.map +0 -1
  108. package/dist/divider/types.d.ts +0 -63
  109. package/dist/divider/types.d.ts.map +0 -1
  110. package/dist/drawer/index.d.ts +0 -23
  111. package/dist/drawer/index.d.ts.map +0 -1
  112. package/dist/drawer/types.d.ts +0 -309
  113. package/dist/drawer/types.d.ts.map +0 -1
  114. package/dist/dropdown/index.d.ts +0 -6
  115. package/dist/dropdown/index.d.ts.map +0 -1
  116. package/dist/dropdown/types.d.ts +0 -116
  117. package/dist/dropdown/types.d.ts.map +0 -1
  118. package/dist/empty/index.d.ts +0 -6
  119. package/dist/empty/index.d.ts.map +0 -1
  120. package/dist/empty/types.d.ts +0 -62
  121. package/dist/empty/types.d.ts.map +0 -1
  122. package/dist/fetching-overlay/index.d.ts +0 -10
  123. package/dist/fetching-overlay/index.d.ts.map +0 -1
  124. package/dist/float-input/index.d.ts +0 -6
  125. package/dist/float-input/index.d.ts.map +0 -1
  126. package/dist/float-input/types.d.ts +0 -23
  127. package/dist/float-input/types.d.ts.map +0 -1
  128. package/dist/form/index.d.ts +0 -31
  129. package/dist/form/index.d.ts.map +0 -1
  130. package/dist/form/types.d.ts +0 -45
  131. package/dist/form/types.d.ts.map +0 -1
  132. package/dist/grid/index.d.ts +0 -6
  133. package/dist/grid/index.d.ts.map +0 -1
  134. package/dist/grid/types.d.ts +0 -21
  135. package/dist/grid/types.d.ts.map +0 -1
  136. package/dist/image/index.d.ts +0 -6
  137. package/dist/image/index.d.ts.map +0 -1
  138. package/dist/image/types.d.ts +0 -53
  139. package/dist/image/types.d.ts.map +0 -1
  140. package/dist/index.d.ts +0 -139
  141. package/dist/index.d.ts.map +0 -1
  142. package/dist/input/index.d.ts +0 -6
  143. package/dist/input/index.d.ts.map +0 -1
  144. package/dist/input/types.d.ts +0 -28
  145. package/dist/input/types.d.ts.map +0 -1
  146. package/dist/input-group/index.d.ts +0 -9
  147. package/dist/input-group/index.d.ts.map +0 -1
  148. package/dist/input-group/types.d.ts +0 -68
  149. package/dist/input-group/types.d.ts.map +0 -1
  150. package/dist/input-otp/index.d.ts +0 -7
  151. package/dist/input-otp/index.d.ts.map +0 -1
  152. package/dist/input-otp/types.d.ts +0 -111
  153. package/dist/input-otp/types.d.ts.map +0 -1
  154. package/dist/input-password/index.d.ts +0 -7
  155. package/dist/input-password/index.d.ts.map +0 -1
  156. package/dist/input-password/types.d.ts +0 -34
  157. package/dist/input-password/types.d.ts.map +0 -1
  158. package/dist/kbd/index.d.ts +0 -6
  159. package/dist/kbd/index.d.ts.map +0 -1
  160. package/dist/kbd/types.d.ts +0 -26
  161. package/dist/kbd/types.d.ts.map +0 -1
  162. package/dist/link/index.d.ts +0 -9
  163. package/dist/link/index.d.ts.map +0 -1
  164. package/dist/link/types.d.ts +0 -30
  165. package/dist/link/types.d.ts.map +0 -1
  166. package/dist/menubar/index.d.ts +0 -6
  167. package/dist/menubar/index.d.ts.map +0 -1
  168. package/dist/menubar/types.d.ts +0 -40
  169. package/dist/menubar/types.d.ts.map +0 -1
  170. package/dist/modal/index.d.ts +0 -39
  171. package/dist/modal/index.d.ts.map +0 -1
  172. package/dist/modal/types.d.ts +0 -77
  173. package/dist/modal/types.d.ts.map +0 -1
  174. package/dist/multi-select/index.d.ts +0 -6
  175. package/dist/multi-select/index.d.ts.map +0 -1
  176. package/dist/multi-select/types.d.ts +0 -81
  177. package/dist/multi-select/types.d.ts.map +0 -1
  178. package/dist/multi-select/utils.d.ts +0 -12
  179. package/dist/multi-select/utils.d.ts.map +0 -1
  180. package/dist/navigation-menu/index.d.ts +0 -5
  181. package/dist/navigation-menu/index.d.ts.map +0 -1
  182. package/dist/navigation-menu/types.d.ts +0 -37
  183. package/dist/navigation-menu/types.d.ts.map +0 -1
  184. package/dist/notification/index.d.ts +0 -6
  185. package/dist/notification/index.d.ts.map +0 -1
  186. package/dist/notification/types.d.ts +0 -90
  187. package/dist/notification/types.d.ts.map +0 -1
  188. package/dist/number-input/index.d.ts +0 -6
  189. package/dist/number-input/index.d.ts.map +0 -1
  190. package/dist/number-input/types.d.ts +0 -28
  191. package/dist/number-input/types.d.ts.map +0 -1
  192. package/dist/pagination/index.d.ts +0 -6
  193. package/dist/pagination/index.d.ts.map +0 -1
  194. package/dist/pagination/types.d.ts +0 -87
  195. package/dist/pagination/types.d.ts.map +0 -1
  196. package/dist/popover/index.d.ts +0 -19
  197. package/dist/popover/index.d.ts.map +0 -1
  198. package/dist/popover/types.d.ts +0 -31
  199. package/dist/popover/types.d.ts.map +0 -1
  200. package/dist/progress/index.d.ts +0 -6
  201. package/dist/progress/index.d.ts.map +0 -1
  202. package/dist/progress/types.d.ts +0 -100
  203. package/dist/progress/types.d.ts.map +0 -1
  204. package/dist/radio/index.d.ts +0 -6
  205. package/dist/radio/index.d.ts.map +0 -1
  206. package/dist/radio/types.d.ts +0 -20
  207. package/dist/radio/types.d.ts.map +0 -1
  208. package/dist/radio-group/index.d.ts +0 -6
  209. package/dist/radio-group/index.d.ts.map +0 -1
  210. package/dist/radio-group/types.d.ts +0 -43
  211. package/dist/radio-group/types.d.ts.map +0 -1
  212. package/dist/rating/index.d.ts +0 -6
  213. package/dist/rating/index.d.ts.map +0 -1
  214. package/dist/rating/types.d.ts +0 -64
  215. package/dist/rating/types.d.ts.map +0 -1
  216. package/dist/ribbon/index.d.ts +0 -6
  217. package/dist/ribbon/index.d.ts.map +0 -1
  218. package/dist/ribbon/types.d.ts +0 -26
  219. package/dist/ribbon/types.d.ts.map +0 -1
  220. package/dist/scroll-area/index.d.ts +0 -10
  221. package/dist/scroll-area/index.d.ts.map +0 -1
  222. package/dist/scroll-area/types.d.ts +0 -24
  223. package/dist/scroll-area/types.d.ts.map +0 -1
  224. package/dist/select/index.d.ts +0 -6
  225. package/dist/select/index.d.ts.map +0 -1
  226. package/dist/select/types.d.ts +0 -34
  227. package/dist/select/types.d.ts.map +0 -1
  228. package/dist/skeleton/index.d.ts +0 -6
  229. package/dist/skeleton/index.d.ts.map +0 -1
  230. package/dist/skeleton/types.d.ts +0 -10
  231. package/dist/skeleton/types.d.ts.map +0 -1
  232. package/dist/slider/index.d.ts +0 -6
  233. package/dist/slider/index.d.ts.map +0 -1
  234. package/dist/slider/types.d.ts +0 -70
  235. package/dist/slider/types.d.ts.map +0 -1
  236. package/dist/spinner/index.d.ts +0 -6
  237. package/dist/spinner/index.d.ts.map +0 -1
  238. package/dist/spinner/types.d.ts +0 -10
  239. package/dist/spinner/types.d.ts.map +0 -1
  240. package/dist/stepper/index.d.ts +0 -6
  241. package/dist/stepper/index.d.ts.map +0 -1
  242. package/dist/stepper/types.d.ts +0 -86
  243. package/dist/stepper/types.d.ts.map +0 -1
  244. package/dist/styles/global.css +0 -7651
  245. package/dist/styles/themes/dark.css +0 -93
  246. package/dist/styles/themes/index.d.ts +0 -9
  247. package/dist/styles/themes/index.d.ts.map +0 -1
  248. package/dist/styles/themes/light.css +0 -89
  249. package/dist/styles/themes/presets/corporate.css +0 -126
  250. package/dist/styles/themes/presets/index.d.ts +0 -21
  251. package/dist/styles/themes/presets/index.d.ts.map +0 -1
  252. package/dist/styles/themes/presets/minimal.css +0 -126
  253. package/dist/styles/themes/presets/vibrant.css +0 -126
  254. package/dist/styles/tokens.d.ts +0 -428
  255. package/dist/styles/tokens.d.ts.map +0 -1
  256. package/dist/switch/index.d.ts +0 -6
  257. package/dist/switch/index.d.ts.map +0 -1
  258. package/dist/switch/types.d.ts +0 -80
  259. package/dist/switch/types.d.ts.map +0 -1
  260. package/dist/table/EditableCell.d.ts +0 -13
  261. package/dist/table/EditableCell.d.ts.map +0 -1
  262. package/dist/table/TableActions.d.ts +0 -21
  263. package/dist/table/TableActions.d.ts.map +0 -1
  264. package/dist/table/TableCell.d.ts +0 -12
  265. package/dist/table/TableCell.d.ts.map +0 -1
  266. package/dist/table/TableHeaderCell.d.ts +0 -16
  267. package/dist/table/TableHeaderCell.d.ts.map +0 -1
  268. package/dist/table/TableRow.d.ts +0 -16
  269. package/dist/table/TableRow.d.ts.map +0 -1
  270. package/dist/table/TableSkeleton.d.ts +0 -13
  271. package/dist/table/TableSkeleton.d.ts.map +0 -1
  272. package/dist/table/index.d.ts +0 -15
  273. package/dist/table/index.d.ts.map +0 -1
  274. package/dist/table/types.d.ts +0 -110
  275. package/dist/table/types.d.ts.map +0 -1
  276. package/dist/table/variants.d.ts +0 -8
  277. package/dist/table/variants.d.ts.map +0 -1
  278. package/dist/tabs/index.d.ts +0 -7
  279. package/dist/tabs/index.d.ts.map +0 -1
  280. package/dist/tabs/types.d.ts +0 -86
  281. package/dist/tabs/types.d.ts.map +0 -1
  282. package/dist/tag/index.d.ts +0 -49
  283. package/dist/tag/index.d.ts.map +0 -1
  284. package/dist/tag/types.d.ts +0 -23
  285. package/dist/tag/types.d.ts.map +0 -1
  286. package/dist/textarea/index.d.ts +0 -6
  287. package/dist/textarea/index.d.ts.map +0 -1
  288. package/dist/textarea/types.d.ts +0 -84
  289. package/dist/textarea/types.d.ts.map +0 -1
  290. package/dist/theme/ThemeProvider.d.ts +0 -44
  291. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  292. package/dist/theme/index.d.ts +0 -7
  293. package/dist/theme/index.d.ts.map +0 -1
  294. package/dist/theme/types.d.ts +0 -47
  295. package/dist/theme/types.d.ts.map +0 -1
  296. package/dist/timeline/index.d.ts +0 -13
  297. package/dist/timeline/index.d.ts.map +0 -1
  298. package/dist/timeline/types.d.ts +0 -25
  299. package/dist/timeline/types.d.ts.map +0 -1
  300. package/dist/toast/index.d.ts +0 -12
  301. package/dist/toast/index.d.ts.map +0 -1
  302. package/dist/toast/types.d.ts +0 -49
  303. package/dist/toast/types.d.ts.map +0 -1
  304. package/dist/toggle/index.d.ts +0 -6
  305. package/dist/toggle/index.d.ts.map +0 -1
  306. package/dist/toggle/types.d.ts +0 -57
  307. package/dist/toggle/types.d.ts.map +0 -1
  308. package/dist/toggle-group/index.d.ts +0 -6
  309. package/dist/toggle-group/index.d.ts.map +0 -1
  310. package/dist/toggle-group/types.d.ts +0 -80
  311. package/dist/toggle-group/types.d.ts.map +0 -1
  312. package/dist/tooltip/index.d.ts +0 -9
  313. package/dist/tooltip/index.d.ts.map +0 -1
  314. package/dist/tooltip/types.d.ts +0 -72
  315. package/dist/tooltip/types.d.ts.map +0 -1
  316. package/dist/transfer/index.d.ts +0 -6
  317. package/dist/transfer/index.d.ts.map +0 -1
  318. package/dist/transfer/types.d.ts +0 -83
  319. package/dist/transfer/types.d.ts.map +0 -1
  320. package/dist/transfer/utils.d.ts +0 -13
  321. package/dist/transfer/utils.d.ts.map +0 -1
  322. package/dist/tree/index.d.ts +0 -6
  323. package/dist/tree/index.d.ts.map +0 -1
  324. package/dist/tree/types.d.ts +0 -143
  325. package/dist/tree/types.d.ts.map +0 -1
  326. package/dist/tree-select/index.d.ts +0 -6
  327. package/dist/tree-select/index.d.ts.map +0 -1
  328. package/dist/tree-select/types.d.ts +0 -147
  329. package/dist/tree-select/types.d.ts.map +0 -1
  330. package/dist/types.d.ts +0 -53
  331. package/dist/types.d.ts.map +0 -1
  332. package/dist/upload/index.d.ts +0 -7
  333. package/dist/upload/index.d.ts.map +0 -1
  334. package/dist/upload/types.d.ts +0 -94
  335. package/dist/upload/types.d.ts.map +0 -1
  336. package/dist/upload/utils.d.ts +0 -26
  337. package/dist/upload/utils.d.ts.map +0 -1
  338. package/dist/utils.d.ts +0 -63
  339. package/dist/utils.d.ts.map +0 -1
  340. package/dist/variants.d.ts +0 -434
  341. package/dist/variants.d.ts.map +0 -1
@@ -88,7 +88,9 @@ var Select = React.memo(
88
88
  const [parentNode, setParentNode] = React.useState(
89
89
  null
90
90
  );
91
- const [internalValue, setInternalValue] = React.useState(defaultValue || "");
91
+ const [internalValue, setInternalValue] = React.useState(
92
+ defaultValue || ""
93
+ );
92
94
  const [searchQuery, setSearchQuery] = React.useState("");
93
95
  const [highlightedIndex, setHighlightedIndex] = React.useState(-1);
94
96
  const [showTopArrow, setShowTopArrow] = React.useState(false);
@@ -223,7 +225,10 @@ var Select = React.memo(
223
225
  case "ArrowDown":
224
226
  e.preventDefault();
225
227
  setHighlightedIndex((prev) => {
226
- const nextIndex = Math.min(prev + 1, selectableOptions.length - 1);
228
+ const nextIndex = Math.min(
229
+ prev + 1,
230
+ selectableOptions.length - 1
231
+ );
227
232
  const option = selectableOptions[nextIndex];
228
233
  if (option) {
229
234
  const optionIndex = filteredOptions.indexOf(option);
@@ -328,7 +333,11 @@ var Select = React.memo(
328
333
  "div",
329
334
  {
330
335
  "data-slot": "empty",
331
- className: cn("select_empty", "px-3 py-4 text-center text-sm text-text-secondary", classNames?.empty),
336
+ className: cn(
337
+ "select_empty",
338
+ "px-3 py-4 text-center text-sm text-text-secondary",
339
+ classNames?.empty
340
+ ),
332
341
  children: "No options found"
333
342
  }
334
343
  ) : shouldVirtualize ? /* @__PURE__ */ jsx(
@@ -364,12 +373,19 @@ var Select = React.memo(
364
373
  height: `${virtualItem.size}px`,
365
374
  transform: `translateY(${virtualItem.start}px)`
366
375
  },
367
- className: cn("select_group", selectGroupVariants(), classNames?.group),
376
+ className: cn(
377
+ "select_group",
378
+ selectGroupVariants(),
379
+ classNames?.group
380
+ ),
368
381
  children: /* @__PURE__ */ jsx(
369
382
  "span",
370
383
  {
371
384
  "data-slot": "groupLabel",
372
- className: cn("select_groupLabel", classNames?.groupLabel),
385
+ className: cn(
386
+ "select_groupLabel",
387
+ classNames?.groupLabel
388
+ ),
373
389
  children: item.data
374
390
  }
375
391
  )
@@ -417,7 +433,10 @@ var Select = React.memo(
417
433
  isSelected && /* @__PURE__ */ jsx("span", { className: "absolute right-3 top-1/2 -translate-y-1/2", children: /* @__PURE__ */ jsx(
418
434
  Check,
419
435
  {
420
- className: cn("text-primary animate-in zoom-in-75 duration-150", iconSizes[size])
436
+ className: cn(
437
+ "text-primary animate-in zoom-in-75 duration-150",
438
+ iconSizes[size]
439
+ )
421
440
  }
422
441
  ) })
423
442
  ]
@@ -434,12 +453,19 @@ var Select = React.memo(
434
453
  "div",
435
454
  {
436
455
  "data-slot": "group",
437
- className: cn("select_group", selectGroupVariants(), classNames?.group),
456
+ className: cn(
457
+ "select_group",
458
+ selectGroupVariants(),
459
+ classNames?.group
460
+ ),
438
461
  children: /* @__PURE__ */ jsx(
439
462
  "span",
440
463
  {
441
464
  "data-slot": "groupLabel",
442
- className: cn("select_groupLabel", classNames?.groupLabel),
465
+ className: cn(
466
+ "select_groupLabel",
467
+ classNames?.groupLabel
468
+ ),
443
469
  children: item.data
444
470
  }
445
471
  )
@@ -479,7 +505,10 @@ var Select = React.memo(
479
505
  isSelected && /* @__PURE__ */ jsx("span", { className: "absolute right-3 top-1/2 -translate-y-1/2", children: /* @__PURE__ */ jsx(
480
506
  Check,
481
507
  {
482
- className: cn("text-primary animate-in zoom-in-75 duration-150", iconSizes[size])
508
+ className: cn(
509
+ "text-primary animate-in zoom-in-75 duration-150",
510
+ iconSizes[size]
511
+ )
483
512
  }
484
513
  ) })
485
514
  ]
@@ -518,7 +547,11 @@ var Select = React.memo(
518
547
  ref: inputRef,
519
548
  type: "text",
520
549
  "data-slot": "search",
521
- className: cn("select_search", "w-full text-ellipsis flex-1 bg-transparent outline-none cursor-pointer placeholder:text-text-secondary/50", classNames?.search),
550
+ className: cn(
551
+ "select_search",
552
+ "w-full text-ellipsis flex-1 bg-transparent outline-none cursor-pointer placeholder:text-text-secondary/50",
553
+ classNames?.search
554
+ ),
522
555
  placeholder,
523
556
  value: displayValue,
524
557
  onChange: handleInputChange,
@@ -535,7 +568,11 @@ var Select = React.memo(
535
568
  "div",
536
569
  {
537
570
  "data-slot": "triggerIcon",
538
- className: cn("select_triggerIcon", "flex items-center gap-1 text-text-secondary", classNames?.triggerIcon),
571
+ className: cn(
572
+ "select_triggerIcon",
573
+ "flex items-center gap-1 text-text-secondary",
574
+ classNames?.triggerIcon
575
+ ),
539
576
  children: [
540
577
  clearable && currentValue && !disabled && !loading && /* @__PURE__ */ jsx(
541
578
  "button",
@@ -558,35 +595,36 @@ var Select = React.memo(
558
595
  "div",
559
596
  {
560
597
  "data-slot": "root",
561
- className: cn("select_root", "relative group", fullWidth ? "w-full" : "inline-block", classNames?.root),
598
+ className: cn(
599
+ "select_root",
600
+ "relative group",
601
+ fullWidth ? "w-full" : "inline-block",
602
+ classNames?.root
603
+ ),
562
604
  ref,
563
605
  ...props,
564
- children: /* @__PURE__ */ jsxs(
565
- Popover,
566
- {
567
- open: isOpen,
568
- onOpenChange: setIsOpen,
569
- children: [
570
- /* @__PURE__ */ jsx(PopoverTrigger, { asChild: true, children: triggerButton }),
571
- /* @__PURE__ */ jsx(
572
- PopoverContent,
573
- {
574
- "data-slot": "dropdown",
575
- className: cn("select_dropdown", "p-0 w-[var(--radix-popover-trigger-width)]", classNames?.dropdown),
576
- align: "start",
577
- onOpenAutoFocus: (e) => {
578
- e.preventDefault();
579
- inputRef.current?.focus();
580
- },
581
- children: renderOptionsList()
582
- }
583
- )
584
- ]
585
- }
586
- )
606
+ children: /* @__PURE__ */ jsxs(Popover, { open: isOpen, onOpenChange: setIsOpen, children: [
607
+ /* @__PURE__ */ jsx(PopoverTrigger, { asChild: true, children: triggerButton }),
608
+ /* @__PURE__ */ jsx(
609
+ PopoverContent,
610
+ {
611
+ "data-slot": "dropdown",
612
+ className: cn(
613
+ "select_dropdown",
614
+ "p-0 w-[var(--radix-popover-trigger-width)]",
615
+ classNames?.dropdown
616
+ ),
617
+ align: "start",
618
+ onOpenAutoFocus: (e) => {
619
+ e.preventDefault();
620
+ inputRef.current?.focus();
621
+ },
622
+ children: renderOptionsList()
623
+ }
624
+ )
625
+ ] })
587
626
  }
588
627
  );
589
- if (!label && !helperText && !error) return selectElement;
590
628
  return /* @__PURE__ */ jsxs("div", { className: cn("w-full flex flex-col", !fullWidth && "inline-block"), children: [
591
629
  /* @__PURE__ */ jsxs("div", { className: "flex gap-2 items-center", children: [
592
630
  label && /* @__PURE__ */ jsx(
@@ -606,7 +644,11 @@ var Select = React.memo(
606
644
  {
607
645
  id: helperId,
608
646
  "data-slot": "helper",
609
- className: cn("select_helper", statusMessageVariants({ status }), classNames?.helper),
647
+ className: cn(
648
+ "select_helper",
649
+ statusMessageVariants({ status }),
650
+ classNames?.helper
651
+ ),
610
652
  children: helperMessage
611
653
  }
612
654
  )
@@ -619,5 +661,5 @@ Select.displayName = "Select";
619
661
  var select_default = Select;
620
662
 
621
663
  export { select_default };
622
- //# sourceMappingURL=chunk-QC7XNMM7.js.map
623
- //# sourceMappingURL=chunk-QC7XNMM7.js.map
664
+ //# sourceMappingURL=chunk-ZESEEYEJ.js.map
665
+ //# sourceMappingURL=chunk-ZESEEYEJ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/select/index.tsx"],"names":[],"mappings":"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","file":"chunk-ZESEEYEJ.js","sourcesContent":["\"use client\";\n\nimport { useVirtualizer } from \"@tanstack/react-virtual\";\nimport { cva } from \"class-variance-authority\";\nimport { Check, ChevronDown, ChevronUp, Search, X } from \"lucide-react\";\nimport React, { useCallback, useId } from \"react\";\n\nimport Spinner from \"../spinner\";\n\nimport { Popover, PopoverContent, PopoverTrigger } from \"../popover\";\nimport {\n cn,\n getValidationStatus,\n iconSizes,\n statusMessageVariants,\n} from \"../utils\";\nimport type { SelectOption, SelectProps } from \"./types\";\n\nconst selectTriggerVariants = 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 transition-colors\",\n {\n variants: {\n status: {\n default: \"border-border hover:border-primary/50\",\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 gap-1.5\",\n sm: \"h-(--select-height-sm) px-(--select-padding-x-sm) text-sm gap-2\",\n md: \"h-(--select-height-md) px-(--select-padding-x-md) text-base gap-2\",\n lg: \"h-(--select-height-lg) px-(--select-padding-x-lg) text-lg gap-3\",\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\nconst selectOptionVariants = cva(\n \"relative cursor-pointer select-none px-3 py-2 text-text-primary rounded-sm transition-colors\",\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\nconst selectGroupVariants = cva(\n \"px-3 py-2 text-xs font-semibold text-text-secondary uppercase tracking-wider bg-surface/50\",\n);\n\nconst Select = React.memo<SelectProps>(\n ({\n size = \"md\",\n label,\n helperText,\n error,\n warning,\n info,\n success,\n options = [],\n placeholder = \"Select an option\",\n loading = false,\n fullWidth = true,\n value,\n defaultValue,\n onChange,\n clearable = false,\n disabled,\n required,\n virtualizeThreshold = 50,\n maxDropdownHeight = 300,\n className,\n classNames,\n ref,\n ...props\n }) => {\n const [isOpen, setIsOpen] = React.useState(false);\n const [parentNode, setParentNode] = React.useState<HTMLDivElement | null>(\n null,\n );\n const [internalValue, setInternalValue] = React.useState<string | number>(\n defaultValue || \"\",\n );\n const [searchQuery, setSearchQuery] = React.useState(\"\");\n const [highlightedIndex, setHighlightedIndex] = React.useState(-1);\n const [showTopArrow, setShowTopArrow] = React.useState(false);\n const [showBottomArrow, setShowBottomArrow] = React.useState(false);\n\n const triggerRef = React.useRef<HTMLButtonElement>(null);\n const inputRef = React.useRef<HTMLInputElement>(null);\n const scrollContainerRef = React.useRef<HTMLDivElement>(null);\n const currentValue = value !== undefined ? value : internalValue;\n\n // Generate unique IDs for accessibility\n const uniqueId = useId();\n const labelId = `select-label-${uniqueId}`;\n const listboxId = `select-listbox-${uniqueId}`;\n const helperId = `select-helper-${uniqueId}`;\n\n // Use shared validation status utility\n const { status, message: helperMessage } = getValidationStatus({\n error,\n warning,\n info,\n success,\n helperText,\n });\n\n const groupedOptions = React.useMemo(() => {\n const groups: Record<string, SelectOption[]> = {};\n const ungrouped: SelectOption[] = [];\n\n options.forEach((option) => {\n if (option.group) {\n if (!groups[option.group]) {\n groups[option.group] = [];\n }\n groups[option.group]!.push(option);\n } else {\n ungrouped.push(option);\n }\n });\n\n return { groups, ungrouped };\n }, [options]);\n\n const flattenedOptions = React.useMemo(() => {\n const items: Array<{\n type: \"option\" | \"group\";\n data: SelectOption | string;\n }> = [];\n\n groupedOptions.ungrouped.forEach((option) => {\n items.push({ type: \"option\", data: option });\n });\n\n Object.entries(groupedOptions.groups).forEach(\n ([groupName, groupOptions]) => {\n items.push({ type: \"group\", data: groupName });\n groupOptions.forEach((option) => {\n items.push({ type: \"option\", data: option });\n });\n },\n );\n\n return items;\n }, [groupedOptions]);\n\n const filteredOptions = React.useMemo(() => {\n if (!searchQuery) return flattenedOptions;\n\n return flattenedOptions.filter((item) => {\n if (item.type === \"group\") return true;\n const option = item.data as SelectOption;\n return option.label.toLowerCase().includes(searchQuery.toLowerCase());\n });\n }, [flattenedOptions, searchQuery]);\n\n const shouldVirtualize = filteredOptions.length > virtualizeThreshold;\n\n const virtualizer = useVirtualizer({\n count: filteredOptions.length,\n getScrollElement: () => parentNode,\n estimateSize: () => 40,\n enabled: shouldVirtualize,\n overscan: 10,\n });\n\n // Store virtualizer in ref to avoid recreating handleKeyDown on every render\n const virtualizerRef = React.useRef(virtualizer);\n React.useEffect(() => {\n virtualizerRef.current = virtualizer;\n }, [virtualizer]);\n\n const refCallback = useCallback((node: HTMLDivElement) => {\n if (node) {\n setParentNode(node);\n // Also set as scroll container for virtualized lists\n scrollContainerRef.current = node;\n }\n }, []);\n\n const selectedOption = options.find((opt) => opt.value === currentValue);\n const displayValue = isOpen ? searchQuery : selectedOption?.label || \"\";\n\n const handleSelect = React.useCallback(\n (optionValue: string | number) => {\n if (value === undefined) {\n setInternalValue(optionValue);\n }\n onChange?.(optionValue);\n setIsOpen(false);\n setSearchQuery(\"\");\n setHighlightedIndex(-1);\n },\n [value, onChange],\n );\n\n const handleClear = React.useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation();\n if (value === undefined) {\n setInternalValue(\"\");\n }\n onChange?.(\"\");\n setSearchQuery(\"\");\n setHighlightedIndex(-1);\n },\n [value, onChange],\n );\n\n const handleInputChange = React.useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n setSearchQuery(e.target.value);\n if (!isOpen) setIsOpen(true);\n },\n [isOpen],\n );\n\n const handleInputFocus = React.useCallback(() => {\n setIsOpen(true);\n }, []);\n\n const handleKeyDown = React.useCallback(\n (e: React.KeyboardEvent) => {\n if (!isOpen && e.key !== \"Tab\") {\n if (e.key === \"Enter\" || e.key === \" \" || e.key === \"ArrowDown\") {\n e.preventDefault();\n setIsOpen(true);\n }\n return;\n }\n\n const selectableOptions = filteredOptions.filter(\n (item) =>\n item.type === \"option\" && !(item.data as SelectOption).disabled,\n );\n\n switch (e.key) {\n case \"Escape\":\n e.preventDefault();\n setIsOpen(false);\n setSearchQuery(\"\");\n setHighlightedIndex(-1);\n inputRef.current?.blur();\n break;\n\n case \"ArrowDown\":\n e.preventDefault();\n setHighlightedIndex((prev) => {\n const nextIndex = Math.min(\n prev + 1,\n selectableOptions.length - 1,\n );\n const option = selectableOptions[nextIndex];\n if (option) {\n const optionIndex = filteredOptions.indexOf(option);\n if (shouldVirtualize && virtualizerRef.current) {\n virtualizerRef.current.scrollToIndex(optionIndex, {\n align: \"auto\",\n });\n }\n }\n return nextIndex;\n });\n break;\n\n case \"ArrowUp\":\n e.preventDefault();\n setHighlightedIndex((prev) => {\n const nextIndex = Math.max(prev - 1, 0);\n const option = selectableOptions[nextIndex];\n if (option) {\n const optionIndex = filteredOptions.indexOf(option);\n if (shouldVirtualize && virtualizerRef.current) {\n virtualizerRef.current.scrollToIndex(optionIndex, {\n align: \"auto\",\n });\n }\n }\n return nextIndex;\n });\n break;\n\n case \"Enter\":\n e.preventDefault();\n if (\n highlightedIndex >= 0 &&\n highlightedIndex < selectableOptions.length\n ) {\n const item = selectableOptions[highlightedIndex];\n if (item) {\n const option = item.data as SelectOption;\n handleSelect(option.value);\n }\n }\n break;\n\n case \"Home\":\n e.preventDefault();\n setHighlightedIndex(0);\n if (shouldVirtualize && virtualizerRef.current) {\n virtualizerRef.current.scrollToIndex(0);\n }\n break;\n\n case \"End\":\n e.preventDefault();\n setHighlightedIndex(selectableOptions.length - 1);\n if (shouldVirtualize && virtualizerRef.current) {\n virtualizerRef.current.scrollToIndex(filteredOptions.length - 1);\n }\n break;\n\n default:\n break;\n }\n },\n [\n isOpen,\n filteredOptions,\n highlightedIndex,\n handleSelect,\n shouldVirtualize,\n ],\n );\n\n // Handle scroll to update arrow visibility\n const handleScroll = React.useCallback(\n (e: React.UIEvent<HTMLDivElement>) => {\n const element = e.currentTarget;\n const { scrollTop, scrollHeight, clientHeight } = element;\n\n setShowTopArrow(scrollTop > 0);\n setShowBottomArrow(scrollTop + clientHeight < scrollHeight - 1);\n },\n [],\n );\n\n // Check initial scroll state when dropdown opens\n React.useEffect(() => {\n if (isOpen) {\n // Use a small delay to ensure the DOM is fully rendered\n const timeoutId = setTimeout(() => {\n const element = scrollContainerRef.current;\n if (element) {\n const { scrollTop, scrollHeight, clientHeight } = element;\n setShowTopArrow(scrollTop > 0);\n setShowBottomArrow(scrollTop + clientHeight < scrollHeight - 1);\n }\n }, 50);\n\n return () => clearTimeout(timeoutId);\n } else {\n setShowTopArrow(false);\n setShowBottomArrow(false);\n return undefined;\n }\n }, [isOpen, filteredOptions, shouldVirtualize]);\n\n const renderOptionsList = () => (\n <div className=\"relative\">\n {/* Top scroll indicator */}\n <div className=\"flex items-center justify-center h-4\">\n {showTopArrow && (\n <ChevronUp className=\"size-4 text-text-primary animate-in fade-in duration-150\" />\n )}\n </div>\n\n <div\n ref={scrollContainerRef}\n className=\"overflow-auto relative\"\n style={{ maxHeight: maxDropdownHeight }}\n role=\"listbox\"\n id={listboxId}\n aria-labelledby={label ? labelId : undefined}\n onScroll={handleScroll}\n >\n {!filteredOptions.length ? (\n <div\n data-slot=\"empty\"\n className={cn(\n \"select_empty\",\n \"px-3 py-4 text-center text-sm text-text-secondary\",\n classNames?.empty,\n )}\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) return null;\n\n if (item.type === \"group\") {\n return (\n <div\n key={`group-${virtualItem.index}`}\n data-slot=\"group\"\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 \"select_group\",\n selectGroupVariants(),\n classNames?.group,\n )}\n >\n <span\n data-slot=\"groupLabel\"\n className={cn(\n \"select_groupLabel\",\n classNames?.groupLabel,\n )}\n >\n {item.data as string}\n </span>\n </div>\n );\n }\n\n const option = item.data as SelectOption;\n const isSelected = option.value === currentValue;\n const selectableOptions = filteredOptions.filter(\n (i) =>\n i.type === \"option\" && !(i.data as SelectOption).disabled,\n );\n const selectableIndex = selectableOptions.findIndex(\n (i) => i === item,\n );\n const isHighlighted = selectableIndex === highlightedIndex;\n\n return (\n <div\n key={option.value}\n data-slot=\"option\"\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 \"select_option\",\n selectOptionVariants({\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 >\n {option.label}\n {isSelected && (\n <span className=\"absolute right-3 top-1/2 -translate-y-1/2\">\n <Check\n className={cn(\n \"text-primary animate-in zoom-in-75 duration-150\",\n iconSizes[size],\n )}\n />\n </span>\n )}\n </div>\n );\n })}\n </div>\n </div>\n ) : (\n <div className=\"py-1\">\n {filteredOptions.map((item, index) => {\n if (item.type === \"group\") {\n return (\n <div\n key={`group-${index}`}\n data-slot=\"group\"\n className={cn(\n \"select_group\",\n selectGroupVariants(),\n classNames?.group,\n )}\n >\n <span\n data-slot=\"groupLabel\"\n className={cn(\n \"select_groupLabel\",\n classNames?.groupLabel,\n )}\n >\n {item.data as string}\n </span>\n </div>\n );\n }\n\n const option = item.data as SelectOption;\n const isSelected = option.value === currentValue;\n const selectableOptions = filteredOptions.filter(\n (i) =>\n i.type === \"option\" && !(i.data as SelectOption).disabled,\n );\n const selectableIndex = selectableOptions.findIndex(\n (i) => i === item,\n );\n const isHighlighted = selectableIndex === highlightedIndex;\n\n return (\n <div\n key={option.value}\n data-slot=\"option\"\n className={cn(\n \"select_option\",\n selectOptionVariants({\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 >\n {option.label}\n {isSelected && (\n <span className=\"absolute right-3 top-1/2 -translate-y-1/2\">\n <Check\n className={cn(\n \"text-primary animate-in zoom-in-75 duration-150\",\n iconSizes[size],\n )}\n />\n </span>\n )}\n </div>\n );\n })}\n </div>\n )}\n </div>\n\n {/* Bottom scroll indicator */}\n <div className=\"flex items-center justify-center h-4\">\n {showBottomArrow && (\n <ChevronDown className=\"size-4 text-text-primary animate-in fade-in duration-150\" />\n )}\n </div>\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 data-slot=\"trigger\"\n className={cn(\n \"select_trigger\",\n selectTriggerVariants({ status, size, fullWidth }),\n loading && \"opacity-50\",\n className,\n classNames?.trigger,\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 onClick={() => setIsOpen(!isOpen)}\n >\n <input\n ref={inputRef}\n type=\"text\"\n data-slot=\"search\"\n className={cn(\n \"select_search\",\n \"w-full text-ellipsis flex-1 bg-transparent outline-none cursor-pointer placeholder:text-text-secondary/50\",\n classNames?.search,\n )}\n placeholder={placeholder}\n value={displayValue}\n onChange={handleInputChange}\n onFocus={handleInputFocus}\n onKeyDown={handleKeyDown}\n disabled={disabled || loading}\n readOnly={!isOpen}\n tabIndex={isOpen ? 0 : -1}\n aria-autocomplete=\"list\"\n aria-controls={isOpen ? listboxId : undefined}\n />\n <div\n data-slot=\"triggerIcon\"\n className={cn(\n \"select_triggerIcon\",\n \"flex items-center gap-1 text-text-secondary\",\n classNames?.triggerIcon,\n )}\n >\n {clearable && currentValue && !disabled && !loading && (\n <button\n type=\"button\"\n onClick={handleClear}\n className=\"hover:text-text-primary transition-colors\"\n aria-label=\"Clear selection\"\n >\n <X className={iconSizes[size]} />\n </button>\n )}\n {loading ? (\n <Spinner />\n ) : (\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 data-slot=\"root\"\n className={cn(\n \"select_root\",\n \"relative group\",\n fullWidth ? \"w-full\" : \"inline-block\",\n classNames?.root,\n )}\n ref={ref}\n {...props}\n >\n <Popover open={isOpen} onOpenChange={setIsOpen}>\n <PopoverTrigger asChild>{triggerButton}</PopoverTrigger>\n\n <PopoverContent\n data-slot=\"dropdown\"\n className={cn(\n \"select_dropdown\",\n \"p-0 w-[var(--radix-popover-trigger-width)]\",\n classNames?.dropdown,\n )}\n align=\"start\"\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 data-slot=\"label\"\n className={cn(\"select_label\", \"block mb-0.5\", classNames?.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 data-slot=\"helper\"\n className={cn(\n \"select_helper\",\n statusMessageVariants({ status }),\n classNames?.helper,\n )}\n >\n {helperMessage}\n </p>\n )}\n </div>\n {selectElement}\n </div>\n );\n },\n);\n\nSelect.displayName = \"Select\";\n\nexport type * from \"./types\";\nexport default Select;\n"]}
@@ -1,4 +1,4 @@
1
- export { float_input_default as default } from '../chunk-I7MESP7F.js';
1
+ export { float_input_default as default } from '../chunk-SB3JGUGE.js';
2
2
  import '../chunk-PHQOHVG3.js';
3
3
  import '../chunk-LK4EPTNG.js';
4
4
  import '../chunk-NGYLRX6F.js';
package/dist/index.js CHANGED
@@ -1,28 +1,28 @@
1
1
  export { tree_select_default as TreeSelect } from './chunk-QLUGKHAA.js';
2
2
  export { tree_default as Tree } from './chunk-HXPMYGSR.js';
3
3
  export { upload_default as Upload } from './chunk-ITCXCSUS.js';
4
- export { textarea_default as Textarea } from './chunk-6JGNJI5T.js';
4
+ export { tag_default as Tag } from './chunk-2SYAIIJE.js';
5
5
  export { ThemeProvider, themeScript, useTheme } from './chunk-5PUATOLR.js';
6
6
  export { ToastProvider, useToast } from './chunk-6YVT3AL2.js';
7
7
  export { timeline_default as Timeline } from './chunk-GGDDE7LC.js';
8
8
  export { toggle_default as Toggle } from './chunk-DUNER5Q3.js';
9
9
  export { tooltip_default as Tooltip, TooltipProvider } from './chunk-MOQDO4XZ.js';
10
- export { Transfer } from './chunk-DHXVNO75.js';
10
+ export { Transfer } from './chunk-XR4UHTK3.js';
11
11
  export { skeleton_default as Skeleton } from './chunk-JZ5F6XDO.js';
12
12
  export { slider_default as Slider } from './chunk-GVEEUHM2.js';
13
13
  export { stepper_default as Stepper } from './chunk-YPHVSPWM.js';
14
- export { switch_default as Switch } from './chunk-2REG4OUB.js';
15
- export { EditableCell, table_default as Table, TableActions, TableCell, TableHeaderCell, TableRow, TableSkeleton } from './chunk-OSHJYIHC.js';
14
+ export { switch_default as Switch } from './chunk-QNPE63O6.js';
15
+ export { EditableCell, table_default as Table, TableActions, TableCell, TableHeaderCell, TableRow, TableSkeleton } from './chunk-NQACKYGF.js';
16
16
  export { toggle_group_default as ToggleGroup } from './chunk-E222IQHF.js';
17
17
  export { tabs_default as Tabs } from './chunk-SJHNFRXG.js';
18
- export { tag_default as Tag } from './chunk-2SYAIIJE.js';
18
+ export { textarea_default as Textarea } from './chunk-6JGNJI5T.js';
19
19
  export { progress_default as Progress } from './chunk-MBAZ7OW5.js';
20
- export { radio_default as Radio } from './chunk-VKLDLJXG.js';
20
+ export { radio_default as Radio } from './chunk-F3OLZMGO.js';
21
21
  export { radio_group_default as RadioGroup } from './chunk-SGRACNBP.js';
22
22
  export { rating_default as Rating } from './chunk-7UCNBMCV.js';
23
23
  export { ribbon_default as Ribbon } from './chunk-FVTMKQUE.js';
24
24
  export { scroll_area_default as ScrollArea } from './chunk-YJOLLSHH.js';
25
- export { select_default as Select } from './chunk-QC7XNMM7.js';
25
+ export { select_default as Select } from './chunk-ZESEEYEJ.js';
26
26
  export { link_default as Link } from './chunk-DRL4CJMI.js';
27
27
  export { menubar_default as Menubar } from './chunk-I75ZSXD6.js';
28
28
  export { multi_select_default as MultiSelect } from './chunk-UK4RHCMM.js';
@@ -30,13 +30,13 @@ export { NavigationMenu } from './chunk-OV6K6GML.js';
30
30
  export { notification_default as Notification } from './chunk-ZYWDJMHF.js';
31
31
  export { number_input_default as NumberInput } from './chunk-D53OQERO.js';
32
32
  export { pagination_default as Pagination } from './chunk-M3AALH7G.js';
33
- export { float_input_default as FloatInput } from './chunk-I7MESP7F.js';
33
+ export { Form, FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, useFormField } from './chunk-T4MGK3WE.js';
34
34
  export { grid_default as Grid } from './chunk-QKSDVYKF.js';
35
35
  export { image_default as Image } from './chunk-WAPZ4QAN.js';
36
36
  export { input_group_default as InputGroup } from './chunk-ROA7BYGB.js';
37
37
  export { input_otp_default as InputOTP } from './chunk-XOIX5WIL.js';
38
- export { input_password_default as InputPassword } from './chunk-623OVNLC.js';
39
- export { input_default as Input } from './chunk-GIWG6BCT.js';
38
+ export { input_password_default as InputPassword } from './chunk-XVRNFPBI.js';
39
+ export { input_default as Input } from './chunk-KYDQJSSW.js';
40
40
  export { kbd_default as Kbd } from './chunk-EGNF7BRT.js';
41
41
  export { DatePicker, RangePickerComponent as RangePicker, TimePickerComponent as TimePicker } from './chunk-KJRKPYYZ.js';
42
42
  export { descriptions_default as Descriptions } from './chunk-BVO2BNFG.js';
@@ -44,10 +44,10 @@ export { divider_default as Divider } from './chunk-VOODO2ZE.js';
44
44
  export { Drawer, DrawerBody, DrawerClose, DrawerContent, DrawerDescription, DrawerFooter, DrawerHeader, DrawerOverlay, DrawerPortal, DrawerTitle, DrawerTrigger } from './chunk-XWEI3MES.js';
45
45
  export { empty_default as Empty } from './chunk-2WZVD7P3.js';
46
46
  export { fetching_overlay_default as FetchingOverlay } from './chunk-ZPVBIQ2R.js';
47
- export { Form, FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, useFormField } from './chunk-T4MGK3WE.js';
47
+ export { float_input_default as FloatInput } from './chunk-SB3JGUGE.js';
48
48
  export { carousel_default as Carousel } from './chunk-DRCT6VZ7.js';
49
49
  export { cascader_default as Cascader } from './chunk-XHDUO3UW.js';
50
- export { checkbox_default as Checkbox } from './chunk-RLYGJN56.js';
50
+ export { checkbox_default as Checkbox } from './chunk-U5GAFTEM.js';
51
51
  export { checkbox_group_default as CheckboxGroup } from './chunk-2PNLIQYM.js';
52
52
  export { clipboard_default as Clipboard } from './chunk-6QZFWSN7.js';
53
53
  export { collapse_default as Collapse } from './chunk-X5XIBIEF.js';
@@ -1,4 +1,4 @@
1
- export { input_default as default } from '../chunk-GIWG6BCT.js';
1
+ export { input_default as default } from '../chunk-KYDQJSSW.js';
2
2
  import '../chunk-PHQOHVG3.js';
3
3
  import '../chunk-LK4EPTNG.js';
4
4
  import '../chunk-NGYLRX6F.js';
@@ -1,5 +1,5 @@
1
- export { PasswordInput, input_password_default as default } from '../chunk-623OVNLC.js';
2
- import '../chunk-GIWG6BCT.js';
1
+ export { PasswordInput, input_password_default as default } from '../chunk-XVRNFPBI.js';
2
+ import '../chunk-KYDQJSSW.js';
3
3
  import '../chunk-PHQOHVG3.js';
4
4
  import '../chunk-LK4EPTNG.js';
5
5
  import '../chunk-NGYLRX6F.js';
@@ -1,4 +1,4 @@
1
- export { radio_default as default } from '../chunk-VKLDLJXG.js';
1
+ export { radio_default as default } from '../chunk-F3OLZMGO.js';
2
2
  import '../chunk-LK4EPTNG.js';
3
3
  import '../chunk-NGYLRX6F.js';
4
4
  //# sourceMappingURL=index.js.map
@@ -1,4 +1,4 @@
1
- export { select_default as default } from '../chunk-QC7XNMM7.js';
1
+ export { select_default as default } from '../chunk-ZESEEYEJ.js';
2
2
  import '../chunk-ZQTJBYKO.js';
3
3
  import '../chunk-PHQOHVG3.js';
4
4
  import '../chunk-LK4EPTNG.js';
@@ -1,4 +1,4 @@
1
- export { switch_default as default } from '../chunk-2REG4OUB.js';
1
+ export { switch_default as default } from '../chunk-QNPE63O6.js';
2
2
  import '../chunk-LK4EPTNG.js';
3
3
  import '../chunk-NGYLRX6F.js';
4
4
  //# sourceMappingURL=index.js.map
@@ -1,8 +1,8 @@
1
- export { EditableCell, TableActions, TableCell, TableHeaderCell, TableRow, TableSkeleton, table_default as default } from '../chunk-OSHJYIHC.js';
1
+ export { EditableCell, TableActions, TableCell, TableHeaderCell, TableRow, TableSkeleton, table_default as default } from '../chunk-NQACKYGF.js';
2
2
  import '../chunk-E222IQHF.js';
3
3
  import '../chunk-M3AALH7G.js';
4
- import '../chunk-GIWG6BCT.js';
5
- import '../chunk-RLYGJN56.js';
4
+ import '../chunk-KYDQJSSW.js';
5
+ import '../chunk-U5GAFTEM.js';
6
6
  import '../chunk-ZQTJBYKO.js';
7
7
  import '../chunk-TBH7QF26.js';
8
8
  import '../chunk-PHQOHVG3.js';
@@ -1,5 +1,5 @@
1
- export { Transfer } from '../chunk-DHXVNO75.js';
2
- import '../chunk-RLYGJN56.js';
1
+ export { Transfer } from '../chunk-XR4UHTK3.js';
2
+ import '../chunk-U5GAFTEM.js';
3
3
  import '../chunk-LK4EPTNG.js';
4
4
  import '../chunk-NGYLRX6F.js';
5
5
  //# sourceMappingURL=index.js.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mdigital_ui/ui",
3
- "version": "0.3.3",
3
+ "version": "0.3.5",
4
4
  "description": "Modern React component library built with Tailwind CSS v4",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
@@ -1,6 +0,0 @@
1
- import React from "react";
2
- import type { AccordionProps } from "./types";
3
- declare const Accordion: React.NamedExoticComponent<AccordionProps>;
4
- export type * from "./types";
5
- export default Accordion;
6
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/accordion/index.tsx"],"names":[],"mappings":"AAIA,OAAO,KAA0B,MAAM,OAAO,CAAC;AAI/C,OAAO,KAAK,EAAE,cAAc,EAAiB,MAAM,SAAS,CAAC;AAqL7D,QAAA,MAAM,SAAS,4CA2Od,CAAC;AAIF,mBAAmB,SAAS,CAAC;AAC7B,eAAe,SAAS,CAAC"}
@@ -1,125 +0,0 @@
1
- import type { ComponentColor } from "../types";
2
- export type AccordionVariant = "default" | "solid" | "soft" | "bordered" | "splitted";
3
- export type AccordionSize = "xs" | "sm" | "md" | "lg";
4
- export interface AccordionClassNames {
5
- root?: string;
6
- item?: string;
7
- trigger?: string;
8
- content?: string;
9
- icon?: string;
10
- }
11
- export interface AccordionItem {
12
- /**
13
- * Unique key for the accordion item
14
- */
15
- key: string;
16
- /**
17
- * Title/header content
18
- */
19
- title: React.ReactNode;
20
- /**
21
- * Panel content
22
- */
23
- content: React.ReactNode;
24
- /**
25
- * Whether the item is disabled
26
- */
27
- disabled?: boolean;
28
- /**
29
- * Custom icon for the item (displayed before title)
30
- */
31
- icon?: React.ReactNode;
32
- /**
33
- * Subtitle displayed below title
34
- */
35
- subtitle?: React.ReactNode;
36
- /**
37
- * Extra content displayed on the right side of the header (before expand icon)
38
- */
39
- extra?: React.ReactNode;
40
- }
41
- export interface AccordionProps {
42
- /**
43
- * Accordion items to display
44
- */
45
- items: AccordionItem[];
46
- /**
47
- * Theme color
48
- * @default 'default'
49
- */
50
- color?: ComponentColor;
51
- /**
52
- * Size variant
53
- * @default 'md'
54
- */
55
- size?: AccordionSize;
56
- /**
57
- * Visual style variant
58
- * - default: subtle background on hover
59
- * - solid: filled background
60
- * - soft: light colored background
61
- * - bordered: outline border only
62
- * - splitted: separated cards with gap
63
- * @default 'default'
64
- */
65
- variant?: AccordionVariant;
66
- /**
67
- * Default active keys (uncontrolled)
68
- */
69
- defaultActiveKey?: string | string[];
70
- /**
71
- * Active keys (controlled)
72
- */
73
- activeKey?: string | string[];
74
- /**
75
- * Callback when active keys change
76
- */
77
- onChange?: (activeKey: string | string[]) => void;
78
- /**
79
- * Allow multiple panels to be open simultaneously
80
- * @default false
81
- */
82
- multiple?: boolean;
83
- /**
84
- * Custom expand/collapse icon or false to hide
85
- */
86
- expandIcon?: React.ReactNode | ((isExpanded: boolean) => React.ReactNode) | false;
87
- /**
88
- * Position of expand icon
89
- * @default 'right'
90
- */
91
- expandIconPosition?: "left" | "right";
92
- /**
93
- * Whether at least one panel must remain open
94
- * Only works when multiple is false
95
- * @default false
96
- */
97
- collapsible?: boolean;
98
- /**
99
- * Unmount content when panel is collapsed (for performance)
100
- * @default false
101
- */
102
- destroyOnClose?: boolean;
103
- /**
104
- * Show divider between items (only for non-splitted variants)
105
- * @default true
106
- */
107
- showDivider?: boolean;
108
- /**
109
- * Additional CSS class
110
- */
111
- className?: string;
112
- /**
113
- * Additional CSS class for each item
114
- */
115
- itemClassName?: string;
116
- /**
117
- * Custom class names for different parts of the accordion
118
- */
119
- classNames?: AccordionClassNames;
120
- /**
121
- * Reference to the accordion container
122
- */
123
- ref?: React.Ref<HTMLDivElement>;
124
- }
125
- //# sourceMappingURL=types.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/accordion/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAE/C,MAAM,MAAM,gBAAgB,GACxB,SAAS,GACT,OAAO,GACP,MAAM,GACN,UAAU,GACV,UAAU,CAAC;AAEf,MAAM,MAAM,aAAa,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;AAEtD,MAAM,WAAW,mBAAmB;IAClC,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,aAAa;IAC5B;;OAEG;IACH,GAAG,EAAE,MAAM,CAAC;IAEZ;;OAEG;IACH,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC;IAEvB;;OAEG;IACH,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;IAEzB;;OAEG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IAEnB;;OAEG;IACH,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAEvB;;OAEG;IACH,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAE3B;;OAEG;IACH,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CACzB;AAED,MAAM,WAAW,cAAc;IAC7B;;OAEG;IACH,KAAK,EAAE,aAAa,EAAE,CAAC;IAEvB;;;OAGG;IACH,KAAK,CAAC,EAAE,cAAc,CAAC;IAEvB;;;OAGG;IACH,IAAI,CAAC,EAAE,aAAa,CAAC;IAErB;;;;;;;;OAQG;IACH,OAAO,CAAC,EAAE,gBAAgB,CAAC;IAE3B;;OAEG;IACH,gBAAgB,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAErC;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAE9B;;OAEG;IACH,QAAQ,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,EAAE,KAAK,IAAI,CAAC;IAElD;;;OAGG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IAEnB;;OAEG;IACH,UAAU,CAAC,EACP,KAAK,CAAC,SAAS,GACf,CAAC,CAAC,UAAU,EAAE,OAAO,KAAK,KAAK,CAAC,SAAS,CAAC,GAC1C,KAAK,CAAC;IAEV;;;OAGG;IACH,kBAAkB,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IAEtC;;;;OAIG;IACH,WAAW,CAAC,EAAE,OAAO,CAAC;IAEtB;;;OAGG;IACH,cAAc,CAAC,EAAE,OAAO,CAAC;IAEzB;;;OAGG;IACH,WAAW,CAAC,EAAE,OAAO,CAAC;IAEtB;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB;;OAEG;IACH,aAAa,CAAC,EAAE,MAAM,CAAC;IAEvB;;OAEG;IACH,UAAU,CAAC,EAAE,mBAAmB,CAAC;IAEjC;;OAEG;IACH,GAAG,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;CACjC"}
@@ -1,14 +0,0 @@
1
- import React from "react";
2
- import type { AvatarGroupProps, AvatarProps } from "./types";
3
- /**
4
- * Avatar Component
5
- */
6
- declare const Avatar: React.NamedExoticComponent<AvatarProps>;
7
- /**
8
- * AvatarGroup Component
9
- */
10
- declare const AvatarGroup: React.NamedExoticComponent<AvatarGroupProps>;
11
- export type * from "./types";
12
- export { Avatar, AvatarGroup };
13
- export default Avatar;
14
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/avatar/index.tsx"],"names":[],"mappings":"AAGA,OAAO,KAA8B,MAAM,OAAO,CAAC;AAGnD,OAAO,KAAK,EAAE,gBAAgB,EAAE,WAAW,EAAc,MAAM,SAAS,CAAC;AAyHzE;;GAEG;AACH,QAAA,MAAM,MAAM,yCA2IX,CAAC;AAIF;;GAEG;AACH,QAAA,MAAM,WAAW,8CA+EhB,CAAC;AAIF,mBAAmB,SAAS,CAAC;AAC7B,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC;AAC/B,eAAe,MAAM,CAAC"}