@zentauri-ui/zentauri-components 1.3.1 → 1.4.1

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 (736) hide show
  1. package/README.md +90 -0
  2. package/cli/cli.integration.test.ts +79 -0
  3. package/cli/index.mjs +718 -0
  4. package/cli/registry.json +63 -0
  5. package/cli/rewrite-imports.mjs +57 -0
  6. package/cli/rewrite-imports.test.ts +71 -0
  7. package/dist/ui/slider.js +21 -25
  8. package/dist/ui/slider.js.map +1 -1
  9. package/dist/ui/slider.mjs +21 -25
  10. package/dist/ui/slider.mjs.map +1 -1
  11. package/package.json +9 -3
  12. package/{dist/hooks/index.d.ts → src/hooks/index.ts} +28 -7
  13. package/{dist/hooks/useBodyScrollLock/index.d.ts → src/hooks/useBodyScrollLock/index.ts} +0 -1
  14. package/src/hooks/useBodyScrollLock/useBodyScrollLock.test.ts +51 -0
  15. package/src/hooks/useBodyScrollLock/useBodyScrollLock.ts +48 -0
  16. package/src/hooks/useClickOutside/index.ts +5 -0
  17. package/src/hooks/useClickOutside/useClickOutside.test.tsx +60 -0
  18. package/src/hooks/useClickOutside/useClickOutside.ts +52 -0
  19. package/{dist/hooks/useClipboard/index.d.ts → src/hooks/useClipboard/index.ts} +0 -1
  20. package/src/hooks/useClipboard/useClipboard.test.ts +101 -0
  21. package/src/hooks/useClipboard/useClipboard.ts +69 -0
  22. package/src/hooks/useControllableState/index.ts +4 -0
  23. package/src/hooks/useControllableState/useControllableState.test.ts +59 -0
  24. package/src/hooks/useControllableState/useControllableState.ts +49 -0
  25. package/{dist/hooks/useDebouncedValue/index.d.ts → src/hooks/useDebouncedValue/index.ts} +0 -1
  26. package/src/hooks/useDebouncedValue/useDebouncedValue.test.ts +74 -0
  27. package/{dist/hooks/useDebouncedValue/useDebouncedValue.d.ts → src/hooks/useDebouncedValue/useDebouncedValue.ts} +18 -2
  28. package/src/hooks/useDisclosure/index.ts +5 -0
  29. package/src/hooks/useDisclosure/useDisclosure.test.ts +64 -0
  30. package/src/hooks/useDisclosure/useDisclosure.ts +62 -0
  31. package/src/hooks/useDocumentTitle/index.ts +4 -0
  32. package/src/hooks/useDocumentTitle/useDocumentTitle.test.ts +40 -0
  33. package/src/hooks/useDocumentTitle/useDocumentTitle.ts +58 -0
  34. package/{dist/hooks/useFocusManagement/index.d.ts → src/hooks/useFocusManagement/index.ts} +0 -1
  35. package/src/hooks/useFocusManagement/useFocusManagement.test.tsx +45 -0
  36. package/src/hooks/useFocusManagement/useFocusManagement.ts +77 -0
  37. package/{dist/hooks/useHover/index.d.ts → src/hooks/useHover/index.ts} +0 -1
  38. package/src/hooks/useHover/useHover.test.ts +45 -0
  39. package/src/hooks/useHover/useHover.ts +45 -0
  40. package/{dist/hooks/useInView/index.d.ts → src/hooks/useInView/index.ts} +0 -1
  41. package/src/hooks/useInView/useInView.test.ts +43 -0
  42. package/{dist/hooks/useInView/useInView.d.ts → src/hooks/useInView/useInView.ts} +15 -4
  43. package/src/hooks/useIntersectionObserver/index.ts +4 -0
  44. package/src/hooks/useIntersectionObserver/useIntersectionObserver.test.ts +75 -0
  45. package/src/hooks/useIntersectionObserver/useIntersectionObserver.ts +54 -0
  46. package/{dist/hooks/useIsMounted/index.d.ts → src/hooks/useIsMounted/index.ts} +0 -1
  47. package/src/hooks/useIsMounted/useIsMounted.test.ts +25 -0
  48. package/{dist/hooks/useIsMounted/useIsMounted.d.ts → src/hooks/useIsMounted/useIsMounted.ts} +14 -2
  49. package/{dist/hooks/useIsomorphicLayoutEffect/index.d.ts → src/hooks/useIsomorphicLayoutEffect/index.ts} +0 -1
  50. package/src/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.test.ts +19 -0
  51. package/{dist/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.d.ts → src/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.ts} +6 -3
  52. package/src/hooks/useLocalStorage/index.ts +4 -0
  53. package/src/hooks/useLocalStorage/useLocalStorage.test.ts +99 -0
  54. package/src/hooks/useLocalStorage/useLocalStorage.ts +109 -0
  55. package/{dist/hooks/useMediaQuery/index.d.ts → src/hooks/useMediaQuery/index.ts} +0 -1
  56. package/src/hooks/useMediaQuery/useMediaQuery.test.ts +63 -0
  57. package/src/hooks/useMediaQuery/useMediaQuery.ts +37 -0
  58. package/{dist/hooks/useNetworkStatus/index.d.ts → src/hooks/useNetworkStatus/index.ts} +0 -1
  59. package/src/hooks/useNetworkStatus/useNetworkStatus.test.ts +53 -0
  60. package/src/hooks/useNetworkStatus/useNetworkStatus.ts +33 -0
  61. package/{dist/hooks/usePageVisibility/index.d.ts → src/hooks/usePageVisibility/index.ts} +0 -1
  62. package/src/hooks/usePageVisibility/usePageVisibility.test.ts +21 -0
  63. package/src/hooks/usePageVisibility/usePageVisibility.ts +31 -0
  64. package/src/hooks/usePagination/index.ts +6 -0
  65. package/src/hooks/usePagination/usePagination.test.ts +139 -0
  66. package/src/hooks/usePagination/usePagination.ts +153 -0
  67. package/src/hooks/usePrefersColorScheme/index.ts +4 -0
  68. package/src/hooks/usePrefersColorScheme/usePrefersColorScheme.test.ts +53 -0
  69. package/{dist/hooks/usePrefersColorScheme/usePrefersColorScheme.d.ts → src/hooks/usePrefersColorScheme/usePrefersColorScheme.ts} +14 -2
  70. package/{dist/hooks/usePrefersReducedMotion/index.d.ts → src/hooks/usePrefersReducedMotion/index.ts} +0 -1
  71. package/src/hooks/usePrefersReducedMotion/usePrefersReducedMotion.test.ts +27 -0
  72. package/{dist/hooks/usePrefersReducedMotion/usePrefersReducedMotion.d.ts → src/hooks/usePrefersReducedMotion/usePrefersReducedMotion.ts} +7 -2
  73. package/src/hooks/useResizeObserver/index.ts +4 -0
  74. package/src/hooks/useResizeObserver/useResizeObserver.test.ts +68 -0
  75. package/src/hooks/useResizeObserver/useResizeObserver.ts +58 -0
  76. package/src/hooks/useSessionStorage/index.ts +4 -0
  77. package/src/hooks/useSessionStorage/useSessionStorage.test.ts +54 -0
  78. package/src/hooks/useSessionStorage/useSessionStorage.ts +84 -0
  79. package/{dist/hooks/useThrottledCallback/index.d.ts → src/hooks/useThrottledCallback/index.ts} +0 -1
  80. package/src/hooks/useThrottledCallback/useThrottledCallback.test.ts +75 -0
  81. package/{dist/hooks/useThrottledCallback/useThrottledCallback.d.ts → src/hooks/useThrottledCallback/useThrottledCallback.ts} +25 -2
  82. package/{dist/hooks/useToggle/index.d.ts → src/hooks/useToggle/index.ts} +0 -1
  83. package/src/hooks/useToggle/useToggle.test.ts +40 -0
  84. package/src/hooks/useToggle/useToggle.ts +22 -0
  85. package/{dist/hooks/useWindowSize/index.d.ts → src/hooks/useWindowSize/index.ts} +0 -1
  86. package/src/hooks/useWindowSize/useWindowSize.test.ts +23 -0
  87. package/src/hooks/useWindowSize/useWindowSize.ts +39 -0
  88. package/src/lib/utils.ts +25 -0
  89. package/src/ui/accordion/accordion-base.tsx +223 -0
  90. package/src/ui/accordion/accordion.test.tsx +146 -0
  91. package/src/ui/accordion/accordion.tsx +11 -0
  92. package/src/ui/accordion/animated/accordion-content-animated.tsx +46 -0
  93. package/src/ui/accordion/animated/accordion-root-animated.tsx +10 -0
  94. package/src/ui/accordion/animated/animations.ts +16 -0
  95. package/{dist/ui/accordion/animated/index.d.ts → src/ui/accordion/animated/index.ts} +2 -1
  96. package/{dist/ui/accordion/animated/types.d.ts → src/ui/accordion/animated/types.ts} +4 -3
  97. package/src/ui/accordion/index.ts +23 -0
  98. package/{dist/ui/accordion/types.d.ts → src/ui/accordion/types.ts} +30 -21
  99. package/src/ui/accordion/variants.ts +115 -0
  100. package/src/ui/alert/alert-base.tsx +157 -0
  101. package/src/ui/alert/alert.test.tsx +150 -0
  102. package/src/ui/alert/alert.tsx +9 -0
  103. package/src/ui/alert/animated/alert-animated.tsx +20 -0
  104. package/src/ui/alert/animated/animations.ts +20 -0
  105. package/src/ui/alert/animated/index.ts +3 -0
  106. package/src/ui/alert/animated/types.ts +16 -0
  107. package/src/ui/alert/index.ts +22 -0
  108. package/{dist/ui/alert/types.d.ts → src/ui/alert/types.ts} +18 -11
  109. package/src/ui/alert/variants.ts +74 -0
  110. package/src/ui/avatar/animated/animations.ts +11 -0
  111. package/src/ui/avatar/animated/avatar-animated.tsx +25 -0
  112. package/{dist/ui/avatar/animated/index.d.ts → src/ui/avatar/animated/index.ts} +3 -2
  113. package/{dist/ui/avatar/animated/types.d.ts → src/ui/avatar/animated/types.ts} +11 -3
  114. package/src/ui/avatar/avatar-base.tsx +184 -0
  115. package/src/ui/avatar/avatar.test.tsx +51 -0
  116. package/src/ui/avatar/avatar.tsx +11 -0
  117. package/src/ui/avatar/index.ts +16 -0
  118. package/{dist/ui/avatar/types.d.ts → src/ui/avatar/types.ts} +22 -11
  119. package/src/ui/avatar/variants.ts +52 -0
  120. package/src/ui/badge/animated/animations.ts +20 -0
  121. package/src/ui/badge/animated/badge-animated.tsx +28 -0
  122. package/{dist/ui/badge/animated/index.d.ts → src/ui/badge/animated/index.ts} +3 -2
  123. package/src/ui/badge/animated/types.ts +18 -0
  124. package/src/ui/badge/badge-base.tsx +53 -0
  125. package/src/ui/badge/badge.test.tsx +48 -0
  126. package/src/ui/badge/badge.tsx +9 -0
  127. package/{dist/ui/badge/index.d.ts → src/ui/badge/index.ts} +2 -1
  128. package/src/ui/badge/types.ts +25 -0
  129. package/src/ui/badge/variants.ts +85 -0
  130. package/src/ui/breadcrumb/breadcrumb.test.tsx +62 -0
  131. package/src/ui/breadcrumb/breadcrumb.tsx +135 -0
  132. package/src/ui/breadcrumb/index.ts +28 -0
  133. package/{dist/ui/breadcrumb/types.d.ts → src/ui/breadcrumb/types.ts} +18 -15
  134. package/src/ui/breadcrumb/variants.ts +53 -0
  135. package/src/ui/buttons/animated/animations.ts +34 -0
  136. package/src/ui/buttons/animated/button-animated.tsx +70 -0
  137. package/{dist/ui/buttons/animated/index.d.ts → src/ui/buttons/animated/index.ts} +2 -1
  138. package/src/ui/buttons/animated/types.ts +29 -0
  139. package/src/ui/buttons/button-base.tsx +59 -0
  140. package/src/ui/buttons/button.test.tsx +480 -0
  141. package/src/ui/buttons/button.tsx +9 -0
  142. package/{dist/ui/buttons/index.d.ts → src/ui/buttons/index.ts} +2 -1
  143. package/{dist/ui/buttons/types.d.ts → src/ui/buttons/types.ts} +10 -6
  144. package/src/ui/buttons/variants.ts +77 -0
  145. package/src/ui/card/animated/animations.ts +32 -0
  146. package/src/ui/card/animated/card-animated.tsx +28 -0
  147. package/{dist/ui/card/animated/index.d.ts → src/ui/card/animated/index.ts} +9 -2
  148. package/{dist/ui/card/animated/types.d.ts → src/ui/card/animated/types.ts} +4 -2
  149. package/src/ui/card/card-base.tsx +146 -0
  150. package/src/ui/card/card.test.tsx +79 -0
  151. package/src/ui/card/card.tsx +11 -0
  152. package/src/ui/card/index.ts +21 -0
  153. package/src/ui/card/types.ts +42 -0
  154. package/src/ui/card/variants.ts +122 -0
  155. package/src/ui/divider/animated/animations.ts +27 -0
  156. package/src/ui/divider/animated/divider-animated.tsx +24 -0
  157. package/{dist/ui/divider/animated/index.d.ts → src/ui/divider/animated/index.ts} +2 -1
  158. package/{dist/ui/divider/animated/types.d.ts → src/ui/divider/animated/types.ts} +13 -3
  159. package/src/ui/divider/divider-base.tsx +80 -0
  160. package/src/ui/divider/divider.tsx +9 -0
  161. package/src/ui/divider/index.ts +14 -0
  162. package/{dist/ui/divider/types.d.ts → src/ui/divider/types.ts} +11 -8
  163. package/src/ui/divider/variants.ts +98 -0
  164. package/src/ui/drawer/animated/animations.ts +39 -0
  165. package/src/ui/drawer/animated/drawer-content-animated.tsx +101 -0
  166. package/{dist/ui/drawer/animated/index.d.ts → src/ui/drawer/animated/index.ts} +11 -2
  167. package/src/ui/drawer/animated/types.ts +18 -0
  168. package/src/ui/drawer/drawer-base.tsx +259 -0
  169. package/src/ui/drawer/drawer.test.tsx +132 -0
  170. package/src/ui/drawer/drawer.tsx +11 -0
  171. package/src/ui/drawer/index.ts +21 -0
  172. package/src/ui/drawer/types.ts +39 -0
  173. package/src/ui/drawer/variants.ts +122 -0
  174. package/src/ui/dropdown/dropdown.test.tsx +114 -0
  175. package/src/ui/dropdown/dropdown.tsx +179 -0
  176. package/src/ui/dropdown/index.ts +15 -0
  177. package/src/ui/dropdown/types.ts +68 -0
  178. package/src/ui/dropdown/variants.ts +138 -0
  179. package/src/ui/empty-state/animated/animations.ts +19 -0
  180. package/src/ui/empty-state/animated/empty-state-animated.tsx +23 -0
  181. package/src/ui/empty-state/animated/index.ts +7 -0
  182. package/{dist/ui/empty-state/animated/types.d.ts → src/ui/empty-state/animated/types.ts} +17 -5
  183. package/src/ui/empty-state/empty-state-base.tsx +114 -0
  184. package/src/ui/empty-state/empty-state.tsx +9 -0
  185. package/{dist/ui/empty-state/index.d.ts → src/ui/empty-state/index.ts} +7 -2
  186. package/{dist/ui/empty-state/types.d.ts → src/ui/empty-state/types.ts} +10 -6
  187. package/src/ui/empty-state/variants.ts +51 -0
  188. package/src/ui/file-upload/file-upload.test.tsx +36 -0
  189. package/src/ui/file-upload/file-upload.tsx +119 -0
  190. package/{dist/ui/file-upload/index.d.ts → src/ui/file-upload/index.ts} +2 -1
  191. package/{dist/ui/file-upload/types.d.ts → src/ui/file-upload/types.ts} +6 -3
  192. package/src/ui/file-upload/variants.ts +29 -0
  193. package/src/ui/inputs/animated/animations.ts +36 -0
  194. package/{dist/ui/inputs/animated/index.d.ts → src/ui/inputs/animated/index.ts} +2 -1
  195. package/src/ui/inputs/animated/input-animated.tsx +124 -0
  196. package/src/ui/inputs/animated/types.ts +40 -0
  197. package/{dist/ui/inputs/index.d.ts → src/ui/inputs/index.ts} +2 -1
  198. package/src/ui/inputs/input-base.tsx +114 -0
  199. package/src/ui/inputs/input.test.tsx +414 -0
  200. package/src/ui/inputs/input.tsx +8 -0
  201. package/src/ui/inputs/types.ts +18 -0
  202. package/src/ui/inputs/variants.ts +316 -0
  203. package/src/ui/modal/animated/animations.ts +29 -0
  204. package/{dist/ui/modal/animated/index.d.ts → src/ui/modal/animated/index.ts} +2 -1
  205. package/src/ui/modal/animated/modal-content-animated.tsx +96 -0
  206. package/src/ui/modal/animated/types.ts +23 -0
  207. package/src/ui/modal/index.ts +21 -0
  208. package/src/ui/modal/modal-base.tsx +279 -0
  209. package/src/ui/modal/modal.test.tsx +129 -0
  210. package/src/ui/modal/modal.tsx +8 -0
  211. package/src/ui/modal/types.ts +31 -0
  212. package/src/ui/modal/variants.ts +109 -0
  213. package/src/ui/pagination/index.ts +13 -0
  214. package/src/ui/pagination/pagination.test.tsx +165 -0
  215. package/src/ui/pagination/pagination.tsx +237 -0
  216. package/{dist/ui/pagination/types.d.ts → src/ui/pagination/types.ts} +37 -27
  217. package/src/ui/pagination/variants.ts +97 -0
  218. package/src/ui/progress/animated/animations.ts +9 -0
  219. package/src/ui/progress/animated/index.ts +17 -0
  220. package/src/ui/progress/animated/progress-animated.tsx +133 -0
  221. package/{dist/ui/progress/animated/types.d.ts → src/ui/progress/animated/types.ts} +20 -8
  222. package/{dist/ui/progress/index.d.ts → src/ui/progress/index.ts} +7 -2
  223. package/src/ui/progress/progress-base.tsx +151 -0
  224. package/src/ui/progress/progress.test.tsx +84 -0
  225. package/src/ui/progress/progress.tsx +12 -0
  226. package/src/ui/progress/types.ts +33 -0
  227. package/src/ui/progress/variants.ts +105 -0
  228. package/src/ui/select/index.ts +25 -0
  229. package/src/ui/select/select.test.tsx +128 -0
  230. package/src/ui/select/select.tsx +221 -0
  231. package/src/ui/select/types.ts +77 -0
  232. package/src/ui/select/variants.ts +163 -0
  233. package/src/ui/skeleton/animated/animations.ts +15 -0
  234. package/src/ui/skeleton/animated/index.ts +20 -0
  235. package/src/ui/skeleton/animated/skeleton-animated.tsx +119 -0
  236. package/{dist/ui/skeleton/animated/types.d.ts → src/ui/skeleton/animated/types.ts} +30 -11
  237. package/src/ui/skeleton/index.ts +24 -0
  238. package/src/ui/skeleton/skeleton-base.tsx +288 -0
  239. package/src/ui/skeleton/skeleton.tsx +8 -0
  240. package/{dist/ui/skeleton/types.d.ts → src/ui/skeleton/types.ts} +15 -7
  241. package/src/ui/skeleton/variants.ts +254 -0
  242. package/src/ui/slider/index.ts +22 -0
  243. package/src/ui/slider/slider.test.tsx +94 -0
  244. package/src/ui/slider/slider.tsx +728 -0
  245. package/src/ui/slider/types.ts +66 -0
  246. package/src/ui/slider/variants.ts +81 -0
  247. package/{dist/ui/spinner/animated/index.d.ts → src/ui/spinner/animated/index.ts} +2 -1
  248. package/src/ui/spinner/animated/spinner.test.tsx +41 -0
  249. package/src/ui/spinner/animated/spinner.tsx +143 -0
  250. package/{dist/ui/spinner/animated/types.d.ts → src/ui/spinner/animated/types.ts} +6 -4
  251. package/src/ui/spinner/animated/variants.ts +50 -0
  252. package/src/ui/stepper/index.ts +22 -0
  253. package/src/ui/stepper/stepper.test.tsx +183 -0
  254. package/src/ui/stepper/stepper.tsx +172 -0
  255. package/{dist/ui/stepper/types.d.ts → src/ui/stepper/types.ts} +18 -11
  256. package/src/ui/stepper/variants.ts +69 -0
  257. package/src/ui/table/animated/animations.ts +9 -0
  258. package/src/ui/table/animated/index.ts +15 -0
  259. package/src/ui/table/animated/table-animated.tsx +15 -0
  260. package/src/ui/table/animated/types.ts +16 -0
  261. package/src/ui/table/index.ts +22 -0
  262. package/src/ui/table/table-base.tsx +197 -0
  263. package/src/ui/table/table.tsx +13 -0
  264. package/src/ui/table/types.ts +47 -0
  265. package/src/ui/table/variants.ts +105 -0
  266. package/src/ui/tabs/animated/animations.ts +48 -0
  267. package/{dist/ui/tabs/animated/index.d.ts → src/ui/tabs/animated/index.ts} +6 -2
  268. package/src/ui/tabs/animated/tabs-content-animated.tsx +46 -0
  269. package/src/ui/tabs/animated/types.ts +24 -0
  270. package/{dist/ui/tabs/index.d.ts → src/ui/tabs/index.ts} +8 -2
  271. package/src/ui/tabs/tabs-base.tsx +185 -0
  272. package/src/ui/tabs/tabs.test.tsx +53 -0
  273. package/{dist/ui/tabs/tabs.d.ts → src/ui/tabs/tabs.tsx} +1 -1
  274. package/src/ui/tabs/types.ts +88 -0
  275. package/src/ui/tabs/variants.ts +70 -0
  276. package/src/ui/toast/animated/animations.ts +17 -0
  277. package/src/ui/toast/animated/index.ts +9 -0
  278. package/src/ui/toast/animated/toast-animated.tsx +96 -0
  279. package/src/ui/toast/animated/types.ts +13 -0
  280. package/src/ui/toast/index.ts +26 -0
  281. package/src/ui/toast/toast-base.tsx +231 -0
  282. package/src/ui/toast/toast.test.tsx +102 -0
  283. package/src/ui/toast/toast.tsx +13 -0
  284. package/{dist/ui/toast/types.d.ts → src/ui/toast/types.ts} +35 -23
  285. package/src/ui/toast/variants.ts +73 -0
  286. package/src/ui/toggle/animated/animations.ts +9 -0
  287. package/src/ui/toggle/animated/index.ts +7 -0
  288. package/src/ui/toggle/animated/toggle-animated.tsx +76 -0
  289. package/{dist/ui/toggle/animated/types.d.ts → src/ui/toggle/animated/types.ts} +6 -2
  290. package/{dist/ui/toggle/index.d.ts → src/ui/toggle/index.ts} +2 -1
  291. package/src/ui/toggle/toggle-base.tsx +70 -0
  292. package/src/ui/toggle/toggle.test.tsx +44 -0
  293. package/src/ui/toggle/toggle.tsx +9 -0
  294. package/{dist/ui/toggle/types.d.ts → src/ui/toggle/types.ts} +7 -3
  295. package/src/ui/toggle/variants.ts +84 -0
  296. package/src/ui/tooltip/animated/animations.ts +16 -0
  297. package/src/ui/tooltip/animated/index.ts +10 -0
  298. package/src/ui/tooltip/animated/tooltip-content-animated.tsx +47 -0
  299. package/src/ui/tooltip/animated/types.ts +19 -0
  300. package/src/ui/tooltip/index.ts +17 -0
  301. package/src/ui/tooltip/tooltip-base.tsx +152 -0
  302. package/src/ui/tooltip/tooltip.test.tsx +84 -0
  303. package/src/ui/tooltip/tooltip.tsx +8 -0
  304. package/src/ui/tooltip/types.ts +57 -0
  305. package/src/ui/tooltip/variants.ts +61 -0
  306. package/dist/hooks/index.d.ts.map +0 -1
  307. package/dist/hooks/useBodyScrollLock/index.d.ts.map +0 -1
  308. package/dist/hooks/useBodyScrollLock/useBodyScrollLock.d.ts +0 -13
  309. package/dist/hooks/useBodyScrollLock/useBodyScrollLock.d.ts.map +0 -1
  310. package/dist/hooks/useClickOutside/index.d.ts +0 -2
  311. package/dist/hooks/useClickOutside/index.d.ts.map +0 -1
  312. package/dist/hooks/useClickOutside/useClickOutside.d.ts +0 -22
  313. package/dist/hooks/useClickOutside/useClickOutside.d.ts.map +0 -1
  314. package/dist/hooks/useClipboard/index.d.ts.map +0 -1
  315. package/dist/hooks/useClipboard/useClipboard.d.ts +0 -21
  316. package/dist/hooks/useClipboard/useClipboard.d.ts.map +0 -1
  317. package/dist/hooks/useControllableState/index.d.ts +0 -2
  318. package/dist/hooks/useControllableState/index.d.ts.map +0 -1
  319. package/dist/hooks/useControllableState/useControllableState.d.ts +0 -21
  320. package/dist/hooks/useControllableState/useControllableState.d.ts.map +0 -1
  321. package/dist/hooks/useDebouncedValue/index.d.ts.map +0 -1
  322. package/dist/hooks/useDebouncedValue/useDebouncedValue.d.ts.map +0 -1
  323. package/dist/hooks/useDisclosure/index.d.ts +0 -2
  324. package/dist/hooks/useDisclosure/index.d.ts.map +0 -1
  325. package/dist/hooks/useDisclosure/useDisclosure.d.ts +0 -24
  326. package/dist/hooks/useDisclosure/useDisclosure.d.ts.map +0 -1
  327. package/dist/hooks/useDocumentTitle/index.d.ts +0 -2
  328. package/dist/hooks/useDocumentTitle/index.d.ts.map +0 -1
  329. package/dist/hooks/useDocumentTitle/useDocumentTitle.d.ts +0 -18
  330. package/dist/hooks/useDocumentTitle/useDocumentTitle.d.ts.map +0 -1
  331. package/dist/hooks/useFocusManagement/index.d.ts.map +0 -1
  332. package/dist/hooks/useFocusManagement/useFocusManagement.d.ts +0 -22
  333. package/dist/hooks/useFocusManagement/useFocusManagement.d.ts.map +0 -1
  334. package/dist/hooks/useHover/index.d.ts.map +0 -1
  335. package/dist/hooks/useHover/useHover.d.ts +0 -13
  336. package/dist/hooks/useHover/useHover.d.ts.map +0 -1
  337. package/dist/hooks/useInView/index.d.ts.map +0 -1
  338. package/dist/hooks/useInView/useInView.d.ts.map +0 -1
  339. package/dist/hooks/useIntersectionObserver/index.d.ts +0 -2
  340. package/dist/hooks/useIntersectionObserver/index.d.ts.map +0 -1
  341. package/dist/hooks/useIntersectionObserver/useIntersectionObserver.d.ts +0 -17
  342. package/dist/hooks/useIntersectionObserver/useIntersectionObserver.d.ts.map +0 -1
  343. package/dist/hooks/useIsMounted/index.d.ts.map +0 -1
  344. package/dist/hooks/useIsMounted/useIsMounted.d.ts.map +0 -1
  345. package/dist/hooks/useIsomorphicLayoutEffect/index.d.ts.map +0 -1
  346. package/dist/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.d.ts.map +0 -1
  347. package/dist/hooks/useLocalStorage/index.d.ts +0 -2
  348. package/dist/hooks/useLocalStorage/index.d.ts.map +0 -1
  349. package/dist/hooks/useLocalStorage/useLocalStorage.d.ts +0 -21
  350. package/dist/hooks/useLocalStorage/useLocalStorage.d.ts.map +0 -1
  351. package/dist/hooks/useMediaQuery/index.d.ts.map +0 -1
  352. package/dist/hooks/useMediaQuery/useMediaQuery.d.ts +0 -12
  353. package/dist/hooks/useMediaQuery/useMediaQuery.d.ts.map +0 -1
  354. package/dist/hooks/useNetworkStatus/index.d.ts.map +0 -1
  355. package/dist/hooks/useNetworkStatus/useNetworkStatus.d.ts +0 -9
  356. package/dist/hooks/useNetworkStatus/useNetworkStatus.d.ts.map +0 -1
  357. package/dist/hooks/usePageVisibility/index.d.ts.map +0 -1
  358. package/dist/hooks/usePageVisibility/usePageVisibility.d.ts +0 -9
  359. package/dist/hooks/usePageVisibility/usePageVisibility.d.ts.map +0 -1
  360. package/dist/hooks/usePagination/index.d.ts +0 -2
  361. package/dist/hooks/usePagination/index.d.ts.map +0 -1
  362. package/dist/hooks/usePagination/usePagination.d.ts +0 -30
  363. package/dist/hooks/usePagination/usePagination.d.ts.map +0 -1
  364. package/dist/hooks/usePrefersColorScheme/index.d.ts +0 -2
  365. package/dist/hooks/usePrefersColorScheme/index.d.ts.map +0 -1
  366. package/dist/hooks/usePrefersColorScheme/usePrefersColorScheme.d.ts.map +0 -1
  367. package/dist/hooks/usePrefersReducedMotion/index.d.ts.map +0 -1
  368. package/dist/hooks/usePrefersReducedMotion/usePrefersReducedMotion.d.ts.map +0 -1
  369. package/dist/hooks/useResizeObserver/index.d.ts +0 -2
  370. package/dist/hooks/useResizeObserver/index.d.ts.map +0 -1
  371. package/dist/hooks/useResizeObserver/useResizeObserver.d.ts +0 -21
  372. package/dist/hooks/useResizeObserver/useResizeObserver.d.ts.map +0 -1
  373. package/dist/hooks/useSessionStorage/index.d.ts +0 -2
  374. package/dist/hooks/useSessionStorage/index.d.ts.map +0 -1
  375. package/dist/hooks/useSessionStorage/useSessionStorage.d.ts +0 -21
  376. package/dist/hooks/useSessionStorage/useSessionStorage.d.ts.map +0 -1
  377. package/dist/hooks/useThrottledCallback/index.d.ts.map +0 -1
  378. package/dist/hooks/useThrottledCallback/useThrottledCallback.d.ts.map +0 -1
  379. package/dist/hooks/useToggle/index.d.ts.map +0 -1
  380. package/dist/hooks/useToggle/useToggle.d.ts +0 -8
  381. package/dist/hooks/useToggle/useToggle.d.ts.map +0 -1
  382. package/dist/hooks/useWindowSize/index.d.ts.map +0 -1
  383. package/dist/hooks/useWindowSize/useWindowSize.d.ts +0 -13
  384. package/dist/hooks/useWindowSize/useWindowSize.d.ts.map +0 -1
  385. package/dist/lib/utils.d.ts +0 -6
  386. package/dist/lib/utils.d.ts.map +0 -1
  387. package/dist/ui/accordion/accordion-base.d.ts +0 -20
  388. package/dist/ui/accordion/accordion-base.d.ts.map +0 -1
  389. package/dist/ui/accordion/accordion.d.ts +0 -8
  390. package/dist/ui/accordion/accordion.d.ts.map +0 -1
  391. package/dist/ui/accordion/animated/accordion-content-animated.d.ts +0 -6
  392. package/dist/ui/accordion/animated/accordion-content-animated.d.ts.map +0 -1
  393. package/dist/ui/accordion/animated/accordion-root-animated.d.ts +0 -6
  394. package/dist/ui/accordion/animated/accordion-root-animated.d.ts.map +0 -1
  395. package/dist/ui/accordion/animated/animations.d.ts +0 -6
  396. package/dist/ui/accordion/animated/animations.d.ts.map +0 -1
  397. package/dist/ui/accordion/animated/index.d.ts.map +0 -1
  398. package/dist/ui/accordion/animated/types.d.ts.map +0 -1
  399. package/dist/ui/accordion/index.d.ts +0 -5
  400. package/dist/ui/accordion/index.d.ts.map +0 -1
  401. package/dist/ui/accordion/types.d.ts.map +0 -1
  402. package/dist/ui/accordion/variants.d.ts +0 -14
  403. package/dist/ui/accordion/variants.d.ts.map +0 -1
  404. package/dist/ui/alert/alert-base.d.ts +0 -28
  405. package/dist/ui/alert/alert-base.d.ts.map +0 -1
  406. package/dist/ui/alert/alert.d.ts +0 -6
  407. package/dist/ui/alert/alert.d.ts.map +0 -1
  408. package/dist/ui/alert/animated/alert-animated.d.ts +0 -3
  409. package/dist/ui/alert/animated/alert-animated.d.ts.map +0 -1
  410. package/dist/ui/alert/animated/animations.d.ts +0 -3
  411. package/dist/ui/alert/animated/animations.d.ts.map +0 -1
  412. package/dist/ui/alert/animated/index.d.ts +0 -4
  413. package/dist/ui/alert/animated/index.d.ts.map +0 -1
  414. package/dist/ui/alert/animated/types.d.ts +0 -8
  415. package/dist/ui/alert/animated/types.d.ts.map +0 -1
  416. package/dist/ui/alert/index.d.ts +0 -5
  417. package/dist/ui/alert/index.d.ts.map +0 -1
  418. package/dist/ui/alert/types.d.ts.map +0 -1
  419. package/dist/ui/alert/variants.d.ts +0 -11
  420. package/dist/ui/alert/variants.d.ts.map +0 -1
  421. package/dist/ui/avatar/animated/animations.d.ts +0 -3
  422. package/dist/ui/avatar/animated/animations.d.ts.map +0 -1
  423. package/dist/ui/avatar/animated/avatar-animated.d.ts +0 -6
  424. package/dist/ui/avatar/animated/avatar-animated.d.ts.map +0 -1
  425. package/dist/ui/avatar/animated/index.d.ts.map +0 -1
  426. package/dist/ui/avatar/animated/types.d.ts.map +0 -1
  427. package/dist/ui/avatar/avatar-base.d.ts +0 -25
  428. package/dist/ui/avatar/avatar-base.d.ts.map +0 -1
  429. package/dist/ui/avatar/avatar.d.ts +0 -8
  430. package/dist/ui/avatar/avatar.d.ts.map +0 -1
  431. package/dist/ui/avatar/index.d.ts +0 -5
  432. package/dist/ui/avatar/index.d.ts.map +0 -1
  433. package/dist/ui/avatar/types.d.ts.map +0 -1
  434. package/dist/ui/avatar/variants.d.ts +0 -8
  435. package/dist/ui/avatar/variants.d.ts.map +0 -1
  436. package/dist/ui/badge/animated/animations.d.ts +0 -3
  437. package/dist/ui/badge/animated/animations.d.ts.map +0 -1
  438. package/dist/ui/badge/animated/badge-animated.d.ts +0 -6
  439. package/dist/ui/badge/animated/badge-animated.d.ts.map +0 -1
  440. package/dist/ui/badge/animated/index.d.ts.map +0 -1
  441. package/dist/ui/badge/animated/types.d.ts +0 -10
  442. package/dist/ui/badge/animated/types.d.ts.map +0 -1
  443. package/dist/ui/badge/badge-base.d.ts +0 -6
  444. package/dist/ui/badge/badge-base.d.ts.map +0 -1
  445. package/dist/ui/badge/badge.d.ts +0 -6
  446. package/dist/ui/badge/badge.d.ts.map +0 -1
  447. package/dist/ui/badge/index.d.ts.map +0 -1
  448. package/dist/ui/badge/types.d.ts +0 -17
  449. package/dist/ui/badge/types.d.ts.map +0 -1
  450. package/dist/ui/badge/variants.d.ts +0 -40
  451. package/dist/ui/badge/variants.d.ts.map +0 -1
  452. package/dist/ui/breadcrumb/breadcrumb.d.ts +0 -33
  453. package/dist/ui/breadcrumb/breadcrumb.d.ts.map +0 -1
  454. package/dist/ui/breadcrumb/index.d.ts +0 -4
  455. package/dist/ui/breadcrumb/index.d.ts.map +0 -1
  456. package/dist/ui/breadcrumb/types.d.ts.map +0 -1
  457. package/dist/ui/breadcrumb/variants.d.ts +0 -11
  458. package/dist/ui/breadcrumb/variants.d.ts.map +0 -1
  459. package/dist/ui/buttons/animated/animations.d.ts +0 -3
  460. package/dist/ui/buttons/animated/animations.d.ts.map +0 -1
  461. package/dist/ui/buttons/animated/button-animated.d.ts +0 -6
  462. package/dist/ui/buttons/animated/button-animated.d.ts.map +0 -1
  463. package/dist/ui/buttons/animated/index.d.ts.map +0 -1
  464. package/dist/ui/buttons/animated/types.d.ts +0 -16
  465. package/dist/ui/buttons/animated/types.d.ts.map +0 -1
  466. package/dist/ui/buttons/button-base.d.ts +0 -6
  467. package/dist/ui/buttons/button-base.d.ts.map +0 -1
  468. package/dist/ui/buttons/button.d.ts +0 -6
  469. package/dist/ui/buttons/button.d.ts.map +0 -1
  470. package/dist/ui/buttons/index.d.ts.map +0 -1
  471. package/dist/ui/buttons/types.d.ts.map +0 -1
  472. package/dist/ui/buttons/variants.d.ts +0 -5
  473. package/dist/ui/buttons/variants.d.ts.map +0 -1
  474. package/dist/ui/card/animated/animations.d.ts +0 -7
  475. package/dist/ui/card/animated/animations.d.ts.map +0 -1
  476. package/dist/ui/card/animated/card-animated.d.ts +0 -6
  477. package/dist/ui/card/animated/card-animated.d.ts.map +0 -1
  478. package/dist/ui/card/animated/index.d.ts.map +0 -1
  479. package/dist/ui/card/animated/types.d.ts.map +0 -1
  480. package/dist/ui/card/card-base.d.ts +0 -26
  481. package/dist/ui/card/card-base.d.ts.map +0 -1
  482. package/dist/ui/card/card.d.ts +0 -6
  483. package/dist/ui/card/card.d.ts.map +0 -1
  484. package/dist/ui/card/index.d.ts +0 -5
  485. package/dist/ui/card/index.d.ts.map +0 -1
  486. package/dist/ui/card/types.d.ts +0 -29
  487. package/dist/ui/card/types.d.ts.map +0 -1
  488. package/dist/ui/card/variants.d.ts +0 -18
  489. package/dist/ui/card/variants.d.ts.map +0 -1
  490. package/dist/ui/divider/animated/animations.d.ts +0 -6
  491. package/dist/ui/divider/animated/animations.d.ts.map +0 -1
  492. package/dist/ui/divider/animated/divider-animated.d.ts +0 -6
  493. package/dist/ui/divider/animated/divider-animated.d.ts.map +0 -1
  494. package/dist/ui/divider/animated/index.d.ts.map +0 -1
  495. package/dist/ui/divider/animated/types.d.ts.map +0 -1
  496. package/dist/ui/divider/divider-base.d.ts +0 -6
  497. package/dist/ui/divider/divider-base.d.ts.map +0 -1
  498. package/dist/ui/divider/divider.d.ts +0 -6
  499. package/dist/ui/divider/divider.d.ts.map +0 -1
  500. package/dist/ui/divider/index.d.ts +0 -4
  501. package/dist/ui/divider/index.d.ts.map +0 -1
  502. package/dist/ui/divider/types.d.ts.map +0 -1
  503. package/dist/ui/divider/variants.d.ts +0 -14
  504. package/dist/ui/divider/variants.d.ts.map +0 -1
  505. package/dist/ui/drawer/animated/animations.d.ts +0 -3
  506. package/dist/ui/drawer/animated/animations.d.ts.map +0 -1
  507. package/dist/ui/drawer/animated/drawer-content-animated.d.ts +0 -6
  508. package/dist/ui/drawer/animated/drawer-content-animated.d.ts.map +0 -1
  509. package/dist/ui/drawer/animated/index.d.ts.map +0 -1
  510. package/dist/ui/drawer/animated/types.d.ts +0 -9
  511. package/dist/ui/drawer/animated/types.d.ts.map +0 -1
  512. package/dist/ui/drawer/drawer-base.d.ts +0 -35
  513. package/dist/ui/drawer/drawer-base.d.ts.map +0 -1
  514. package/dist/ui/drawer/drawer.d.ts +0 -2
  515. package/dist/ui/drawer/drawer.d.ts.map +0 -1
  516. package/dist/ui/drawer/index.d.ts +0 -4
  517. package/dist/ui/drawer/index.d.ts.map +0 -1
  518. package/dist/ui/drawer/types.d.ts +0 -33
  519. package/dist/ui/drawer/types.d.ts.map +0 -1
  520. package/dist/ui/drawer/variants.d.ts +0 -10
  521. package/dist/ui/drawer/variants.d.ts.map +0 -1
  522. package/dist/ui/dropdown/dropdown.d.ts +0 -6
  523. package/dist/ui/dropdown/dropdown.d.ts.map +0 -1
  524. package/dist/ui/dropdown/index.d.ts +0 -4
  525. package/dist/ui/dropdown/index.d.ts.map +0 -1
  526. package/dist/ui/dropdown/types.d.ts +0 -38
  527. package/dist/ui/dropdown/types.d.ts.map +0 -1
  528. package/dist/ui/dropdown/variants.d.ts +0 -12
  529. package/dist/ui/dropdown/variants.d.ts.map +0 -1
  530. package/dist/ui/empty-state/animated/animations.d.ts +0 -3
  531. package/dist/ui/empty-state/animated/animations.d.ts.map +0 -1
  532. package/dist/ui/empty-state/animated/empty-state-animated.d.ts +0 -6
  533. package/dist/ui/empty-state/animated/empty-state-animated.d.ts.map +0 -1
  534. package/dist/ui/empty-state/animated/index.d.ts +0 -4
  535. package/dist/ui/empty-state/animated/index.d.ts.map +0 -1
  536. package/dist/ui/empty-state/animated/types.d.ts.map +0 -1
  537. package/dist/ui/empty-state/empty-state-base.d.ts +0 -23
  538. package/dist/ui/empty-state/empty-state-base.d.ts.map +0 -1
  539. package/dist/ui/empty-state/empty-state.d.ts +0 -6
  540. package/dist/ui/empty-state/empty-state.d.ts.map +0 -1
  541. package/dist/ui/empty-state/index.d.ts.map +0 -1
  542. package/dist/ui/empty-state/types.d.ts.map +0 -1
  543. package/dist/ui/empty-state/variants.d.ts +0 -12
  544. package/dist/ui/empty-state/variants.d.ts.map +0 -1
  545. package/dist/ui/file-upload/file-upload.d.ts +0 -8
  546. package/dist/ui/file-upload/file-upload.d.ts.map +0 -1
  547. package/dist/ui/file-upload/index.d.ts.map +0 -1
  548. package/dist/ui/file-upload/types.d.ts.map +0 -1
  549. package/dist/ui/file-upload/variants.d.ts +0 -4
  550. package/dist/ui/file-upload/variants.d.ts.map +0 -1
  551. package/dist/ui/inputs/animated/animations.d.ts +0 -3
  552. package/dist/ui/inputs/animated/animations.d.ts.map +0 -1
  553. package/dist/ui/inputs/animated/index.d.ts.map +0 -1
  554. package/dist/ui/inputs/animated/input-animated.d.ts +0 -6
  555. package/dist/ui/inputs/animated/input-animated.d.ts.map +0 -1
  556. package/dist/ui/inputs/animated/types.d.ts +0 -16
  557. package/dist/ui/inputs/animated/types.d.ts.map +0 -1
  558. package/dist/ui/inputs/index.d.ts.map +0 -1
  559. package/dist/ui/inputs/input-base.d.ts +0 -6
  560. package/dist/ui/inputs/input-base.d.ts.map +0 -1
  561. package/dist/ui/inputs/input.d.ts +0 -6
  562. package/dist/ui/inputs/input.d.ts.map +0 -1
  563. package/dist/ui/inputs/types.d.ts +0 -12
  564. package/dist/ui/inputs/types.d.ts.map +0 -1
  565. package/dist/ui/inputs/variants.d.ts +0 -7
  566. package/dist/ui/inputs/variants.d.ts.map +0 -1
  567. package/dist/ui/modal/animated/animations.d.ts +0 -3
  568. package/dist/ui/modal/animated/animations.d.ts.map +0 -1
  569. package/dist/ui/modal/animated/index.d.ts.map +0 -1
  570. package/dist/ui/modal/animated/modal-content-animated.d.ts +0 -6
  571. package/dist/ui/modal/animated/modal-content-animated.d.ts.map +0 -1
  572. package/dist/ui/modal/animated/types.d.ts +0 -9
  573. package/dist/ui/modal/animated/types.d.ts.map +0 -1
  574. package/dist/ui/modal/index.d.ts +0 -5
  575. package/dist/ui/modal/index.d.ts.map +0 -1
  576. package/dist/ui/modal/modal-base.d.ts +0 -47
  577. package/dist/ui/modal/modal-base.d.ts.map +0 -1
  578. package/dist/ui/modal/modal.d.ts +0 -6
  579. package/dist/ui/modal/modal.d.ts.map +0 -1
  580. package/dist/ui/modal/types.d.ts +0 -26
  581. package/dist/ui/modal/types.d.ts.map +0 -1
  582. package/dist/ui/modal/variants.d.ts +0 -10
  583. package/dist/ui/modal/variants.d.ts.map +0 -1
  584. package/dist/ui/pagination/index.d.ts +0 -5
  585. package/dist/ui/pagination/index.d.ts.map +0 -1
  586. package/dist/ui/pagination/pagination.d.ts +0 -17
  587. package/dist/ui/pagination/pagination.d.ts.map +0 -1
  588. package/dist/ui/pagination/types.d.ts.map +0 -1
  589. package/dist/ui/pagination/variants.d.ts +0 -12
  590. package/dist/ui/pagination/variants.d.ts.map +0 -1
  591. package/dist/ui/progress/animated/animations.d.ts +0 -3
  592. package/dist/ui/progress/animated/animations.d.ts.map +0 -1
  593. package/dist/ui/progress/animated/index.d.ts +0 -4
  594. package/dist/ui/progress/animated/index.d.ts.map +0 -1
  595. package/dist/ui/progress/animated/progress-animated.d.ts +0 -16
  596. package/dist/ui/progress/animated/progress-animated.d.ts.map +0 -1
  597. package/dist/ui/progress/animated/types.d.ts.map +0 -1
  598. package/dist/ui/progress/index.d.ts.map +0 -1
  599. package/dist/ui/progress/progress-base.d.ts +0 -23
  600. package/dist/ui/progress/progress-base.d.ts.map +0 -1
  601. package/dist/ui/progress/progress.d.ts +0 -6
  602. package/dist/ui/progress/progress.d.ts.map +0 -1
  603. package/dist/ui/progress/types.d.ts +0 -28
  604. package/dist/ui/progress/types.d.ts.map +0 -1
  605. package/dist/ui/progress/variants.d.ts +0 -15
  606. package/dist/ui/progress/variants.d.ts.map +0 -1
  607. package/dist/ui/select/index.d.ts +0 -4
  608. package/dist/ui/select/index.d.ts.map +0 -1
  609. package/dist/ui/select/select.d.ts +0 -10
  610. package/dist/ui/select/select.d.ts.map +0 -1
  611. package/dist/ui/select/types.d.ts +0 -48
  612. package/dist/ui/select/types.d.ts.map +0 -1
  613. package/dist/ui/select/variants.d.ts +0 -14
  614. package/dist/ui/select/variants.d.ts.map +0 -1
  615. package/dist/ui/skeleton/animated/animations.d.ts +0 -3
  616. package/dist/ui/skeleton/animated/animations.d.ts.map +0 -1
  617. package/dist/ui/skeleton/animated/index.d.ts +0 -4
  618. package/dist/ui/skeleton/animated/index.d.ts.map +0 -1
  619. package/dist/ui/skeleton/animated/skeleton-animated.d.ts +0 -22
  620. package/dist/ui/skeleton/animated/skeleton-animated.d.ts.map +0 -1
  621. package/dist/ui/skeleton/animated/types.d.ts.map +0 -1
  622. package/dist/ui/skeleton/index.d.ts +0 -5
  623. package/dist/ui/skeleton/index.d.ts.map +0 -1
  624. package/dist/ui/skeleton/skeleton-base.d.ts +0 -24
  625. package/dist/ui/skeleton/skeleton-base.d.ts.map +0 -1
  626. package/dist/ui/skeleton/skeleton.d.ts +0 -2
  627. package/dist/ui/skeleton/skeleton.d.ts.map +0 -1
  628. package/dist/ui/skeleton/types.d.ts.map +0 -1
  629. package/dist/ui/skeleton/variants.d.ts +0 -38
  630. package/dist/ui/skeleton/variants.d.ts.map +0 -1
  631. package/dist/ui/slider/index.d.ts +0 -4
  632. package/dist/ui/slider/index.d.ts.map +0 -1
  633. package/dist/ui/slider/slider.d.ts +0 -33
  634. package/dist/ui/slider/slider.d.ts.map +0 -1
  635. package/dist/ui/slider/types.d.ts +0 -49
  636. package/dist/ui/slider/types.d.ts.map +0 -1
  637. package/dist/ui/slider/variants.d.ts +0 -13
  638. package/dist/ui/slider/variants.d.ts.map +0 -1
  639. package/dist/ui/spinner/animated/index.d.ts.map +0 -1
  640. package/dist/ui/spinner/animated/spinner.d.ts +0 -6
  641. package/dist/ui/spinner/animated/spinner.d.ts.map +0 -1
  642. package/dist/ui/spinner/animated/types.d.ts.map +0 -1
  643. package/dist/ui/spinner/animated/variants.d.ts +0 -6
  644. package/dist/ui/spinner/animated/variants.d.ts.map +0 -1
  645. package/dist/ui/stepper/index.d.ts +0 -4
  646. package/dist/ui/stepper/index.d.ts.map +0 -1
  647. package/dist/ui/stepper/stepper.d.ts +0 -33
  648. package/dist/ui/stepper/stepper.d.ts.map +0 -1
  649. package/dist/ui/stepper/types.d.ts.map +0 -1
  650. package/dist/ui/stepper/variants.d.ts +0 -11
  651. package/dist/ui/stepper/variants.d.ts.map +0 -1
  652. package/dist/ui/table/animated/animations.d.ts +0 -3
  653. package/dist/ui/table/animated/animations.d.ts.map +0 -1
  654. package/dist/ui/table/animated/index.d.ts +0 -5
  655. package/dist/ui/table/animated/index.d.ts.map +0 -1
  656. package/dist/ui/table/animated/table-animated.d.ts +0 -5
  657. package/dist/ui/table/animated/table-animated.d.ts.map +0 -1
  658. package/dist/ui/table/animated/types.d.ts +0 -8
  659. package/dist/ui/table/animated/types.d.ts.map +0 -1
  660. package/dist/ui/table/index.d.ts +0 -4
  661. package/dist/ui/table/index.d.ts.map +0 -1
  662. package/dist/ui/table/table-base.d.ts +0 -38
  663. package/dist/ui/table/table-base.d.ts.map +0 -1
  664. package/dist/ui/table/table.d.ts +0 -2
  665. package/dist/ui/table/table.d.ts.map +0 -1
  666. package/dist/ui/table/types.d.ts +0 -33
  667. package/dist/ui/table/types.d.ts.map +0 -1
  668. package/dist/ui/table/variants.d.ts +0 -14
  669. package/dist/ui/table/variants.d.ts.map +0 -1
  670. package/dist/ui/tabs/animated/animations.d.ts +0 -5
  671. package/dist/ui/tabs/animated/animations.d.ts.map +0 -1
  672. package/dist/ui/tabs/animated/index.d.ts.map +0 -1
  673. package/dist/ui/tabs/animated/tabs-content-animated.d.ts +0 -6
  674. package/dist/ui/tabs/animated/tabs-content-animated.d.ts.map +0 -1
  675. package/dist/ui/tabs/animated/types.d.ts +0 -14
  676. package/dist/ui/tabs/animated/types.d.ts.map +0 -1
  677. package/dist/ui/tabs/index.d.ts.map +0 -1
  678. package/dist/ui/tabs/tabs-base.d.ts +0 -8
  679. package/dist/ui/tabs/tabs-base.d.ts.map +0 -1
  680. package/dist/ui/tabs/tabs.d.ts.map +0 -1
  681. package/dist/ui/tabs/types.d.ts +0 -40
  682. package/dist/ui/tabs/types.d.ts.map +0 -1
  683. package/dist/ui/tabs/variants.d.ts +0 -11
  684. package/dist/ui/tabs/variants.d.ts.map +0 -1
  685. package/dist/ui/toast/animated/animations.d.ts +0 -3
  686. package/dist/ui/toast/animated/animations.d.ts.map +0 -1
  687. package/dist/ui/toast/animated/index.d.ts +0 -4
  688. package/dist/ui/toast/animated/index.d.ts.map +0 -1
  689. package/dist/ui/toast/animated/toast-animated.d.ts +0 -10
  690. package/dist/ui/toast/animated/toast-animated.d.ts.map +0 -1
  691. package/dist/ui/toast/animated/types.d.ts +0 -5
  692. package/dist/ui/toast/animated/types.d.ts.map +0 -1
  693. package/dist/ui/toast/index.d.ts +0 -4
  694. package/dist/ui/toast/index.d.ts.map +0 -1
  695. package/dist/ui/toast/toast-base.d.ts +0 -35
  696. package/dist/ui/toast/toast-base.d.ts.map +0 -1
  697. package/dist/ui/toast/toast.d.ts +0 -2
  698. package/dist/ui/toast/toast.d.ts.map +0 -1
  699. package/dist/ui/toast/types.d.ts.map +0 -1
  700. package/dist/ui/toast/variants.d.ts +0 -8
  701. package/dist/ui/toast/variants.d.ts.map +0 -1
  702. package/dist/ui/toggle/animated/animations.d.ts +0 -3
  703. package/dist/ui/toggle/animated/animations.d.ts.map +0 -1
  704. package/dist/ui/toggle/animated/index.d.ts +0 -4
  705. package/dist/ui/toggle/animated/index.d.ts.map +0 -1
  706. package/dist/ui/toggle/animated/toggle-animated.d.ts +0 -6
  707. package/dist/ui/toggle/animated/toggle-animated.d.ts.map +0 -1
  708. package/dist/ui/toggle/animated/types.d.ts.map +0 -1
  709. package/dist/ui/toggle/index.d.ts.map +0 -1
  710. package/dist/ui/toggle/toggle-base.d.ts +0 -6
  711. package/dist/ui/toggle/toggle-base.d.ts.map +0 -1
  712. package/dist/ui/toggle/toggle.d.ts +0 -6
  713. package/dist/ui/toggle/toggle.d.ts.map +0 -1
  714. package/dist/ui/toggle/types.d.ts.map +0 -1
  715. package/dist/ui/toggle/variants.d.ts +0 -8
  716. package/dist/ui/toggle/variants.d.ts.map +0 -1
  717. package/dist/ui/tooltip/animated/animations.d.ts +0 -3
  718. package/dist/ui/tooltip/animated/animations.d.ts.map +0 -1
  719. package/dist/ui/tooltip/animated/index.d.ts +0 -4
  720. package/dist/ui/tooltip/animated/index.d.ts.map +0 -1
  721. package/dist/ui/tooltip/animated/tooltip-content-animated.d.ts +0 -3
  722. package/dist/ui/tooltip/animated/tooltip-content-animated.d.ts.map +0 -1
  723. package/dist/ui/tooltip/animated/types.d.ts +0 -9
  724. package/dist/ui/tooltip/animated/types.d.ts.map +0 -1
  725. package/dist/ui/tooltip/index.d.ts +0 -4
  726. package/dist/ui/tooltip/index.d.ts.map +0 -1
  727. package/dist/ui/tooltip/tooltip-base.d.ts +0 -7
  728. package/dist/ui/tooltip/tooltip-base.d.ts.map +0 -1
  729. package/dist/ui/tooltip/tooltip.d.ts +0 -2
  730. package/dist/ui/tooltip/tooltip.d.ts.map +0 -1
  731. package/dist/ui/tooltip/types.d.ts +0 -30
  732. package/dist/ui/tooltip/types.d.ts.map +0 -1
  733. package/dist/ui/tooltip/variants.d.ts +0 -6
  734. package/dist/ui/tooltip/variants.d.ts.map +0 -1
  735. package/dist/vitest-setup.d.ts +0 -2
  736. package/dist/vitest-setup.d.ts.map +0 -1
