@zentauri-ui/zentauri-components 1.4.61 → 1.4.63

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 (597) hide show
  1. package/README.md +73 -73
  2. package/dist/{chunk-JE3PD5ZA.js → chunk-2VUMVDR3.js} +8 -8
  3. package/dist/{chunk-JE3PD5ZA.js.map → chunk-2VUMVDR3.js.map} +1 -1
  4. package/dist/{chunk-DFEZH7TC.mjs → chunk-4D54YOL6.mjs} +2 -2
  5. package/dist/{chunk-DFEZH7TC.mjs.map → chunk-4D54YOL6.mjs.map} +1 -1
  6. package/dist/{chunk-UXGHUBNJ.mjs → chunk-4LT2GNJL.mjs} +13 -13
  7. package/dist/{chunk-UXGHUBNJ.mjs.map → chunk-4LT2GNJL.mjs.map} +1 -1
  8. package/dist/{chunk-BORK3BJO.mjs → chunk-5TV7EL3H.mjs} +19 -19
  9. package/dist/chunk-5TV7EL3H.mjs.map +1 -0
  10. package/dist/{chunk-BSWYZTYK.js → chunk-7DCFVPWN.js} +2 -2
  11. package/dist/chunk-7DCFVPWN.js.map +1 -0
  12. package/dist/{chunk-5QB2KNZQ.js → chunk-7TLKLMBM.js} +11 -9
  13. package/dist/chunk-7TLKLMBM.js.map +1 -0
  14. package/dist/{chunk-2P3UU2J3.mjs → chunk-A6KMZ5ZS.mjs} +12 -12
  15. package/dist/chunk-A6KMZ5ZS.mjs.map +1 -0
  16. package/dist/{chunk-OJ67PZ6N.js → chunk-BCZIYH53.js} +8 -8
  17. package/dist/{chunk-OJ67PZ6N.js.map → chunk-BCZIYH53.js.map} +1 -1
  18. package/dist/{chunk-3OR47XMY.js → chunk-E4FZY7O2.js} +52 -33
  19. package/dist/chunk-E4FZY7O2.js.map +1 -0
  20. package/dist/{chunk-XLAFQ24R.js → chunk-G3B6OHFG.js} +49 -41
  21. package/dist/chunk-G3B6OHFG.js.map +1 -0
  22. package/dist/{chunk-RDSPHBHK.mjs → chunk-G3LEYBRV.mjs} +50 -7
  23. package/dist/chunk-G3LEYBRV.mjs.map +1 -0
  24. package/dist/chunk-GBWGVNDA.js +160 -0
  25. package/dist/chunk-GBWGVNDA.js.map +1 -0
  26. package/dist/{chunk-LVUPECBT.mjs → chunk-H2I54QPJ.mjs} +12 -12
  27. package/dist/chunk-H2I54QPJ.mjs.map +1 -0
  28. package/dist/{chunk-XWM2S6VV.mjs → chunk-I6GR234Z.mjs} +22 -20
  29. package/dist/chunk-I6GR234Z.mjs.map +1 -0
  30. package/dist/{chunk-WZKGRU3U.js → chunk-JUDMPOCI.js} +103 -38
  31. package/dist/chunk-JUDMPOCI.js.map +1 -0
  32. package/dist/chunk-K6YI4FJO.mjs +158 -0
  33. package/dist/chunk-K6YI4FJO.mjs.map +1 -0
  34. package/dist/{chunk-WP7GYBRI.js → chunk-KC5LEZ6J.js} +2 -2
  35. package/dist/chunk-KC5LEZ6J.js.map +1 -0
  36. package/dist/{chunk-PCK6LX3K.js → chunk-KEKNNZD3.js} +19 -19
  37. package/dist/{chunk-PCK6LX3K.js.map → chunk-KEKNNZD3.js.map} +1 -1
  38. package/dist/{chunk-UBFKTC2P.mjs → chunk-LJ7AAIA3.mjs} +3 -3
  39. package/dist/{chunk-UBFKTC2P.mjs.map → chunk-LJ7AAIA3.mjs.map} +1 -1
  40. package/dist/{chunk-BVXTOEBI.mjs → chunk-LN77JJTY.mjs} +45 -26
  41. package/dist/chunk-LN77JJTY.mjs.map +1 -0
  42. package/dist/{chunk-E3DZNJAD.js → chunk-MCOQHXRW.js} +23 -21
  43. package/dist/chunk-MCOQHXRW.js.map +1 -0
  44. package/dist/{chunk-FLILFCQE.mjs → chunk-MTLLJFUI.mjs} +7 -8
  45. package/dist/chunk-MTLLJFUI.mjs.map +1 -0
  46. package/dist/{chunk-C2FCPQTO.js → chunk-MXKGDFQH.js} +7 -7
  47. package/dist/{chunk-C2FCPQTO.js.map → chunk-MXKGDFQH.js.map} +1 -1
  48. package/dist/{chunk-UOFTZKMM.js → chunk-MXLRXYIX.js} +18 -18
  49. package/dist/{chunk-UOFTZKMM.js.map → chunk-MXLRXYIX.js.map} +1 -1
  50. package/dist/{chunk-6I7X5BF2.js → chunk-N2OAI2HN.js} +18 -18
  51. package/dist/chunk-N2OAI2HN.js.map +1 -0
  52. package/dist/{chunk-BITDSQMR.js → chunk-OB4KJZK2.js} +19 -19
  53. package/dist/chunk-OB4KJZK2.js.map +1 -0
  54. package/dist/{chunk-2PQEXQVR.js → chunk-PWL5WD34.js} +76 -27
  55. package/dist/chunk-PWL5WD34.js.map +1 -0
  56. package/dist/{chunk-FT2LMA66.mjs → chunk-QADZK5R7.mjs} +2 -2
  57. package/dist/chunk-QADZK5R7.mjs.map +1 -0
  58. package/dist/{chunk-XIXF7UVM.mjs → chunk-QEGACUFU.mjs} +12 -12
  59. package/dist/chunk-QEGACUFU.mjs.map +1 -0
  60. package/dist/{chunk-WDCIZHXY.mjs → chunk-QZTEFGZF.mjs} +6 -4
  61. package/dist/chunk-QZTEFGZF.mjs.map +1 -0
  62. package/dist/{chunk-N4NO3SYL.js → chunk-SKPZCISM.js} +48 -40
  63. package/dist/chunk-SKPZCISM.js.map +1 -0
  64. package/dist/{chunk-7HL3A4YF.mjs → chunk-TJUNN2PT.mjs} +73 -24
  65. package/dist/chunk-TJUNN2PT.mjs.map +1 -0
  66. package/dist/{chunk-IXDJ3IPG.mjs → chunk-TTYZBO4E.mjs} +40 -32
  67. package/dist/chunk-TTYZBO4E.mjs.map +1 -0
  68. package/dist/{chunk-4B7KGBQB.js → chunk-UWA23DUC.js} +12 -13
  69. package/dist/chunk-UWA23DUC.js.map +1 -0
  70. package/dist/{chunk-CY5BQKRZ.mjs → chunk-VXDEPZKH.mjs} +2 -2
  71. package/dist/chunk-VXDEPZKH.mjs.map +1 -0
  72. package/dist/{chunk-TZ2JVWTZ.mjs → chunk-YNBJAFI2.mjs} +3 -3
  73. package/dist/{chunk-TZ2JVWTZ.mjs.map → chunk-YNBJAFI2.mjs.map} +1 -1
  74. package/dist/{chunk-P5HUBXUX.js → chunk-YTRGRHEB.js} +55 -12
  75. package/dist/chunk-YTRGRHEB.js.map +1 -0
  76. package/dist/{chunk-U4YQCAXW.js → chunk-Z7PHKV2T.js} +18 -18
  77. package/dist/chunk-Z7PHKV2T.js.map +1 -0
  78. package/dist/{chunk-YNCD6TKE.mjs → chunk-ZBBFOMSJ.mjs} +103 -38
  79. package/dist/chunk-ZBBFOMSJ.mjs.map +1 -0
  80. package/dist/{chunk-PGH27VTL.mjs → chunk-ZIDKBEQJ.mjs} +40 -32
  81. package/dist/chunk-ZIDKBEQJ.mjs.map +1 -0
  82. package/dist/{chunk-UOZYPWDZ.js → chunk-ZS5756ZC.js} +2 -2
  83. package/dist/{chunk-UOZYPWDZ.js.map → chunk-ZS5756ZC.js.map} +1 -1
  84. package/dist/{chunk-W6PRMYUC.mjs → chunk-ZYZJ74XB.mjs} +3 -3
  85. package/dist/{chunk-W6PRMYUC.mjs.map → chunk-ZYZJ74XB.mjs.map} +1 -1
  86. package/dist/hooks/index.d.ts +2 -2
  87. package/dist/hooks/index.d.ts.map +1 -1
  88. package/dist/hooks/useClickOutside/useClickOutside.d.ts.map +1 -1
  89. package/dist/hooks/useClickOutside.js +2 -2
  90. package/dist/hooks/useClickOutside.mjs +1 -1
  91. package/dist/hooks/useClipboard/useClipboard.d.ts.map +1 -1
  92. package/dist/hooks/useClipboard.js.map +1 -1
  93. package/dist/hooks/useClipboard.mjs.map +1 -1
  94. package/dist/hooks/useFocusManagement/useFocusManagement.d.ts +5 -14
  95. package/dist/hooks/useFocusManagement/useFocusManagement.d.ts.map +1 -1
  96. package/dist/hooks/useFocusManagement.js +2 -2
  97. package/dist/hooks/useFocusManagement.mjs +1 -1
  98. package/dist/hooks/useLocalStorage/index.d.ts +1 -1
  99. package/dist/hooks/useLocalStorage/index.d.ts.map +1 -1
  100. package/dist/hooks/useLocalStorage.js +1 -3
  101. package/dist/hooks/useLocalStorage.js.map +1 -1
  102. package/dist/hooks/useLocalStorage.mjs +1 -3
  103. package/dist/hooks/useLocalStorage.mjs.map +1 -1
  104. package/dist/hooks/useMediaQuery/useMediaQuery.d.ts.map +1 -1
  105. package/dist/hooks/useMediaQuery.js +2 -2
  106. package/dist/hooks/useMediaQuery.mjs +1 -1
  107. package/dist/hooks/usePagination.js +4 -4
  108. package/dist/hooks/usePagination.mjs +2 -2
  109. package/dist/hooks/usePrefersColorScheme.js +2 -2
  110. package/dist/hooks/usePrefersColorScheme.mjs +1 -1
  111. package/dist/hooks/usePrefersReducedMotion.js +2 -2
  112. package/dist/hooks/usePrefersReducedMotion.mjs +1 -1
  113. package/dist/hooks/useResizeObserver/index.d.ts +1 -1
  114. package/dist/hooks/useResizeObserver/index.d.ts.map +1 -1
  115. package/dist/hooks/useSessionStorage/useSessionStorage.d.ts.map +1 -1
  116. package/dist/hooks/useSessionStorage.js.map +1 -1
  117. package/dist/hooks/useSessionStorage.mjs.map +1 -1
  118. package/dist/hooks/useThrottledCallback/useThrottledCallback.d.ts.map +1 -1
  119. package/dist/hooks/useThrottledCallback.js.map +1 -1
  120. package/dist/hooks/useThrottledCallback.mjs.map +1 -1
  121. package/dist/hooks/useWindowSize/useWindowSize.d.ts.map +1 -1
  122. package/dist/hooks/useWindowSize.js +4 -1
  123. package/dist/hooks/useWindowSize.js.map +1 -1
  124. package/dist/hooks/useWindowSize.mjs +4 -1
  125. package/dist/hooks/useWindowSize.mjs.map +1 -1
  126. package/dist/hooks/utils.js +5 -5
  127. package/dist/hooks/utils.mjs +1 -1
  128. package/dist/lib/utils.d.ts.map +1 -1
  129. package/dist/ui/accordion/accordion.d.ts.map +1 -1
  130. package/dist/ui/accordion/animated/accordion-content-animated.d.ts.map +1 -1
  131. package/dist/ui/accordion/animated/index.d.ts +1 -1
  132. package/dist/ui/accordion/animated/index.d.ts.map +1 -1
  133. package/dist/ui/accordion/animated/types.d.ts.map +1 -1
  134. package/dist/ui/accordion/animated.js +8 -11
  135. package/dist/ui/accordion/animated.js.map +1 -1
  136. package/dist/ui/accordion/animated.mjs +4 -7
  137. package/dist/ui/accordion/animated.mjs.map +1 -1
  138. package/dist/ui/accordion.js +10 -10
  139. package/dist/ui/accordion.js.map +1 -1
  140. package/dist/ui/accordion.mjs +3 -3
  141. package/dist/ui/accordion.mjs.map +1 -1
  142. package/dist/ui/alert/alert-base.d.ts.map +1 -1
  143. package/dist/ui/alert/alert.d.ts.map +1 -1
  144. package/dist/ui/alert/animated/index.d.ts.map +1 -1
  145. package/dist/ui/alert/animated.js +3 -3
  146. package/dist/ui/alert/animated.mjs +2 -2
  147. package/dist/ui/alert/types.d.ts.map +1 -1
  148. package/dist/ui/alert.js +11 -11
  149. package/dist/ui/alert.js.map +1 -1
  150. package/dist/ui/alert.mjs +3 -3
  151. package/dist/ui/alert.mjs.map +1 -1
  152. package/dist/ui/avatar/animated/index.d.ts +1 -1
  153. package/dist/ui/avatar/animated/index.d.ts.map +1 -1
  154. package/dist/ui/avatar/animated.js +6 -6
  155. package/dist/ui/avatar/animated.mjs +3 -3
  156. package/dist/ui/avatar/avatar-base.d.ts.map +1 -1
  157. package/dist/ui/avatar/avatar.d.ts.map +1 -1
  158. package/dist/ui/avatar/variants.d.ts.map +1 -1
  159. package/dist/ui/avatar.js +10 -10
  160. package/dist/ui/avatar.js.map +1 -1
  161. package/dist/ui/avatar.mjs +3 -3
  162. package/dist/ui/avatar.mjs.map +1 -1
  163. package/dist/ui/badge/animated/index.d.ts +1 -1
  164. package/dist/ui/badge/animated/index.d.ts.map +1 -1
  165. package/dist/ui/badge/animated/types.d.ts.map +1 -1
  166. package/dist/ui/badge/animated.js +3 -3
  167. package/dist/ui/badge/animated.mjs +2 -2
  168. package/dist/ui/badge/badge-base.d.ts +1 -1
  169. package/dist/ui/badge/badge-base.d.ts.map +1 -1
  170. package/dist/ui/badge/types.d.ts +1 -0
  171. package/dist/ui/badge/types.d.ts.map +1 -1
  172. package/dist/ui/badge/variants.d.ts +16 -16
  173. package/dist/ui/badge/variants.d.ts.map +1 -1
  174. package/dist/ui/badge.js +5 -5
  175. package/dist/ui/badge.mjs +3 -3
  176. package/dist/ui/breadcrumb/breadcrumb.d.ts.map +1 -1
  177. package/dist/ui/breadcrumb/types.d.ts.map +1 -1
  178. package/dist/ui/breadcrumb/variants.d.ts.map +1 -1
  179. package/dist/ui/breadcrumb.js +47 -43
  180. package/dist/ui/breadcrumb.js.map +1 -1
  181. package/dist/ui/breadcrumb.mjs +43 -39
  182. package/dist/ui/breadcrumb.mjs.map +1 -1
  183. package/dist/ui/buttons/animated/index.d.ts +1 -1
  184. package/dist/ui/buttons/animated/index.d.ts.map +1 -1
  185. package/dist/ui/buttons/animated/types.d.ts.map +1 -1
  186. package/dist/ui/buttons/animated.js +4 -4
  187. package/dist/ui/buttons/animated.mjs +2 -2
  188. package/dist/ui/buttons/types.d.ts.map +1 -1
  189. package/dist/ui/buttons.js +5 -5
  190. package/dist/ui/buttons.mjs +3 -3
  191. package/dist/ui/card/animated.js +8 -8
  192. package/dist/ui/card/animated.mjs +3 -3
  193. package/dist/ui/card/card-base.d.ts.map +1 -1
  194. package/dist/ui/card/card.d.ts.map +1 -1
  195. package/dist/ui/card/index.d.ts +2 -2
  196. package/dist/ui/card/index.d.ts.map +1 -1
  197. package/dist/ui/card.js +13 -13
  198. package/dist/ui/card.js.map +1 -1
  199. package/dist/ui/card.mjs +3 -3
  200. package/dist/ui/card.mjs.map +1 -1
  201. package/dist/ui/divider/animated/index.d.ts +1 -1
  202. package/dist/ui/divider/animated/index.d.ts.map +1 -1
  203. package/dist/ui/divider/animated/types.d.ts.map +1 -1
  204. package/dist/ui/divider/animated.js +3 -3
  205. package/dist/ui/divider/animated.mjs +2 -2
  206. package/dist/ui/divider/divider-base.d.ts.map +1 -1
  207. package/dist/ui/divider.js +7 -7
  208. package/dist/ui/divider.mjs +3 -3
  209. package/dist/ui/drawer/animated/drawer-content-animated.d.ts.map +1 -1
  210. package/dist/ui/drawer/animated/index.d.ts +1 -1
  211. package/dist/ui/drawer/animated/index.d.ts.map +1 -1
  212. package/dist/ui/drawer/animated.js +19 -20
  213. package/dist/ui/drawer/animated.js.map +1 -1
  214. package/dist/ui/drawer/animated.mjs +9 -10
  215. package/dist/ui/drawer/animated.mjs.map +1 -1
  216. package/dist/ui/drawer/drawer-base.d.ts +1 -1
  217. package/dist/ui/drawer/drawer-base.d.ts.map +1 -1
  218. package/dist/ui/drawer/types.d.ts +1 -0
  219. package/dist/ui/drawer/types.d.ts.map +1 -1
  220. package/dist/ui/drawer.js +13 -13
  221. package/dist/ui/drawer.mjs +3 -3
  222. package/dist/ui/dropdown/dropdown.d.ts +1 -1
  223. package/dist/ui/dropdown/dropdown.d.ts.map +1 -1
  224. package/dist/ui/dropdown/types.d.ts +1 -0
  225. package/dist/ui/dropdown/types.d.ts.map +1 -1
  226. package/dist/ui/dropdown/variants.d.ts +1 -1
  227. package/dist/ui/dropdown.js +49 -31
  228. package/dist/ui/dropdown.js.map +1 -1
  229. package/dist/ui/dropdown.mjs +46 -28
  230. package/dist/ui/dropdown.mjs.map +1 -1
  231. package/dist/ui/empty-state/animated/empty-state-animated.d.ts.map +1 -1
  232. package/dist/ui/empty-state/animated/index.d.ts +2 -2
  233. package/dist/ui/empty-state/animated/index.d.ts.map +1 -1
  234. package/dist/ui/empty-state/animated.js +3 -3
  235. package/dist/ui/empty-state/animated.js.map +1 -1
  236. package/dist/ui/empty-state/animated.mjs +2 -2
  237. package/dist/ui/empty-state/animated.mjs.map +1 -1
  238. package/dist/ui/empty-state/empty-state-base.d.ts.map +1 -1
  239. package/dist/ui/empty-state/index.d.ts +1 -1
  240. package/dist/ui/empty-state/index.d.ts.map +1 -1
  241. package/dist/ui/empty-state/types.d.ts +1 -0
  242. package/dist/ui/empty-state/types.d.ts.map +1 -1
  243. package/dist/ui/empty-state.js +11 -11
  244. package/dist/ui/empty-state.mjs +3 -3
  245. package/dist/ui/file-upload/file-upload.d.ts.map +1 -1
  246. package/dist/ui/file-upload/variants.d.ts.map +1 -1
  247. package/dist/ui/file-upload.js +4 -6
  248. package/dist/ui/file-upload.js.map +1 -1
  249. package/dist/ui/file-upload.mjs +2 -4
  250. package/dist/ui/file-upload.mjs.map +1 -1
  251. package/dist/ui/inputs/animated/index.d.ts +1 -1
  252. package/dist/ui/inputs/animated/index.d.ts.map +1 -1
  253. package/dist/ui/inputs/animated.js +3 -3
  254. package/dist/ui/inputs/animated.mjs +1 -1
  255. package/dist/ui/inputs/input-base.d.ts.map +1 -1
  256. package/dist/ui/inputs/types.d.ts +3 -1
  257. package/dist/ui/inputs/types.d.ts.map +1 -1
  258. package/dist/ui/inputs.js +49 -5
  259. package/dist/ui/inputs.js.map +1 -1
  260. package/dist/ui/inputs.mjs +47 -3
  261. package/dist/ui/inputs.mjs.map +1 -1
  262. package/dist/ui/modal/animated/index.d.ts +1 -1
  263. package/dist/ui/modal/animated/index.d.ts.map +1 -1
  264. package/dist/ui/modal/animated/modal-content-animated.d.ts.map +1 -1
  265. package/dist/ui/modal/animated.js +12 -13
  266. package/dist/ui/modal/animated.js.map +1 -1
  267. package/dist/ui/modal/animated.mjs +8 -9
  268. package/dist/ui/modal/animated.mjs.map +1 -1
  269. package/dist/ui/modal/index.d.ts +1 -1
  270. package/dist/ui/modal/index.d.ts.map +1 -1
  271. package/dist/ui/modal/modal-base.d.ts +4 -2
  272. package/dist/ui/modal/modal-base.d.ts.map +1 -1
  273. package/dist/ui/modal/types.d.ts.map +1 -1
  274. package/dist/ui/modal.js +14 -14
  275. package/dist/ui/modal.js.map +1 -1
  276. package/dist/ui/modal.mjs +4 -4
  277. package/dist/ui/modal.mjs.map +1 -1
  278. package/dist/ui/pagination.js +25 -25
  279. package/dist/ui/pagination.js.map +1 -1
  280. package/dist/ui/pagination.mjs +15 -15
  281. package/dist/ui/pagination.mjs.map +1 -1
  282. package/dist/ui/progress/animated/progress-animated.d.ts.map +1 -1
  283. package/dist/ui/progress/animated.js +52 -14
  284. package/dist/ui/progress/animated.js.map +1 -1
  285. package/dist/ui/progress/animated.mjs +45 -7
  286. package/dist/ui/progress/animated.mjs.map +1 -1
  287. package/dist/ui/progress/index.d.ts +2 -2
  288. package/dist/ui/progress/index.d.ts.map +1 -1
  289. package/dist/ui/progress/progress-base.d.ts.map +1 -1
  290. package/dist/ui/progress/progress.d.ts.map +1 -1
  291. package/dist/ui/progress/types.d.ts +3 -0
  292. package/dist/ui/progress/types.d.ts.map +1 -1
  293. package/dist/ui/progress.js +10 -15
  294. package/dist/ui/progress.js.map +1 -1
  295. package/dist/ui/progress.mjs +4 -9
  296. package/dist/ui/progress.mjs.map +1 -1
  297. package/dist/ui/search/search-bar.d.ts +1 -1
  298. package/dist/ui/search/search-bar.d.ts.map +1 -1
  299. package/dist/ui/search/search-suggestion-list.d.ts.map +1 -1
  300. package/dist/ui/search/search-suggestion-utils.d.ts.map +1 -1
  301. package/dist/ui/search.js +15 -7
  302. package/dist/ui/search.js.map +1 -1
  303. package/dist/ui/search.mjs +11 -3
  304. package/dist/ui/search.mjs.map +1 -1
  305. package/dist/ui/select/select.d.ts +1 -1
  306. package/dist/ui/select/select.d.ts.map +1 -1
  307. package/dist/ui/select/types.d.ts +1 -0
  308. package/dist/ui/select/types.d.ts.map +1 -1
  309. package/dist/ui/select/variants.d.ts +1 -1
  310. package/dist/ui/select/variants.d.ts.map +1 -1
  311. package/dist/ui/select.js +145 -63
  312. package/dist/ui/select.js.map +1 -1
  313. package/dist/ui/select.mjs +141 -59
  314. package/dist/ui/select.mjs.map +1 -1
  315. package/dist/ui/skeleton/animated/skeleton-animated.d.ts.map +1 -1
  316. package/dist/ui/skeleton/animated/types.d.ts.map +1 -1
  317. package/dist/ui/skeleton/animated.js +34 -10
  318. package/dist/ui/skeleton/animated.js.map +1 -1
  319. package/dist/ui/skeleton/animated.mjs +29 -5
  320. package/dist/ui/skeleton/animated.mjs.map +1 -1
  321. package/dist/ui/skeleton/variants.d.ts +1 -1
  322. package/dist/ui/skeleton.js +10 -10
  323. package/dist/ui/skeleton.mjs +2 -2
  324. package/dist/ui/slider/slider.d.ts.map +1 -1
  325. package/dist/ui/slider/types.d.ts +8 -2
  326. package/dist/ui/slider/types.d.ts.map +1 -1
  327. package/dist/ui/slider.js +53 -17
  328. package/dist/ui/slider.js.map +1 -1
  329. package/dist/ui/slider.mjs +45 -9
  330. package/dist/ui/slider.mjs.map +1 -1
  331. package/dist/ui/spinner/animated/spinner.d.ts.map +1 -1
  332. package/dist/ui/spinner/animated.js +68 -56
  333. package/dist/ui/spinner/animated.js.map +1 -1
  334. package/dist/ui/spinner/animated.mjs +64 -52
  335. package/dist/ui/spinner/animated.mjs.map +1 -1
  336. package/dist/ui/stepper/stepper.d.ts +2 -7
  337. package/dist/ui/stepper/stepper.d.ts.map +1 -1
  338. package/dist/ui/stepper/types.d.ts +3 -3
  339. package/dist/ui/stepper/types.d.ts.map +1 -1
  340. package/dist/ui/stepper/variants.d.ts +1 -1
  341. package/dist/ui/stepper/variants.d.ts.map +1 -1
  342. package/dist/ui/stepper.js +12 -13
  343. package/dist/ui/stepper.js.map +1 -1
  344. package/dist/ui/stepper.mjs +9 -10
  345. package/dist/ui/stepper.mjs.map +1 -1
  346. package/dist/ui/table/animated/index.d.ts +2 -2
  347. package/dist/ui/table/animated/index.d.ts.map +1 -1
  348. package/dist/ui/table/animated.js +9 -9
  349. package/dist/ui/table/animated.mjs +3 -3
  350. package/dist/ui/table/table-base.d.ts +1 -1
  351. package/dist/ui/table/table-base.d.ts.map +1 -1
  352. package/dist/ui/table/types.d.ts +5 -1
  353. package/dist/ui/table/types.d.ts.map +1 -1
  354. package/dist/ui/table.js +15 -15
  355. package/dist/ui/table.mjs +2 -2
  356. package/dist/ui/tabs/animated/animations.d.ts.map +1 -1
  357. package/dist/ui/tabs/animated/index.d.ts +1 -1
  358. package/dist/ui/tabs/animated/index.d.ts.map +1 -1
  359. package/dist/ui/tabs/animated/types.d.ts.map +1 -1
  360. package/dist/ui/tabs/animated.js +4 -4
  361. package/dist/ui/tabs/animated.js.map +1 -1
  362. package/dist/ui/tabs/animated.mjs +2 -2
  363. package/dist/ui/tabs/animated.mjs.map +1 -1
  364. package/dist/ui/tabs/index.d.ts +1 -1
  365. package/dist/ui/tabs/index.d.ts.map +1 -1
  366. package/dist/ui/tabs/tabs-base.d.ts.map +1 -1
  367. package/dist/ui/tabs/tabs.d.ts +1 -1
  368. package/dist/ui/tabs/tabs.d.ts.map +1 -1
  369. package/dist/ui/tabs/types.d.ts +2 -1
  370. package/dist/ui/tabs/types.d.ts.map +1 -1
  371. package/dist/ui/tabs.js +10 -10
  372. package/dist/ui/tabs.mjs +2 -2
  373. package/dist/ui/toast/animated/toast-animated.d.ts.map +1 -1
  374. package/dist/ui/toast/animated.js +12 -10
  375. package/dist/ui/toast/animated.js.map +1 -1
  376. package/dist/ui/toast/animated.mjs +5 -3
  377. package/dist/ui/toast/animated.mjs.map +1 -1
  378. package/dist/ui/toast/types.d.ts.map +1 -1
  379. package/dist/ui/toast.js +13 -13
  380. package/dist/ui/toast.mjs +2 -2
  381. package/dist/ui/toggle/animated/index.d.ts +2 -2
  382. package/dist/ui/toggle/animated/index.d.ts.map +1 -1
  383. package/dist/ui/toggle/animated/types.d.ts.map +1 -1
  384. package/dist/ui/toggle/animated.js +3 -3
  385. package/dist/ui/toggle/animated.mjs +1 -1
  386. package/dist/ui/toggle/index.d.ts +1 -1
  387. package/dist/ui/toggle/index.d.ts.map +1 -1
  388. package/dist/ui/toggle/toggle-base.d.ts.map +1 -1
  389. package/dist/ui/toggle.js +31 -6
  390. package/dist/ui/toggle.js.map +1 -1
  391. package/dist/ui/toggle.mjs +30 -5
  392. package/dist/ui/toggle.mjs.map +1 -1
  393. package/dist/ui/tooltip/animated/animations.d.ts.map +1 -1
  394. package/dist/ui/tooltip/animated/types.d.ts.map +1 -1
  395. package/dist/ui/tooltip/animated.js +5 -5
  396. package/dist/ui/tooltip/animated.js.map +1 -1
  397. package/dist/ui/tooltip/animated.mjs +2 -2
  398. package/dist/ui/tooltip/animated.mjs.map +1 -1
  399. package/dist/ui/tooltip/tooltip-base.d.ts.map +1 -1
  400. package/dist/ui/tooltip/types.d.ts +1 -0
  401. package/dist/ui/tooltip/types.d.ts.map +1 -1
  402. package/dist/ui/tooltip/variants.d.ts.map +1 -1
  403. package/dist/ui/tooltip.js +8 -8
  404. package/dist/ui/tooltip.mjs +2 -2
  405. package/dist/ui/typography/blockquote-base.d.ts.map +1 -1
  406. package/dist/ui/typography/code-block-base.d.ts.map +1 -1
  407. package/dist/ui/typography/heading-base.d.ts.map +1 -1
  408. package/dist/ui/typography/list-base.d.ts.map +1 -1
  409. package/dist/ui/typography/types.d.ts.map +1 -1
  410. package/dist/ui/typography/variants.d.ts.map +1 -1
  411. package/dist/ui/typography.js +12 -34
  412. package/dist/ui/typography.js.map +1 -1
  413. package/dist/ui/typography.mjs +4 -26
  414. package/dist/ui/typography.mjs.map +1 -1
  415. package/package.json +1 -1
  416. package/src/hooks/index.ts +8 -2
  417. package/src/hooks/useClickOutside/useClickOutside.ts +1 -4
  418. package/src/hooks/useClipboard/useClipboard.test.ts +3 -1
  419. package/src/hooks/useClipboard/useClipboard.ts +1 -2
  420. package/src/hooks/useDisclosure/useDisclosure.test.ts +1 -2
  421. package/src/hooks/useDocumentTitle/useDocumentTitle.test.ts +1 -3
  422. package/src/hooks/useFocusManagement/useFocusManagement.test.tsx +8 -0
  423. package/src/hooks/useFocusManagement/useFocusManagement.ts +162 -34
  424. package/src/hooks/useInView/useInView.test.ts +6 -1
  425. package/src/hooks/useLocalStorage/index.ts +1 -4
  426. package/src/hooks/useLocalStorage/useLocalStorage.test.ts +8 -20
  427. package/src/hooks/useLocalStorage/useLocalStorage.ts +4 -4
  428. package/src/hooks/useMediaQuery/useMediaQuery.ts +1 -4
  429. package/src/hooks/usePrefersReducedMotion/usePrefersReducedMotion.test.ts +3 -1
  430. package/src/hooks/useResizeObserver/index.ts +1 -4
  431. package/src/hooks/useSessionStorage/useSessionStorage.test.ts +2 -6
  432. package/src/hooks/useSessionStorage/useSessionStorage.ts +4 -2
  433. package/src/hooks/useThrottledCallback/useThrottledCallback.ts +4 -3
  434. package/src/hooks/useWindowSize/useWindowSize.ts +4 -1
  435. package/src/lib/utils.ts +3 -3
  436. package/src/ui/accordion/accordion.tsx +6 -1
  437. package/src/ui/accordion/animated/accordion-content-animated.tsx +1 -4
  438. package/src/ui/accordion/animated/index.ts +4 -1
  439. package/src/ui/accordion/animated/types.ts +6 -2
  440. package/src/ui/alert/alert-base.tsx +6 -1
  441. package/src/ui/alert/alert.tsx +2 -2
  442. package/src/ui/alert/animated/index.ts +2 -2
  443. package/src/ui/alert/animated/types.ts +1 -1
  444. package/src/ui/alert/types.ts +1 -3
  445. package/src/ui/alert/variants.ts +9 -9
  446. package/src/ui/avatar/animated/index.ts +6 -2
  447. package/src/ui/avatar/avatar-base.tsx +2 -7
  448. package/src/ui/avatar/avatar.tsx +6 -1
  449. package/src/ui/avatar/variants.ts +23 -11
  450. package/src/ui/badge/animated/index.ts +6 -2
  451. package/src/ui/badge/animated/types.ts +1 -2
  452. package/src/ui/badge/badge-base.tsx +4 -1
  453. package/src/ui/badge/types.ts +1 -0
  454. package/src/ui/badge/variants.ts +16 -18
  455. package/src/ui/breadcrumb/breadcrumb.tsx +10 -2
  456. package/src/ui/breadcrumb/types.ts +20 -9
  457. package/src/ui/breadcrumb/variants.ts +34 -38
  458. package/src/ui/buttons/animated/index.ts +7 -1
  459. package/src/ui/buttons/animated/types.ts +0 -1
  460. package/src/ui/buttons/button.test.tsx +2 -2
  461. package/src/ui/buttons/types.ts +4 -5
  462. package/src/ui/buttons/variants.ts +17 -17
  463. package/src/ui/card/animated/types.ts +0 -1
  464. package/src/ui/card/card-base.tsx +1 -6
  465. package/src/ui/card/card.test.tsx +7 -3
  466. package/src/ui/card/card.tsx +1 -3
  467. package/src/ui/card/index.ts +7 -3
  468. package/src/ui/card/types.ts +1 -1
  469. package/src/ui/card/variants.ts +9 -9
  470. package/src/ui/divider/animated/index.ts +5 -1
  471. package/src/ui/divider/animated/types.ts +4 -2
  472. package/src/ui/divider/divider-base.tsx +0 -1
  473. package/src/ui/drawer/animated/drawer-content-animated.tsx +6 -11
  474. package/src/ui/drawer/animated/index.ts +6 -1
  475. package/src/ui/drawer/drawer-base.tsx +16 -8
  476. package/src/ui/drawer/types.ts +12 -3
  477. package/src/ui/drawer/variants.ts +18 -18
  478. package/src/ui/dropdown/dropdown.test.tsx +1 -3
  479. package/src/ui/dropdown/dropdown.tsx +30 -5
  480. package/src/ui/dropdown/types.ts +1 -0
  481. package/src/ui/dropdown/variants.ts +20 -20
  482. package/src/ui/empty-state/animated/empty-state-animated.tsx +2 -4
  483. package/src/ui/empty-state/animated/index.ts +8 -5
  484. package/src/ui/empty-state/empty-state-base.tsx +14 -2
  485. package/src/ui/empty-state/index.ts +7 -1
  486. package/src/ui/empty-state/types.ts +1 -0
  487. package/src/ui/file-upload/file-upload.tsx +3 -9
  488. package/src/ui/file-upload/variants.ts +18 -9
  489. package/src/ui/inputs/animated/index.ts +7 -1
  490. package/src/ui/inputs/input-base.tsx +60 -6
  491. package/src/ui/inputs/input.test.tsx +5 -1
  492. package/src/ui/inputs/types.ts +7 -2
  493. package/src/ui/modal/animated/index.ts +6 -1
  494. package/src/ui/modal/animated/modal-content-animated.tsx +4 -5
  495. package/src/ui/modal/index.ts +1 -1
  496. package/src/ui/modal/modal-base.tsx +19 -10
  497. package/src/ui/modal/modal.test.tsx +44 -4
  498. package/src/ui/modal/modal.tsx +1 -1
  499. package/src/ui/modal/types.ts +10 -2
  500. package/src/ui/modal/variants.ts +18 -18
  501. package/src/ui/pagination/pagination.tsx +2 -2
  502. package/src/ui/pagination/variants.ts +9 -9
  503. package/src/ui/progress/animated/progress-animated.tsx +43 -5
  504. package/src/ui/progress/animated/types.ts +1 -1
  505. package/src/ui/progress/index.ts +12 -2
  506. package/src/ui/progress/progress-base.tsx +61 -5
  507. package/src/ui/progress/progress.test.tsx +1 -3
  508. package/src/ui/progress/progress.tsx +2 -6
  509. package/src/ui/progress/types.ts +3 -0
  510. package/src/ui/search/filter-search-suggestions.test.ts +46 -12
  511. package/src/ui/search/filter-search-suggestions.ts +3 -3
  512. package/src/ui/search/search-bar.tsx +22 -22
  513. package/src/ui/search/search-suggestion-list.tsx +14 -5
  514. package/src/ui/search/search-suggestion-utils.ts +4 -1
  515. package/src/ui/select/select.tsx +96 -6
  516. package/src/ui/select/types.ts +1 -0
  517. package/src/ui/select/variants.ts +71 -68
  518. package/src/ui/skeleton/animated/skeleton-animated.tsx +25 -4
  519. package/src/ui/skeleton/animated/types.ts +0 -1
  520. package/src/ui/skeleton/skeleton-base.tsx +3 -3
  521. package/src/ui/skeleton/variants.ts +9 -9
  522. package/src/ui/slider/slider.test.tsx +23 -9
  523. package/src/ui/slider/slider.tsx +45 -4
  524. package/src/ui/slider/types.ts +9 -3
  525. package/src/ui/slider/variants.ts +1 -1
  526. package/src/ui/spinner/animated/spinner.tsx +6 -3
  527. package/src/ui/stepper/stepper.test.tsx +5 -6
  528. package/src/ui/stepper/stepper.tsx +12 -16
  529. package/src/ui/stepper/types.ts +11 -5
  530. package/src/ui/stepper/variants.ts +30 -15
  531. package/src/ui/table/animated/index.ts +6 -4
  532. package/src/ui/table/table-base.tsx +32 -11
  533. package/src/ui/table/types.ts +8 -1
  534. package/src/ui/tabs/animated/animations.ts +5 -1
  535. package/src/ui/tabs/animated/index.ts +7 -1
  536. package/src/ui/tabs/animated/types.ts +3 -3
  537. package/src/ui/tabs/index.ts +8 -1
  538. package/src/ui/tabs/tabs-base.tsx +71 -10
  539. package/src/ui/tabs/tabs.tsx +8 -1
  540. package/src/ui/tabs/types.ts +2 -1
  541. package/src/ui/tabs/variants.ts +10 -10
  542. package/src/ui/toast/animated/toast-animated.tsx +3 -1
  543. package/src/ui/toast/animated/types.ts +1 -1
  544. package/src/ui/toast/toast-base.tsx +1 -1
  545. package/src/ui/toast/types.ts +3 -1
  546. package/src/ui/toast/variants.ts +9 -9
  547. package/src/ui/toggle/animated/index.ts +7 -4
  548. package/src/ui/toggle/animated/types.ts +4 -2
  549. package/src/ui/toggle/index.ts +5 -1
  550. package/src/ui/toggle/toggle-base.tsx +36 -4
  551. package/src/ui/tooltip/animated/animations.ts +0 -1
  552. package/src/ui/tooltip/animated/types.ts +0 -1
  553. package/src/ui/tooltip/tooltip-base.tsx +118 -22
  554. package/src/ui/tooltip/types.ts +1 -0
  555. package/src/ui/tooltip/variants.ts +11 -13
  556. package/src/ui/typography/blockquote-base.tsx +1 -8
  557. package/src/ui/typography/code-block-base.tsx +19 -24
  558. package/src/ui/typography/heading-base.tsx +35 -38
  559. package/src/ui/typography/inline-code-base.tsx +15 -15
  560. package/src/ui/typography/list-base.tsx +1 -9
  561. package/src/ui/typography/text-base.tsx +32 -32
  562. package/src/ui/typography/types.ts +4 -17
  563. package/src/ui/typography/typography.test.tsx +3 -1
  564. package/src/ui/typography/variants.ts +16 -8
  565. package/dist/chunk-2P3UU2J3.mjs.map +0 -1
  566. package/dist/chunk-2PQEXQVR.js.map +0 -1
  567. package/dist/chunk-3OR47XMY.js.map +0 -1
  568. package/dist/chunk-4B7KGBQB.js.map +0 -1
  569. package/dist/chunk-5QB2KNZQ.js.map +0 -1
  570. package/dist/chunk-6I7X5BF2.js.map +0 -1
  571. package/dist/chunk-7HL3A4YF.mjs.map +0 -1
  572. package/dist/chunk-BITDSQMR.js.map +0 -1
  573. package/dist/chunk-BORK3BJO.mjs.map +0 -1
  574. package/dist/chunk-BSWYZTYK.js.map +0 -1
  575. package/dist/chunk-BVXTOEBI.mjs.map +0 -1
  576. package/dist/chunk-CY5BQKRZ.mjs.map +0 -1
  577. package/dist/chunk-E3DZNJAD.js.map +0 -1
  578. package/dist/chunk-FLILFCQE.mjs.map +0 -1
  579. package/dist/chunk-FT2LMA66.mjs.map +0 -1
  580. package/dist/chunk-IXDJ3IPG.mjs.map +0 -1
  581. package/dist/chunk-LVUPECBT.mjs.map +0 -1
  582. package/dist/chunk-N4NO3SYL.js.map +0 -1
  583. package/dist/chunk-P5HUBXUX.js.map +0 -1
  584. package/dist/chunk-PGH27VTL.mjs.map +0 -1
  585. package/dist/chunk-RDSPHBHK.mjs.map +0 -1
  586. package/dist/chunk-U4YQCAXW.js.map +0 -1
  587. package/dist/chunk-WDCIZHXY.mjs.map +0 -1
  588. package/dist/chunk-WL5I7RVS.mjs +0 -54
  589. package/dist/chunk-WL5I7RVS.mjs.map +0 -1
  590. package/dist/chunk-WP7GYBRI.js.map +0 -1
  591. package/dist/chunk-WZKGRU3U.js.map +0 -1
  592. package/dist/chunk-XIXF7UVM.mjs.map +0 -1
  593. package/dist/chunk-XLAFQ24R.js.map +0 -1
  594. package/dist/chunk-XWM2S6VV.mjs.map +0 -1
  595. package/dist/chunk-YNCD6TKE.mjs.map +0 -1
  596. package/dist/chunk-YPLVTUYL.js +0 -56
  597. package/dist/chunk-YPLVTUYL.js.map +0 -1
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var chunkUOZYPWDZ_js = require('./chunk-UOZYPWDZ.js');
3
+ var chunkZS5756ZC_js = require('./chunk-ZS5756ZC.js');
4
4
  var classVarianceAuthority = require('class-variance-authority');
