@zentauri-ui/zentauri-components 1.3.0 → 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (942) hide show
  1. package/README.md +78 -0
  2. package/cli/cli.integration.test.ts +51 -0
  3. package/cli/index.mjs +664 -0
  4. package/cli/registry.json +36 -0
  5. package/cli/rewrite-imports.mjs +57 -0
  6. package/cli/rewrite-imports.test.ts +71 -0
  7. package/dist/hooks/index.d.ts +27 -0
  8. package/dist/hooks/index.d.ts.map +1 -0
  9. package/dist/hooks/useBodyScrollLock/index.d.ts +2 -0
  10. package/dist/hooks/useBodyScrollLock/index.d.ts.map +1 -0
  11. package/dist/hooks/{useBodyScrollLock.d.ts → useBodyScrollLock/useBodyScrollLock.d.ts} +2 -3
  12. package/dist/hooks/useBodyScrollLock/useBodyScrollLock.d.ts.map +1 -0
  13. package/dist/hooks/useClickOutside/index.d.ts +2 -0
  14. package/dist/hooks/useClickOutside/index.d.ts.map +1 -0
  15. package/dist/hooks/{useClickOutside.d.ts → useClickOutside/useClickOutside.d.ts} +6 -7
  16. package/dist/hooks/useClickOutside/useClickOutside.d.ts.map +1 -0
  17. package/dist/hooks/useClipboard/index.d.ts +2 -0
  18. package/dist/hooks/useClipboard/index.d.ts.map +1 -0
  19. package/dist/hooks/{useClipboard.d.ts → useClipboard/useClipboard.d.ts} +3 -4
  20. package/dist/hooks/useClipboard/useClipboard.d.ts.map +1 -0
  21. package/dist/hooks/useControllableState/index.d.ts +2 -0
  22. package/dist/hooks/useControllableState/index.d.ts.map +1 -0
  23. package/dist/hooks/{useControllableState.d.ts → useControllableState/useControllableState.d.ts} +3 -4
  24. package/dist/hooks/useControllableState/useControllableState.d.ts.map +1 -0
  25. package/dist/hooks/useDebouncedValue/index.d.ts +2 -0
  26. package/dist/hooks/useDebouncedValue/index.d.ts.map +1 -0
  27. package/dist/hooks/{useDebouncedValue.d.ts → useDebouncedValue/useDebouncedValue.d.ts} +2 -3
  28. package/dist/hooks/useDebouncedValue/useDebouncedValue.d.ts.map +1 -0
  29. package/dist/hooks/useDisclosure/index.d.ts +2 -0
  30. package/dist/hooks/useDisclosure/index.d.ts.map +1 -0
  31. package/dist/hooks/{useDisclosure.d.ts → useDisclosure/useDisclosure.d.ts} +4 -5
  32. package/dist/hooks/useDisclosure/useDisclosure.d.ts.map +1 -0
  33. package/dist/hooks/useDocumentTitle/index.d.ts +2 -0
  34. package/dist/hooks/useDocumentTitle/index.d.ts.map +1 -0
  35. package/dist/hooks/{useDocumentTitle.d.ts → useDocumentTitle/useDocumentTitle.d.ts} +3 -4
  36. package/dist/hooks/useDocumentTitle/useDocumentTitle.d.ts.map +1 -0
  37. package/dist/hooks/useFocusManagement/index.d.ts +2 -0
  38. package/dist/hooks/useFocusManagement/index.d.ts.map +1 -0
  39. package/dist/hooks/{useFocusManagement.d.ts → useFocusManagement/useFocusManagement.d.ts} +3 -5
  40. package/dist/hooks/useFocusManagement/useFocusManagement.d.ts.map +1 -0
  41. package/dist/hooks/useHover/index.d.ts +2 -0
  42. package/dist/hooks/useHover/index.d.ts.map +1 -0
  43. package/dist/hooks/{useHover.d.ts → useHover/useHover.d.ts} +3 -5
  44. package/dist/hooks/useHover/useHover.d.ts.map +1 -0
  45. package/dist/hooks/useInView/index.d.ts +2 -0
  46. package/dist/hooks/useInView/index.d.ts.map +1 -0
  47. package/dist/hooks/{useInView.d.ts → useInView/useInView.d.ts} +4 -6
  48. package/dist/hooks/useInView/useInView.d.ts.map +1 -0
  49. package/dist/hooks/useIntersectionObserver/index.d.ts +2 -0
  50. package/dist/hooks/useIntersectionObserver/index.d.ts.map +1 -0
  51. package/dist/hooks/{useIntersectionObserver.d.ts → useIntersectionObserver/useIntersectionObserver.d.ts} +4 -6
  52. package/dist/hooks/useIntersectionObserver/useIntersectionObserver.d.ts.map +1 -0
  53. package/dist/hooks/useIsMounted/index.d.ts +2 -0
  54. package/dist/hooks/useIsMounted/index.d.ts.map +1 -0
  55. package/dist/hooks/{useIsMounted.d.ts → useIsMounted/useIsMounted.d.ts} +2 -3
  56. package/dist/hooks/useIsMounted/useIsMounted.d.ts.map +1 -0
  57. package/dist/hooks/useIsomorphicLayoutEffect/index.d.ts +2 -0
  58. package/dist/hooks/useIsomorphicLayoutEffect/index.d.ts.map +1 -0
  59. package/dist/hooks/{useIsomorphicLayoutEffect.d.ts → useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.d.ts} +3 -5
  60. package/dist/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.d.ts.map +1 -0
  61. package/dist/hooks/useLocalStorage/index.d.ts +2 -0
  62. package/dist/hooks/useLocalStorage/index.d.ts.map +1 -0
  63. package/dist/hooks/{useLocalStorage.d.ts → useLocalStorage/useLocalStorage.d.ts} +3 -4
  64. package/dist/hooks/useLocalStorage/useLocalStorage.d.ts.map +1 -0
  65. package/dist/hooks/useMediaQuery/index.d.ts +2 -0
  66. package/dist/hooks/useMediaQuery/index.d.ts.map +1 -0
  67. package/dist/hooks/{useMediaQuery.d.ts → useMediaQuery/useMediaQuery.d.ts} +2 -3
  68. package/dist/hooks/useMediaQuery/useMediaQuery.d.ts.map +1 -0
  69. package/dist/hooks/useNetworkStatus/index.d.ts +2 -0
  70. package/dist/hooks/useNetworkStatus/index.d.ts.map +1 -0
  71. package/dist/hooks/{useNetworkStatus.d.ts → useNetworkStatus/useNetworkStatus.d.ts} +2 -3
  72. package/dist/hooks/useNetworkStatus/useNetworkStatus.d.ts.map +1 -0
  73. package/dist/hooks/usePageVisibility/index.d.ts +2 -0
  74. package/dist/hooks/usePageVisibility/index.d.ts.map +1 -0
  75. package/dist/hooks/{usePageVisibility.d.ts → usePageVisibility/usePageVisibility.d.ts} +2 -3
  76. package/dist/hooks/usePageVisibility/usePageVisibility.d.ts.map +1 -0
  77. package/dist/hooks/usePagination/index.d.ts +2 -0
  78. package/dist/hooks/usePagination/index.d.ts.map +1 -0
  79. package/dist/hooks/usePagination/usePagination.d.ts +30 -0
  80. package/dist/hooks/usePagination/usePagination.d.ts.map +1 -0
  81. package/dist/hooks/usePrefersColorScheme/index.d.ts +2 -0
  82. package/dist/hooks/usePrefersColorScheme/index.d.ts.map +1 -0
  83. package/dist/hooks/{usePrefersColorScheme.d.ts → usePrefersColorScheme/usePrefersColorScheme.d.ts} +3 -4
  84. package/dist/hooks/usePrefersColorScheme/usePrefersColorScheme.d.ts.map +1 -0
  85. package/dist/hooks/usePrefersReducedMotion/index.d.ts +2 -0
  86. package/dist/hooks/usePrefersReducedMotion/index.d.ts.map +1 -0
  87. package/dist/hooks/{usePrefersReducedMotion.d.ts → usePrefersReducedMotion/usePrefersReducedMotion.d.ts} +2 -3
  88. package/dist/hooks/usePrefersReducedMotion/usePrefersReducedMotion.d.ts.map +1 -0
  89. package/dist/hooks/useResizeObserver/index.d.ts +2 -0
  90. package/dist/hooks/useResizeObserver/index.d.ts.map +1 -0
  91. package/dist/hooks/{useResizeObserver.d.ts → useResizeObserver/useResizeObserver.d.ts} +5 -7
  92. package/dist/hooks/useResizeObserver/useResizeObserver.d.ts.map +1 -0
  93. package/dist/hooks/useSessionStorage/index.d.ts +2 -0
  94. package/dist/hooks/useSessionStorage/index.d.ts.map +1 -0
  95. package/dist/hooks/{useSessionStorage.d.ts → useSessionStorage/useSessionStorage.d.ts} +3 -4
  96. package/dist/hooks/useSessionStorage/useSessionStorage.d.ts.map +1 -0
  97. package/dist/hooks/useThrottledCallback/index.d.ts +2 -0
  98. package/dist/hooks/useThrottledCallback/index.d.ts.map +1 -0
  99. package/dist/hooks/{useThrottledCallback.d.ts → useThrottledCallback/useThrottledCallback.d.ts} +2 -3
  100. package/dist/hooks/useThrottledCallback/useThrottledCallback.d.ts.map +1 -0
  101. package/dist/hooks/useToggle/index.d.ts +2 -0
  102. package/dist/hooks/useToggle/index.d.ts.map +1 -0
  103. package/dist/hooks/{useToggle.d.ts → useToggle/useToggle.d.ts} +2 -3
  104. package/dist/hooks/useToggle/useToggle.d.ts.map +1 -0
  105. package/dist/hooks/useWindowSize/index.d.ts +2 -0
  106. package/dist/hooks/useWindowSize/index.d.ts.map +1 -0
  107. package/dist/hooks/{useWindowSize.d.ts → useWindowSize/useWindowSize.d.ts} +3 -4
  108. package/dist/hooks/useWindowSize/useWindowSize.d.ts.map +1 -0
  109. package/dist/lib/utils.d.ts +6 -0
  110. package/dist/lib/utils.d.ts.map +1 -0
  111. package/dist/ui/accordion/accordion-base.d.ts +20 -0
  112. package/dist/ui/accordion/accordion-base.d.ts.map +1 -0
  113. package/dist/ui/accordion/accordion.d.ts +8 -0
  114. package/dist/ui/accordion/accordion.d.ts.map +1 -0
  115. package/dist/ui/accordion/animated/accordion-content-animated.d.ts +6 -0
  116. package/dist/ui/accordion/animated/accordion-content-animated.d.ts.map +1 -0
  117. package/dist/ui/accordion/animated/accordion-root-animated.d.ts +6 -0
  118. package/dist/ui/accordion/animated/accordion-root-animated.d.ts.map +1 -0
  119. package/dist/ui/accordion/animated/animations.d.ts +6 -0
  120. package/dist/ui/accordion/animated/animations.d.ts.map +1 -0
  121. package/dist/ui/accordion/animated/index.d.ts +6 -0
  122. package/dist/ui/accordion/animated/index.d.ts.map +1 -0
  123. package/dist/ui/accordion/animated/types.d.ts +6 -0
  124. package/dist/ui/accordion/animated/types.d.ts.map +1 -0
  125. package/dist/ui/accordion/index.d.ts +5 -0
  126. package/dist/ui/accordion/index.d.ts.map +1 -0
  127. package/dist/ui/accordion/types.d.ts +39 -0
  128. package/dist/ui/accordion/types.d.ts.map +1 -0
  129. package/dist/ui/accordion/variants.d.ts +14 -0
  130. package/dist/ui/accordion/variants.d.ts.map +1 -0
  131. package/dist/ui/alert/alert-base.d.ts +28 -0
  132. package/dist/ui/alert/alert-base.d.ts.map +1 -0
  133. package/dist/ui/alert/alert.d.ts +6 -0
  134. package/dist/ui/alert/alert.d.ts.map +1 -0
  135. package/dist/ui/alert/animated/alert-animated.d.ts +3 -0
  136. package/dist/ui/alert/animated/alert-animated.d.ts.map +1 -0
  137. package/dist/ui/alert/animated/animations.d.ts +3 -0
  138. package/dist/ui/alert/animated/animations.d.ts.map +1 -0
  139. package/dist/ui/alert/animated/index.d.ts +4 -0
  140. package/dist/ui/alert/animated/index.d.ts.map +1 -0
  141. package/dist/ui/alert/animated/types.d.ts +8 -0
  142. package/dist/ui/alert/animated/types.d.ts.map +1 -0
  143. package/dist/ui/alert/index.d.ts +5 -0
  144. package/dist/ui/alert/index.d.ts.map +1 -0
  145. package/dist/ui/alert/types.d.ts +21 -0
  146. package/dist/ui/alert/types.d.ts.map +1 -0
  147. package/dist/ui/alert/variants.d.ts +11 -0
  148. package/dist/ui/alert/variants.d.ts.map +1 -0
  149. package/dist/ui/avatar/animated/animations.d.ts +3 -0
  150. package/dist/ui/avatar/animated/animations.d.ts.map +1 -0
  151. package/dist/ui/avatar/animated/avatar-animated.d.ts +6 -0
  152. package/dist/ui/avatar/animated/avatar-animated.d.ts.map +1 -0
  153. package/dist/ui/avatar/animated/index.d.ts +5 -0
  154. package/dist/ui/avatar/animated/index.d.ts.map +1 -0
  155. package/dist/ui/avatar/animated/types.d.ts +8 -0
  156. package/dist/ui/avatar/animated/types.d.ts.map +1 -0
  157. package/dist/ui/avatar/avatar-base.d.ts +25 -0
  158. package/dist/ui/avatar/avatar-base.d.ts.map +1 -0
  159. package/dist/ui/avatar/avatar.d.ts +8 -0
  160. package/dist/ui/avatar/avatar.d.ts.map +1 -0
  161. package/dist/ui/avatar/index.d.ts +5 -0
  162. package/dist/ui/avatar/index.d.ts.map +1 -0
  163. package/dist/ui/avatar/types.d.ts +25 -0
  164. package/dist/ui/avatar/types.d.ts.map +1 -0
  165. package/dist/ui/avatar/variants.d.ts +8 -0
  166. package/dist/ui/avatar/variants.d.ts.map +1 -0
  167. package/dist/ui/badge/animated/animations.d.ts +3 -0
  168. package/dist/ui/badge/animated/animations.d.ts.map +1 -0
  169. package/dist/ui/badge/animated/badge-animated.d.ts +6 -0
  170. package/dist/ui/badge/animated/badge-animated.d.ts.map +1 -0
  171. package/dist/ui/badge/animated/index.d.ts +4 -0
  172. package/dist/ui/badge/animated/index.d.ts.map +1 -0
  173. package/dist/ui/badge/animated/types.d.ts +10 -0
  174. package/dist/ui/badge/animated/types.d.ts.map +1 -0
  175. package/dist/ui/badge/badge-base.d.ts +6 -0
  176. package/dist/ui/badge/badge-base.d.ts.map +1 -0
  177. package/dist/ui/badge/badge.d.ts +6 -0
  178. package/dist/ui/badge/badge.d.ts.map +1 -0
  179. package/dist/ui/badge/index.d.ts +4 -0
  180. package/dist/ui/badge/index.d.ts.map +1 -0
  181. package/dist/ui/badge/types.d.ts +17 -0
  182. package/dist/ui/badge/types.d.ts.map +1 -0
  183. package/dist/ui/badge/variants.d.ts +40 -0
  184. package/dist/ui/badge/variants.d.ts.map +1 -0
  185. package/dist/ui/breadcrumb/breadcrumb.d.ts +33 -0
  186. package/dist/ui/breadcrumb/breadcrumb.d.ts.map +1 -0
  187. package/dist/ui/breadcrumb/index.d.ts +4 -0
  188. package/dist/ui/breadcrumb/index.d.ts.map +1 -0
  189. package/dist/ui/breadcrumb/types.d.ts +26 -0
  190. package/dist/ui/breadcrumb/types.d.ts.map +1 -0
  191. package/dist/ui/breadcrumb/variants.d.ts +11 -0
  192. package/dist/ui/breadcrumb/variants.d.ts.map +1 -0
  193. package/dist/ui/buttons/animated/animations.d.ts +3 -0
  194. package/dist/ui/buttons/animated/animations.d.ts.map +1 -0
  195. package/dist/ui/buttons/animated/button-animated.d.ts +6 -0
  196. package/dist/ui/buttons/animated/button-animated.d.ts.map +1 -0
  197. package/dist/ui/buttons/animated/index.d.ts +4 -0
  198. package/dist/ui/buttons/animated/index.d.ts.map +1 -0
  199. package/dist/ui/buttons/animated/types.d.ts +16 -0
  200. package/dist/ui/buttons/animated/types.d.ts.map +1 -0
  201. package/dist/ui/buttons/button-base.d.ts +6 -0
  202. package/dist/ui/buttons/button-base.d.ts.map +1 -0
  203. package/dist/ui/buttons/button.d.ts +6 -0
  204. package/dist/ui/buttons/button.d.ts.map +1 -0
  205. package/dist/ui/buttons/index.d.ts +4 -0
  206. package/dist/ui/buttons/index.d.ts.map +1 -0
  207. package/dist/ui/buttons/types.d.ts +10 -0
  208. package/dist/ui/buttons/types.d.ts.map +1 -0
  209. package/dist/{variants-Dd9pe-ov.d.mts → ui/buttons/variants.d.ts} +4 -7
  210. package/dist/ui/buttons/variants.d.ts.map +1 -0
  211. package/dist/ui/card/animated/animations.d.ts +7 -0
  212. package/dist/ui/card/animated/animations.d.ts.map +1 -0
  213. package/dist/ui/card/animated/card-animated.d.ts +6 -0
  214. package/dist/ui/card/animated/card-animated.d.ts.map +1 -0
  215. package/dist/ui/card/animated/index.d.ts +5 -0
  216. package/dist/ui/card/animated/index.d.ts.map +1 -0
  217. package/dist/ui/card/animated/types.d.ts +6 -0
  218. package/dist/ui/card/animated/types.d.ts.map +1 -0
  219. package/dist/ui/card/card-base.d.ts +26 -0
  220. package/dist/ui/card/card-base.d.ts.map +1 -0
  221. package/dist/ui/card/card.d.ts +6 -0
  222. package/dist/ui/card/card.d.ts.map +1 -0
  223. package/dist/ui/card/index.d.ts +5 -0
  224. package/dist/ui/card/index.d.ts.map +1 -0
  225. package/dist/ui/card/types.d.ts +29 -0
  226. package/dist/ui/card/types.d.ts.map +1 -0
  227. package/dist/ui/card/variants.d.ts +18 -0
  228. package/dist/ui/card/variants.d.ts.map +1 -0
  229. package/dist/ui/divider/animated/animations.d.ts +6 -0
  230. package/dist/ui/divider/animated/animations.d.ts.map +1 -0
  231. package/dist/ui/divider/animated/divider-animated.d.ts +6 -0
  232. package/dist/ui/divider/animated/divider-animated.d.ts.map +1 -0
  233. package/dist/ui/divider/animated/index.d.ts +3 -0
  234. package/dist/ui/divider/animated/index.d.ts.map +1 -0
  235. package/dist/ui/divider/animated/types.d.ts +8 -0
  236. package/dist/ui/divider/animated/types.d.ts.map +1 -0
  237. package/dist/ui/divider/divider-base.d.ts +6 -0
  238. package/dist/ui/divider/divider-base.d.ts.map +1 -0
  239. package/dist/ui/divider/divider.d.ts +6 -0
  240. package/dist/ui/divider/divider.d.ts.map +1 -0
  241. package/dist/ui/divider/index.d.ts +4 -0
  242. package/dist/ui/divider/index.d.ts.map +1 -0
  243. package/dist/ui/divider/types.d.ts +15 -0
  244. package/dist/ui/divider/types.d.ts.map +1 -0
  245. package/dist/ui/divider/variants.d.ts +14 -0
  246. package/dist/ui/divider/variants.d.ts.map +1 -0
  247. package/dist/ui/drawer/animated/animations.d.ts +3 -0
  248. package/dist/ui/drawer/animated/animations.d.ts.map +1 -0
  249. package/dist/ui/drawer/animated/drawer-content-animated.d.ts +6 -0
  250. package/dist/ui/drawer/animated/drawer-content-animated.d.ts.map +1 -0
  251. package/dist/ui/drawer/animated/index.d.ts +5 -0
  252. package/dist/ui/drawer/animated/index.d.ts.map +1 -0
  253. package/dist/ui/drawer/animated/types.d.ts +9 -0
  254. package/dist/ui/drawer/animated/types.d.ts.map +1 -0
  255. package/dist/ui/drawer/drawer-base.d.ts +35 -0
  256. package/dist/ui/drawer/drawer-base.d.ts.map +1 -0
  257. package/dist/ui/drawer/drawer.d.ts +2 -0
  258. package/dist/ui/drawer/drawer.d.ts.map +1 -0
  259. package/dist/ui/drawer/index.d.ts +4 -0
  260. package/dist/ui/drawer/index.d.ts.map +1 -0
  261. package/dist/ui/drawer/types.d.ts +33 -0
  262. package/dist/ui/drawer/types.d.ts.map +1 -0
  263. package/dist/ui/drawer/variants.d.ts +10 -0
  264. package/dist/ui/drawer/variants.d.ts.map +1 -0
  265. package/dist/ui/dropdown/dropdown.d.ts +6 -0
  266. package/dist/ui/dropdown/dropdown.d.ts.map +1 -0
  267. package/dist/ui/dropdown/index.d.ts +4 -0
  268. package/dist/ui/dropdown/index.d.ts.map +1 -0
  269. package/dist/ui/dropdown/types.d.ts +38 -0
  270. package/dist/ui/dropdown/types.d.ts.map +1 -0
  271. package/dist/ui/dropdown/variants.d.ts +12 -0
  272. package/dist/ui/dropdown/variants.d.ts.map +1 -0
  273. package/dist/ui/empty-state/animated/animations.d.ts +3 -0
  274. package/dist/ui/empty-state/animated/animations.d.ts.map +1 -0
  275. package/dist/ui/empty-state/animated/empty-state-animated.d.ts +6 -0
  276. package/dist/ui/empty-state/animated/empty-state-animated.d.ts.map +1 -0
  277. package/dist/ui/empty-state/animated/index.d.ts +4 -0
  278. package/dist/ui/empty-state/animated/index.d.ts.map +1 -0
  279. package/dist/ui/empty-state/animated/types.d.ts +14 -0
  280. package/dist/ui/empty-state/animated/types.d.ts.map +1 -0
  281. package/dist/ui/empty-state/empty-state-base.d.ts +23 -0
  282. package/dist/ui/empty-state/empty-state-base.d.ts.map +1 -0
  283. package/dist/ui/empty-state/empty-state.d.ts +6 -0
  284. package/dist/ui/empty-state/empty-state.d.ts.map +1 -0
  285. package/dist/ui/empty-state/index.d.ts +5 -0
  286. package/dist/ui/empty-state/index.d.ts.map +1 -0
  287. package/dist/ui/empty-state/types.d.ts +15 -0
  288. package/dist/ui/empty-state/types.d.ts.map +1 -0
  289. package/dist/ui/empty-state/variants.d.ts +12 -0
  290. package/dist/ui/empty-state/variants.d.ts.map +1 -0
  291. package/dist/ui/file-upload/file-upload.d.ts +8 -0
  292. package/dist/ui/file-upload/file-upload.d.ts.map +1 -0
  293. package/dist/ui/file-upload/index.d.ts +4 -0
  294. package/dist/ui/file-upload/index.d.ts.map +1 -0
  295. package/dist/ui/file-upload/types.d.ts +18 -0
  296. package/dist/ui/file-upload/types.d.ts.map +1 -0
  297. package/dist/ui/file-upload/variants.d.ts +4 -0
  298. package/dist/ui/file-upload/variants.d.ts.map +1 -0
  299. package/dist/ui/inputs/animated/animations.d.ts +3 -0
  300. package/dist/ui/inputs/animated/animations.d.ts.map +1 -0
  301. package/dist/ui/inputs/animated/index.d.ts +4 -0
  302. package/dist/ui/inputs/animated/index.d.ts.map +1 -0
  303. package/dist/ui/inputs/animated/input-animated.d.ts +6 -0
  304. package/dist/ui/inputs/animated/input-animated.d.ts.map +1 -0
  305. package/dist/ui/inputs/animated/types.d.ts +16 -0
  306. package/dist/ui/inputs/animated/types.d.ts.map +1 -0
  307. package/dist/ui/inputs/index.d.ts +4 -0
  308. package/dist/ui/inputs/index.d.ts.map +1 -0
  309. package/dist/ui/inputs/input-base.d.ts +6 -0
  310. package/dist/ui/inputs/input-base.d.ts.map +1 -0
  311. package/dist/ui/inputs/input.d.ts +6 -0
  312. package/dist/ui/inputs/input.d.ts.map +1 -0
  313. package/dist/ui/inputs/types.d.ts +12 -0
  314. package/dist/ui/inputs/types.d.ts.map +1 -0
  315. package/dist/ui/inputs/variants.d.ts +7 -0
  316. package/dist/ui/inputs/variants.d.ts.map +1 -0
  317. package/dist/ui/modal/animated/animations.d.ts +3 -0
  318. package/dist/ui/modal/animated/animations.d.ts.map +1 -0
  319. package/dist/ui/modal/animated/index.d.ts +4 -0
  320. package/dist/ui/modal/animated/index.d.ts.map +1 -0
  321. package/dist/ui/modal/animated/modal-content-animated.d.ts +6 -0
  322. package/dist/ui/modal/animated/modal-content-animated.d.ts.map +1 -0
  323. package/dist/ui/modal/animated/types.d.ts +9 -0
  324. package/dist/ui/modal/animated/types.d.ts.map +1 -0
  325. package/dist/ui/modal/index.d.ts +5 -0
  326. package/dist/ui/modal/index.d.ts.map +1 -0
  327. package/dist/ui/modal/modal-base.d.ts +47 -0
  328. package/dist/ui/modal/modal-base.d.ts.map +1 -0
  329. package/dist/ui/modal/modal.d.ts +6 -0
  330. package/dist/ui/modal/modal.d.ts.map +1 -0
  331. package/dist/ui/modal/types.d.ts +26 -0
  332. package/dist/ui/modal/types.d.ts.map +1 -0
  333. package/dist/ui/modal/variants.d.ts +10 -0
  334. package/dist/ui/modal/variants.d.ts.map +1 -0
  335. package/dist/ui/pagination/index.d.ts +5 -0
  336. package/dist/ui/pagination/index.d.ts.map +1 -0
  337. package/dist/ui/pagination/pagination.d.ts +17 -0
  338. package/dist/ui/pagination/pagination.d.ts.map +1 -0
  339. package/dist/ui/pagination/types.d.ts +56 -0
  340. package/dist/ui/pagination/types.d.ts.map +1 -0
  341. package/dist/ui/pagination/variants.d.ts +12 -0
  342. package/dist/ui/pagination/variants.d.ts.map +1 -0
  343. package/dist/ui/progress/animated/animations.d.ts +3 -0
  344. package/dist/ui/progress/animated/animations.d.ts.map +1 -0
  345. package/dist/ui/progress/animated/index.d.ts +4 -0
  346. package/dist/ui/progress/animated/index.d.ts.map +1 -0
  347. package/dist/ui/progress/animated/progress-animated.d.ts +16 -0
  348. package/dist/ui/progress/animated/progress-animated.d.ts.map +1 -0
  349. package/dist/ui/progress/animated/types.d.ts +23 -0
  350. package/dist/ui/progress/animated/types.d.ts.map +1 -0
  351. package/dist/ui/progress/index.d.ts +5 -0
  352. package/dist/ui/progress/index.d.ts.map +1 -0
  353. package/dist/ui/progress/progress-base.d.ts +23 -0
  354. package/dist/ui/progress/progress-base.d.ts.map +1 -0
  355. package/dist/ui/progress/progress.d.ts +6 -0
  356. package/dist/ui/progress/progress.d.ts.map +1 -0
  357. package/dist/ui/progress/types.d.ts +28 -0
  358. package/dist/ui/progress/types.d.ts.map +1 -0
  359. package/dist/ui/progress/variants.d.ts +15 -0
  360. package/dist/ui/progress/variants.d.ts.map +1 -0
  361. package/dist/ui/select/index.d.ts +4 -0
  362. package/dist/ui/select/index.d.ts.map +1 -0
  363. package/dist/ui/select/select.d.ts +10 -0
  364. package/dist/ui/select/select.d.ts.map +1 -0
  365. package/dist/ui/select/types.d.ts +48 -0
  366. package/dist/ui/select/types.d.ts.map +1 -0
  367. package/dist/ui/select/variants.d.ts +14 -0
  368. package/dist/ui/select/variants.d.ts.map +1 -0
  369. package/dist/ui/skeleton/animated/animations.d.ts +3 -0
  370. package/dist/ui/skeleton/animated/animations.d.ts.map +1 -0
  371. package/dist/ui/skeleton/animated/index.d.ts +4 -0
  372. package/dist/ui/skeleton/animated/index.d.ts.map +1 -0
  373. package/dist/ui/skeleton/animated/skeleton-animated.d.ts +22 -0
  374. package/dist/ui/skeleton/animated/skeleton-animated.d.ts.map +1 -0
  375. package/dist/ui/skeleton/animated/types.d.ts +30 -0
  376. package/dist/ui/skeleton/animated/types.d.ts.map +1 -0
  377. package/dist/ui/skeleton/index.d.ts +5 -0
  378. package/dist/ui/skeleton/index.d.ts.map +1 -0
  379. package/dist/ui/skeleton/skeleton-base.d.ts +24 -0
  380. package/dist/ui/skeleton/skeleton-base.d.ts.map +1 -0
  381. package/dist/ui/skeleton/skeleton.d.ts +2 -0
  382. package/dist/ui/skeleton/skeleton.d.ts.map +1 -0
  383. package/dist/ui/skeleton/types.d.ts +23 -0
  384. package/dist/ui/skeleton/types.d.ts.map +1 -0
  385. package/dist/{types-CK_vNRIb.d.mts → ui/skeleton/variants.d.ts} +9 -34
  386. package/dist/ui/skeleton/variants.d.ts.map +1 -0
  387. package/dist/ui/slider/index.d.ts +4 -0
  388. package/dist/ui/slider/index.d.ts.map +1 -0
  389. package/dist/ui/slider/slider.d.ts +51 -0
  390. package/dist/ui/slider/slider.d.ts.map +1 -0
  391. package/dist/ui/slider/types.d.ts +49 -0
  392. package/dist/ui/slider/types.d.ts.map +1 -0
  393. package/dist/ui/slider/variants.d.ts +13 -0
  394. package/dist/ui/slider/variants.d.ts.map +1 -0
  395. package/dist/ui/slider.js +21 -25
  396. package/dist/ui/slider.js.map +1 -1
  397. package/dist/ui/slider.mjs +21 -25
  398. package/dist/ui/slider.mjs.map +1 -1
  399. package/dist/ui/spinner/animated/index.d.ts +4 -0
  400. package/dist/ui/spinner/animated/index.d.ts.map +1 -0
  401. package/dist/ui/spinner/animated/spinner.d.ts +6 -0
  402. package/dist/ui/spinner/animated/spinner.d.ts.map +1 -0
  403. package/dist/ui/spinner/animated/types.d.ts +9 -0
  404. package/dist/ui/spinner/animated/types.d.ts.map +1 -0
  405. package/dist/ui/spinner/animated/variants.d.ts +6 -0
  406. package/dist/ui/spinner/animated/variants.d.ts.map +1 -0
  407. package/dist/ui/stepper/index.d.ts +4 -0
  408. package/dist/ui/stepper/index.d.ts.map +1 -0
  409. package/dist/ui/stepper/stepper.d.ts +33 -0
  410. package/dist/ui/stepper/stepper.d.ts.map +1 -0
  411. package/dist/ui/stepper/types.d.ts +25 -0
  412. package/dist/ui/stepper/types.d.ts.map +1 -0
  413. package/dist/ui/stepper/variants.d.ts +11 -0
  414. package/dist/ui/stepper/variants.d.ts.map +1 -0
  415. package/dist/ui/table/animated/animations.d.ts +3 -0
  416. package/dist/ui/table/animated/animations.d.ts.map +1 -0
  417. package/dist/ui/table/animated/index.d.ts +5 -0
  418. package/dist/ui/table/animated/index.d.ts.map +1 -0
  419. package/dist/ui/table/animated/table-animated.d.ts +5 -0
  420. package/dist/ui/table/animated/table-animated.d.ts.map +1 -0
  421. package/dist/ui/table/animated/types.d.ts +8 -0
  422. package/dist/ui/table/animated/types.d.ts.map +1 -0
  423. package/dist/ui/table/index.d.ts +4 -0
  424. package/dist/ui/table/index.d.ts.map +1 -0
  425. package/dist/ui/table/table-base.d.ts +38 -0
  426. package/dist/ui/table/table-base.d.ts.map +1 -0
  427. package/dist/ui/table/table.d.ts +2 -0
  428. package/dist/ui/table/table.d.ts.map +1 -0
  429. package/dist/ui/table/types.d.ts +33 -0
  430. package/dist/ui/table/types.d.ts.map +1 -0
  431. package/dist/ui/table/variants.d.ts +14 -0
  432. package/dist/ui/table/variants.d.ts.map +1 -0
  433. package/dist/ui/tabs/animated/animations.d.ts +5 -0
  434. package/dist/ui/tabs/animated/animations.d.ts.map +1 -0
  435. package/dist/ui/tabs/animated/index.d.ts +4 -0
  436. package/dist/ui/tabs/animated/index.d.ts.map +1 -0
  437. package/dist/ui/tabs/animated/tabs-content-animated.d.ts +6 -0
  438. package/dist/ui/tabs/animated/tabs-content-animated.d.ts.map +1 -0
  439. package/dist/ui/tabs/animated/types.d.ts +14 -0
  440. package/dist/ui/tabs/animated/types.d.ts.map +1 -0
  441. package/dist/ui/tabs/index.d.ts +4 -0
  442. package/dist/ui/tabs/index.d.ts.map +1 -0
  443. package/dist/ui/tabs/tabs-base.d.ts +8 -0
  444. package/dist/ui/tabs/tabs-base.d.ts.map +1 -0
  445. package/dist/ui/tabs/tabs.d.ts +2 -0
  446. package/dist/ui/tabs/tabs.d.ts.map +1 -0
  447. package/dist/{types-zHcMUtKK.d.mts → ui/tabs/types.d.ts} +8 -10
  448. package/dist/ui/tabs/types.d.ts.map +1 -0
  449. package/dist/ui/tabs/variants.d.ts +11 -0
  450. package/dist/ui/tabs/variants.d.ts.map +1 -0
  451. package/dist/ui/toast/animated/animations.d.ts +3 -0
  452. package/dist/ui/toast/animated/animations.d.ts.map +1 -0
  453. package/dist/ui/toast/animated/index.d.ts +4 -0
  454. package/dist/ui/toast/animated/index.d.ts.map +1 -0
  455. package/dist/ui/toast/animated/toast-animated.d.ts +10 -0
  456. package/dist/ui/toast/animated/toast-animated.d.ts.map +1 -0
  457. package/dist/ui/toast/animated/types.d.ts +5 -0
  458. package/dist/ui/toast/animated/types.d.ts.map +1 -0
  459. package/dist/ui/toast/index.d.ts +4 -0
  460. package/dist/ui/toast/index.d.ts.map +1 -0
  461. package/dist/ui/toast/toast-base.d.ts +35 -0
  462. package/dist/ui/toast/toast-base.d.ts.map +1 -0
  463. package/dist/ui/toast/toast.d.ts +2 -0
  464. package/dist/ui/toast/toast.d.ts.map +1 -0
  465. package/dist/ui/toast/types.d.ts +45 -0
  466. package/dist/ui/toast/types.d.ts.map +1 -0
  467. package/dist/ui/toast/variants.d.ts +8 -0
  468. package/dist/ui/toast/variants.d.ts.map +1 -0
  469. package/dist/ui/toggle/animated/animations.d.ts +3 -0
  470. package/dist/ui/toggle/animated/animations.d.ts.map +1 -0
  471. package/dist/ui/toggle/animated/index.d.ts +4 -0
  472. package/dist/ui/toggle/animated/index.d.ts.map +1 -0
  473. package/dist/ui/toggle/animated/toggle-animated.d.ts +6 -0
  474. package/dist/ui/toggle/animated/toggle-animated.d.ts.map +1 -0
  475. package/dist/ui/toggle/animated/types.d.ts +9 -0
  476. package/dist/ui/toggle/animated/types.d.ts.map +1 -0
  477. package/dist/ui/toggle/index.d.ts +4 -0
  478. package/dist/ui/toggle/index.d.ts.map +1 -0
  479. package/dist/ui/toggle/toggle-base.d.ts +6 -0
  480. package/dist/ui/toggle/toggle-base.d.ts.map +1 -0
  481. package/dist/ui/toggle/toggle.d.ts +6 -0
  482. package/dist/ui/toggle/toggle.d.ts.map +1 -0
  483. package/dist/ui/toggle/types.d.ts +14 -0
  484. package/dist/ui/toggle/types.d.ts.map +1 -0
  485. package/dist/ui/toggle/variants.d.ts +8 -0
  486. package/dist/ui/toggle/variants.d.ts.map +1 -0
  487. package/dist/ui/tooltip/animated/animations.d.ts +3 -0
  488. package/dist/ui/tooltip/animated/animations.d.ts.map +1 -0
  489. package/dist/ui/tooltip/animated/index.d.ts +4 -0
  490. package/dist/ui/tooltip/animated/index.d.ts.map +1 -0
  491. package/dist/ui/tooltip/animated/tooltip-content-animated.d.ts +3 -0
  492. package/dist/ui/tooltip/animated/tooltip-content-animated.d.ts.map +1 -0
  493. package/dist/ui/tooltip/animated/types.d.ts +9 -0
  494. package/dist/ui/tooltip/animated/types.d.ts.map +1 -0
  495. package/dist/ui/tooltip/index.d.ts +4 -0
  496. package/dist/ui/tooltip/index.d.ts.map +1 -0
  497. package/dist/ui/tooltip/tooltip-base.d.ts +7 -0
  498. package/dist/ui/tooltip/tooltip-base.d.ts.map +1 -0
  499. package/dist/ui/tooltip/tooltip.d.ts +2 -0
  500. package/dist/ui/tooltip/tooltip.d.ts.map +1 -0
  501. package/dist/{types-Cn7IcgkH.d.mts → ui/tooltip/types.d.ts} +7 -9
  502. package/dist/ui/tooltip/types.d.ts.map +1 -0
  503. package/dist/ui/tooltip/variants.d.ts +6 -0
  504. package/dist/ui/tooltip/variants.d.ts.map +1 -0
  505. package/dist/vitest-setup.d.ts +2 -0
  506. package/dist/vitest-setup.d.ts.map +1 -0
  507. package/package.json +19 -6
  508. package/src/hooks/index.ts +48 -0
  509. package/src/hooks/useBodyScrollLock/index.ts +1 -0
  510. package/src/hooks/useBodyScrollLock/useBodyScrollLock.test.ts +51 -0
  511. package/src/hooks/useBodyScrollLock/useBodyScrollLock.ts +48 -0
  512. package/src/hooks/useClickOutside/index.ts +5 -0
  513. package/src/hooks/useClickOutside/useClickOutside.test.tsx +60 -0
  514. package/src/hooks/useClickOutside/useClickOutside.ts +52 -0
  515. package/src/hooks/useClipboard/index.ts +1 -0
  516. package/src/hooks/useClipboard/useClipboard.test.ts +101 -0
  517. package/src/hooks/useClipboard/useClipboard.ts +69 -0
  518. package/src/hooks/useControllableState/index.ts +4 -0
  519. package/src/hooks/useControllableState/useControllableState.test.ts +59 -0
  520. package/src/hooks/useControllableState/useControllableState.ts +49 -0
  521. package/src/hooks/useDebouncedValue/index.ts +1 -0
  522. package/src/hooks/useDebouncedValue/useDebouncedValue.test.ts +74 -0
  523. package/{dist/hooks/useDebouncedValue.d.mts → src/hooks/useDebouncedValue/useDebouncedValue.ts} +17 -2
  524. package/src/hooks/useDisclosure/index.ts +5 -0
  525. package/src/hooks/useDisclosure/useDisclosure.test.ts +64 -0
  526. package/src/hooks/useDisclosure/useDisclosure.ts +62 -0
  527. package/src/hooks/useDocumentTitle/index.ts +4 -0
  528. package/src/hooks/useDocumentTitle/useDocumentTitle.test.ts +40 -0
  529. package/src/hooks/useDocumentTitle/useDocumentTitle.ts +58 -0
  530. package/src/hooks/useFocusManagement/index.ts +1 -0
  531. package/src/hooks/useFocusManagement/useFocusManagement.test.tsx +45 -0
  532. package/src/hooks/useFocusManagement/useFocusManagement.ts +77 -0
  533. package/src/hooks/useHover/index.ts +1 -0
  534. package/src/hooks/useHover/useHover.test.ts +45 -0
  535. package/src/hooks/useHover/useHover.ts +45 -0
  536. package/src/hooks/useInView/index.ts +1 -0
  537. package/src/hooks/useInView/useInView.test.ts +43 -0
  538. package/src/hooks/useInView/useInView.ts +28 -0
  539. package/src/hooks/useIntersectionObserver/index.ts +4 -0
  540. package/src/hooks/useIntersectionObserver/useIntersectionObserver.test.ts +75 -0
  541. package/src/hooks/useIntersectionObserver/useIntersectionObserver.ts +54 -0
  542. package/src/hooks/useIsMounted/index.ts +1 -0
  543. package/src/hooks/useIsMounted/useIsMounted.test.ts +25 -0
  544. package/{dist/hooks/useIsMounted.d.mts → src/hooks/useIsMounted/useIsMounted.ts} +14 -3
  545. package/src/hooks/useIsomorphicLayoutEffect/index.ts +1 -0
  546. package/src/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.test.ts +19 -0
  547. package/{dist/hooks/useIsomorphicLayoutEffect.d.mts → src/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.ts} +5 -4
  548. package/src/hooks/useLocalStorage/index.ts +4 -0
  549. package/src/hooks/useLocalStorage/useLocalStorage.test.ts +99 -0
  550. package/src/hooks/useLocalStorage/useLocalStorage.ts +109 -0
  551. package/src/hooks/useMediaQuery/index.ts +1 -0
  552. package/src/hooks/useMediaQuery/useMediaQuery.test.ts +63 -0
  553. package/src/hooks/useMediaQuery/useMediaQuery.ts +37 -0
  554. package/src/hooks/useNetworkStatus/index.ts +1 -0
  555. package/src/hooks/useNetworkStatus/useNetworkStatus.test.ts +53 -0
  556. package/src/hooks/useNetworkStatus/useNetworkStatus.ts +33 -0
  557. package/src/hooks/usePageVisibility/index.ts +1 -0
  558. package/src/hooks/usePageVisibility/usePageVisibility.test.ts +21 -0
  559. package/src/hooks/usePageVisibility/usePageVisibility.ts +31 -0
  560. package/src/hooks/usePagination/index.ts +6 -0
  561. package/src/hooks/usePagination/usePagination.test.ts +139 -0
  562. package/src/hooks/usePagination/usePagination.ts +153 -0
  563. package/src/hooks/usePrefersColorScheme/index.ts +4 -0
  564. package/src/hooks/usePrefersColorScheme/usePrefersColorScheme.test.ts +53 -0
  565. package/src/hooks/usePrefersColorScheme/usePrefersColorScheme.ts +21 -0
  566. package/src/hooks/usePrefersReducedMotion/index.ts +1 -0
  567. package/src/hooks/usePrefersReducedMotion/usePrefersReducedMotion.test.ts +27 -0
  568. package/{dist/hooks/usePrefersReducedMotion.d.mts → src/hooks/usePrefersReducedMotion/usePrefersReducedMotion.ts} +7 -3
  569. package/src/hooks/useResizeObserver/index.ts +4 -0
  570. package/src/hooks/useResizeObserver/useResizeObserver.test.ts +68 -0
  571. package/src/hooks/useResizeObserver/useResizeObserver.ts +58 -0
  572. package/src/hooks/useSessionStorage/index.ts +4 -0
  573. package/src/hooks/useSessionStorage/useSessionStorage.test.ts +54 -0
  574. package/src/hooks/useSessionStorage/useSessionStorage.ts +84 -0
  575. package/src/hooks/useThrottledCallback/index.ts +1 -0
  576. package/src/hooks/useThrottledCallback/useThrottledCallback.test.ts +75 -0
  577. package/{dist/hooks/useThrottledCallback.d.mts → src/hooks/useThrottledCallback/useThrottledCallback.ts} +24 -2
  578. package/src/hooks/useToggle/index.ts +1 -0
  579. package/src/hooks/useToggle/useToggle.test.ts +40 -0
  580. package/src/hooks/useToggle/useToggle.ts +22 -0
  581. package/src/hooks/useWindowSize/index.ts +1 -0
  582. package/src/hooks/useWindowSize/useWindowSize.test.ts +23 -0
  583. package/src/hooks/useWindowSize/useWindowSize.ts +39 -0
  584. package/src/lib/utils.ts +25 -0
  585. package/src/ui/accordion/accordion-base.tsx +223 -0
  586. package/src/ui/accordion/accordion.test.tsx +146 -0
  587. package/src/ui/accordion/accordion.tsx +11 -0
  588. package/src/ui/accordion/animated/accordion-content-animated.tsx +46 -0
  589. package/src/ui/accordion/animated/accordion-root-animated.tsx +10 -0
  590. package/src/ui/accordion/animated/animations.ts +16 -0
  591. package/src/ui/accordion/animated/index.ts +7 -0
  592. package/src/ui/accordion/animated/types.ts +7 -0
  593. package/src/ui/accordion/index.ts +23 -0
  594. package/src/ui/accordion/types.ts +48 -0
  595. package/src/ui/accordion/variants.ts +115 -0
  596. package/src/ui/alert/alert-base.tsx +157 -0
  597. package/src/ui/alert/alert.test.tsx +150 -0
  598. package/src/ui/alert/alert.tsx +9 -0
  599. package/src/ui/alert/animated/alert-animated.tsx +20 -0
  600. package/src/ui/alert/animated/animations.ts +20 -0
  601. package/src/ui/alert/animated/index.ts +3 -0
  602. package/src/ui/alert/animated/types.ts +16 -0
  603. package/src/ui/alert/index.ts +22 -0
  604. package/src/ui/alert/types.ts +28 -0
  605. package/src/ui/alert/variants.ts +74 -0
  606. package/src/ui/avatar/animated/animations.ts +11 -0
  607. package/src/ui/avatar/animated/avatar-animated.tsx +25 -0
  608. package/src/ui/avatar/animated/index.ts +6 -0
  609. package/src/ui/avatar/animated/types.ts +16 -0
  610. package/src/ui/avatar/avatar-base.tsx +184 -0
  611. package/src/ui/avatar/avatar.test.tsx +51 -0
  612. package/src/ui/avatar/avatar.tsx +11 -0
  613. package/src/ui/avatar/index.ts +16 -0
  614. package/src/ui/avatar/types.ts +36 -0
  615. package/src/ui/avatar/variants.ts +52 -0
  616. package/src/ui/badge/animated/animations.ts +20 -0
  617. package/src/ui/badge/animated/badge-animated.tsx +28 -0
  618. package/src/ui/badge/animated/index.ts +5 -0
  619. package/src/ui/badge/animated/types.ts +18 -0
  620. package/src/ui/badge/badge-base.tsx +53 -0
  621. package/src/ui/badge/badge.test.tsx +48 -0
  622. package/src/ui/badge/badge.tsx +9 -0
  623. package/src/ui/badge/index.ts +5 -0
  624. package/src/ui/badge/types.ts +25 -0
  625. package/src/ui/badge/variants.ts +85 -0
  626. package/src/ui/breadcrumb/breadcrumb.test.tsx +62 -0
  627. package/src/ui/breadcrumb/breadcrumb.tsx +135 -0
  628. package/src/ui/breadcrumb/index.ts +28 -0
  629. package/src/ui/breadcrumb/types.ts +29 -0
  630. package/src/ui/breadcrumb/variants.ts +53 -0
  631. package/src/ui/buttons/animated/animations.ts +34 -0
  632. package/src/ui/buttons/animated/button-animated.tsx +70 -0
  633. package/src/ui/buttons/animated/index.ts +5 -0
  634. package/src/ui/buttons/animated/types.ts +29 -0
  635. package/src/ui/buttons/button-base.tsx +59 -0
  636. package/src/ui/buttons/button.test.tsx +480 -0
  637. package/src/ui/buttons/button.tsx +9 -0
  638. package/src/ui/buttons/index.ts +5 -0
  639. package/src/ui/buttons/types.ts +14 -0
  640. package/src/ui/buttons/variants.ts +77 -0
  641. package/src/ui/card/animated/animations.ts +32 -0
  642. package/src/ui/card/animated/card-animated.tsx +28 -0
  643. package/src/ui/card/animated/index.ts +12 -0
  644. package/src/ui/card/animated/types.ts +8 -0
  645. package/src/ui/card/card-base.tsx +146 -0
  646. package/src/ui/card/card.test.tsx +79 -0
  647. package/src/ui/card/card.tsx +11 -0
  648. package/src/ui/card/index.ts +21 -0
  649. package/src/ui/card/types.ts +42 -0
  650. package/src/ui/card/variants.ts +122 -0
  651. package/src/ui/divider/animated/animations.ts +27 -0
  652. package/src/ui/divider/animated/divider-animated.tsx +24 -0
  653. package/src/ui/divider/animated/index.ts +4 -0
  654. package/src/ui/divider/animated/types.ts +18 -0
  655. package/src/ui/divider/divider-base.tsx +80 -0
  656. package/src/ui/divider/divider.tsx +9 -0
  657. package/src/ui/divider/index.ts +14 -0
  658. package/src/ui/divider/types.ts +18 -0
  659. package/src/ui/divider/variants.ts +98 -0
  660. package/src/ui/drawer/animated/animations.ts +39 -0
  661. package/src/ui/drawer/animated/drawer-content-animated.tsx +101 -0
  662. package/src/ui/drawer/animated/index.ts +14 -0
  663. package/src/ui/drawer/animated/types.ts +18 -0
  664. package/src/ui/drawer/drawer-base.tsx +259 -0
  665. package/src/ui/drawer/drawer.test.tsx +132 -0
  666. package/src/ui/drawer/drawer.tsx +11 -0
  667. package/src/ui/drawer/index.ts +21 -0
  668. package/src/ui/drawer/types.ts +39 -0
  669. package/src/ui/drawer/variants.ts +122 -0
  670. package/src/ui/dropdown/dropdown.test.tsx +114 -0
  671. package/src/ui/dropdown/dropdown.tsx +179 -0
  672. package/src/ui/dropdown/index.ts +15 -0
  673. package/src/ui/dropdown/types.ts +68 -0
  674. package/src/ui/dropdown/variants.ts +138 -0
  675. package/src/ui/empty-state/animated/animations.ts +19 -0
  676. package/src/ui/empty-state/animated/empty-state-animated.tsx +23 -0
  677. package/src/ui/empty-state/animated/index.ts +7 -0
  678. package/src/ui/empty-state/animated/types.ts +26 -0
  679. package/src/ui/empty-state/empty-state-base.tsx +114 -0
  680. package/src/ui/empty-state/empty-state.tsx +9 -0
  681. package/src/ui/empty-state/index.ts +10 -0
  682. package/src/ui/empty-state/types.ts +19 -0
  683. package/src/ui/empty-state/variants.ts +51 -0
  684. package/src/ui/file-upload/file-upload.test.tsx +36 -0
  685. package/src/ui/file-upload/file-upload.tsx +119 -0
  686. package/src/ui/file-upload/index.ts +5 -0
  687. package/src/ui/file-upload/types.ts +21 -0
  688. package/src/ui/file-upload/variants.ts +29 -0
  689. package/src/ui/inputs/animated/animations.ts +36 -0
  690. package/src/ui/inputs/animated/index.ts +5 -0
  691. package/src/ui/inputs/animated/input-animated.tsx +124 -0
  692. package/src/ui/inputs/animated/types.ts +40 -0
  693. package/src/ui/inputs/index.ts +5 -0
  694. package/src/ui/inputs/input-base.tsx +114 -0
  695. package/src/ui/inputs/input.test.tsx +414 -0
  696. package/src/ui/inputs/input.tsx +8 -0
  697. package/src/ui/inputs/types.ts +18 -0
  698. package/src/ui/inputs/variants.ts +316 -0
  699. package/src/ui/modal/animated/animations.ts +29 -0
  700. package/src/ui/modal/animated/index.ts +5 -0
  701. package/src/ui/modal/animated/modal-content-animated.tsx +96 -0
  702. package/src/ui/modal/animated/types.ts +23 -0
  703. package/src/ui/modal/index.ts +21 -0
  704. package/src/ui/modal/modal-base.tsx +279 -0
  705. package/src/ui/modal/modal.test.tsx +129 -0
  706. package/src/ui/modal/modal.tsx +8 -0
  707. package/src/ui/modal/types.ts +31 -0
  708. package/src/ui/modal/variants.ts +109 -0
  709. package/src/ui/pagination/index.ts +13 -0
  710. package/src/ui/pagination/pagination.test.tsx +165 -0
  711. package/src/ui/pagination/pagination.tsx +237 -0
  712. package/src/ui/pagination/types.ts +66 -0
  713. package/src/ui/pagination/variants.ts +97 -0
  714. package/src/ui/progress/animated/animations.ts +9 -0
  715. package/src/ui/progress/animated/index.ts +17 -0
  716. package/src/ui/progress/animated/progress-animated.tsx +133 -0
  717. package/src/ui/progress/animated/types.ts +35 -0
  718. package/src/ui/progress/index.ts +10 -0
  719. package/src/ui/progress/progress-base.tsx +151 -0
  720. package/src/ui/progress/progress.test.tsx +84 -0
  721. package/src/ui/progress/progress.tsx +12 -0
  722. package/src/ui/progress/types.ts +33 -0
  723. package/src/ui/progress/variants.ts +105 -0
  724. package/src/ui/select/index.ts +25 -0
  725. package/src/ui/select/select.test.tsx +128 -0
  726. package/src/ui/select/select.tsx +221 -0
  727. package/src/ui/select/types.ts +77 -0
  728. package/src/ui/select/variants.ts +163 -0
  729. package/src/ui/skeleton/animated/animations.ts +15 -0
  730. package/src/ui/skeleton/animated/index.ts +20 -0
  731. package/src/ui/skeleton/animated/skeleton-animated.tsx +119 -0
  732. package/src/ui/skeleton/animated/types.ts +49 -0
  733. package/src/ui/skeleton/index.ts +24 -0
  734. package/src/ui/skeleton/skeleton-base.tsx +288 -0
  735. package/src/ui/skeleton/skeleton.tsx +8 -0
  736. package/src/ui/skeleton/types.ts +31 -0
  737. package/src/ui/skeleton/variants.ts +254 -0
  738. package/src/ui/slider/index.ts +22 -0
  739. package/src/ui/slider/slider.test.tsx +94 -0
  740. package/src/ui/slider/slider.tsx +728 -0
  741. package/src/ui/slider/types.ts +66 -0
  742. package/src/ui/slider/variants.ts +81 -0
  743. package/src/ui/spinner/animated/index.ts +5 -0
  744. package/src/ui/spinner/animated/spinner.test.tsx +41 -0
  745. package/src/ui/spinner/animated/spinner.tsx +143 -0
  746. package/src/ui/spinner/animated/types.ts +11 -0
  747. package/src/ui/spinner/animated/variants.ts +50 -0
  748. package/src/ui/stepper/index.ts +22 -0
  749. package/src/ui/stepper/stepper.test.tsx +183 -0
  750. package/src/ui/stepper/stepper.tsx +172 -0
  751. package/src/ui/stepper/types.ts +32 -0
  752. package/src/ui/stepper/variants.ts +69 -0
  753. package/src/ui/table/animated/animations.ts +9 -0
  754. package/src/ui/table/animated/index.ts +15 -0
  755. package/src/ui/table/animated/table-animated.tsx +15 -0
  756. package/src/ui/table/animated/types.ts +16 -0
  757. package/src/ui/table/index.ts +22 -0
  758. package/src/ui/table/table-base.tsx +197 -0
  759. package/src/ui/table/table.tsx +13 -0
  760. package/src/ui/table/types.ts +47 -0
  761. package/src/ui/table/variants.ts +105 -0
  762. package/src/ui/tabs/animated/animations.ts +48 -0
  763. package/src/ui/tabs/animated/index.ts +8 -0
  764. package/src/ui/tabs/animated/tabs-content-animated.tsx +46 -0
  765. package/src/ui/tabs/animated/types.ts +24 -0
  766. package/src/ui/tabs/index.ts +10 -0
  767. package/src/ui/tabs/tabs-base.tsx +185 -0
  768. package/src/ui/tabs/tabs.test.tsx +53 -0
  769. package/src/ui/tabs/tabs.tsx +2 -0
  770. package/src/ui/tabs/types.ts +88 -0
  771. package/src/ui/tabs/variants.ts +70 -0
  772. package/src/ui/toast/animated/animations.ts +17 -0
  773. package/src/ui/toast/animated/index.ts +9 -0
  774. package/src/ui/toast/animated/toast-animated.tsx +96 -0
  775. package/src/ui/toast/animated/types.ts +13 -0
  776. package/src/ui/toast/index.ts +26 -0
  777. package/src/ui/toast/toast-base.tsx +231 -0
  778. package/src/ui/toast/toast.test.tsx +102 -0
  779. package/src/ui/toast/toast.tsx +13 -0
  780. package/src/ui/toast/types.ts +57 -0
  781. package/src/ui/toast/variants.ts +73 -0
  782. package/src/ui/toggle/animated/animations.ts +9 -0
  783. package/src/ui/toggle/animated/index.ts +7 -0
  784. package/src/ui/toggle/animated/toggle-animated.tsx +76 -0
  785. package/src/ui/toggle/animated/types.ts +13 -0
  786. package/src/ui/toggle/index.ts +5 -0
  787. package/src/ui/toggle/toggle-base.tsx +70 -0
  788. package/src/ui/toggle/toggle.test.tsx +44 -0
  789. package/src/ui/toggle/toggle.tsx +9 -0
  790. package/src/ui/toggle/types.ts +18 -0
  791. package/src/ui/toggle/variants.ts +84 -0
  792. package/src/ui/tooltip/animated/animations.ts +16 -0
  793. package/src/ui/tooltip/animated/index.ts +10 -0
  794. package/src/ui/tooltip/animated/tooltip-content-animated.tsx +47 -0
  795. package/src/ui/tooltip/animated/types.ts +19 -0
  796. package/src/ui/tooltip/index.ts +17 -0
  797. package/src/ui/tooltip/tooltip-base.tsx +152 -0
  798. package/src/ui/tooltip/tooltip.test.tsx +84 -0
  799. package/src/ui/tooltip/tooltip.tsx +8 -0
  800. package/src/ui/tooltip/types.ts +57 -0
  801. package/src/ui/tooltip/variants.ts +61 -0
  802. package/dist/accordion-base-qVomr7f_.d.mts +0 -66
  803. package/dist/accordion-base-qVomr7f_.d.ts +0 -66
  804. package/dist/avatar-base-s4dYg-24.d.mts +0 -49
  805. package/dist/avatar-base-s4dYg-24.d.ts +0 -49
  806. package/dist/card-base-CIGac8D_.d.mts +0 -70
  807. package/dist/card-base-CIGac8D_.d.ts +0 -70
  808. package/dist/hooks/useBodyScrollLock.d.mts +0 -14
  809. package/dist/hooks/useClickOutside.d.mts +0 -23
  810. package/dist/hooks/useClipboard.d.mts +0 -22
  811. package/dist/hooks/useControllableState.d.mts +0 -22
  812. package/dist/hooks/useDisclosure.d.mts +0 -25
  813. package/dist/hooks/useDocumentTitle.d.mts +0 -19
  814. package/dist/hooks/useFocusManagement.d.mts +0 -24
  815. package/dist/hooks/useHover.d.mts +0 -15
  816. package/dist/hooks/useInView.d.mts +0 -19
  817. package/dist/hooks/useIntersectionObserver.d.mts +0 -19
  818. package/dist/hooks/useLocalStorage.d.mts +0 -22
  819. package/dist/hooks/useMediaQuery.d.mts +0 -13
  820. package/dist/hooks/useNetworkStatus.d.mts +0 -10
  821. package/dist/hooks/usePageVisibility.d.mts +0 -10
  822. package/dist/hooks/usePagination.d.mts +0 -5
  823. package/dist/hooks/usePagination.d.ts +0 -5
  824. package/dist/hooks/usePrefersColorScheme.d.mts +0 -10
  825. package/dist/hooks/useResizeObserver.d.mts +0 -23
  826. package/dist/hooks/useSessionStorage.d.mts +0 -22
  827. package/dist/hooks/useToggle.d.mts +0 -9
  828. package/dist/hooks/useWindowSize.d.mts +0 -14
  829. package/dist/hooks/utils.d.mts +0 -8
  830. package/dist/hooks/utils.d.ts +0 -8
  831. package/dist/index-ClPu5gDp.d.ts +0 -86
  832. package/dist/index-D4p9fn1o.d.mts +0 -86
  833. package/dist/progress-base-Cm1JODYA.d.mts +0 -66
  834. package/dist/progress-base-Cm1JODYA.d.ts +0 -66
  835. package/dist/types-C7N9UvRm.d.mts +0 -38
  836. package/dist/types-C7N9UvRm.d.ts +0 -38
  837. package/dist/types-CFpwSbpK.d.mts +0 -27
  838. package/dist/types-CFpwSbpK.d.ts +0 -27
  839. package/dist/types-CK_vNRIb.d.ts +0 -63
  840. package/dist/types-Ca3t5aC_.d.mts +0 -31
  841. package/dist/types-Ca3t5aC_.d.ts +0 -31
  842. package/dist/types-Cn7IcgkH.d.ts +0 -32
  843. package/dist/types-CtFK7mFE.d.mts +0 -34
  844. package/dist/types-CtFK7mFE.d.ts +0 -34
  845. package/dist/types-DMkTQsWg.d.mts +0 -46
  846. package/dist/types-DMkTQsWg.d.ts +0 -46
  847. package/dist/types-DN400jNg.d.mts +0 -28
  848. package/dist/types-DN400jNg.d.ts +0 -28
  849. package/dist/types-vcZcRc6w.d.mts +0 -24
  850. package/dist/types-vcZcRc6w.d.ts +0 -24
  851. package/dist/types-zHcMUtKK.d.ts +0 -42
  852. package/dist/ui/accordion/animated.d.mts +0 -24
  853. package/dist/ui/accordion/animated.d.ts +0 -24
  854. package/dist/ui/accordion.d.mts +0 -14
  855. package/dist/ui/accordion.d.ts +0 -14
  856. package/dist/ui/alert/animated.d.mts +0 -18
  857. package/dist/ui/alert/animated.d.ts +0 -18
  858. package/dist/ui/alert.d.mts +0 -36
  859. package/dist/ui/alert.d.ts +0 -36
  860. package/dist/ui/avatar/animated.d.mts +0 -22
  861. package/dist/ui/avatar/animated.d.ts +0 -22
  862. package/dist/ui/avatar.d.mts +0 -13
  863. package/dist/ui/avatar.d.ts +0 -13
  864. package/dist/ui/badge/animated.d.mts +0 -22
  865. package/dist/ui/badge/animated.d.ts +0 -22
  866. package/dist/ui/badge.d.mts +0 -13
  867. package/dist/ui/badge.d.ts +0 -13
  868. package/dist/ui/breadcrumb.d.mts +0 -71
  869. package/dist/ui/breadcrumb.d.ts +0 -71
  870. package/dist/ui/buttons/animated.d.mts +0 -27
  871. package/dist/ui/buttons/animated.d.ts +0 -27
  872. package/dist/ui/buttons.d.mts +0 -19
  873. package/dist/ui/buttons.d.ts +0 -19
  874. package/dist/ui/card/animated.d.mts +0 -23
  875. package/dist/ui/card/animated.d.ts +0 -23
  876. package/dist/ui/card.d.mts +0 -13
  877. package/dist/ui/card.d.ts +0 -13
  878. package/dist/ui/divider/animated.d.mts +0 -19
  879. package/dist/ui/divider/animated.d.ts +0 -19
  880. package/dist/ui/divider.d.mts +0 -13
  881. package/dist/ui/divider.d.ts +0 -13
  882. package/dist/ui/drawer/animated.d.mts +0 -23
  883. package/dist/ui/drawer/animated.d.ts +0 -23
  884. package/dist/ui/drawer.d.mts +0 -80
  885. package/dist/ui/drawer.d.ts +0 -80
  886. package/dist/ui/dropdown.d.mts +0 -50
  887. package/dist/ui/dropdown.d.ts +0 -50
  888. package/dist/ui/empty-state/animated.d.mts +0 -24
  889. package/dist/ui/empty-state/animated.d.ts +0 -24
  890. package/dist/ui/empty-state.d.mts +0 -34
  891. package/dist/ui/empty-state.d.ts +0 -34
  892. package/dist/ui/file-upload.d.mts +0 -32
  893. package/dist/ui/file-upload.d.ts +0 -32
  894. package/dist/ui/inputs/animated.d.mts +0 -27
  895. package/dist/ui/inputs/animated.d.ts +0 -27
  896. package/dist/ui/inputs.d.mts +0 -21
  897. package/dist/ui/inputs.d.ts +0 -21
  898. package/dist/ui/modal/animated.d.mts +0 -21
  899. package/dist/ui/modal/animated.d.ts +0 -21
  900. package/dist/ui/modal.d.mts +0 -46
  901. package/dist/ui/modal.d.ts +0 -46
  902. package/dist/ui/pagination.d.mts +0 -36
  903. package/dist/ui/pagination.d.ts +0 -36
  904. package/dist/ui/progress/animated.d.mts +0 -41
  905. package/dist/ui/progress/animated.d.ts +0 -41
  906. package/dist/ui/progress.d.mts +0 -13
  907. package/dist/ui/progress.d.ts +0 -13
  908. package/dist/ui/select.d.mts +0 -73
  909. package/dist/ui/select.d.ts +0 -73
  910. package/dist/ui/skeleton/animated.d.mts +0 -56
  911. package/dist/ui/skeleton/animated.d.ts +0 -56
  912. package/dist/ui/skeleton.d.mts +0 -29
  913. package/dist/ui/skeleton.d.ts +0 -29
  914. package/dist/ui/slider.d.mts +0 -83
  915. package/dist/ui/slider.d.ts +0 -83
  916. package/dist/ui/spinner/animated.d.mts +0 -22
  917. package/dist/ui/spinner/animated.d.ts +0 -22
  918. package/dist/ui/stepper.d.mts +0 -64
  919. package/dist/ui/stepper.d.ts +0 -64
  920. package/dist/ui/table/animated.d.mts +0 -21
  921. package/dist/ui/table/animated.d.ts +0 -21
  922. package/dist/ui/table.d.mts +0 -87
  923. package/dist/ui/table.d.ts +0 -87
  924. package/dist/ui/tabs/animated.d.mts +0 -25
  925. package/dist/ui/tabs/animated.d.ts +0 -25
  926. package/dist/ui/tabs.d.mts +0 -24
  927. package/dist/ui/tabs.d.ts +0 -24
  928. package/dist/ui/toast/animated.d.mts +0 -23
  929. package/dist/ui/toast/animated.d.ts +0 -23
  930. package/dist/ui/toast.d.mts +0 -41
  931. package/dist/ui/toast.d.ts +0 -41
  932. package/dist/ui/toggle/animated.d.mts +0 -22
  933. package/dist/ui/toggle/animated.d.ts +0 -22
  934. package/dist/ui/toggle.d.mts +0 -13
  935. package/dist/ui/toggle.d.ts +0 -13
  936. package/dist/ui/tooltip/animated.d.mts +0 -17
  937. package/dist/ui/tooltip/animated.d.ts +0 -17
  938. package/dist/ui/tooltip.d.mts +0 -19
  939. package/dist/ui/tooltip.d.ts +0 -19
  940. package/dist/variants-CYODHI8b.d.mts +0 -10
  941. package/dist/variants-CYODHI8b.d.ts +0 -10
  942. package/dist/variants-Dd9pe-ov.d.ts +0 -8