@@ -0,0 +1,98 @@
1
+ import { cva } from "class-variance-authority";
2
+
3
+ const APPEARANCES = {
4
+ default: "text-slate-200",
5
+ muted: "text-slate-500",
6
+ primary: "text-cyan-300",
7
+ destructive: "text-rose-400",
8
+ ghost: "text-slate-600",
9
+ sky: "text-sky-400",
10
+ rose: "text-rose-400",
11
+ purple: "text-purple-400",
12
+ pink: "text-pink-400",
13
+ orange: "text-orange-400",
14
+ yellow: "text-yellow-400",
15
+ teal: "text-teal-400",
16
+ indigo: "text-indigo-400",
17
+ emerald: "text-emerald-400",
18
+ gray: "text-gray-400",
19
+ amber: "text-amber-400",
20
+ violet: "text-violet-400",
21
+ "gradient-blue": "text-blue-400",
22
+ "gradient-green": "text-green-400",
23
+ "gradient-red": "text-red-400",
24
+ "gradient-yellow": "text-yellow-400",
25
+ "gradient-purple": "text-purple-400",
26
+ "gradient-teal": "text-teal-400",
27
+ "gradient-indigo": "text-indigo-400",
28
+ "gradient-pink": "text-pink-400",
29
+ "gradient-orange": "text-orange-400",
30
+ };
31
+
32
+ export const dividerToneVariants = cva("", {
33
+ variants: {
34
+ appearance: APPEARANCES,
35
+ },
36
+ defaultVariants: { appearance: "default" },
37
+ });
38
+
39
+ export const dividerVariants = cva("flex w-full items-center gap-3", {
40
+ variants: {
41
+ appearance: APPEARANCES,
42
+ orientation: {
43
+ horizontal: "w-full flex-row",
44
+ vertical: "h-full min-h-[2rem] w-auto flex-col self-stretch",
45
+ },
46
+ size: {
47
+ sm: "",
48
+ md: "",
49
+ lg: "",
50
+ },
51
+ },
52
+ compoundVariants: [
53
+ { orientation: "horizontal", size: "sm", class: "min-h-px" },
54
+ { orientation: "horizontal", size: "md", class: "min-h-[2px]" },
55
+ { orientation: "horizontal", size: "lg", class: "min-h-[3px]" },
56
+ { orientation: "vertical", size: "sm", class: "min-w-px" },
57
+ { orientation: "vertical", size: "md", class: "min-w-[2px]" },
58
+ { orientation: "vertical", size: "lg", class: "min-w-[3px]" },
59
+ ],
60
+ defaultVariants: {
61
+ appearance: "default",
62
+ orientation: "horizontal",
63
+ size: "md",
64
+ },
65
+ });
66
+
67
+ export const dividerLineVariants = cva(
68
+ "shrink grow rounded-full bg-current opacity-80",
69
+ {
70
+ variants: {
71
+ orientation: {
72
+ horizontal: "h-px",
73
+ vertical: "w-px flex-1",
74
+ },
75
+ size: {
76
+ sm: "",
77
+ md: "",
78
+ lg: "",
79
+ },
80
+ },
81
+ compoundVariants: [
82
+ { orientation: "horizontal", size: "sm", class: "h-px" },
83
+ { orientation: "horizontal", size: "md", class: "h-0.5" },
84
+ { orientation: "horizontal", size: "lg", class: "h-1" },
85
+ { orientation: "vertical", size: "sm", class: "w-px" },
86
+ { orientation: "vertical", size: "md", class: "w-0.5" },
87
+ { orientation: "vertical", size: "lg", class: "w-1" },
88
+ ],
89
+ defaultVariants: {
90
+ orientation: "horizontal",
91
+ size: "md",
92
+ },
93
+ },
94
+ );
95
+
96
+ export const dividerLabelVariants = cva(
97
+ "shrink-0 text-xs font-medium uppercase tracking-wide text-current",
98
+ );
@@ -0,0 +1,39 @@
1
+ import { DrawerAnimationPresets } from "./types";
2
+
3
+ export const drawerPanelPresets = (
4
+ side: "left" | "right" | "top" | "bottom",
5
+ ): DrawerAnimationPresets => ({
6
+ none: {},
7
+ fade: {
8
+ initial: { opacity: 0 },
9
+ animate: { opacity: 1 },
10
+ exit: { opacity: 0 },
11
+ transition: { duration: 0.2 },
12
+ },
13
+ scale: {
14
+ initial: { opacity: 0, scale: 0.98 },
15
+ animate: { opacity: 1, scale: 1 },
16
+ exit: { opacity: 0, scale: 0.98 },
17
+ transition: { type: "spring", stiffness: 420, damping: 32 },
18
+ },
19
+ slide: {
20
+ initial:
21
+ side === "left"
22
+ ? { x: -24, opacity: 0 }
23
+ : side === "right"
24
+ ? { x: 24, opacity: 0 }
25
+ : side === "top"
26
+ ? { y: -24, opacity: 0 }
27
+ : { y: 24, opacity: 0 },
28
+ animate: { x: 0, y: 0, opacity: 1 },
29
+ exit:
30
+ side === "left"
31
+ ? { x: -16, opacity: 0 }
32
+ : side === "right"
33
+ ? { x: 16, opacity: 0 }
34
+ : side === "top"
35
+ ? { y: -16, opacity: 0 }
36
+ : { y: 16, opacity: 0 },
37
+ transition: { type: "spring", stiffness: 380, damping: 30 },
38
+ },
39
+ });
@@ -0,0 +1,101 @@
1
+ "use client";
2
+
3
+ import { AnimatePresence, motion, useReducedMotion } from "framer-motion";
4
+ import type { MutableRefObject } from "react";
5
+ import { createPortal } from "react-dom";
6
+
7
+ import { cn } from "../../../lib/utils";
8
+ import { useFocusManagement } from "../../../hooks/useFocusManagement";
9
+
10
+ import { drawerPanelPresets } from "./animations";
11
+ import { useDrawerContext } from "../drawer-base";
12
+ import {
13
+ drawerContentVariants,
14
+ drawerOverlayVariants,
15
+ } from "../variants";
16
+ import type { DrawerContentAnimatedProps } from "./types";
17
+
18
+ export function DrawerContentAnimated({
19
+ className,
20
+ side = "right",
21
+ size,
22
+ appearance,
23
+ animation = "slide",
24
+ children,
25
+ ref,
26
+ id,
27
+ style,
28
+ }: DrawerContentAnimatedProps) {
29
+ const { open, setOpen, titleId, descriptionId, contentRef } =
30
+ useDrawerContext("DrawerContent");
31
+ const resolvedSide = side ?? "right";
32
+ const reduceMotion = useReducedMotion();
33
+ const overlayMotion =
34
+ drawerPanelPresets(resolvedSide)[reduceMotion ? "fade" : animation];
35
+ const panelMotion =
36
+ drawerPanelPresets(resolvedSide)[reduceMotion ? "fade" : animation];
37
+
38
+ useFocusManagement({
39
+ open,
40
+ setOpen,
41
+ contentRef,
42
+ });
43
+
44
+ const portalTarget = typeof document !== "undefined" ? document.body : null;
45
+ if (!portalTarget) {
46
+ return null;
47
+ }
48
+
49
+ return createPortal(
50
+ <AnimatePresence>
51
+ {open ? (
52
+ <div className="fixed inset-0 z-50" data-slot="drawer-portal">
53
+ <motion.button
54
+ type="button"
55
+ aria-hidden
56
+ tabIndex={-1}
57
+ data-slot="drawer-overlay"
58
+ className={drawerOverlayVariants()}
59
+ onClick={() => setOpen(false)}
60
+ initial={animation === "none" ? false : overlayMotion.initial}
61
+ animate={animation === "none" ? undefined : overlayMotion.animate}
62
+ exit={animation === "none" ? undefined : overlayMotion.exit}
63
+ transition={overlayMotion.transition}
64
+ />
65
+ <motion.div
66
+ ref={(node) => {
67
+ contentRef.current = node;
68
+ if (typeof ref === "function") {
69
+ ref(node);
70
+ } else if (ref) {
71
+ (ref as MutableRefObject<HTMLDivElement | null>).current =
72
+ node;
73
+ }
74
+ }}
75
+ role="dialog"
76
+ aria-modal="true"
77
+ aria-labelledby={titleId}
78
+ aria-describedby={descriptionId}
79
+ data-slot="drawer-content"
80
+ tabIndex={-1}
81
+ className={cn(
82
+ drawerContentVariants({ side: resolvedSide, size, appearance }),
83
+ className,
84
+ )}
85
+ initial={animation === "none" ? false : panelMotion.initial}
86
+ animate={animation === "none" ? undefined : panelMotion.animate}
87
+ exit={animation === "none" ? undefined : panelMotion.exit}
88
+ transition={panelMotion.transition}
89
+ id={id}
90
+ style={style}
91
+ >
92
+ {children}
93
+ </motion.div>
94
+ </div>
95
+ ) : null}
96
+ </AnimatePresence>,
97
+ portalTarget,
98
+ );
99
+ }
100
+
101
+ DrawerContentAnimated.displayName = "DrawerContent";
@@ -1,5 +1,14 @@
1
- export { Drawer, DrawerBody, DrawerClose, DrawerFooter, DrawerHeader, DrawerTitle, DrawerTrigger, } from "../drawer-base";
1
+ "use client";
2
+
3
+ export {
4
+ Drawer,
5
+ DrawerBody,
6
+ DrawerClose,
7
+ DrawerFooter,
8
+ DrawerHeader,
9
+ DrawerTitle,
10
+ DrawerTrigger,
11
+ } from "../drawer-base";
2
12
  export { DrawerContentAnimated } from "./drawer-content-animated";