5
5
  var react = require('react');
6
6
  var jsxRuntime = require('react/jsx-runtime');
@@ -28,7 +28,7 @@ var tabsListVariants = classVarianceAuthority.cva("flex items-center gap-1", {
28
28
  }
29
29
  });
30
30
  var tabsTriggerVariants = classVarianceAuthority.cva(
31
- "px-3 py-1.5 rounded-md transition-all focus:outline-none focus:ring-2 focus:ring-ring",
31
+ "px-3 py-1.5 rounded-md transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring",
32
32
  {
33
33
  variants: {
34
34
  appearance: {
@@ -43,15 +43,15 @@ var tabsTriggerVariants = classVarianceAuthority.cva(
43
43
  indigo: "bg-indigo-500/75",
44
44
  emerald: "bg-emerald-500/75",
45
45
  gray: "bg-gray-500/75",
46
- "gradient-blue": "bg-gradient-to-r from-blue-600 to-purple-600",
47
- "gradient-green": "bg-gradient-to-r from-green-600 to-lime-600",
48
- "gradient-red": "bg-gradient-to-r from-red-600 to-pink-600",
49
- "gradient-yellow": "bg-gradient-to-r from-yellow-600 to-orange-600",
50
- "gradient-purple": "bg-gradient-to-r from-purple-600 to-pink-600",
51
- "gradient-teal": "bg-gradient-to-r from-teal-600 to-cyan-600",
52
- "gradient-indigo": "bg-gradient-to-r from-indigo-600 to-purple-600",
53
- "gradient-pink": "bg-gradient-to-r from-pink-600 to-rose-600",
54
- "gradient-orange": "bg-gradient-to-r from-orange-600 to-red-600"
46
+ "gradient-blue": "bg-linear-to-r from-blue-600 to-purple-600",
47
+ "gradient-green": "bg-linear-to-r from-green-600 to-lime-600",
48
+ "gradient-red": "bg-linear-to-r from-red-600 to-pink-600",
49
+ "gradient-yellow": "bg-linear-to-r from-yellow-600 to-orange-600",
50
+ "gradient-purple": "bg-linear-to-r from-purple-600 to-pink-600",
51
+ "gradient-teal": "bg-linear-to-r from-teal-600 to-cyan-600",
52
+ "gradient-indigo": "bg-linear-to-r from-indigo-600 to-purple-600",
53
+ "gradient-pink": "bg-linear-to-r from-pink-600 to-rose-600",
54
+ "gradient-orange": "bg-linear-to-r from-orange-600 to-red-600"
55
55
  },
56
56
  variant: {
57
57
  default: "data-[state=active]:bg-background",
@@ -90,6 +90,7 @@ function Tabs({
90
90
  }) {
91
91
  const [internalValue, setInternalValue] = react.useState(defaultValue);
92
92
  const idPrefix = react.useId();
93
+ const listRef = react.useRef(null);
93
94
  const isControlled = value !== void 0;
94
95
  const currentValue = isControlled ? value : internalValue;
95
96
  const setValue = (val) => {
@@ -104,6 +105,7 @@ function Tabs({
104
105
  value: {
105
106
  value: currentValue,
106
107
  setValue,
108
+ listRef,
107
109
  orientation,
108
110
  size,
109
111
  variant,
@@ -111,18 +113,19 @@ function Tabs({
111
113
  tabTriggerId,
112
114
  tabPanelId
113
115
  },
114
- children: /* @__PURE__ */ jsxRuntime.jsx("div", { "data-slot": "tabs", className: chunkUOZYPWDZ_js.cn("w-full", className), children })
116
+ children: /* @__PURE__ */ jsxRuntime.jsx("div", { "data-slot": "tabs", className: chunkZS5756ZC_js.cn("w-full", className), children })
115
117
  }
116
118
  );
117
119
  }
118
120
  function TabsList({ children, className, ...props }) {
119
- const { orientation, size } = useTabs();
121
+ const { orientation, size, listRef } = useTabs();
120
122
  return /* @__PURE__ */ jsxRuntime.jsx(
121
123
  "div",
122
124
  {
125
+ ref: listRef,
123
126
  role: "tablist",
124
127
  "aria-orientation": orientation,
125
- className: chunkUOZYPWDZ_js.cn(tabsListVariants({ orientation, size }), className),
128
+ className: chunkZS5756ZC_js.cn(tabsListVariants({ orientation, size }), className),
126
129
  ...props,
127
130
  children
128
131
  }
@@ -138,6 +141,8 @@ function TabsTrigger({
138
141
  const {
139
142
  value: activeValue,
140
143
  setValue,
144
+ listRef,
145
+ orientation,
141
146
  tabTriggerId,
142
147
  tabPanelId,
143
148
  size,
@@ -146,25 +151,68 @@ function TabsTrigger({
146
151
  } = useTabs();
147
152
  const isActive = activeValue === value;
148
153
  const handleKeyDown = (e) => {
149
- const triggers = Array.from(
150
- document.querySelectorAll('[role="tab"]')
151
- );
154
+ const list = listRef.current;
155
+ const triggers = list === null ? [] : Array.from(list.querySelectorAll('[role="tab"]'));
156
+ const nextKeys = orientation === "vertical" ? ["ArrowDown"] : ["ArrowRight"];
157
+ const prevKeys = orientation === "vertical" ? ["ArrowUp"] : ["ArrowLeft"];
152
158
  const index = triggers.findIndex((el) => el === e.currentTarget);
153
- if (e.key === "ArrowRight" || e.key === "ArrowDown") {
159
+ if (index === -1) {
160
+ return;
161
+ }
162
+ const findEnabledIndex = (start, direction) => {
163
+ const n = triggers.length;
164
+ if (n === 0) {
165
+ return void 0;
166
+ }
167
+ let i = start;
168
+ for (let step = 0; step < n; step += 1) {
169
+ i = (i + direction + n) % n;
170
+ if (triggers[i]?.disabled !== true) {
171
+ return i;
172
+ }
173
+ }
174
+ return void 0;
175
+ };
176
+ const focusAt = (i) => {
177
+ const target = triggers[i];
178
+ if (target !== void 0 && target.disabled !== true) {
179
+ target.focus();
180
+ }
181
+ };
182
+ const isNext = nextKeys.includes(e.key);
183
+ const isPrev = prevKeys.includes(e.key);
184
+ if (isNext) {
154
185
  e.preventDefault();
155
- triggers[index + 1]?.focus();
186
+ const nextIdx = findEnabledIndex(index, 1);
187
+ if (nextIdx !== void 0) {
188
+ focusAt(nextIdx);
189
+ }
190
+ return;
156
191
  }
157
- if (e.key === "ArrowLeft" || e.key === "ArrowUp") {
192
+ if (isPrev) {
158
193
  e.preventDefault();
159
- triggers[index - 1]?.focus();
194
+ const prevIdx = findEnabledIndex(index, -1);
195
+ if (prevIdx !== void 0) {
196
+ focusAt(prevIdx);
197
+ }
198
+ return;
160
199
  }
161
200
  if (e.key === "Home") {
162
201
  e.preventDefault();
163
- triggers[0]?.focus();
202
+ const firstEnabledIndex = triggers.findIndex((btn) => !btn.disabled);
203
+ if (firstEnabledIndex !== -1) {
204
+ triggers[firstEnabledIndex]?.focus();
205
+ }
206
+ return;
164
207
  }
165
208
  if (e.key === "End") {
166
209
  e.preventDefault();
167
- triggers[triggers.length - 1]?.focus();
210
+ for (let i = triggers.length - 1; i >= 0; i -= 1) {
211
+ if (!triggers[i]?.disabled) {
212
+ triggers[i]?.focus();
213
+ break;
214
+ }
215
+ }
168
216
  }
169
217
  };
170
218
  return /* @__PURE__ */ jsxRuntime.jsx(
@@ -177,9 +225,10 @@ function TabsTrigger({
177
225
  "aria-selected": isActive,
178
226
  "aria-controls": tabPanelId(value),
179
227
  disabled,
228
+ tabIndex: activeValue === void 0 ? void 0 : isActive ? 0 : -1,
180
229
  onClick: () => setValue(value),
181
230
  onKeyDown: handleKeyDown,
182
- className: chunkUOZYPWDZ_js.cn(
231
+ className: chunkZS5756ZC_js.cn(
183
232
  tabsTriggerVariants({ size, appearance, variant }),
184
233
  className,
185
234
  "cursor-pointer"
@@ -204,7 +253,7 @@ function TabsContent({
204
253
  id: tabPanelId(value),
205
254
  role: "tabpanel",
206
255
  "aria-labelledby": tabTriggerId(value),
207
- className: chunkUOZYPWDZ_js.cn("mt-2", className),
256
+ className: chunkZS5756ZC_js.cn("mt-2", className),
208
257
  ...props,
209
258
  children
210
259
  }
@@ -219,5 +268,5 @@ exports.TabsTrigger = TabsTrigger;
219
268
  exports.tabsListVariants = tabsListVariants;
220
269
  exports.tabsTriggerVariants = tabsTriggerVariants;
221
270
  exports.useTabs = useTabs;
222
- //# sourceMappingURL=chunk-2PQEXQVR.js.map
223
- //# sourceMappingURL=chunk-2PQEXQVR.js.map
271
+ //# sourceMappingURL=chunk-PWL5WD34.js.map
272
+ //# sourceMappingURL=chunk-PWL5WD34.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/ui/tabs/variants.ts","../src/ui/tabs/tabs-base.tsx"],"names":["cva","createContext","useContext","useState","useId","useRef","jsx","cn"],"mappings":"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","file":"chunk-PWL5WD34.js","sourcesContent":["import { cva } from \"class-variance-authority\";\n\nexport const tabsListVariants = cva(\"flex items-center gap-1\", {\n variants: {\n variant: {\n default: \"bg-transparent\",\n underline: \"border-b-2 border-transparent\",\n pills: \"rounded-md\",\n },\n size: {\n sm: \"text-sm p-1\",\n md: \"text-base p-1.5\",\n lg: \"text-lg p-2\",\n },\n orientation: {\n horizontal: \"flex-row\",\n vertical: \"flex-col\",\n },\n },\n defaultVariants: {\n size: \"md\",\n orientation: \"horizontal\",\n },\n});\n\nexport const tabsTriggerVariants = cva(\n \"px-3 py-1.5 rounded-md transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring\",\n {\n variants: {\n appearance: {\n default: \"bg-transparent\",\n sky: \"bg-sky-500/75\",\n rose: \"bg-rose-500/75\",\n purple: \"bg-purple-500/75\",\n pink: \"bg-pink-500/75\",\n orange: \"bg-orange-500/75\",\n yellow: \"bg-yellow-500/75\",\n teal: \"bg-teal-500/75\",\n indigo: \"bg-indigo-500/75\",\n emerald: \"bg-emerald-500/75\",\n gray: \"bg-gray-500/75\",\n \"gradient-blue\": \"bg-linear-to-r from-blue-600 to-purple-600\",\n \"gradient-green\": \"bg-linear-to-r from-green-600 to-lime-600\",\n \"gradient-red\": \"bg-linear-to-r from-red-600 to-pink-600\",\n \"gradient-yellow\": \"bg-linear-to-r from-yellow-600 to-orange-600\",\n \"gradient-purple\": \"bg-linear-to-r from-purple-600 to-pink-600\",\n \"gradient-teal\": \"bg-linear-to-r from-teal-600 to-cyan-600\",\n \"gradient-indigo\": \"bg-linear-to-r from-indigo-600 to-purple-600\",\n \"gradient-pink\": \"bg-linear-to-r from-pink-600 to-rose-600\",\n \"gradient-orange\": \"bg-linear-to-r from-orange-600 to-red-600\",\n },\n variant: {\n default: \"data-[state=active]:bg-background\",\n underline:\n \"border-b-2 border-transparent data-[state=active]:border-primary rounded-none\",\n pills: \"data-[state=active]:bg-primary data-[state=active]:text-white\",\n },\n size: {\n sm: \"px-2 py-1\",\n md: \"px-3 py-1.5\",\n lg: \"px-4 py-2\",\n },\n },\n defaultVariants: {\n appearance: \"default\",\n variant: \"default\",\n size: \"md\",\n },\n },\n);\n","\"use client\";\n\nimport {\n createContext,\n KeyboardEvent,\n useContext,\n useId,\n useRef,\n useState,\n} from \"react\";\n\nimport { cn } from \"../../lib/utils\";\n\nimport {\n TabsContentProps,\n TabsListProps,\n TabsProps,\n TabsTriggerProps,\n TabsValue,\n TabsContextType,\n} from \"./types\";\nimport { tabsListVariants, tabsTriggerVariants } from \"./variants\";\n\nexport const TabsContext = createContext<TabsContextType | null>(null);\n\nexport const useTabs = () => {\n const ctx = useContext(TabsContext);\n if (!ctx) throw new Error(\"Tabs components must be used within Tabs\");\n return ctx;\n};\n\nexport function Tabs({\n value,\n defaultValue,\n onValueChange,\n orientation = \"horizontal\",\n variant,\n size,\n appearance,\n children,\n className,\n}: TabsProps) {\n const [internalValue, setInternalValue] = useState(defaultValue);\n const idPrefix = useId();\n const listRef = useRef<HTMLDivElement | null>(null);\n\n const isControlled = value !== undefined;\n const currentValue = isControlled ? value : internalValue;\n\n const setValue = (val: string) => {\n if (!isControlled) setInternalValue(val);\n onValueChange?.(val);\n };\n\n const tabTriggerId = (tabValue: TabsValue) =>\n `${idPrefix}zentauri-tab-${tabValue}`;\n const tabPanelId = (tabValue: TabsValue) =>\n `${idPrefix}zentauri-panel-${tabValue}`;\n\n return (\n <TabsContext.Provider\n value={{\n value: currentValue,\n setValue,\n listRef,\n orientation,\n size,\n variant,\n appearance,\n tabTriggerId,\n tabPanelId,\n }}\n >\n <div data-slot=\"tabs\" className={cn(\"w-full\", className)}>\n {children}\n </div>\n </TabsContext.Provider>\n );\n}\n\nexport function TabsList({ children, className, ...props }: TabsListProps) {\n const { orientation, size, listRef } = useTabs();\n\n return (\n <div\n ref={listRef}\n role=\"tablist\"\n aria-orientation={orientation}\n className={cn(tabsListVariants({ orientation, size }), className)}\n {...props}\n >\n {children}\n </div>\n );\n}\n\nexport function TabsTrigger({\n value,\n children,\n disabled,\n className,\n ...props\n}: TabsTriggerProps) {\n const {\n value: activeValue,\n setValue,\n listRef,\n orientation,\n tabTriggerId,\n tabPanelId,\n size,\n appearance,\n variant,\n } = useTabs();\n\n const isActive = activeValue === value;\n\n const handleKeyDown = (e: KeyboardEvent<HTMLButtonElement>) => {\n const list = listRef.current;\n const triggers =\n list === null\n ? []\n : Array.from(list.querySelectorAll<HTMLButtonElement>('[role=\"tab\"]'));\n\n const nextKeys =\n orientation === \"vertical\" ? [\"ArrowDown\"] : [\"ArrowRight\"];\n const prevKeys = orientation === \"vertical\" ? [\"ArrowUp\"] : [\"ArrowLeft\"];\n\n const index = triggers.findIndex((el) => el === e.currentTarget);\n if (index === -1) {\n return;\n }\n\n const findEnabledIndex = (\n start: number,\n direction: 1 | -1,\n ): number | undefined => {\n const n = triggers.length;\n if (n === 0) {\n return undefined;\n }\n let i = start;\n for (let step = 0; step < n; step += 1) {\n i = (i + direction + n) % n;\n if (triggers[i]?.disabled !== true) {\n return i;\n }\n }\n return undefined;\n };\n\n const focusAt = (i: number) => {\n const target = triggers[i];\n if (target !== undefined && target.disabled !== true) {\n target.focus();\n }\n };\n\n const isNext = nextKeys.includes(e.key);\n const isPrev = prevKeys.includes(e.key);\n\n if (isNext) {\n e.preventDefault();\n const nextIdx = findEnabledIndex(index, 1);\n if (nextIdx !== undefined) {\n focusAt(nextIdx);\n }\n return;\n }\n\n if (isPrev) {\n e.preventDefault();\n const prevIdx = findEnabledIndex(index, -1);\n if (prevIdx !== undefined) {\n focusAt(prevIdx);\n }\n return;\n }\n\n if (e.key === \"Home\") {\n e.preventDefault();\n const firstEnabledIndex = triggers.findIndex((btn) => !btn.disabled);\n if (firstEnabledIndex !== -1) {\n triggers[firstEnabledIndex]?.focus();\n }\n return;\n }\n\n if (e.key === \"End\") {\n e.preventDefault();\n for (let i = triggers.length - 1; i >= 0; i -= 1) {\n if (!triggers[i]?.disabled) {\n triggers[i]?.focus();\n break;\n }\n }\n }\n };\n\n return (\n <button\n id={tabTriggerId(value)}\n type=\"button\"\n role=\"tab\"\n data-state={isActive ? \"active\" : \"inactive\"}\n aria-selected={isActive}\n aria-controls={tabPanelId(value)}\n disabled={disabled}\n tabIndex={activeValue === undefined ? undefined : isActive ? 0 : -1}\n onClick={() => setValue(value)}\n onKeyDown={handleKeyDown}\n className={cn(\n tabsTriggerVariants({ size, appearance, variant }),\n className,\n \"cursor-pointer\",\n )}\n {...props}\n >\n {children}\n </button>\n );\n}\n\nexport function TabsContent({\n value,\n children,\n className,\n as: Wrapper = \"div\",\n ...props\n}: TabsContentProps) {\n const { value: activeValue, tabTriggerId, tabPanelId } = useTabs();\n\n if (activeValue !== value) return null;\n\n return (\n <Wrapper\n id={tabPanelId(value)}\n role=\"tabpanel\"\n aria-labelledby={tabTriggerId(value)}\n className={cn(\"mt-2\", className)}\n {...props}\n >\n {children}\n </Wrapper>\n );\n}\n"]}
@@ -21,5 +21,5 @@ function useMediaQuery(query, defaultValue = false) {
21
21
  }
22
22
 
23
23
  export { useMediaQuery };
24
- //# sourceMappingURL=chunk-FT2LMA66.mjs.map
25
- //# sourceMappingURL=chunk-FT2LMA66.mjs.map
24
+ //# sourceMappingURL=chunk-QADZK5R7.mjs.map
25
+ //# sourceMappingURL=chunk-QADZK5R7.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/hooks/useMediaQuery/useMediaQuery.ts"],"names":[],"mappings":";;;AAcO,SAAS,aAAA,CAAc,KAAA,EAAe,YAAA,GAAe,KAAA,EAAgB;AAC1E,EAAA,MAAM,CAAC,OAAA,EAAS,UAAU,CAAA,GAAI,SAAS,YAAY,CAAA;AAEnD,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,IAAI,OAAO,MAAA,KAAW,WAAA,IAAe,CAAC,OAAO,UAAA,EAAY;AACvD,MAAA;AAAA,IACF;AACA,IAAA,MAAM,KAAA,GAAQ,MAAA,CAAO,UAAA,CAAW,KAAK,CAAA;AACrC,IAAA,MAAM,WAAW,MAAM;AACrB,MAAA,UAAA,CAAW,MAAM,OAAO,CAAA;AAAA,IAC1B,CAAA;AACA,IAAA,UAAA,CAAW,MAAM,OAAO,CAAA;AACxB,IAAA,KAAA,CAAM,gBAAA,CAAiB,UAAU,QAAQ,CAAA;AACzC,IAAA,OAAO,MAAM;AACX,MAAA,KAAA,CAAM,mBAAA,CAAoB,UAAU,QAAQ,CAAA;AAAA,IAC9C,CAAA;AAAA,EACF,CAAA,EAAG,CAAC,KAAK,CAAC,CAAA;AAEV,EAAA,OAAO,OAAA;AACT","file":"chunk-QADZK5R7.mjs","sourcesContent":["\"use client\";\n\nimport { useEffect, useState } from \"react\";\n\n/**\n * Subscribes to `window.matchMedia(query)` and returns whether the query currently matches.\n *\n * On the server or when `matchMedia` is missing, `defaultValue` is used for the initial render and the effect no-ops.\n * The `change` listener keeps `matches` updated when the viewport or user settings change.\n *\n * @param query - A valid media query string, e.g. `\"(min-width: 768px)\"`.\n * @param defaultValue - Value to use before hydration or when `matchMedia` is unavailable (default `false`).\n * @returns Current `matches` boolean for the query.\n */\nexport function useMediaQuery(query: string, defaultValue = false): boolean {\n const [matches, setMatches] = useState(defaultValue);\n\n useEffect(() => {\n if (typeof window === \"undefined\" || !window.matchMedia) {\n return;\n }\n const media = window.matchMedia(query);\n const onChange = () => {\n setMatches(media.matches);\n };\n setMatches(media.matches);\n media.addEventListener(\"change\", onChange);\n return () => {\n media.removeEventListener(\"change\", onChange);\n };\n }, [query]);\n\n return matches;\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { cn } from './chunk-DFEZH7TC.mjs';
1
+ import { cn } from './chunk-4D54YOL6.mjs';
2
2
  import { cva } from 'class-variance-authority';
3
3
  import { createContext, useMemo, useContext } from 'react';
4
4
  import { HiXMark, HiExclamationTriangle, HiInformationCircle } from 'react-icons/hi2';
@@ -23,15 +23,15 @@ var alertVariants = cva(
23
23
  indigo: "border-indigo-600 bg-indigo-950/70 backdrop-blur-xl",
24
24
  gray: "border-gray-600 bg-gray-950/70 backdrop-blur-xl",
25
25
  violet: "border-violet-600 bg-violet-950/70 backdrop-blur-xl",
26
- "gradient-blue": "border-gradient-to-r from-blue-600 to-purple-600 bg-gradient-to-r from-blue-950/70 to-purple-950/70 backdrop-blur-xl",
27
- "gradient-green": "border-gradient-to-r from-green-600 to-lime-600 bg-gradient-to-r from-green-950/70 to-lime-950/70 backdrop-blur-xl",
28
- "gradient-red": "border-gradient-to-r from-red-600 to-pink-600 bg-gradient-to-r from-red-950/70 to-pink-950/70 backdrop-blur-xl",
29
- "gradient-yellow": "border-gradient-to-r from-yellow-600 to-orange-600 bg-gradient-to-r from-yellow-950/70 to-orange-950/70 backdrop-blur-xl",
30
- "gradient-purple": "border-gradient-to-r from-purple-600 to-pink-600 bg-gradient-to-r from-purple-950/70 to-pink-950/70 backdrop-blur-xl",
31
- "gradient-teal": "border-gradient-to-r from-teal-600 to-cyan-600 bg-gradient-to-r from-teal-950/70 to-cyan-950/70 backdrop-blur-xl",
32
- "gradient-indigo": "border-gradient-to-r from-indigo-600 to-purple-600 bg-gradient-to-r from-indigo-950/70 to-purple-950/70 backdrop-blur-xl",
33
- "gradient-pink": "border-gradient-to-r from-pink-600 to-rose-600 bg-gradient-to-r from-pink-950/70 to-rose-950/70 backdrop-blur-xl",
34
- "gradient-orange": "border-gradient-to-r from-orange-600 to-red-600 bg-gradient-to-r from-orange-950/70 to-red-950/70 backdrop-blur-xl"
26
+ "gradient-blue": "border-gradient-to-r from-blue-600 to-purple-600 bg-linear-to-r from-blue-950/70 to-purple-950/70 backdrop-blur-xl",
27
+ "gradient-green": "border-gradient-to-r from-green-600 to-lime-600 bg-linear-to-r from-green-950/70 to-lime-950/70 backdrop-blur-xl",
28
+ "gradient-red": "border-gradient-to-r from-red-600 to-pink-600 bg-linear-to-r from-red-950/70 to-pink-950/70 backdrop-blur-xl",
29
+ "gradient-yellow": "border-gradient-to-r from-yellow-600 to-orange-600 bg-linear-to-r from-yellow-950/70 to-orange-950/70 backdrop-blur-xl",
30
+ "gradient-purple": "border-gradient-to-r from-purple-600 to-pink-600 bg-linear-to-r from-purple-950/70 to-pink-950/70 backdrop-blur-xl",
31
+ "gradient-teal": "border-gradient-to-r from-teal-600 to-cyan-600 bg-linear-to-r from-teal-950/70 to-cyan-950/70 backdrop-blur-xl",
32
+ "gradient-indigo": "border-gradient-to-r from-indigo-600 to-purple-600 bg-linear-to-r from-indigo-950/70 to-purple-950/70 backdrop-blur-xl",
33
+ "gradient-pink": "border-gradient-to-r from-pink-600 to-rose-600 bg-linear-to-r from-pink-950/70 to-rose-950/70 backdrop-blur-xl",
34
+ "gradient-orange": "border-gradient-to-r from-orange-600 to-red-600 bg-linear-to-r from-orange-950/70 to-red-950/70 backdrop-blur-xl"
35
35
  },
36
36
  size: {
37
37
  sm: "rounded-lg p-3",
@@ -190,5 +190,5 @@ function AlertDefaultIcon({
190
190
  }
191
191
 
192
192
  export { AlertBase, AlertClose, AlertDefaultIcon, AlertDescription, AlertIcon, AlertTitle, alertDescriptionVariants, alertTitleVariants, alertVariants };
193
- //# sourceMappingURL=chunk-XIXF7UVM.mjs.map
194
- //# sourceMappingURL=chunk-XIXF7UVM.mjs.map
193
+ //# sourceMappingURL=chunk-QEGACUFU.mjs.map
194
+ //# sourceMappingURL=chunk-QEGACUFU.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/ui/alert/variants.ts","../src/ui/alert/alert-base.tsx"],"names":[],"mappings":"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","file":"chunk-QEGACUFU.mjs","sourcesContent":["import { cva } from \"class-variance-authority\";\n\nexport const alertVariants = cva(\n \"relative flex w-full gap-3 border text-sm ring-offset-slate-950 transition-colors\",\n {\n variants: {\n appearance: {\n default: \"border-white/10 bg-white/5 text-slate-50\",\n success: \"border-emerald-500/40 bg-emerald-500/10 text-emerald-50\",\n warning: \"border-amber-500/40 bg-amber-500/10 text-amber-50\",\n error: \"border-rose-500/50 bg-rose-500/10 text-rose-50\",\n info: \"border-sky-500/40 bg-sky-500/10 text-sky-50\",\n ghost: \"border-transparent bg-transparent text-slate-200\",\n purple: \"border-purple-600 bg-purple-950/70 backdrop-blur-xl\",\n pink: \"border-pink-600 bg-pink-950/70 backdrop-blur-xl\",\n orange: \"border-orange-600 bg-orange-950/70 backdrop-blur-xl\",\n yellow: \"border-yellow-600 bg-yellow-950/70 backdrop-blur-xl\",\n teal: \"border-teal-600 bg-teal-950/70 backdrop-blur-xl\",\n indigo: \"border-indigo-600 bg-indigo-950/70 backdrop-blur-xl\",\n gray: \"border-gray-600 bg-gray-950/70 backdrop-blur-xl\",\n violet: \"border-violet-600 bg-violet-950/70 backdrop-blur-xl\",\n \"gradient-blue\":\n \"border-gradient-to-r from-blue-600 to-purple-600 bg-linear-to-r from-blue-950/70 to-purple-950/70 backdrop-blur-xl\",\n \"gradient-green\":\n \"border-gradient-to-r from-green-600 to-lime-600 bg-linear-to-r from-green-950/70 to-lime-950/70 backdrop-blur-xl\",\n \"gradient-red\":\n \"border-gradient-to-r from-red-600 to-pink-600 bg-linear-to-r from-red-950/70 to-pink-950/70 backdrop-blur-xl\",\n \"gradient-yellow\":\n \"border-gradient-to-r from-yellow-600 to-orange-600 bg-linear-to-r from-yellow-950/70 to-orange-950/70 backdrop-blur-xl\",\n \"gradient-purple\":\n \"border-gradient-to-r from-purple-600 to-pink-600 bg-linear-to-r from-purple-950/70 to-pink-950/70 backdrop-blur-xl\",\n \"gradient-teal\":\n \"border-gradient-to-r from-teal-600 to-cyan-600 bg-linear-to-r from-teal-950/70 to-cyan-950/70 backdrop-blur-xl\",\n \"gradient-indigo\":\n \"border-gradient-to-r from-indigo-600 to-purple-600 bg-linear-to-r from-indigo-950/70 to-purple-950/70 backdrop-blur-xl\",\n \"gradient-pink\":\n \"border-gradient-to-r from-pink-600 to-rose-600 bg-linear-to-r from-pink-950/70 to-rose-950/70 backdrop-blur-xl\",\n \"gradient-orange\":\n \"border-gradient-to-r from-orange-600 to-red-600 bg-linear-to-r from-orange-950/70 to-red-950/70 backdrop-blur-xl\",\n },\n size: {\n sm: \"rounded-lg p-3\",\n md: \"rounded-xl p-4\",\n lg: \"rounded-2xl p-5 text-base\",\n },\n },\n defaultVariants: {\n appearance: \"default\",\n size: \"md\",\n },\n },\n);\n\nexport const alertTitleVariants = cva(\"font-semibold leading-tight\", {\n variants: {\n size: {\n sm: \"text-xs md:text-sm\",\n md: \"text-xs md:text-sm\",\n lg: \"text-xs md:text-sm\",\n },\n },\n defaultVariants: { size: \"md\" },\n});\n\nexport const alertDescriptionVariants = cva(\"text-slate-300\", {\n variants: {\n size: {\n sm: \"text-xs md:text-sm\",\n md: \"text-xs md:text-sm\",\n lg: \"text-xs md:text-sm\",\n },\n },\n defaultVariants: { size: \"md\" },\n});\n","\"use client\";\n\nimport { createContext, useContext, useMemo } from \"react\";\nimport {\n HiExclamationTriangle,\n HiInformationCircle,\n HiXMark,\n} from \"react-icons/hi2\";\n\nimport { cn } from \"../../lib/utils\";\n\nimport type {\n AlertBaseProps,\n AlertProps,\n AlertSectionProps,\n AlertSize,\n} from \"./types\";\nimport {\n alertDescriptionVariants,\n alertTitleVariants,\n alertVariants,\n} from \"./variants\";\n\nconst AlertSizeContext = createContext<AlertSize>(\"md\");\n\nfunction useAlertSize(): AlertSize {\n const ctx = useContext(AlertSizeContext);\n if (!ctx) {\n throw new Error(\"useAlertSize must be used within an Alert\");\n }\n return ctx;\n}\n\nexport function AlertBase(props: AlertBaseProps) {\n const {\n className,\n triggerClassName,\n appearance = \"default\",\n size = \"md\",\n closable = false,\n onClose,\n closeLabel = \"Dismiss alert\",\n children,\n ref,\n as: Wrapper = \"div\",\n ...rest\n } = props;\n\n const live = appearance === \"error\" ? \"assertive\" : \"polite\";\n const ctx = useMemo(() => size ?? \"md\", [size]);\n\n return (\n <AlertSizeContext.Provider value={ctx}>\n <Wrapper\n ref={ref}\n data-slot=\"alert\"\n role=\"alert\"\n aria-live={live}\n className={cn(\n alertVariants({ appearance, size }),\n closable ? \"pr-12\" : \"\",\n className,\n )}\n {...rest}\n >\n {children}\n {closable ? (\n <button\n type=\"button\"\n data-slot=\"alert-close\"\n aria-label={closeLabel}\n onClick={onClose}\n className={cn(\n \"absolute right-3 top-3 inline-flex size-8 items-center justify-center rounded-md text-slate-200 transition hover:bg-white/10 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-white/30\",\n triggerClassName,\n )}\n >\n <HiXMark className=\"size-4\" aria-hidden />\n </button>\n ) : null}\n </Wrapper>\n </AlertSizeContext.Provider>\n );\n}\n\nAlertBase.displayName = \"AlertBase\";\n\nexport function AlertIcon({ className, children }: AlertSectionProps) {\n return (\n <span\n data-slot=\"alert-icon\"\n className={cn(\"mt-0.5 shrink-0 text-current\", className)}\n >\n {children}\n </span>\n );\n}\n\nAlertIcon.displayName = \"AlertIcon\";\n\nexport function AlertTitle({ className, children }: AlertSectionProps) {\n const size = useAlertSize();\n return (\n <div\n data-slot=\"alert-title\"\n className={cn(alertTitleVariants({ size }), className)}\n >\n {children}\n </div>\n );\n}\n\nAlertTitle.displayName = \"AlertTitle\";\n\nexport function AlertDescription({ className, children }: AlertSectionProps) {\n const size = useAlertSize();\n return (\n <div\n data-slot=\"alert-description\"\n className={cn(alertDescriptionVariants({ size }), className)}\n >\n {children}\n </div>\n );\n}\n\nAlertDescription.displayName = \"AlertDescription\";\n\nexport function AlertClose({\n className,\n children,\n \"aria-label\": ariaLabel = \"Dismiss alert\",\n onClick,\n}: AlertSectionProps & { onClick?: () => void; \"aria-label\"?: string }) {\n return (\n <button\n type=\"button\"\n data-slot=\"alert-close\"\n aria-label={ariaLabel}\n onClick={onClick}\n className={cn(\n \"inline-flex size-8 items-center justify-center rounded-md text-slate-200 transition hover:bg-white/10 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-white/30\",\n className,\n )}\n >\n {children ?? <HiXMark className=\"size-4\" aria-hidden />}\n </button>\n );\n}\n\nAlertClose.displayName = \"AlertClose\";\n\nexport function AlertDefaultIcon({\n appearance,\n}: {\n appearance?: AlertProps[\"appearance\"];\n}) {\n if (appearance === \"error\") {\n return <HiExclamationTriangle className=\"size-5\" aria-hidden />;\n }\n return <HiInformationCircle className=\"size-5\" aria-hidden />;\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { cn } from './chunk-DFEZH7TC.mjs';
1
+ import { cn } from './chunk-4D54YOL6.mjs';
2
2
  import { cva } from 'class-variance-authority';
3
3
  import { createContext, useMemo, useContext } from 'react';
4
4
  import { jsx } from 'react/jsx-runtime';
@@ -62,16 +62,18 @@ function EmptyStateBase(props) {
62
62
  align,
63
63
  children,
64
64
  ref,
65
+ liveRegion = false,
65
66
  as: Wrapper = "section",
66
67
  ...rest
67
68
  } = props;
68
69
  const ctx = useMemo(() => size ?? "md", [size]);
70
+ const liveAria = typeof liveRegion === "string" ? liveRegion : liveRegion === true ? "polite" : void 0;
69
71
  return /* @__PURE__ */ jsx(EmptyStateSizeContext.Provider, { value: ctx, children: /* @__PURE__ */ jsx(
70
72
  Wrapper,
71
73
  {
72
74
  ref,
73
75
  "data-slot": "empty-state",
74
- "aria-live": "polite",
76
+ "aria-live": liveAria,
75
77
  className: cn(
76
78
  emptyStateVariants({ size, appearance, align }),
77
79
  className
@@ -135,5 +137,5 @@ function EmptyStateAction({
135
137
  EmptyStateAction.displayName = "EmptyStateAction";
136
138
 
137
139
  export { EmptyStateAction, EmptyStateBase, EmptyStateDescription, EmptyStateIcon, EmptyStateTitle, emptyStateDescriptionVariants, emptyStateTitleVariants, emptyStateVariants };
138
- //# sourceMappingURL=chunk-WDCIZHXY.mjs.map
139
- //# sourceMappingURL=chunk-WDCIZHXY.mjs.map
140
+ //# sourceMappingURL=chunk-QZTEFGZF.mjs.map
141
+ //# sourceMappingURL=chunk-QZTEFGZF.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/ui/empty-state/variants.ts","../src/ui/empty-state/empty-state-base.tsx"],"names":[],"mappings":"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","file":"chunk-QZTEFGZF.mjs","sourcesContent":["import { cva } from \"class-variance-authority\";\n\nexport const emptyStateVariants = cva(\n \"flex w-full flex-col items-center text-center\",\n {\n variants: {\n size: {\n sm: \"gap-2 p-4 text-sm\",\n md: \"gap-3 p-6 text-sm\",\n lg: \"gap-4 p-8 text-base\",\n },\n appearance: {\n default: \"text-slate-50\",\n ghost: \"text-slate-200\",\n card: \"rounded-2xl border border-white/10 bg-white/5 p-8 text-slate-50 shadow-[0_18px_48px_rgba(15,23,42,0.35)]\",\n },\n align: {\n start: \"items-start text-left\",\n center: \"items-center text-center\",\n end: \"items-end text-right\",\n },\n },\n defaultVariants: {\n size: \"md\",\n appearance: \"default\",\n align: \"center\",\n },\n },\n);\n\nexport const emptyStateTitleVariants = cva(\"font-semibold tracking-tight\", {\n variants: {\n size: {\n sm: \"text-base\",\n md: \"text-lg\",\n lg: \"text-xl\",\n },\n },\n defaultVariants: { size: \"md\" },\n});\n\nexport const emptyStateDescriptionVariants = cva(\"max-w-md text-slate-400\", {\n variants: {\n size: {\n sm: \"text-xs\",\n md: \"text-sm\",\n lg: \"text-base\",\n },\n },\n defaultVariants: { size: \"md\" },\n});\n","\"use client\";\n\nimport { createContext, useContext, useMemo } from \"react\";\n\nimport { cn } from \"../../lib/utils\";\n\nimport type {\n EmptyStateProps,\n EmptyStateSectionProps,\n EmptyStateSize,\n} from \"./types\";\nimport {\n emptyStateDescriptionVariants,\n emptyStateTitleVariants,\n emptyStateVariants,\n} from \"./variants\";\n\nexport const EmptyStateSizeContext = createContext<EmptyStateSize>(\"md\");\n\nfunction useEmptyStateSize(): EmptyStateSize {\n return useContext(EmptyStateSizeContext);\n}\n\nexport function EmptyStateBase(props: EmptyStateProps) {\n const {\n className,\n size = \"md\",\n appearance,\n align,\n children,\n ref,\n liveRegion = false,\n as: Wrapper = \"section\",\n ...rest\n } = props;\n const ctx = useMemo(() => size ?? \"md\", [size]);\n\n const liveAria =\n typeof liveRegion === \"string\"\n ? liveRegion\n : liveRegion === true\n ? \"polite\"\n : undefined;\n\n return (\n <EmptyStateSizeContext.Provider value={ctx}>\n <Wrapper\n ref={ref}\n data-slot=\"empty-state\"\n aria-live={liveAria}\n className={cn(\n emptyStateVariants({ size, appearance, align }),\n className,\n )}\n {...rest}\n >\n {children}\n </Wrapper>\n </EmptyStateSizeContext.Provider>\n );\n}\n\nEmptyStateBase.displayName = \"EmptyState\";\n\nexport function EmptyStateIcon({\n className,\n children,\n}: EmptyStateSectionProps) {\n return (\n <div\n data-slot=\"empty-state-icon\"\n className={cn(\"text-slate-300\", className)}\n >\n {children}\n </div>\n );\n}\n\nEmptyStateIcon.displayName = \"EmptyStateIcon\";\n\nexport function EmptyStateTitle({\n className,\n children,\n}: EmptyStateSectionProps) {\n const size = useEmptyStateSize();\n return (\n <h2\n data-slot=\"empty-state-title\"\n className={cn(emptyStateTitleVariants({ size }), className)}\n >\n {children}\n </h2>\n );\n}\n\nEmptyStateTitle.displayName = \"EmptyStateTitle\";\n\nexport function EmptyStateDescription({\n className,\n children,\n}: EmptyStateSectionProps) {\n const size = useEmptyStateSize();\n return (\n <p\n data-slot=\"empty-state-description\"\n className={cn(emptyStateDescriptionVariants({ size }), className)}\n >\n {children}\n </p>\n );\n}\n\nEmptyStateDescription.displayName = \"EmptyStateDescription\";\n\nexport function EmptyStateAction({\n className,\n children,\n}: EmptyStateSectionProps) {\n return (\n <div data-slot=\"empty-state-action\" className={cn(\"mt-2\", className)}>\n {children}\n </div>\n );\n}\n\nEmptyStateAction.displayName = \"EmptyStateAction\";\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
- var chunkYPLVTUYL_js = require('./chunk-YPLVTUYL.js');
4
- var chunkUOZYPWDZ_js = require('./chunk-UOZYPWDZ.js');
3
+ var chunkGBWGVNDA_js = require('./chunk-GBWGVNDA.js');
4
+ var chunkZS5756ZC_js = require('./chunk-ZS5756ZC.js');
5
5
  var classVarianceAuthority = require('class-variance-authority');
6
6
  var react = require('react');
7
7
  var reactDom = require('react-dom');
@@ -29,15 +29,15 @@ var drawerTriggerVariants = classVarianceAuthority.cva(
29
29
  gray: "border-gray-600 bg-gray-950/70 backdrop-blur-xl",
30
30
  amber: "border-amber-600 bg-amber-950/70 backdrop-blur-xl",
31
31
  violet: "border-violet-600 bg-violet-950/70 backdrop-blur-xl",
32
- "gradient-blue": "border-gradient-to-r from-blue-600 to-purple-600 bg-gradient-to-r from-blue-950/70 to-purple-950/70 backdrop-blur-xl",
33
- "gradient-green": "border-gradient-to-r from-green-600 to-lime-600 bg-gradient-to-r from-green-950/70 to-lime-950/70 backdrop-blur-xl",
34
- "gradient-red": "border-gradient-to-r from-red-600 to-pink-600 bg-gradient-to-r from-red-950/70 to-pink-950/70 backdrop-blur-xl",
35
- "gradient-yellow": "border-gradient-to-r from-yellow-600 to-orange-600 bg-gradient-to-r from-yellow-950/70 to-orange-950/70 backdrop-blur-xl",
36
- "gradient-purple": "border-gradient-to-r from-purple-600 to-pink-600 bg-gradient-to-r from-purple-950/70 to-pink-950/70 backdrop-blur-xl",
37
- "gradient-teal": "border-gradient-to-r from-teal-600 to-cyan-600 bg-gradient-to-r from-teal-950/70 to-cyan-950/70 backdrop-blur-xl",
38
- "gradient-indigo": "border-gradient-to-r from-indigo-600 to-purple-600 bg-gradient-to-r from-indigo-950/70 to-purple-950/70 backdrop-blur-xl",
39
- "gradient-pink": "border-gradient-to-r from-pink-600 to-rose-600 bg-gradient-to-r from-pink-950/70 to-rose-950/70 backdrop-blur-xl",
40
- "gradient-orange": "border-gradient-to-r from-orange-600 to-red-600 bg-gradient-to-r from-orange-950/70 to-red-950/70 backdrop-blur-xl"
32
+ "gradient-blue": "border-gradient-to-r from-blue-600 to-purple-600 bg-linear-to-r from-blue-950/70 to-purple-950/70 backdrop-blur-xl",
33
+ "gradient-green": "border-gradient-to-r from-green-600 to-lime-600 bg-linear-to-r from-green-950/70 to-lime-950/70 backdrop-blur-xl",
34
+ "gradient-red": "border-gradient-to-r from-red-600 to-pink-600 bg-linear-to-r from-red-950/70 to-pink-950/70 backdrop-blur-xl",
35
+ "gradient-yellow": "border-gradient-to-r from-yellow-600 to-orange-600 bg-linear-to-r from-yellow-950/70 to-orange-950/70 backdrop-blur-xl",
36
+ "gradient-purple": "border-gradient-to-r from-purple-600 to-pink-600 bg-linear-to-r from-purple-950/70 to-pink-950/70 backdrop-blur-xl",
37
+ "gradient-teal": "border-gradient-to-r from-teal-600 to-cyan-600 bg-linear-to-r from-teal-950/70 to-cyan-950/70 backdrop-blur-xl",
38
+ "gradient-indigo": "border-gradient-to-r from-indigo-600 to-purple-600 bg-linear-to-r from-indigo-950/70 to-purple-950/70 backdrop-blur-xl",
39
+ "gradient-pink": "border-gradient-to-r from-pink-600 to-rose-600 bg-linear-to-r from-pink-950/70 to-rose-950/70 backdrop-blur-xl",
40
+ "gradient-orange": "border-gradient-to-r from-orange-600 to-red-600 bg-linear-to-r from-orange-950/70 to-red-950/70 backdrop-blur-xl"
41
41
  }
42
42
  },
43
43
  defaultVariants: {
@@ -77,15 +77,15 @@ var drawerContentVariants = classVarianceAuthority.cva(
77
77
  gray: "border-gray-600 bg-gray-950/70 backdrop-blur-xl",
78
78
  amber: "border-amber-600 bg-amber-950/70 backdrop-blur-xl",
79
79
  violet: "border-violet-600 bg-violet-950/70 backdrop-blur-xl",
80
- "gradient-blue": "border-gradient-to-r from-blue-600 to-purple-600 bg-gradient-to-r from-blue-950/70 to-purple-950/70 backdrop-blur-xl",
81
- "gradient-green": "border-gradient-to-r from-green-600 to-lime-600 bg-gradient-to-r from-green-950/70 to-lime-950/70 backdrop-blur-xl",
82
- "gradient-red": "border-gradient-to-r from-red-600 to-pink-600 bg-gradient-to-r from-red-950/70 to-pink-950/70 backdrop-blur-xl",
83
- "gradient-yellow": "border-gradient-to-r from-yellow-600 to-orange-600 bg-gradient-to-r from-yellow-950/70 to-orange-950/70 backdrop-blur-xl",
84
- "gradient-purple": "border-gradient-to-r from-purple-600 to-pink-600 bg-gradient-to-r from-purple-950/70 to-pink-950/70 backdrop-blur-xl",
85
- "gradient-teal": "border-gradient-to-r from-teal-600 to-cyan-600 bg-gradient-to-r from-teal-950/70 to-cyan-950/70 backdrop-blur-xl",
86
- "gradient-indigo": "border-gradient-to-r from-indigo-600 to-purple-600 bg-gradient-to-r from-indigo-950/70 to-purple-950/70 backdrop-blur-xl",
87
- "gradient-pink": "border-gradient-to-r from-pink-600 to-rose-600 bg-gradient-to-r from-pink-950/70 to-rose-950/70 backdrop-blur-xl",
88
- "gradient-orange": "border-gradient-to-r from-orange-600 to-red-600 bg-gradient-to-r from-orange-950/70 to-red-950/70 backdrop-blur-xl"
80
+ "gradient-blue": "border-gradient-to-r from-blue-600 to-purple-600 bg-linear-to-r from-blue-950/70 to-purple-950/70 backdrop-blur-xl",
81
+ "gradient-green": "border-gradient-to-r from-green-600 to-lime-600 bg-linear-to-r from-green-950/70 to-lime-950/70 backdrop-blur-xl",
82
+ "gradient-red": "border-gradient-to-r from-red-600 to-pink-600 bg-linear-to-r from-red-950/70 to-pink-950/70 backdrop-blur-xl",
83
+ "gradient-yellow": "border-gradient-to-r from-yellow-600 to-orange-600 bg-linear-to-r from-yellow-950/70 to-orange-950/70 backdrop-blur-xl",
84
+ "gradient-purple": "border-gradient-to-r from-purple-600 to-pink-600 bg-linear-to-r from-purple-950/70 to-pink-950/70 backdrop-blur-xl",
85
+ "gradient-teal": "border-gradient-to-r from-teal-600 to-cyan-600 bg-linear-to-r from-teal-950/70 to-cyan-950/70 backdrop-blur-xl",
86
+ "gradient-indigo": "border-gradient-to-r from-indigo-600 to-purple-600 bg-linear-to-r from-indigo-950/70 to-purple-950/70 backdrop-blur-xl",
87
+ "gradient-pink": "border-gradient-to-r from-pink-600 to-rose-600 bg-linear-to-r from-pink-950/70 to-rose-950/70 backdrop-blur-xl",
88
+ "gradient-orange": "border-gradient-to-r from-orange-600 to-red-600 bg-linear-to-r from-orange-950/70 to-red-950/70 backdrop-blur-xl"
89
89
  }
90
90
  },
91
91
  compoundVariants: [
@@ -137,13 +137,15 @@ function Drawer({
137
137
  const titleId = `${baseId}-title`;
138
138
  const descriptionId = `${baseId}-description`;
139
139
  const contentRef = react.useRef(null);
140
+ const triggerRef = react.useRef(null);
140
141
  const ctx = react.useMemo(
141
142
  () => ({
142
143
  open: resolvedOpen,
143
144
  setOpen,
144
145
  titleId,
145
146
  descriptionId,
146
- contentRef
147
+ contentRef,
148
+ triggerRef
147
149
  }),
148
150
  [descriptionId, resolvedOpen, setOpen, titleId]
149
151
  );
@@ -155,17 +157,24 @@ function DrawerTrigger({
155
157
  children,
156
158
  appearance,
157
159
  onClick,
158
- ref,
160
+ ref: refProp,
159
161
  ...rest
160
162
  }) {
161
- const { setOpen } = useDrawerContext("DrawerTrigger");
163
+ const { setOpen, triggerRef } = useDrawerContext("DrawerTrigger");
162
164
  return /* @__PURE__ */ jsxRuntime.jsx(
163
165
  "button",
164
166
  {
165
- ref,
167
+ ref: (node) => {
168
+ triggerRef.current = node;
169
+ if (typeof refProp === "function") {
170
+ refProp(node);
171
+ } else if (refProp) {
172
+ refProp.current = node;
173
+ }
174
+ },
166
175
  type: "button",
167
176
  "data-slot": "drawer-trigger",
168
- className: chunkUOZYPWDZ_js.cn(drawerTriggerVariants({ appearance }), className),
177
+ className: chunkZS5756ZC_js.cn(drawerTriggerVariants({ appearance }), className),
169
178
  onClick: (event) => {
170
179
  onClick?.(event);
171
180
  if (!event.defaultPrevented) {
@@ -188,12 +197,13 @@ function DrawerContent({
188
197
  id,
189
198
  style
190
199
  }) {
191
- const { open, setOpen, titleId, descriptionId, contentRef } = useDrawerContext("DrawerContent");
200
+ const { open, setOpen, titleId, descriptionId, contentRef, triggerRef } = useDrawerContext("DrawerContent");
192
201
  const resolvedSide = side ?? "right";
193
- chunkYPLVTUYL_js.useFocusManagement({
202
+ chunkGBWGVNDA_js.useFocusManagement({
194
203
  open,
195
204
  setOpen,
196
- contentRef
205
+ contentRef,
206
+ triggerRef
197
207
  });
198
208
  const portalTarget = typeof document !== "undefined" ? document.body : null;
199
209
  if (!portalTarget) {
@@ -202,11 +212,9 @@ function DrawerContent({
202
212
  return reactDom.createPortal(
203
213
  open ? /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "fixed inset-0 z-50", "data-slot": "drawer-portal", children: [
204
214
  /* @__PURE__ */ jsxRuntime.jsx(
205
- "button",
215
+ "div",
206
216
  {
207
- type: "button",
208
- "aria-hidden": true,
209
- tabIndex: -1,
217
+ role: "presentation",
210
218
  "data-slot": "drawer-overlay",
211
219
  className: drawerOverlayVariants(),
212
220
  onClick: () => setOpen(false)
@@ -229,7 +237,7 @@ function DrawerContent({
229
237
  "aria-describedby": descriptionId,
230
238
  "data-slot": "drawer-content",
231
239
  tabIndex: -1,
232
- className: chunkUOZYPWDZ_js.cn(
240
+ className: chunkZS5756ZC_js.cn(
233
241
  drawerContentVariants({ side: resolvedSide, size, appearance }),
234
242
  className
235
243
  ),
@@ -248,7 +256,7 @@ function DrawerHeader({ className, children }) {
248
256
  "header",
249
257
  {
250
258
  "data-slot": "drawer-header",
251
- className: chunkUOZYPWDZ_js.cn("mb-4 flex flex-col gap-2", className),
259
+ className: chunkZS5756ZC_js.cn("mb-4 flex flex-col gap-2", className),
252
260
  children
253
261
  }
254
262
  );
@@ -259,7 +267,7 @@ function DrawerBody({ className, children }) {
259
267
  "div",
260
268
  {
261
269
  "data-slot": "drawer-body",
262
- className: chunkUOZYPWDZ_js.cn("flex-1 text-sm text-slate-300", className),
270
+ className: chunkZS5756ZC_js.cn("flex-1 text-sm text-slate-300", className),
263
271
  children
264
272
  }
265
273
  );
@@ -270,7 +278,7 @@ function DrawerFooter({ className, children }) {
270
278
  "footer",
271
279
  {
272
280
  "data-slot": "drawer-footer",
273
- className: chunkUOZYPWDZ_js.cn("mt-6 flex justify-end gap-2", className),
281
+ className: chunkZS5756ZC_js.cn("mt-6 flex justify-end gap-2", className),
274
282
  children
275
283
  }
276
284
  );
@@ -283,7 +291,7 @@ function DrawerTitle({ className, children }) {
283
291
  {
284
292
  id: titleId,
285
293
  "data-slot": "drawer-title",
286
- className: chunkUOZYPWDZ_js.cn("text-lg font-semibold", className),
294
+ className: chunkZS5756ZC_js.cn("text-lg font-semibold", className),
287
295
  children
288
296
  }
289
297
  );
@@ -300,7 +308,7 @@ function DrawerClose({
300
308
  {
301
309
  type: "button",
302
310
  "data-slot": "drawer-close",
303
- className: chunkUOZYPWDZ_js.cn(
311
+ className: chunkZS5756ZC_js.cn(
304
312
  "absolute right-4 top-4 inline-flex size-9 items-center justify-center rounded-md text-slate-200 transition hover:bg-white/10 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-white/30",
305
313
  className
306
314
  ),
@@ -324,5 +332,5 @@ exports.DrawerTrigger = DrawerTrigger;
324
332
  exports.drawerContentVariants = drawerContentVariants;
325
333
  exports.drawerOverlayVariants = drawerOverlayVariants;
326
334
  exports.useDrawerContext = useDrawerContext;
327
- //# sourceMappingURL=chunk-N4NO3SYL.js.map
328
- //# sourceMappingURL=chunk-N4NO3SYL.js.map
335
+ //# sourceMappingURL=chunk-SKPZCISM.js.map
336
+ //# sourceMappingURL=chunk-SKPZCISM.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/ui/drawer/variants.ts","../src/ui/drawer/drawer-base.tsx"],"names":["cva","createContext","useContext","useState","useCallback","useId","useRef","useMemo","jsx","cn","useFocusManagement","createPortal","jsxs"],"mappings":"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","file":"chunk-SKPZCISM.js","sourcesContent":["import { cva } from \"class-variance-authority\";\n\nexport const drawerOverlayVariants = cva(\n \"fixed inset-0 z-50 bg-slate-950/70 backdrop-blur-sm\",\n);\n\nexport const drawerTriggerVariants = cva(\n \"relative inline-flex shrink-0 cursor-pointer rounded-md border\",\n {\n variants: {\n appearance: {\n default: \"bg-slate-950\",\n glass: \"border-white/15 bg-slate-950/70 backdrop-blur-xl\",\n sky: \"border-sky-600 bg-sky-950/70 backdrop-blur-xl\",\n rose: \"border-rose-600 bg-rose-950/70 backdrop-blur-xl\",\n purple: \"border-purple-600 bg-purple-950/70 backdrop-blur-xl\",\n pink: \"border-pink-600 bg-pink-950/70 backdrop-blur-xl\",\n orange: \"border-orange-600 bg-orange-950/70 backdrop-blur-xl\",\n yellow: \"border-yellow-600 bg-yellow-950/70 backdrop-blur-xl\",\n teal: \"border-teal-600 bg-teal-950/70 backdrop-blur-xl\",\n indigo: \"border-indigo-600 bg-indigo-950/70 backdrop-blur-xl\",\n emerald: \"border-emerald-600 bg-emerald-950/70 backdrop-blur-xl\",\n gray: \"border-gray-600 bg-gray-950/70 backdrop-blur-xl\",\n amber: \"border-amber-600 bg-amber-950/70 backdrop-blur-xl\",\n violet: \"border-violet-600 bg-violet-950/70 backdrop-blur-xl\",\n \"gradient-blue\":\n \"border-gradient-to-r from-blue-600 to-purple-600 bg-linear-to-r from-blue-950/70 to-purple-950/70 backdrop-blur-xl\",\n \"gradient-green\":\n \"border-gradient-to-r from-green-600 to-lime-600 bg-linear-to-r from-green-950/70 to-lime-950/70 backdrop-blur-xl\",\n \"gradient-red\":\n \"border-gradient-to-r from-red-600 to-pink-600 bg-linear-to-r from-red-950/70 to-pink-950/70 backdrop-blur-xl\",\n \"gradient-yellow\":\n \"border-gradient-to-r from-yellow-600 to-orange-600 bg-linear-to-r from-yellow-950/70 to-orange-950/70 backdrop-blur-xl\",\n \"gradient-purple\":\n \"border-gradient-to-r from-purple-600 to-pink-600 bg-linear-to-r from-purple-950/70 to-pink-950/70 backdrop-blur-xl\",\n \"gradient-teal\":\n \"border-gradient-to-r from-teal-600 to-cyan-600 bg-linear-to-r from-teal-950/70 to-cyan-950/70 backdrop-blur-xl\",\n \"gradient-indigo\":\n \"border-gradient-to-r from-indigo-600 to-purple-600 bg-linear-to-r from-indigo-950/70 to-purple-950/70 backdrop-blur-xl\",\n \"gradient-pink\":\n \"border-gradient-to-r from-pink-600 to-rose-600 bg-linear-to-r from-pink-950/70 to-rose-950/70 backdrop-blur-xl\",\n \"gradient-orange\":\n \"border-gradient-to-r from-orange-600 to-red-600 bg-linear-to-r from-orange-950/70 to-red-950/70 backdrop-blur-xl\",\n },\n },\n defaultVariants: {\n appearance: \"default\",\n },\n },\n);\n\nexport const drawerContentVariants = cva(\n \"fixed z-50 flex max-h-[min(92vh,900px)] flex-col border border-white/10 bg-slate-950 p-6 text-slate-50 shadow-[0_24px_80px_rgba(15,23,42,0.55)] focus:outline-none\",\n {\n variants: {\n side: {\n left: \"left-0 top-0 h-full w-[min(100%,420px)]\",\n right: \"right-0 top-0 h-full w-[min(100%,420px)]\",\n top: \"left-0 top-0 w-full max-h-[min(92vh,520px)]\",\n bottom: \"bottom-0 left-0 w-full max-h-[min(92vh,520px)]\",\n },\n size: {\n sm: \"\",\n md: \"\",\n lg: \"\",\n xl: \"\",\n full: \"\",\n },\n appearance: {\n default: \"bg-slate-950\",\n glass: \"border-white/15 bg-slate-950/70 backdrop-blur-xl\",\n sky: \"border-sky-600 bg-sky-950/70 backdrop-blur-xl\",\n rose: \"border-rose-600 bg-rose-950/70 backdrop-blur-xl\",\n purple: \"border-purple-600 bg-purple-950/70 backdrop-blur-xl\",\n pink: \"border-pink-600 bg-pink-950/70 backdrop-blur-xl\",\n orange: \"border-orange-600 bg-orange-950/70 backdrop-blur-xl\",\n yellow: \"border-yellow-600 bg-yellow-950/70 backdrop-blur-xl\",\n teal: \"border-teal-600 bg-teal-950/70 backdrop-blur-xl\",\n indigo: \"border-indigo-600 bg-indigo-950/70 backdrop-blur-xl\",\n emerald: \"border-emerald-600 bg-emerald-950/70 backdrop-blur-xl\",\n gray: \"border-gray-600 bg-gray-950/70 backdrop-blur-xl\",\n amber: \"border-amber-600 bg-amber-950/70 backdrop-blur-xl\",\n violet: \"border-violet-600 bg-violet-950/70 backdrop-blur-xl\",\n \"gradient-blue\":\n \"border-gradient-to-r from-blue-600 to-purple-600 bg-linear-to-r from-blue-950/70 to-purple-950/70 backdrop-blur-xl\",\n \"gradient-green\":\n \"border-gradient-to-r from-green-600 to-lime-600 bg-linear-to-r from-green-950/70 to-lime-950/70 backdrop-blur-xl\",\n \"gradient-red\":\n \"border-gradient-to-r from-red-600 to-pink-600 bg-linear-to-r from-red-950/70 to-pink-950/70 backdrop-blur-xl\",\n \"gradient-yellow\":\n \"border-gradient-to-r from-yellow-600 to-orange-600 bg-linear-to-r from-yellow-950/70 to-orange-950/70 backdrop-blur-xl\",\n \"gradient-purple\":\n \"border-gradient-to-r from-purple-600 to-pink-600 bg-linear-to-r from-purple-950/70 to-pink-950/70 backdrop-blur-xl\",\n \"gradient-teal\":\n \"border-gradient-to-r from-teal-600 to-cyan-600 bg-linear-to-r from-teal-950/70 to-cyan-950/70 backdrop-blur-xl\",\n \"gradient-indigo\":\n \"border-gradient-to-r from-indigo-600 to-purple-600 bg-linear-to-r from-indigo-950/70 to-purple-950/70 backdrop-blur-xl\",\n \"gradient-pink\":\n \"border-gradient-to-r from-pink-600 to-rose-600 bg-linear-to-r from-pink-950/70 to-rose-950/70 backdrop-blur-xl\",\n \"gradient-orange\":\n \"border-gradient-to-r from-orange-600 to-red-600 bg-linear-to-r from-orange-950/70 to-red-950/70 backdrop-blur-xl\",\n },\n },\n compoundVariants: [\n { side: \"left\", size: \"sm\", class: \"w-[min(100%,320px)]\" },\n { side: \"left\", size: \"md\", class: \"w-[min(100%,420px)]\" },\n { side: \"left\", size: \"lg\", class: \"w-[min(100%,520px)]\" },\n { side: \"left\", size: \"xl\", class: \"w-[min(100%,640px)]\" },\n { side: \"left\", size: \"full\", class: \"w-full max-w-none\" },\n { side: \"right\", size: \"sm\", class: \"w-[min(100%,320px)]\" },\n { side: \"right\", size: \"md\", class: \"w-[min(100%,420px)]\" },\n { side: \"right\", size: \"lg\", class: \"w-[min(100%,520px)]\" },\n { side: \"right\", size: \"xl\", class: \"w-[min(100%,640px)]\" },\n { side: \"right\", size: \"full\", class: \"w-full max-w-none\" },\n ],\n defaultVariants: {\n side: \"right\",\n size: \"md\",\n appearance: \"default\",\n },\n },\n);\n","\"use client\";\n\nimport {\n createContext,\n useCallback,\n useContext,\n useId,\n useMemo,\n useRef,\n useState,\n type RefObject,\n} from \"react\";\nimport { createPortal } from \"react-dom\";\n\nimport { cn } from \"../../lib/utils\";\nimport { useFocusManagement } from \"../../hooks/useFocusManagement\";\n\nimport type {\n DrawerContentProps,\n DrawerCtx,\n DrawerProps,\n DrawerSectionProps,\n DrawerTriggerProps,\n} from \"./types\";\nimport {\n drawerContentVariants,\n drawerOverlayVariants,\n drawerTriggerVariants,\n} from \"./variants\";\n\nconst DrawerContext = createContext<DrawerCtx | null>(null);\n\nexport function useDrawerContext(component: string): DrawerCtx {\n const ctx = useContext(DrawerContext);\n if (!ctx) {\n throw new Error(`${component} must be used within <Drawer>`);\n }\n return ctx;\n}\n\nexport function Drawer({\n open,\n defaultOpen = false,\n onOpenChange,\n children,\n}: DrawerProps) {\n const isControlled = open !== undefined;\n const [uncontrolledOpen, setUncontrolledOpen] = useState(defaultOpen);\n const resolvedOpen = isControlled ? Boolean(open) : uncontrolledOpen;\n\n const setOpen = useCallback(\n (next: boolean) => {\n if (!isControlled) {\n setUncontrolledOpen(next);\n }\n onOpenChange?.(next);\n },\n [isControlled, onOpenChange],\n );\n\n const baseId = useId();\n const titleId = `${baseId}-title`;\n const descriptionId = `${baseId}-description`;\n const contentRef = useRef<HTMLDivElement | null>(null);\n const triggerRef = useRef<HTMLElement | null>(null);\n\n const ctx = useMemo(\n () => ({\n open: resolvedOpen,\n setOpen,\n titleId,\n descriptionId,\n contentRef,\n triggerRef,\n }),\n [descriptionId, resolvedOpen, setOpen, titleId],\n );\n\n return (\n <DrawerContext.Provider value={ctx}>{children}</DrawerContext.Provider>\n );\n}\n\nDrawer.displayName = \"Drawer\";\n\nexport function DrawerTrigger({\n className,\n children,\n appearance,\n onClick,\n ref: refProp,\n ...rest\n}: DrawerTriggerProps) {\n const { setOpen, triggerRef } = useDrawerContext(\"DrawerTrigger\");\n return (\n <button\n ref={(node) => {\n triggerRef.current = node;\n if (typeof refProp === \"function\") {\n refProp(node);\n } else if (refProp) {\n (refProp as RefObject<HTMLButtonElement | null>).current = node;\n }\n }}\n type=\"button\"\n data-slot=\"drawer-trigger\"\n className={cn(drawerTriggerVariants({ appearance }), className)}\n onClick={(event) => {\n onClick?.(event);\n if (!event.defaultPrevented) {\n setOpen(true);\n }\n }}\n {...rest}\n >\n {children}\n </button>\n );\n}\n\nDrawerTrigger.displayName = \"DrawerTrigger\";\n\nexport function DrawerContent({\n className,\n side = \"right\",\n size,\n appearance,\n children,\n ref,\n id,\n style,\n}: DrawerContentProps) {\n const { open, setOpen, titleId, descriptionId, contentRef, triggerRef } =\n useDrawerContext(\"DrawerContent\");\n const resolvedSide = side ?? \"right\";\n\n useFocusManagement({\n open,\n setOpen,\n contentRef,\n triggerRef,\n });\n\n const portalTarget = typeof document !== \"undefined\" ? document.body : null;\n if (!portalTarget) {\n return null;\n }\n\n return createPortal(\n open ? (\n <div className=\"fixed inset-0 z-50\" data-slot=\"drawer-portal\">\n <div\n role=\"presentation\"\n data-slot=\"drawer-overlay\"\n className={drawerOverlayVariants()}\n onClick={() => setOpen(false)}\n />\n <div\n ref={(node) => {\n contentRef.current = node;\n if (typeof ref === \"function\") {\n ref(node);\n } else if (ref) {\n (ref as RefObject<HTMLDivElement | null>).current = node;\n }\n }}\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby={titleId}\n aria-describedby={descriptionId}\n data-slot=\"drawer-content\"\n tabIndex={-1}\n className={cn(\n drawerContentVariants({ side: resolvedSide, size, appearance }),\n className,\n )}\n id={id}\n style={style}\n >\n {children}\n </div>\n </div>\n ) : null,\n portalTarget,\n );\n}\n\nDrawerContent.displayName = \"DrawerContent\";\n\nexport function DrawerHeader({ className, children }: DrawerSectionProps) {\n return (\n <header\n data-slot=\"drawer-header\"\n className={cn(\"mb-4 flex flex-col gap-2\", className)}\n >\n {children}\n </header>\n );\n}\n\nDrawerHeader.displayName = \"DrawerHeader\";\n\nexport function DrawerBody({ className, children }: DrawerSectionProps) {\n return (\n <div\n data-slot=\"drawer-body\"\n className={cn(\"flex-1 text-sm text-slate-300\", className)}\n >\n {children}\n </div>\n );\n}\n\nDrawerBody.displayName = \"DrawerBody\";\n\nexport function DrawerFooter({ className, children }: DrawerSectionProps) {\n return (\n <footer\n data-slot=\"drawer-footer\"\n className={cn(\"mt-6 flex justify-end gap-2\", className)}\n >\n {children}\n </footer>\n );\n}\n\nDrawerFooter.displayName = \"DrawerFooter\";\n\nexport function DrawerTitle({ className, children }: DrawerSectionProps) {\n const { titleId } = useDrawerContext(\"DrawerTitle\");\n return (\n <h2\n id={titleId}\n data-slot=\"drawer-title\"\n className={cn(\"text-lg font-semibold\", className)}\n >\n {children}\n </h2>\n );\n}\n\nDrawerTitle.displayName = \"DrawerTitle\";\n\nexport function DrawerClose({\n className,\n children,\n ...rest\n}: DrawerSectionProps) {\n const { setOpen } = useDrawerContext(\"DrawerClose\");\n return (\n <button\n type=\"button\"\n data-slot=\"drawer-close\"\n className={cn(\n \"absolute right-4 top-4 inline-flex size-9 items-center justify-center rounded-md text-slate-200 transition hover:bg-white/10 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-white/30\",\n className,\n )}\n aria-label=\"Close drawer\"\n onClick={() => setOpen(false)}\n {...rest}\n >\n {children ?? \"×\"}\n </button>\n );\n}\n\nDrawerClose.displayName = \"DrawerClose\";\n"]}