@@ -0,0 +1,165 @@
1
+ import { render, screen } from "@testing-library/react";
2
+ import userEvent from "@testing-library/user-event";
3
+ import { describe, expect, it, vi } from "vitest";
4
+
5
+ import { buildPaginationItems } from "../../hooks/usePagination";
6
+ import { clampPage } from "../../lib/utils";
7
+ import { Pagination } from "./pagination";
8
+
9
+ const PAGINATION_SLOT = '[data-slot="pagination"]';
10
+
11
+ function getPaginationRoot(container: HTMLElement = document.body) {
12
+ const elements = container.querySelectorAll(PAGINATION_SLOT);
13
+ expect(
14
+ elements.length,
15
+ `Expected exactly one element matching ${PAGINATION_SLOT}, found ${elements.length}`,
16
+ ).toBe(1);
17
+ return elements[0] as HTMLElement;
18
+ }
19
+
20
+ describe("buildPaginationItems", () => {
21
+ it("should return an empty list when pageCount is zero", () => {
22
+ expect(
23
+ buildPaginationItems({
24
+ pageCount: 0,
25
+ currentPage: 1,
26
+ siblingCount: 1,
27
+ boundaryCount: 1,
28
+ }),
29
+ ).toEqual([]);
30
+ });
31
+
32
+ it("should enumerate all pages when pageCount is within the compact threshold", () => {
33
+ const items = buildPaginationItems({
34
+ pageCount: 5,
35
+ currentPage: 3,
36
+ siblingCount: 1,
37
+ boundaryCount: 1,
38
+ });
39
+ expect(items).toEqual([
40
+ { type: "page", value: 1 },
41
+ { type: "page", value: 2 },
42
+ { type: "page", value: 3 },
43
+ { type: "page", value: 4 },
44
+ { type: "page", value: 5 },
45
+ ]);
46
+ });
47
+
48
+ it("should insert ellipses when the current page sits between boundary windows", () => {
49
+ const items = buildPaginationItems({
50
+ pageCount: 20,
51
+ currentPage: 10,
52
+ siblingCount: 1,
53
+ boundaryCount: 1,
54
+ });
55
+ expect(items).toEqual([
56
+ { type: "page", value: 1 },
57
+ { type: "ellipsis", key: "gap-1-9" },
58
+ { type: "page", value: 9 },
59
+ { type: "page", value: 10 },
60
+ { type: "page", value: 11 },
61
+ { type: "ellipsis", key: "gap-11-20" },
62
+ { type: "page", value: 20 },
63
+ ]);
64
+ });
65
+
66
+ it("should widen the middle window when siblingCount is larger", () => {
67
+ const items = buildPaginationItems({
68
+ pageCount: 30,
69
+ currentPage: 15,
70
+ siblingCount: 2,
71
+ boundaryCount: 1,
72
+ });
73
+ const pageValues = items
74
+ .filter(
75
+ (item): item is { type: "page"; value: number } => item.type === "page",
76
+ )
77
+ .map((item) => item.value);
78
+ expect(pageValues).toContain(1);
79
+ expect(pageValues).toContain(30);
80
+ expect(pageValues).toContain(13);
81
+ expect(pageValues).toContain(14);
82
+ expect(pageValues).toContain(15);
83
+ expect(pageValues).toContain(16);
84
+ expect(pageValues).toContain(17);
85
+ });
86
+ });
87
+
88
+ describe("clampPage", () => {
89
+ it("should clampPage values into the inclusive page range", () => {
90
+ expect(clampPage(0, 5)).toBe(1);
91
+ expect(clampPage(100, 5)).toBe(5);
92
+ expect(clampPage(3, 5)).toBe(3);
93
+ });
94
+
95
+ it("should return 1 when pageCount is zero", () => {
96
+ expect(clampPage(5, 0)).toBe(1);
97
+ });
98
+ });
99
+
100
+ describe("Pagination (component library)", () => {
101
+ it("should expose a stable displayName", () => {
102
+ expect(Pagination.displayName).toBe("Pagination");
103
+ });
104
+
105
+ it("should stamp data-slot on the root nav element", () => {
106
+ render(<Pagination pageCount={3} defaultPage={1} />);
107
+ expect(getPaginationRoot().getAttribute("data-slot")).toBe("pagination");
108
+ });
109
+
110
+ it("should render navigation with an accessible name", () => {
111
+ render(<Pagination pageCount={3} defaultPage={1} />);
112
+ expect(
113
+ screen.getByRole("navigation", { name: "Pagination" }),
114
+ ).toBeVisible();
115
+ });
116
+
117
+ it("should mark the active page with aria-current", () => {
118
+ render(<Pagination pageCount={5} page={3} />);
119
+ expect(screen.getByRole("button", { name: "Page 3" })).toHaveAttribute(
120
+ "aria-current",
121
+ "page",
122
+ );
123
+ });
124
+
125
+ it("should call onPageChange when a different page is activated", async () => {
126
+ const user = userEvent.setup();
127
+ const handleChange = vi.fn();
128
+ render(
129
+ <Pagination pageCount={5} defaultPage={1} onPageChange={handleChange} />,
130
+ );
131
+ await user.click(screen.getByRole("button", { name: "Page 4" }));
132
+ expect(handleChange).toHaveBeenCalledWith(4);
133
+ });
134
+
135
+ it("should disable the previous control on the first page", () => {
136
+ render(<Pagination pageCount={4} page={1} />);
137
+ expect(
138
+ screen.getByRole("button", { name: "Previous page" }),
139
+ ).toBeDisabled();
140
+ });
141
+
142
+ it("should disable the next control on the last page", () => {
143
+ render(<Pagination pageCount={4} page={4} />);
144
+ expect(screen.getByRole("button", { name: "Next page" })).toBeDisabled();
145
+ });
146
+
147
+ it("should apply list variant classes for the selected appearance", () => {
148
+ render(<Pagination pageCount={3} page={1} appearance="emerald" />);
149
+ const list = document.querySelector('[data-slot="pagination-list"]');
150
+ expect(list?.className).toMatch(/border-emerald-500/);
151
+ });
152
+
153
+ it("should render anchors for page controls when getPageHref is provided", () => {
154
+ render(
155
+ <Pagination
156
+ pageCount={3}
157
+ page={2}
158
+ getPageHref={(p) => `/items?page=${p}`}
159
+ />,
160
+ );
161
+ const page2 = screen.getByRole("link", { name: "Page 2" });
162
+ expect(page2.getAttribute("href")).toBe("/items?page=2");
163
+ expect(page2).toHaveAttribute("aria-current", "page");
164
+ });
165
+ });
@@ -0,0 +1,237 @@
1
+ "use client";
2
+
3
+ import { forwardRef, useCallback, useId, type KeyboardEvent } from "react";
4
+
5
+ import { cn, clampPage } from "../../lib/utils";
6
+ import { buttonVariants } from "../buttons/variants";
7
+
8
+ import type { PaginationProps } from "./types";
9
+ import { usePagination } from "../../hooks/usePagination";
10
+ import { paginationEllipsisVariants, paginationListVariants } from "./variants";
11
+
12
+ const defaultPrevLabel = "Previous page";
13
+ const defaultNextLabel = "Next page";
14
+ const defaultEllipsisLabel = "More pages";
15
+
16
+ export const Pagination = forwardRef<HTMLElement, PaginationProps>(
17
+ function Pagination(
18
+ {
19
+ className,
20
+ appearance = "default",
21
+ size = "md",
22
+ pageCount,
23
+ page,
24
+ defaultPage = 1,
25
+ onPageChange,
26
+ siblingCount = 1,
27
+ boundaryCount = 1,
28
+ showPrevNext = true,
29
+ prevLabel = defaultPrevLabel,
30
+ nextLabel = defaultNextLabel,
31
+ ellipsisLabel = defaultEllipsisLabel,
32
+ getPageHref,
33
+ "aria-label": ariaLabel = "Pagination",
34
+ ...rest
35
+ },
36
+ ref,
37
+ ) {
38
+ const id = useId();
39
+ const listId = `${id}-list`;
40
+
41
+ const {
42
+ currentPage,
43
+ items,
44
+ setPage,
45
+ goPrev,
46
+ goNext,
47
+ canGoPrev,
48
+ canGoNext,
49
+ } = usePagination({
50
+ pageCount,
51
+ page,
52
+ defaultPage,
53
+ siblingCount,
54
+ boundaryCount,
55
+ onPageChange,
56
+ });
57
+
58
+ const handleKeyDown = useCallback(
59
+ (event: KeyboardEvent<HTMLElement>) => {
60
+ if (pageCount <= 0) {
61
+ return;
62
+ }
63
+ if (event.key === "ArrowRight" || event.key === "ArrowDown") {
64
+ event.preventDefault();
65
+ if (canGoNext) {
66
+ setPage(currentPage + 1);
67
+ }
68
+ } else if (event.key === "ArrowLeft" || event.key === "ArrowUp") {
69
+ event.preventDefault();
70
+ if (canGoPrev) {
71
+ setPage(currentPage - 1);
72
+ }
73
+ } else if (event.key === "Home") {
74
+ event.preventDefault();
75
+ setPage(1);
76
+ } else if (event.key === "End") {
77
+ event.preventDefault();
78
+ setPage(pageCount);
79
+ }
80
+ },
81
+ [canGoNext, canGoPrev, currentPage, pageCount, setPage],
82
+ );
83
+
84
+ if (pageCount <= 0) {
85
+ return null;
86
+ }
87
+
88
+ const inactiveTriggerClass = cn(
89
+ buttonVariants({ appearance: "ghost", size }),
90
+ "bg-white/[0.04] text-slate-200 hover:bg-white/10",
91
+ );
92
+
93
+ const currentTriggerClass = buttonVariants({ appearance, size });
94
+
95
+ const triggerFocusRing =
96
+ "focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-slate-300 focus-visible:ring-offset-2 focus-visible:ring-offset-slate-950";
97
+
98
+ const renderPageControl = (pageNumber: number) => {
99
+ const isCurrent = pageNumber === currentPage;
100
+ const href = getPageHref?.(pageNumber);
101
+ const shared = cn(
102
+ isCurrent ? currentTriggerClass : inactiveTriggerClass,
103
+ "min-w-[2.25ch] shrink-0",
104
+ triggerFocusRing,
105
+ );
106
+
107
+ if (href) {
108
+ return (
109
+ <a
110
+ data-slot="pagination-trigger"
111
+ href={href}
112
+ aria-label={`Page ${pageNumber}`}
113
+ aria-current={isCurrent ? "page" : undefined}
114
+ className={shared}
115
+ >
116
+ {pageNumber}
117
+ </a>
118
+ );
119
+ }
120
+
121
+ return (
122
+ <button
123
+ type="button"
124
+ data-slot="pagination-trigger"
125
+ aria-label={`Page ${pageNumber}`}
126
+ aria-current={isCurrent ? "page" : undefined}
127
+ className={shared}
128
+ onClick={() => {
129
+ if (!isCurrent) {
130
+ setPage(pageNumber);
131
+ }
132
+ }}
133
+ >
134
+ {pageNumber}
135
+ </button>
136
+ );
137
+ };
138
+
139
+ const prevHref = getPageHref?.(clampPage(currentPage - 1, pageCount));
140
+ const nextHref = getPageHref?.(clampPage(currentPage + 1, pageCount));
141
+
142
+ const navTriggerClass = cn(
143
+ buttonVariants({ appearance: "outline", size }),
144
+ "shrink-0 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-slate-300 focus-visible:ring-offset-2 focus-visible:ring-offset-slate-950",
145
+ );
146
+
147
+ return (
148
+ <nav
149
+ ref={ref}
150
+ data-slot="pagination"
151
+ aria-label={ariaLabel}
152
+ className={cn("w-full", className)}
153
+ onKeyDown={handleKeyDown}
154
+ {...rest}
155
+ >
156
+ <div className="flex flex-wrap items-center gap-2">
157
+ {showPrevNext ? (
158
+ getPageHref && prevHref && canGoPrev ? (
159
+ <a
160
+ data-slot="pagination-prev"
161
+ aria-label={prevLabel}
162
+ href={prevHref}
163
+ className={navTriggerClass}
164
+ >
165
+ Prev
166
+ </a>
167
+ ) : (
168
+ <button
169
+ type="button"
170
+ data-slot="pagination-prev"
171
+ aria-label={prevLabel}
172
+ disabled={!canGoPrev}
173
+ className={navTriggerClass}
174
+ onClick={goPrev}
175
+ >
176
+ Prev
177
+ </button>
178
+ )
179
+ ) : null}
180
+
181
+ <ul
182
+ id={listId}
183
+ data-slot="pagination-list"
184
+ className={paginationListVariants({ appearance, size })}
185
+ >
186
+ {items.map((item) => (
187
+ <li
188
+ key={item.type === "page" ? `page-${item.value}` : item.key}
189
+ data-slot="pagination-item"
190
+ className="inline-flex items-center"
191
+ >
192
+ {item.type === "ellipsis" ? (
193
+ <span
194
+ data-slot="pagination-ellipsis"
195
+ aria-hidden="true"
196
+ title={ellipsisLabel}
197
+ className={paginationEllipsisVariants({ size })}
198
+ >
199
+
200
+ </span>
201
+ ) : (
202
+ renderPageControl(item.value)
203
+ )}
204
+ </li>
205
+ ))}
206
+ </ul>
207
+
208
+ {showPrevNext ? (
209
+ getPageHref && nextHref && canGoNext ? (
210
+ <a
211
+ data-slot="pagination-next"
212
+ aria-label={nextLabel}
213
+ href={nextHref}
214
+ className={navTriggerClass}
215
+ >
216
+ Next
217
+ </a>
218
+ ) : (
219
+ <button
220
+ type="button"
221
+ data-slot="pagination-next"
222
+ aria-label={nextLabel}
223
+ disabled={!canGoNext}
224
+ className={navTriggerClass}
225
+ onClick={goNext}
226
+ >
227
+ Next
228
+ </button>
229
+ )
230
+ ) : null}
231
+ </div>
232
+ </nav>
233
+ );
234
+ },
235
+ );
236
+
237
+ Pagination.displayName = "Pagination";
@@ -0,0 +1,66 @@
1
+ import type { VariantProps } from "class-variance-authority";
2
+ import type { ComponentPropsWithoutRef } from "react";
3
+
4
+ import type { buttonVariants } from "../buttons/variants";
5
+
6
+ export type PaginationAppearance = NonNullable<
7
+ VariantProps<typeof buttonVariants>["appearance"]
8
+ >;
9
+
10
+ export type PaginationSize = NonNullable<
11
+ VariantProps<typeof buttonVariants>["size"]
12
+ >;
13
+
14
+ export type PaginationPageItem =
15
+ | { type: "page"; value: number }
16
+ | { type: "ellipsis"; key: string };
17
+
18
+ export type UsePaginationParams = {
19
+ pageCount: number;
20
+ page?: number;
21
+ defaultPage?: number;
22
+ siblingCount?: number;
23
+ boundaryCount?: number;
24
+ onPageChange?: (page: number) => void;
25
+ };
26
+
27
+ export type UsePaginationResult = {
28
+ /** 1-based active page, clamped to `[1, pageCount]`. */
29
+ currentPage: number;
30
+ pageCount: number;
31
+ items: PaginationPageItem[];
32
+ setPage: (page: number) => void;
33
+ goPrev: () => void;
34
+ goNext: () => void;
35
+ canGoPrev: boolean;
36
+ canGoNext: boolean;
37
+ };
38
+
39
+ export type PaginationProps = Omit<
40
+ ComponentPropsWithoutRef<"nav">,
41
+ "onChange"
42
+ > &
43
+ VariantProps<typeof buttonVariants> & {
44
+ pageCount: number;
45
+ page?: number;
46
+ defaultPage?: number;
47
+ onPageChange?: (page: number) => void;
48
+ /**
49
+ * Number of page buttons to show on each side of the current page (the “middle” window).
50
+ * @defaultValue 1
51
+ */
52
+ siblingCount?: number;
53
+ /**
54
+ * Number of pages to keep visible at the start and end of the range.
55
+ * @defaultValue 1
56
+ */
57
+ boundaryCount?: number;
58
+ showPrevNext?: boolean;
59
+ prevLabel?: string;
60
+ nextLabel?: string;
61
+ ellipsisLabel?: string;
62
+ /**
63
+ * When set, page controls render as anchors suitable for URL-based pagination.
64
+ */
65
+ getPageHref?: (page: number) => string | undefined;
66
+ };
@@ -0,0 +1,97 @@
1
+ import { cva } from "class-variance-authority";
2
+
3
+ /**
4
+ * Layout and chrome for the page list cluster. Appearance and size keys align with
5
+ * `components/ui/buttons/variants.ts` for consistent design-system tokens.
6
+ */
7
+ export const paginationListVariants = cva(
8
+ "inline-flex flex-wrap items-center rounded-xl border p-1 ring-offset-slate-950",
9
+ {
10
+ variants: {
11
+ appearance: {
12
+ default: "border-white/10 bg-white/[0.03]",
13
+ secondary: "border-white/10 bg-slate-900/40",
14
+ destructive: "border-rose-500/25 bg-rose-950/20",
15
+ outline: "border-white/15 bg-transparent",
16
+ ghost: "border-transparent bg-transparent",
17
+ link: "border-transparent bg-transparent",
18
+ glass: "border-white/15 bg-white/5 backdrop-blur-md",
19
+ emerald: "border-emerald-500/25 bg-emerald-950/20",
20
+ indigo: "border-indigo-500/25 bg-indigo-950/20",
21
+ purple: "border-purple-500/25 bg-purple-950/20",
22
+ pink: "border-pink-500/25 bg-pink-950/20",
23
+ rose: "border-rose-500/25 bg-rose-950/20",
24
+ sky: "border-sky-500/25 bg-sky-950/20",
25
+ teal: "border-teal-500/25 bg-teal-950/20",
26
+ yellow: "border-yellow-500/25 bg-yellow-950/20",
27
+ orange: "border-orange-500/25 bg-orange-950/20",
28
+ gray: "border-gray-500/25 bg-gray-950/20",
29
+ amber: "border-amber-500/25 bg-amber-950/20",
30
+ violet: "border-violet-500/25 bg-violet-950/20",
31
+ "gradient-blue":
32
+ "border-blue-500/30 bg-gradient-to-r from-blue-950/30 to-purple-950/30",
33
+ "gradient-green":
34
+ "border-lime-500/30 bg-gradient-to-r from-green-950/30 to-lime-950/30",
35
+ "gradient-red":
36
+ "border-pink-500/30 bg-gradient-to-r from-red-950/30 to-pink-950/30",
37
+ "gradient-yellow":
38
+ "border-orange-500/30 bg-gradient-to-r from-yellow-950/30 to-orange-950/30",
39
+ "gradient-purple":
40
+ "border-pink-500/30 bg-gradient-to-r from-purple-950/30 to-pink-950/30",
41
+ "gradient-teal":
42
+ "border-cyan-500/30 bg-gradient-to-r from-teal-950/30 to-cyan-950/30",
43
+ "gradient-indigo":
44
+ "border-purple-500/30 bg-gradient-to-r from-indigo-950/30 to-purple-950/30",
45
+ "gradient-pink":
46
+ "border-rose-500/30 bg-gradient-to-r from-pink-950/30 to-rose-950/30",
47
+ "gradient-orange":
48
+ "border-orange-500/30 bg-gradient-to-r from-orange-950/30 to-red-950/30",
49
+ },
50
+ size: {
51
+ sm: "gap-0.5",
52
+ md: "gap-1",
53
+ lg: "gap-1",
54
+ xl: "gap-1.5",
55
+ "2xl": "gap-1.5",
56
+ "3xl": "gap-2",
57
+ "4xl": "gap-2",
58
+ "5xl": "gap-2",
59
+ "6xl": "gap-2",
60
+ "7xl": "gap-2.5",
61
+ "8xl": "gap-2.5",
62
+ "9xl": "gap-2.5",
63
+ "10xl": "gap-3",
64
+ icon: "gap-1",
65
+ },
66
+ },
67
+ defaultVariants: {
68
+ appearance: "default",
69
+ size: "md",
70
+ },
71
+ },
72
+ );
73
+
74
+ export const paginationEllipsisVariants = cva(
75
+ "inline-flex min-w-[2ch] select-none items-center justify-center px-1 font-medium text-slate-400",
76
+ {
77
+ variants: {
78
+ size: {
79
+ sm: "text-xs",
80
+ md: "text-sm",
81
+ lg: "text-base",
82
+ xl: "text-base",
83
+ "2xl": "text-lg",
84
+ "3xl": "text-lg",
85
+ "4xl": "text-xl",
86
+ "5xl": "text-xl",
87
+ "6xl": "text-xl",
88
+ "7xl": "text-2xl",
89
+ "8xl": "text-2xl",
90
+ "9xl": "text-2xl",
91
+ "10xl": "text-2xl",
92
+ icon: "text-sm",
93
+ },
94
+ },
95
+ defaultVariants: { size: "md" },
96
+ },
97
+ );
@@ -0,0 +1,9 @@
1
+ import { ProgressAnimationPresets } from "./types";
2
+
3
+ export const progressAnimationPresets: ProgressAnimationPresets = {
4
+ none: {},
5
+ shimmer: {
6
+ animate: { backgroundPosition: ["0% 0%", "100% 0%"] },
7
+ transition: { repeat: Infinity, duration: 1.2, ease: "linear" },
8
+ },
9
+ };
@@ -0,0 +1,17 @@
1
+ "use client";
2
+
3
+ export {
4
+ ProgressAnimated,
5
+ ProgressBarAnimated,
6
+ ProgressLabel,
7
+ ProgressValue,
8
+ } from "./progress-animated";
9
+ export type {
10
+ ProgressAnimatedProps,
11
+ ProgressAnimation,
12
+ ProgressAnimationPresets,
13
+ ProgressPresetMotionProps,
14
+ ProgressVariantProps,
15
+ ProgressBarAnimatedProps,
16
+ } from "./types";
17
+ export { progressAnimationPresets } from "./animations";