3
13
  export type { DrawerContentAnimatedProps, DrawerAnimation, DrawerPresetMotionProps, DrawerAnimationPresets } from "./types";
4
14
  export { drawerPanelPresets } from "./animations";
5
- //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,18 @@
1
+ import { HTMLMotionProps } from "framer-motion";
2
+ import type { DrawerContentProps } from "../types";
3
+
4
+ export type DrawerContentAnimatedProps = DrawerContentProps & {
5
+ animation?: DrawerAnimation;
6
+ };
7
+
8
+ export type DrawerAnimation = "none" | "fade" | "scale" | "slide";
9
+
10
+ export type DrawerPresetMotionProps = Pick<
11
+ HTMLMotionProps<"div">,
12
+ "initial" | "animate" | "exit" | "transition"
13
+ >;
14
+
15
+ export type DrawerAnimationPresets = Record<
16
+ DrawerAnimation,
17
+ DrawerPresetMotionProps
18
+ >;
@@ -0,0 +1,259 @@
1
+ "use client";
2
+
3
+ import {
4
+ createContext,
5
+ useCallback,
6
+ useContext,
7
+ useId,
8
+ useMemo,
9
+ useRef,
10
+ useState,
11
+ type RefObject,
12
+ } from "react";
13
+ import { createPortal } from "react-dom";
14
+
15
+ import { cn } from "../../lib/utils";
16
+ import { useFocusManagement } from "../../hooks/useFocusManagement";
17
+
18
+ import type {
19
+ DrawerContentProps,
20
+ DrawerCtx,
21
+ DrawerProps,
22
+ DrawerSectionProps,
23
+ DrawerTriggerProps,
24
+ } from "./types";
25
+ import {
26
+ drawerContentVariants,
27
+ drawerOverlayVariants,
28
+ drawerTriggerVariants,
29
+ } from "./variants";
30
+
31
+ const DrawerContext = createContext<DrawerCtx | null>(null);
32
+
33
+ export function useDrawerContext(component: string): DrawerCtx {
34
+ const ctx = useContext(DrawerContext);
35
+ if (!ctx) {
36
+ throw new Error(`${component} must be used within <Drawer>`);
37
+ }
38
+ return ctx;
39
+ }
40
+
41
+ export function Drawer({
42
+ open,
43
+ defaultOpen = false,
44
+ onOpenChange,
45
+ children,
46
+ }: DrawerProps) {
47
+ const isControlled = open !== undefined;
48
+ const [uncontrolledOpen, setUncontrolledOpen] = useState(defaultOpen);
49
+ const resolvedOpen = isControlled ? Boolean(open) : uncontrolledOpen;
50
+
51
+ const setOpen = useCallback(
52
+ (next: boolean) => {
53
+ if (!isControlled) {
54
+ setUncontrolledOpen(next);
55
+ }
56
+ onOpenChange?.(next);
57
+ },
58
+ [isControlled, onOpenChange],
59
+ );
60
+
61
+ const baseId = useId();
62
+ const titleId = `${baseId}-title`;
63
+ const descriptionId = `${baseId}-description`;
64
+ const contentRef = useRef<HTMLDivElement | null>(null);
65
+
66
+ const ctx = useMemo(
67
+ () => ({
68
+ open: resolvedOpen,
69
+ setOpen,
70
+ titleId,
71
+ descriptionId,
72
+ contentRef,
73
+ }),
74
+ [descriptionId, resolvedOpen, setOpen, titleId],
75
+ );
76
+
77
+ return (
78
+ <DrawerContext.Provider value={ctx}>{children}</DrawerContext.Provider>
79
+ );
80
+ }
81
+
82
+ Drawer.displayName = "Drawer";
83
+
84
+ export function DrawerTrigger({
85
+ className,
86
+ children,
87
+ appearance,
88
+ onClick,
89
+ ref,
90
+ ...rest
91
+ }: DrawerTriggerProps) {
92
+ const { setOpen } = useDrawerContext("DrawerTrigger");
93
+ return (
94
+ <button
95
+ ref={ref}
96
+ type="button"
97
+ data-slot="drawer-trigger"
98
+ className={cn(drawerTriggerVariants({ appearance }), className)}
99
+ onClick={(event) => {
100
+ onClick?.(event);
101
+ if (!event.defaultPrevented) {
102
+ setOpen(true);
103
+ }
104
+ }}
105
+ {...rest}
106
+ >
107
+ {children}
108
+ </button>
109
+ );
110
+ }
111
+
112
+ DrawerTrigger.displayName = "DrawerTrigger";
113
+
114
+ export function DrawerContent({
115
+ className,
116
+ side = "right",
117
+ size,
118
+ appearance,
119
+ children,
120
+ ref,
121
+ id,
122
+ style,
123
+ }: DrawerContentProps) {
124
+ const { open, setOpen, titleId, descriptionId, contentRef } =
125
+ useDrawerContext("DrawerContent");
126
+ const resolvedSide = side ?? "right";
127
+
128
+ useFocusManagement({
129
+ open,
130
+ setOpen,
131
+ contentRef,
132
+ });
133
+
134
+ const portalTarget = typeof document !== "undefined" ? document.body : null;
135
+ if (!portalTarget) {
136
+ return null;
137
+ }
138
+
139
+ return createPortal(
140
+ open ? (
141
+ <div className="fixed inset-0 z-50" data-slot="drawer-portal">
142
+ <button
143
+ type="button"
144
+ aria-hidden
145
+ tabIndex={-1}
146
+ data-slot="drawer-overlay"
147
+ className={drawerOverlayVariants()}
148
+ onClick={() => setOpen(false)}
149
+ />
150
+ <div
151
+ ref={(node) => {
152
+ contentRef.current = node;
153
+ if (typeof ref === "function") {
154
+ ref(node);
155
+ } else if (ref) {
156
+ (ref as RefObject<HTMLDivElement | null>).current = node;
157
+ }
158
+ }}
159
+ role="dialog"
160
+ aria-modal="true"
161
+ aria-labelledby={titleId}
162
+ aria-describedby={descriptionId}
163
+ data-slot="drawer-content"
164
+ tabIndex={-1}
165
+ className={cn(
166
+ drawerContentVariants({ side: resolvedSide, size, appearance }),
167
+ className,
168
+ )}
169
+ id={id}
170
+ style={style}
171
+ >
172
+ {children}
173
+ </div>
174
+ </div>
175
+ ) : null,
176
+ portalTarget,
177
+ );
178
+ }
179
+
180
+ DrawerContent.displayName = "DrawerContent";
181
+
182
+ export function DrawerHeader({ className, children }: DrawerSectionProps) {
183
+ return (
184
+ <header
185
+ data-slot="drawer-header"
186
+ className={cn("mb-4 flex flex-col gap-2", className)}
187
+ >
188
+ {children}
189
+ </header>
190
+ );
191
+ }
192
+
193
+ DrawerHeader.displayName = "DrawerHeader";
194
+
195
+ export function DrawerBody({ className, children }: DrawerSectionProps) {
196
+ return (
197
+ <div
198
+ data-slot="drawer-body"
199
+ className={cn("flex-1 text-sm text-slate-300", className)}
200
+ >
201
+ {children}
202
+ </div>
203
+ );
204
+ }
205
+
206
+ DrawerBody.displayName = "DrawerBody";
207
+
208
+ export function DrawerFooter({ className, children }: DrawerSectionProps) {
209
+ return (
210
+ <footer
211
+ data-slot="drawer-footer"
212
+ className={cn("mt-6 flex justify-end gap-2", className)}
213
+ >
214
+ {children}
215
+ </footer>
216
+ );
217
+ }
218
+
219
+ DrawerFooter.displayName = "DrawerFooter";
220
+
221
+ export function DrawerTitle({ className, children }: DrawerSectionProps) {
222
+ const { titleId } = useDrawerContext("DrawerTitle");
223
+ return (
224
+ <h2
225
+ id={titleId}
226
+ data-slot="drawer-title"
227
+ className={cn("text-lg font-semibold", className)}
228
+ >
229
+ {children}
230
+ </h2>
231
+ );
232
+ }
233
+
234
+ DrawerTitle.displayName = "DrawerTitle";
235
+
236
+ export function DrawerClose({
237
+ className,
238
+ children,
239
+ ...rest
240
+ }: DrawerSectionProps) {
241
+ const { setOpen } = useDrawerContext("DrawerClose");
242
+ return (
243
+ <button
244
+ type="button"
245
+ data-slot="drawer-close"
246
+ className={cn(
247
+ "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",
248
+ className,
249
+ )}
250
+ aria-label="Close drawer"
251
+ onClick={() => setOpen(false)}
252
+ {...rest}
253
+ >
254
+ {children ?? "×"}
255
+ </button>
256
+ );
257
+ }
258
+
259
+ DrawerClose.displayName = "DrawerClose";
@@ -0,0 +1,132 @@
1
+ import { render, screen, waitFor } from "@testing-library/react";
2
+ import userEvent from "@testing-library/user-event";
3
+ import { describe, expect, it, vi } from "vitest";
4
+
5
+ import {
6
+ Drawer,
7
+ DrawerBody,
8
+ DrawerClose,
9
+ DrawerContent,
10
+ DrawerTitle,
11
+ DrawerTrigger,
12
+ } from "./drawer";
13
+
14
+ describe("Drawer", () => {
15
+ it("should expose displayName on exported parts", () => {
16
+ expect(Drawer.displayName).toBe("Drawer");
17
+ expect(DrawerTrigger.displayName).toBe("DrawerTrigger");
18
+ expect(DrawerContent.displayName).toBe("DrawerContent");
19
+ expect(DrawerTitle.displayName).toBe("DrawerTitle");
20
+ expect(DrawerBody.displayName).toBe("DrawerBody");
21
+ expect(DrawerClose.displayName).toBe("DrawerClose");
22
+ });
23
+
24
+ it("should open from the trigger and render a dialog in the portal", async () => {
25
+ const user = userEvent.setup();
26
+ render(
27
+ <Drawer>
28
+ <DrawerTrigger>Open</DrawerTrigger>
29
+ <DrawerContent>
30
+ <DrawerTitle>Settings</DrawerTitle>
31
+ <DrawerBody>Drawer content</DrawerBody>
32
+ </DrawerContent>
33
+ </Drawer>,
34
+ );
35
+ await user.click(screen.getByRole("button", { name: "Open" }));
36
+ await waitFor(() => {
37
+ expect(screen.getByRole("dialog")).toBeInTheDocument();
38
+ });
39
+ expect(screen.getByText("Drawer content")).toBeInTheDocument();
40
+ expect(document.querySelector('[data-slot="drawer-content"]')).toBeTruthy();
41
+ });
42
+
43
+ it("should stamp data-slot on trigger and portal shell", async () => {
44
+ const user = userEvent.setup();
45
+ render(
46
+ <Drawer>
47
+ <DrawerTrigger>Go</DrawerTrigger>
48
+ <DrawerContent>
49
+ <DrawerTitle>T</DrawerTitle>
50
+ </DrawerContent>
51
+ </Drawer>,
52
+ );
53
+ expect(
54
+ screen.getByRole("button", { name: "Go" }).getAttribute("data-slot"),
55
+ ).toBe("drawer-trigger");
56
+ await user.click(screen.getByRole("button", { name: "Go" }));
57
+ await waitFor(() => {
58
+ expect(
59
+ document.querySelector('[data-slot="drawer-portal"]'),
60
+ ).toBeTruthy();
61
+ });
62
+ });
63
+
64
+ it("should close when the overlay is clicked", async () => {
65
+ const user = userEvent.setup();
66
+ render(
67
+ <Drawer defaultOpen>
68
+ <DrawerContent>
69
+ <DrawerTitle>Panel</DrawerTitle>
70
+ </DrawerContent>
71
+ </Drawer>,
72
+ );
73
+ await waitFor(() => expect(screen.getByRole("dialog")).toBeInTheDocument());
74
+ const overlay = document.querySelector(
75
+ '[data-slot="drawer-overlay"]',
76
+ ) as HTMLElement;
77
+ await user.click(overlay);
78
+ await waitFor(() => {
79
+ expect(screen.queryByRole("dialog")).not.toBeInTheDocument();
80
+ });
81
+ });
82
+
83
+ it("should close when Escape is pressed", async () => {
84
+ const user = userEvent.setup();
85
+ render(
86
+ <Drawer defaultOpen>
87
+ <DrawerContent>
88
+ <DrawerTitle>Panel</DrawerTitle>
89
+ </DrawerContent>
90
+ </Drawer>,
91
+ );
92
+ await waitFor(() => expect(screen.getByRole("dialog")).toBeInTheDocument());
93
+ await user.keyboard("{Escape}");
94
+ await waitFor(() => {
95
+ expect(screen.queryByRole("dialog")).not.toBeInTheDocument();
96
+ });
97
+ });
98
+
99
+ it("should close when DrawerClose is activated", async () => {
100
+ const user = userEvent.setup();
101
+ render(
102
+ <Drawer defaultOpen>
103
+ <DrawerContent>
104
+ <DrawerTitle>Panel</DrawerTitle>
105
+ <DrawerClose />
106
+ </DrawerContent>
107
+ </Drawer>,
108
+ );
109
+ await waitFor(() => expect(screen.getByRole("dialog")).toBeInTheDocument());
110
+ await user.click(screen.getByRole("button", { name: /close drawer/i }));
111
+ await waitFor(() => {
112
+ expect(screen.queryByRole("dialog")).not.toBeInTheDocument();
113
+ });
114
+ });
115
+
116
+ it("should call onOpenChange when opening and closing", async () => {
117
+ const user = userEvent.setup();
118
+ const handleChange = vi.fn();
119
+ render(
120
+ <Drawer onOpenChange={handleChange}>
121
+ <DrawerTrigger>Open</DrawerTrigger>
122
+ <DrawerContent>
123
+ <DrawerTitle>T</DrawerTitle>
124
+ </DrawerContent>
125
+ </Drawer>,
126
+ );
127
+ await user.click(screen.getByRole("button", { name: "Open" }));
128
+ await waitFor(() => expect(handleChange).toHaveBeenLastCalledWith(true));
129
+ await user.keyboard("{Escape}");
130
+ await waitFor(() => expect(handleChange).toHaveBeenLastCalledWith(false));
131
+ });
132
+ });
@@ -0,0 +1,11 @@
1
+ // drawer.tsx — default static entry (no framer-motion)
2
+ export {
3
+ Drawer,
4
+ DrawerBody,
5
+ DrawerClose,
6
+ DrawerContent,
7
+ DrawerFooter,
8
+ DrawerHeader,
9
+ DrawerTitle,
10
+ DrawerTrigger,
11
+ } from "./drawer-base";
@@ -0,0 +1,21 @@
1
+ "use client";
2
+
3
+ export {
4
+ Drawer,
5
+ DrawerBody,
6
+ DrawerClose,
7
+ DrawerContent,
8
+ DrawerFooter,
9
+ DrawerHeader,
10
+ DrawerTitle,
11
+ DrawerTrigger,
12
+ } from "./drawer";
13
+ export type {
14
+ DrawerContentVariantProps,
15
+ DrawerContentProps,
16
+ DrawerProps,
17
+ DrawerSectionProps,
18
+ DrawerTriggerProps,
19
+ DrawerCtx,
20
+ } from "./types";
21
+ export { drawerContentVariants, drawerOverlayVariants } from "./variants";