@work-rjkashyap/unified-ui 0.3.4 → 0.3.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (456) hide show
  1. package/CHANGELOG.md +105 -0
  2. package/LICENSE +21 -0
  3. package/dist/components/accordion.cjs +225 -0
  4. package/dist/components/accordion.d.cts +157 -0
  5. package/dist/components/accordion.d.ts +157 -0
  6. package/dist/components/accordion.mjs +199 -0
  7. package/dist/components/alert-dialog.cjs +246 -0
  8. package/dist/components/alert-dialog.d.cts +61 -0
  9. package/dist/components/alert-dialog.d.ts +61 -0
  10. package/dist/components/alert-dialog.mjs +218 -0
  11. package/dist/components/alert.cjs +401 -0
  12. package/dist/components/alert.d.cts +217 -0
  13. package/dist/components/alert.d.ts +217 -0
  14. package/dist/components/alert.mjs +374 -0
  15. package/dist/components/aspect-ratio.cjs +45 -0
  16. package/dist/components/aspect-ratio.d.cts +10 -0
  17. package/dist/components/aspect-ratio.d.ts +10 -0
  18. package/dist/components/aspect-ratio.mjs +23 -0
  19. package/dist/components/avatar.cjs +348 -0
  20. package/dist/components/avatar.d.cts +198 -0
  21. package/dist/components/avatar.d.ts +198 -0
  22. package/dist/components/avatar.mjs +329 -0
  23. package/dist/components/badge.cjs +325 -0
  24. package/dist/components/badge.d.cts +259 -0
  25. package/dist/components/badge.d.ts +259 -0
  26. package/dist/components/badge.mjs +298 -0
  27. package/dist/components/banner.cjs +147 -0
  28. package/dist/components/banner.d.cts +31 -0
  29. package/dist/components/banner.d.ts +31 -0
  30. package/dist/components/banner.mjs +122 -0
  31. package/dist/components/breadcrumb.cjs +266 -0
  32. package/dist/components/breadcrumb.d.cts +159 -0
  33. package/dist/components/breadcrumb.d.ts +159 -0
  34. package/dist/components/breadcrumb.mjs +235 -0
  35. package/dist/components/button.cjs +254 -0
  36. package/dist/components/button.d.cts +126 -0
  37. package/dist/components/button.d.ts +126 -0
  38. package/dist/components/button.mjs +229 -0
  39. package/dist/components/calendar.cjs +511 -0
  40. package/dist/components/calendar.d.cts +94 -0
  41. package/dist/components/calendar.d.ts +94 -0
  42. package/dist/components/calendar.mjs +492 -0
  43. package/dist/components/card.cjs +234 -0
  44. package/dist/components/card.d.cts +190 -0
  45. package/dist/components/card.d.ts +190 -0
  46. package/dist/components/card.mjs +210 -0
  47. package/dist/components/carousel.cjs +234 -0
  48. package/dist/components/carousel.d.cts +30 -0
  49. package/dist/components/carousel.d.ts +30 -0
  50. package/dist/components/carousel.mjs +217 -0
  51. package/dist/components/chart.cjs +122 -0
  52. package/dist/components/chart.d.cts +103 -0
  53. package/dist/components/chart.d.ts +103 -0
  54. package/dist/components/chart.mjs +96 -0
  55. package/dist/components/checkbox.cjs +318 -0
  56. package/dist/components/checkbox.d.cts +182 -0
  57. package/dist/components/checkbox.d.ts +182 -0
  58. package/dist/components/checkbox.mjs +296 -0
  59. package/dist/components/code-highlight.cjs +335 -0
  60. package/dist/components/code-highlight.d.cts +18 -0
  61. package/dist/components/code-highlight.d.ts +18 -0
  62. package/dist/components/code-highlight.mjs +308 -0
  63. package/dist/components/code.cjs +265 -0
  64. package/dist/components/code.d.cts +40 -0
  65. package/dist/components/code.d.ts +40 -0
  66. package/dist/components/code.mjs +243 -0
  67. package/dist/components/collapsible.cjs +143 -0
  68. package/dist/components/collapsible.d.cts +159 -0
  69. package/dist/components/collapsible.d.ts +159 -0
  70. package/dist/components/collapsible.mjs +123 -0
  71. package/dist/components/color-picker.cjs +348 -0
  72. package/dist/components/color-picker.d.cts +35 -0
  73. package/dist/components/color-picker.d.ts +35 -0
  74. package/dist/components/color-picker.mjs +331 -0
  75. package/dist/components/combobox.cjs +584 -0
  76. package/dist/components/combobox.d.cts +183 -0
  77. package/dist/components/combobox.d.ts +183 -0
  78. package/dist/components/combobox.mjs +571 -0
  79. package/dist/components/command.cjs +329 -0
  80. package/dist/components/command.d.cts +97 -0
  81. package/dist/components/command.d.ts +97 -0
  82. package/dist/components/command.mjs +311 -0
  83. package/dist/components/confirm-dialog.cjs +100 -0
  84. package/dist/components/confirm-dialog.d.cts +25 -0
  85. package/dist/components/confirm-dialog.d.ts +25 -0
  86. package/dist/components/confirm-dialog.mjs +86 -0
  87. package/dist/components/context-menu.cjs +325 -0
  88. package/dist/components/context-menu.d.cts +259 -0
  89. package/dist/components/context-menu.d.ts +259 -0
  90. package/dist/components/context-menu.mjs +290 -0
  91. package/dist/components/copy-button.cjs +203 -0
  92. package/dist/components/copy-button.d.cts +22 -0
  93. package/dist/components/copy-button.d.ts +22 -0
  94. package/dist/components/copy-button.mjs +178 -0
  95. package/dist/components/data-list.cjs +140 -0
  96. package/dist/components/data-list.d.cts +36 -0
  97. package/dist/components/data-list.d.ts +36 -0
  98. package/dist/components/data-list.mjs +113 -0
  99. package/dist/components/data-table-toolbar.cjs +338 -0
  100. package/dist/components/data-table-toolbar.d.cts +84 -0
  101. package/dist/components/data-table-toolbar.d.ts +84 -0
  102. package/dist/components/data-table-toolbar.mjs +320 -0
  103. package/dist/components/data-table.cjs +1324 -0
  104. package/dist/components/data-table.d.cts +349 -0
  105. package/dist/components/data-table.d.ts +349 -0
  106. package/dist/components/data-table.mjs +1323 -0
  107. package/dist/components/date-picker.cjs +282 -0
  108. package/dist/components/date-picker.d.cts +97 -0
  109. package/dist/components/date-picker.d.ts +97 -0
  110. package/dist/components/date-picker.mjs +258 -0
  111. package/dist/components/dialog.cjs +319 -0
  112. package/dist/components/dialog.d.cts +74 -0
  113. package/dist/components/dialog.d.ts +74 -0
  114. package/dist/components/dialog.mjs +292 -0
  115. package/dist/components/drawer.cjs +262 -0
  116. package/dist/components/drawer.d.cts +113 -0
  117. package/dist/components/drawer.d.ts +113 -0
  118. package/dist/components/drawer.mjs +230 -0
  119. package/dist/components/dropdown-menu.cjs +328 -0
  120. package/dist/components/dropdown-menu.d.cts +95 -0
  121. package/dist/components/dropdown-menu.d.ts +95 -0
  122. package/dist/components/dropdown-menu.mjs +293 -0
  123. package/dist/components/empty-state.cjs +123 -0
  124. package/dist/components/empty-state.d.cts +15 -0
  125. package/dist/components/empty-state.d.ts +15 -0
  126. package/dist/components/empty-state.mjs +99 -0
  127. package/dist/components/file-upload.cjs +442 -0
  128. package/dist/components/file-upload.d.cts +35 -0
  129. package/dist/components/file-upload.d.ts +35 -0
  130. package/dist/components/file-upload.mjs +423 -0
  131. package/dist/components/form-field.cjs +191 -0
  132. package/dist/components/form-field.d.cts +163 -0
  133. package/dist/components/form-field.d.ts +163 -0
  134. package/dist/components/form-field.mjs +167 -0
  135. package/dist/components/hover-card.cjs +99 -0
  136. package/dist/components/hover-card.d.cts +28 -0
  137. package/dist/components/hover-card.d.ts +28 -0
  138. package/dist/components/hover-card.mjs +75 -0
  139. package/dist/components/image-gallery.cjs +359 -0
  140. package/dist/components/image-gallery.d.cts +46 -0
  141. package/dist/components/image-gallery.d.ts +46 -0
  142. package/dist/components/image-gallery.mjs +340 -0
  143. package/dist/components/index.cjs +719 -0
  144. package/dist/components/index.d.cts +84 -0
  145. package/dist/components/index.d.ts +84 -0
  146. package/dist/components/index.mjs +771 -0
  147. package/dist/components/infinite-scroll.cjs +95 -0
  148. package/dist/components/infinite-scroll.d.cts +54 -0
  149. package/dist/components/infinite-scroll.d.ts +54 -0
  150. package/dist/components/infinite-scroll.mjs +71 -0
  151. package/dist/components/input-group.cjs +202 -0
  152. package/dist/components/input-group.d.cts +22 -0
  153. package/dist/components/input-group.d.ts +22 -0
  154. package/dist/components/input-group.mjs +178 -0
  155. package/dist/components/input.cjs +318 -0
  156. package/dist/components/input.d.cts +99 -0
  157. package/dist/components/input.d.ts +99 -0
  158. package/dist/components/input.mjs +296 -0
  159. package/dist/components/kbd.cjs +69 -0
  160. package/dist/components/kbd.d.cts +25 -0
  161. package/dist/components/kbd.d.ts +25 -0
  162. package/dist/components/kbd.mjs +44 -0
  163. package/dist/components/label.cjs +138 -0
  164. package/dist/components/label.d.cts +91 -0
  165. package/dist/components/label.d.ts +91 -0
  166. package/dist/components/label.mjs +113 -0
  167. package/dist/components/markdown.cjs +179 -0
  168. package/dist/components/markdown.d.cts +41 -0
  169. package/dist/components/markdown.d.ts +41 -0
  170. package/dist/components/markdown.mjs +155 -0
  171. package/dist/components/menubar.cjs +365 -0
  172. package/dist/components/menubar.d.cts +88 -0
  173. package/dist/components/menubar.d.ts +88 -0
  174. package/dist/components/menubar.mjs +329 -0
  175. package/dist/components/navigation-menu.cjs +280 -0
  176. package/dist/components/navigation-menu.d.cts +123 -0
  177. package/dist/components/navigation-menu.d.ts +123 -0
  178. package/dist/components/navigation-menu.mjs +250 -0
  179. package/dist/components/number-input.cjs +419 -0
  180. package/dist/components/number-input.d.cts +111 -0
  181. package/dist/components/number-input.d.ts +111 -0
  182. package/dist/components/number-input.mjs +400 -0
  183. package/dist/components/pagination.cjs +322 -0
  184. package/dist/components/pagination.d.cts +119 -0
  185. package/dist/components/pagination.d.ts +119 -0
  186. package/dist/components/pagination.mjs +297 -0
  187. package/dist/components/pin-input.cjs +321 -0
  188. package/dist/components/pin-input.d.cts +112 -0
  189. package/dist/components/pin-input.d.ts +112 -0
  190. package/dist/components/pin-input.mjs +303 -0
  191. package/dist/components/popover.cjs +194 -0
  192. package/dist/components/popover.d.cts +108 -0
  193. package/dist/components/popover.d.ts +108 -0
  194. package/dist/components/popover.mjs +168 -0
  195. package/dist/components/progress.cjs +237 -0
  196. package/dist/components/progress.d.cts +137 -0
  197. package/dist/components/progress.d.ts +137 -0
  198. package/dist/components/progress.mjs +211 -0
  199. package/dist/components/radio.cjs +344 -0
  200. package/dist/components/radio.d.cts +145 -0
  201. package/dist/components/radio.d.ts +145 -0
  202. package/dist/components/radio.mjs +320 -0
  203. package/dist/components/resizable.cjs +121 -0
  204. package/dist/components/resizable.d.cts +23 -0
  205. package/dist/components/resizable.d.ts +23 -0
  206. package/dist/components/resizable.mjs +99 -0
  207. package/dist/components/scroll-area.cjs +168 -0
  208. package/dist/components/scroll-area.d.cts +131 -0
  209. package/dist/components/scroll-area.d.ts +131 -0
  210. package/dist/components/scroll-area.mjs +143 -0
  211. package/dist/components/search-input.cjs +261 -0
  212. package/dist/components/search-input.d.cts +26 -0
  213. package/dist/components/search-input.d.ts +26 -0
  214. package/dist/components/search-input.mjs +243 -0
  215. package/dist/components/select.cjs +320 -0
  216. package/dist/components/select.d.cts +55 -0
  217. package/dist/components/select.d.ts +55 -0
  218. package/dist/components/select.mjs +288 -0
  219. package/dist/components/separator.cjs +193 -0
  220. package/dist/components/separator.d.cts +92 -0
  221. package/dist/components/separator.d.ts +92 -0
  222. package/dist/components/separator.mjs +170 -0
  223. package/dist/components/sheet.cjs +399 -0
  224. package/dist/components/sheet.d.cts +219 -0
  225. package/dist/components/sheet.d.ts +219 -0
  226. package/dist/components/sheet.mjs +379 -0
  227. package/dist/components/sidebar.cjs +1077 -0
  228. package/dist/components/sidebar.d.cts +733 -0
  229. package/dist/components/sidebar.d.ts +733 -0
  230. package/dist/components/sidebar.mjs +1033 -0
  231. package/dist/components/skeleton.cjs +210 -0
  232. package/dist/components/skeleton.d.cts +202 -0
  233. package/dist/components/skeleton.d.ts +202 -0
  234. package/dist/components/skeleton.mjs +182 -0
  235. package/dist/components/slider.cjs +319 -0
  236. package/dist/components/slider.d.cts +82 -0
  237. package/dist/components/slider.d.ts +82 -0
  238. package/dist/components/slider.mjs +296 -0
  239. package/dist/components/sonner.cjs +119 -0
  240. package/dist/components/sonner.d.cts +60 -0
  241. package/dist/components/sonner.d.ts +60 -0
  242. package/dist/components/sonner.mjs +94 -0
  243. package/dist/components/spinner.cjs +238 -0
  244. package/dist/components/spinner.d.cts +101 -0
  245. package/dist/components/spinner.d.ts +101 -0
  246. package/dist/components/spinner.mjs +213 -0
  247. package/dist/components/stat.cjs +180 -0
  248. package/dist/components/stat.d.cts +21 -0
  249. package/dist/components/stat.d.ts +21 -0
  250. package/dist/components/stat.mjs +161 -0
  251. package/dist/components/steps.cjs +228 -0
  252. package/dist/components/steps.d.cts +76 -0
  253. package/dist/components/steps.d.ts +76 -0
  254. package/dist/components/steps.mjs +207 -0
  255. package/dist/components/switch.cjs +243 -0
  256. package/dist/components/switch.d.cts +90 -0
  257. package/dist/components/switch.d.ts +90 -0
  258. package/dist/components/switch.mjs +228 -0
  259. package/dist/components/table.cjs +381 -0
  260. package/dist/components/table.d.cts +181 -0
  261. package/dist/components/table.d.ts +181 -0
  262. package/dist/components/table.mjs +349 -0
  263. package/dist/components/tabs.cjs +326 -0
  264. package/dist/components/tabs.d.cts +154 -0
  265. package/dist/components/tabs.d.ts +154 -0
  266. package/dist/components/tabs.mjs +304 -0
  267. package/dist/components/textarea.cjs +258 -0
  268. package/dist/components/textarea.d.cts +112 -0
  269. package/dist/components/textarea.d.ts +112 -0
  270. package/dist/components/textarea.mjs +233 -0
  271. package/dist/components/theme-toggle.cjs +282 -0
  272. package/dist/components/theme-toggle.d.cts +58 -0
  273. package/dist/components/theme-toggle.d.ts +58 -0
  274. package/dist/components/theme-toggle.mjs +258 -0
  275. package/dist/components/timeline.cjs +178 -0
  276. package/dist/components/timeline.d.cts +41 -0
  277. package/dist/components/timeline.d.ts +41 -0
  278. package/dist/components/timeline.mjs +157 -0
  279. package/dist/components/toast.cjs +546 -0
  280. package/dist/components/toast.d.cts +169 -0
  281. package/dist/components/toast.d.ts +169 -0
  282. package/dist/components/toast.mjs +528 -0
  283. package/dist/components/toggle-group.cjs +204 -0
  284. package/dist/components/toggle-group.d.cts +215 -0
  285. package/dist/components/toggle-group.d.ts +215 -0
  286. package/dist/components/toggle-group.mjs +180 -0
  287. package/dist/components/toggle.cjs +155 -0
  288. package/dist/components/toggle.d.cts +100 -0
  289. package/dist/components/toggle.d.ts +100 -0
  290. package/dist/components/toggle.mjs +130 -0
  291. package/dist/components/tooltip.cjs +155 -0
  292. package/dist/components/tooltip.d.cts +129 -0
  293. package/dist/components/tooltip.d.ts +129 -0
  294. package/dist/components/tooltip.mjs +132 -0
  295. package/dist/components/tree-view.cjs +450 -0
  296. package/dist/components/tree-view.d.cts +67 -0
  297. package/dist/components/tree-view.d.ts +67 -0
  298. package/dist/components/tree-view.mjs +433 -0
  299. package/dist/components/video-player.cjs +344 -0
  300. package/dist/components/video-player.d.cts +34 -0
  301. package/dist/components/video-player.d.ts +34 -0
  302. package/dist/components/video-player.mjs +320 -0
  303. package/dist/components/virtual-list.cjs +153 -0
  304. package/dist/components/virtual-list.d.cts +53 -0
  305. package/dist/components/virtual-list.d.ts +53 -0
  306. package/dist/components/virtual-list.mjs +136 -0
  307. package/dist/components/visually-hidden.cjs +43 -0
  308. package/dist/components/visually-hidden.d.cts +9 -0
  309. package/dist/components/visually-hidden.d.ts +9 -0
  310. package/dist/components/visually-hidden.mjs +21 -0
  311. package/dist/index.cjs +1081 -1957
  312. package/dist/index.d.cts +99 -11
  313. package/dist/index.d.ts +99 -11
  314. package/dist/index.mjs +1138 -16
  315. package/dist/motion/hooks.cjs +98 -0
  316. package/dist/motion/hooks.d.cts +32 -0
  317. package/dist/motion/hooks.d.ts +32 -0
  318. package/dist/motion/hooks.mjs +70 -0
  319. package/dist/motion/index.cjs +157 -0
  320. package/dist/motion/index.d.cts +5 -0
  321. package/dist/motion/index.d.ts +5 -0
  322. package/dist/motion/index.mjs +137 -0
  323. package/dist/motion/presets.cjs +609 -0
  324. package/dist/{motion.d.ts → motion/presets.d.cts} +1 -30
  325. package/dist/{motion.d.cts → motion/presets.d.ts} +1 -30
  326. package/dist/{chunk-PLRSH37T.mjs → motion/presets.mjs} +119 -126
  327. package/dist/primitives/container.cjs +88 -0
  328. package/dist/primitives/container.d.cts +82 -0
  329. package/dist/primitives/container.d.ts +82 -0
  330. package/dist/primitives/container.mjs +64 -0
  331. package/dist/primitives/divider.cjs +74 -0
  332. package/dist/primitives/divider.d.cts +30 -0
  333. package/dist/primitives/divider.d.ts +30 -0
  334. package/dist/primitives/divider.mjs +50 -0
  335. package/dist/primitives/index.cjs +54 -0
  336. package/dist/primitives/index.d.cts +6 -0
  337. package/dist/primitives/index.d.ts +6 -0
  338. package/dist/primitives/index.mjs +33 -0
  339. package/dist/primitives/stack.cjs +167 -0
  340. package/dist/primitives/stack.d.cts +132 -0
  341. package/dist/primitives/stack.d.ts +132 -0
  342. package/dist/primitives/stack.mjs +142 -0
  343. package/dist/primitives/typography.cjs +260 -0
  344. package/dist/primitives/typography.d.cts +157 -0
  345. package/dist/primitives/typography.d.ts +157 -0
  346. package/dist/primitives/typography.mjs +229 -0
  347. package/dist/theme/contract.cjs +246 -0
  348. package/dist/theme/contract.d.cts +76 -0
  349. package/dist/theme/contract.d.ts +76 -0
  350. package/dist/theme/contract.mjs +221 -0
  351. package/dist/theme/customizer-store.cjs +266 -0
  352. package/dist/theme/customizer-store.d.cts +76 -0
  353. package/dist/theme/customizer-store.d.ts +76 -0
  354. package/dist/theme/customizer-store.mjs +261 -0
  355. package/dist/theme/customizer.cjs +812 -0
  356. package/dist/theme/customizer.d.cts +13 -0
  357. package/dist/theme/customizer.d.ts +13 -0
  358. package/dist/theme/customizer.mjs +803 -0
  359. package/dist/theme/index.cjs +105 -0
  360. package/dist/theme/index.d.cts +13 -0
  361. package/dist/theme/index.d.ts +13 -0
  362. package/dist/theme/index.mjs +87 -0
  363. package/dist/theme/presets.cjs +1205 -0
  364. package/dist/theme/presets.d.cts +232 -0
  365. package/dist/theme/presets.d.ts +232 -0
  366. package/dist/theme/presets.mjs +1175 -0
  367. package/dist/theme/provider.cjs +122 -0
  368. package/dist/theme/provider.d.cts +57 -0
  369. package/dist/theme/provider.d.ts +57 -0
  370. package/dist/theme/provider.mjs +104 -0
  371. package/dist/{chunk-AAEWG5VR.mjs → tokens/colors.cjs} +94 -94
  372. package/dist/{z-index-DmLl6FUD.d.ts → tokens/colors.d.cts} +118 -72
  373. package/dist/{z-index-DmLl6FUD.d.cts → tokens/colors.d.ts} +118 -72
  374. package/dist/{chunk-6ZZZBOCH.cjs → tokens/colors.mjs} +47 -121
  375. package/dist/tokens/index.cjs +96 -0
  376. package/dist/tokens/index.d.cts +7 -0
  377. package/dist/tokens/index.d.ts +7 -0
  378. package/dist/tokens/index.mjs +71 -0
  379. package/dist/{chunk-XCKK6P46.cjs → tokens/motion.cjs} +46 -18
  380. package/dist/{motion-D9wQbcKL.d.cts → tokens/motion.d.cts} +1 -1
  381. package/dist/{motion-D9wQbcKL.d.ts → tokens/motion.d.ts} +1 -1
  382. package/dist/{chunk-EZ2L3XPS.mjs → tokens/motion.mjs} +16 -10
  383. package/dist/tokens/radius.cjs +41 -0
  384. package/dist/tokens/radius.d.cts +18 -0
  385. package/dist/tokens/radius.d.ts +18 -0
  386. package/dist/tokens/radius.mjs +17 -0
  387. package/dist/tokens/shadows.cjs +57 -0
  388. package/dist/tokens/shadows.d.cts +32 -0
  389. package/dist/tokens/shadows.d.ts +32 -0
  390. package/dist/tokens/shadows.mjs +32 -0
  391. package/dist/tokens/spacing.cjs +51 -0
  392. package/dist/tokens/spacing.d.cts +26 -0
  393. package/dist/tokens/spacing.d.ts +26 -0
  394. package/dist/{chunk-NMPHV6ZD.mjs → tokens/spacing.mjs} +4 -4
  395. package/dist/{chunk-ECIGDEAH.cjs → tokens/typography.cjs} +43 -16
  396. package/dist/{typography-DlvVjEdE.d.ts → tokens/typography.d.cts} +1 -1
  397. package/dist/{typography-DlvVjEdE.d.cts → tokens/typography.d.ts} +1 -1
  398. package/dist/{chunk-ITBG42M5.mjs → tokens/typography.mjs} +14 -9
  399. package/dist/tokens/z-index.cjs +47 -0
  400. package/dist/tokens/z-index.d.cts +24 -0
  401. package/dist/tokens/z-index.d.ts +24 -0
  402. package/dist/tokens/z-index.mjs +23 -0
  403. package/dist/utils/cn.cjs +102 -0
  404. package/dist/utils/cn.d.cts +84 -0
  405. package/dist/utils/cn.d.ts +84 -0
  406. package/dist/{chunk-ZT3PCXDF.mjs → utils/cn.mjs} +14 -7
  407. package/dist/{chunk-33QEKXRQ.cjs → utils/contrast.cjs} +68 -38
  408. package/dist/utils/contrast.d.cts +209 -0
  409. package/dist/utils/contrast.d.ts +209 -0
  410. package/dist/{chunk-5NZDQWRV.mjs → utils/contrast.mjs} +27 -18
  411. package/dist/utils/focus-ring.cjs +81 -0
  412. package/dist/utils/focus-ring.d.cts +80 -0
  413. package/dist/utils/focus-ring.d.ts +80 -0
  414. package/dist/utils/focus-ring.mjs +47 -0
  415. package/dist/utils/index.cjs +107 -0
  416. package/dist/utils/index.d.cts +6 -0
  417. package/dist/utils/index.d.ts +6 -0
  418. package/dist/utils/index.mjs +88 -0
  419. package/dist/utils/types.cjs +38 -0
  420. package/dist/utils/types.d.cts +187 -0
  421. package/dist/utils/types.d.ts +187 -0
  422. package/dist/utils/types.mjs +13 -0
  423. package/package.json +191 -191
  424. package/dist/chunk-2JFREULQ.cjs +0 -29
  425. package/dist/chunk-3EHT6IOA.cjs +0 -49
  426. package/dist/chunk-4ON3M3OM.cjs +0 -73
  427. package/dist/chunk-A2DGHQL2.cjs +0 -21808
  428. package/dist/chunk-BJ55D5IK.mjs +0 -2433
  429. package/dist/chunk-F4JJFWWU.cjs +0 -604
  430. package/dist/chunk-FUWXGHWQ.cjs +0 -468
  431. package/dist/chunk-MBYCK2JJ.mjs +0 -37
  432. package/dist/chunk-OHEH57BV.mjs +0 -455
  433. package/dist/chunk-RUG3BW2B.cjs +0 -2471
  434. package/dist/chunk-XAIUX2YS.mjs +0 -21477
  435. package/dist/components.cjs +0 -1247
  436. package/dist/components.d.cts +0 -7881
  437. package/dist/components.d.ts +0 -7881
  438. package/dist/components.mjs +0 -6
  439. package/dist/motion.cjs +0 -264
  440. package/dist/motion.mjs +0 -3
  441. package/dist/primitives.cjs +0 -57
  442. package/dist/primitives.d.cts +0 -390
  443. package/dist/primitives.d.ts +0 -390
  444. package/dist/primitives.mjs +0 -4
  445. package/dist/theme.cjs +0 -159
  446. package/dist/theme.d.cts +0 -440
  447. package/dist/theme.d.ts +0 -440
  448. package/dist/theme.mjs +0 -6
  449. package/dist/tokens.cjs +0 -137
  450. package/dist/tokens.d.cts +0 -30
  451. package/dist/tokens.d.ts +0 -30
  452. package/dist/tokens.mjs +0 -4
  453. package/dist/utils.cjs +0 -164
  454. package/dist/utils.d.cts +0 -525
  455. package/dist/utils.d.ts +0 -525
  456. package/dist/utils.mjs +0 -3
package/CHANGELOG.md CHANGED
@@ -10,8 +10,113 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
10
10
 
11
11
  ### 🚀 Features
12
12
 
13
+ - **docs:** Add motion preset previews (#13)
14
+ * feat(docs): add motion preset previews
15
+
16
+ * Update content/docs/motion.mdx ([#13](https://github.com/imrj05/unified-ui/issues/13)) ([5bc4c3c](https://github.com/imrj05/unified-ui/commit/5bc4c3c60757c82b713b6a3772c5642c26d36ca0))
17
+ - **docs:** Add motion preset previews (#11)
18
+ * feat(docs): add motion preset previews
19
+
20
+ * Update content/docs/motion.mdx ([#11](https://github.com/imrj05/unified-ui/issues/11)) ([ceb9fed](https://github.com/imrj05/unified-ui/commit/ceb9fed3307003cbf575b55178f4bd3b5fc941b3))
21
+ - Add new color tokens (indigo, purple, pink, cyan, emerald, yellow, fuchsia, sky, lime) to the design system ([2eafdc1](https://github.com/imrj05/unified-ui/commit/2eafdc1c3a3f29ea8abaaa93c1b4cf5eea74acb4))
22
+
23
+ ### 📖 Documentation
24
+
25
+ - **oss:** Add contribution standards and protected-branch CI fixes (#5)
26
+ * docs(plan): add open-source contribution setup design
27
+
28
+ * docs(oss): add contribution, security, and governance standards
29
+
30
+ * chore(dist): add regenerated chunk artifacts
31
+
32
+ * ci: switch changelog updates to PR flow for protected main
33
+
34
+ * docs(readme): refresh component count and monorepo sections
35
+
36
+ * ci(sync): trigger template sync only on template path changes
37
+
38
+ * docs: remove brainstorming design artifact ([#5](https://github.com/imrj05/unified-ui/issues/5)) ([7286344](https://github.com/imrj05/unified-ui/commit/7286344503ed667ca1bbb861a29e400f271fbe2c))
39
+ - **oss:** Add contribution standards and protected-branch CI fixes (#3)
40
+ * docs(plan): add open-source contribution setup design
41
+
42
+ * docs(oss): add contribution, security, and governance standards
43
+
44
+ * chore(dist): add regenerated chunk artifacts
45
+
46
+ * ci: switch changelog updates to PR flow for protected main
47
+
48
+ * docs(readme): refresh component count and monorepo sections ([#3](https://github.com/imrj05/unified-ui/issues/3)) ([e77d86f](https://github.com/imrj05/unified-ui/commit/e77d86f818f7226eced8d846ebed265504ed4127))
49
+
50
+ ### 🏗️ Miscellaneous
51
+
52
+ - **changelog:** Auto-update unreleased entries [skip ci] (#12) ([#12](https://github.com/imrj05/unified-ui/issues/12)) ([77d3670](https://github.com/imrj05/unified-ui/commit/77d36705c83146732171f838f2bcdb52bac409fb))
53
+ - **changelog:** Auto-update unreleased entries [skip ci] (#10) ([#10](https://github.com/imrj05/unified-ui/issues/10)) ([dc691b1](https://github.com/imrj05/unified-ui/commit/dc691b1df0d28dee7961a0cf695a3751e756d8af))
54
+ - **changelog:** Auto-update unreleased entries [skip ci] (#8) ([#8](https://github.com/imrj05/unified-ui/issues/8)) ([59a0b38](https://github.com/imrj05/unified-ui/commit/59a0b3863c9deb7b6914202d7be46707ea83a09b))
55
+ - **changelog:** Auto-update unreleased entries [skip ci] (#6) ([#6](https://github.com/imrj05/unified-ui/issues/6)) ([00f8056](https://github.com/imrj05/unified-ui/commit/00f805695032ac4eb6f25984d276f85cde6aa2f3))
56
+ - **changelog:** Auto-update unreleased entries [skip ci] (#4) ([#4](https://github.com/imrj05/unified-ui/issues/4)) ([6e46e82](https://github.com/imrj05/unified-ui/commit/6e46e82745d62b346015991d075994869d0e4322))
57
+ - **changelog:** Auto-update unreleased entries [skip ci] ([7fb8661](https://github.com/imrj05/unified-ui/commit/7fb8661ffd7650de9bf5e90f52dbf73e2b628ae0))
58
+ - **changelog:** Auto-update unreleased entries [skip ci] ([f9f2c15](https://github.com/imrj05/unified-ui/commit/f9f2c156c6c15a716d56635de647eb3c308ba2fb))
59
+
60
+ ### Other
61
+
62
+ - Feat/add analytics (#9)
63
+
64
+ * docs(plan): add open-source contribution setup design
65
+
66
+ * docs(oss): add contribution, security, and governance standards
67
+
68
+ * chore(dist): add regenerated chunk artifacts
69
+
70
+ * ci: switch changelog updates to PR flow for protected main
71
+
72
+ * docs(readme): refresh component count and monorepo sections
73
+
74
+ * ci(sync): trigger template sync only on template path changes
75
+
76
+ * docs: remove brainstorming design artifact
77
+
78
+ * Add MIT license
79
+
80
+ * feat: add @vercel/speed-insights dependency and integrate into layout ([#9](https://github.com/imrj05/unified-ui/issues/9)) ([7628e79](https://github.com/imrj05/unified-ui/commit/7628e79bff11cfe1e57c593f0c13961c395412e6))
81
+ - Add MIT license (#7)
82
+
83
+ * docs(plan): add open-source contribution setup design
84
+
85
+ * docs(oss): add contribution, security, and governance standards
86
+
87
+ * chore(dist): add regenerated chunk artifacts
88
+
89
+ * ci: switch changelog updates to PR flow for protected main
90
+
91
+ * docs(readme): refresh component count and monorepo sections
92
+
93
+ * ci(sync): trigger template sync only on template path changes
94
+
95
+ * docs: remove brainstorming design artifact
96
+
97
+ * Add MIT license ([#7](https://github.com/imrj05/unified-ui/issues/7)) ([9ccd0da](https://github.com/imrj05/unified-ui/commit/9ccd0daf66750f4a009ee777ded828ad874772d9))
98
+ - Fix/oss contrib pr (#2)
99
+
100
+ * docs(plan): add open-source contribution setup design
101
+
102
+ * docs(oss): add contribution, security, and governance standards
103
+
104
+ * chore(dist): add regenerated chunk artifacts ([#2](https://github.com/imrj05/unified-ui/issues/2)) ([2a39426](https://github.com/imrj05/unified-ui/commit/2a3942616f95f7616db1a52dded533345688f948))
105
+ ## [0.3.4] — 2026-03-10
106
+
107
+ ### 🚀 Features
108
+
109
+ - Update version to 0.3.3, enhance CLI with Tailwind CSS setup, and auto-update changelog ([9ac9ceb](https://github.com/imrj05/unified-ui/commit/9ac9cebee65702a8e3864cb5358a2bf198f0b168))
110
+ ## [0.3.3] — 2026-03-10
111
+
112
+ ### 🚀 Features
113
+
13
114
  - Add motion tokens for animation consistency
14
115
  - Introduced motion tokens in `motion.ts` for durations, easings, springs, and stagger timings to standardize animations across the design system. ([65feea0](https://github.com/imrj05/unified-ui/commit/65feea0c5ab3b43d3aa6a4300aedda58b9769fad))
116
+
117
+ ### 🏗️ Miscellaneous
118
+
119
+ - **changelog:** Auto-update unreleased entries [skip ci] ([d3abb8a](https://github.com/imrj05/unified-ui/commit/d3abb8a6527f8275d3cabf9f81c3c636c9e5831b))
15
120
  ## [0.3.2] — 2026-03-09
16
121
 
17
122
  ### 🚀 Features
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2026 Rajeshwar Kashyap
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
@@ -0,0 +1,225 @@
1
+ "use strict";
2
+ "use client";
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
20
+ var accordion_exports = {};
21
+ __export(accordion_exports, {
22
+ Accordion: () => Accordion,
23
+ AccordionContent: () => AccordionContent,
24
+ AccordionItem: () => AccordionItem,
25
+ AccordionTrigger: () => AccordionTrigger,
26
+ accordionContentVariants: () => accordionContentVariants,
27
+ accordionRootVariants: () => accordionRootVariants,
28
+ accordionTriggerVariants: () => accordionTriggerVariants
29
+ });
30
+ module.exports = __toCommonJS(accordion_exports);
31
+ var import_jsx_runtime = require("react/jsx-runtime");
32
+ var import_cn = require("../utils/cn");
33
+ var import_focus_ring = require("../utils/focus-ring");
34
+ var import_class_variance_authority = require("class-variance-authority");
35
+ var import_radix_ui = require("radix-ui");
36
+ var import_react = require("react");
37
+ const AccordionContext = (0, import_react.createContext)({
38
+ variant: "bordered",
39
+ size: "md"
40
+ });
41
+ function useAccordionContext() {
42
+ return (0, import_react.useContext)(AccordionContext);
43
+ }
44
+ const accordionRootVariants = (0, import_class_variance_authority.cva)(["flex flex-col"], {
45
+ variants: {
46
+ variant: {
47
+ /**
48
+ * Bordered — each item has a visible border separator.
49
+ * Default variant for most use cases.
50
+ */
51
+ bordered: "divide-y divide-border",
52
+ /**
53
+ * Borderless — no visible borders between items.
54
+ * Use for tighter layouts or when embedded inside cards.
55
+ */
56
+ borderless: ""
57
+ }
58
+ },
59
+ defaultVariants: {
60
+ variant: "bordered"
61
+ }
62
+ });
63
+ const accordionTriggerVariants = (0, import_class_variance_authority.cva)(
64
+ [
65
+ // Layout
66
+ "flex flex-1 items-center justify-between w-full",
67
+ // Typography
68
+ "font-medium text-foreground",
69
+ // Transition
70
+ "transition-[color,background-color,opacity]",
71
+ "duration-fast ease-standard",
72
+ // Focus ring
73
+ import_focus_ring.focusRingClasses,
74
+ // Hover
75
+ "hover:text-foreground hover:underline",
76
+ // Disabled
77
+ "disabled:pointer-events-none disabled:opacity-50 disabled:cursor-not-allowed",
78
+ // Cursor
79
+ "cursor-pointer",
80
+ // Chevron rotation on open
81
+ "[&>svg]:transition-transform [&>svg]:duration-normal [&>svg]:ease-standard",
82
+ "[&[data-state=open]>svg]:rotate-180"
83
+ ],
84
+ {
85
+ variants: {
86
+ size: {
87
+ /**
88
+ * Small — compact for dense UIs, sidebars.
89
+ */
90
+ sm: "py-3 text-sm leading-5",
91
+ /**
92
+ * Medium — default size for most accordions.
93
+ */
94
+ md: "py-4 text-sm leading-5"
95
+ }
96
+ },
97
+ defaultVariants: {
98
+ size: "md"
99
+ }
100
+ }
101
+ );
102
+ const accordionContentVariants = (0, import_class_variance_authority.cva)(
103
+ [
104
+ // Animate expand/collapse using CSS grid trick
105
+ "overflow-hidden",
106
+ "data-[state=closed]:animate-accordion-up",
107
+ "data-[state=open]:animate-accordion-down"
108
+ ],
109
+ {
110
+ variants: {
111
+ size: {
112
+ sm: "text-sm leading-5",
113
+ md: "text-sm leading-5"
114
+ }
115
+ },
116
+ defaultVariants: {
117
+ size: "md"
118
+ }
119
+ }
120
+ );
121
+ const accordionContentInnerVariants = (0, import_class_variance_authority.cva)(["text-muted-foreground"], {
122
+ variants: {
123
+ size: {
124
+ sm: "pb-3",
125
+ md: "pb-4"
126
+ }
127
+ },
128
+ defaultVariants: {
129
+ size: "md"
130
+ }
131
+ });
132
+ function ChevronDownIcon({ className }) {
133
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
134
+ "svg",
135
+ {
136
+ xmlns: "http://www.w3.org/2000/svg",
137
+ viewBox: "0 0 24 24",
138
+ fill: "none",
139
+ stroke: "currentColor",
140
+ strokeWidth: "2",
141
+ strokeLinecap: "round",
142
+ strokeLinejoin: "round",
143
+ className,
144
+ "aria-hidden": "true",
145
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("path", { d: "m6 9 6 6 6-6" })
146
+ }
147
+ );
148
+ }
149
+ const Accordion = (0, import_react.forwardRef)(function Accordion2({ variant = "bordered", size = "md", className, children, ...rest }, ref) {
150
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(AccordionContext.Provider, { value: { variant, size }, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
151
+ import_radix_ui.Accordion.Root,
152
+ {
153
+ ref,
154
+ className: (0, import_cn.cn)(
155
+ "not-prose",
156
+ accordionRootVariants({ variant }),
157
+ className
158
+ ),
159
+ "data-ds": "",
160
+ "data-ds-component": "accordion",
161
+ "data-ds-variant": variant,
162
+ "data-ds-size": size,
163
+ ...rest,
164
+ children
165
+ }
166
+ ) });
167
+ });
168
+ Accordion.displayName = "Accordion";
169
+ const AccordionItem = (0, import_react.forwardRef)(function AccordionItem2({ className, children, ...rest }, ref) {
170
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
171
+ import_radix_ui.Accordion.Item,
172
+ {
173
+ ref,
174
+ className: (0, import_cn.cn)("", className),
175
+ "data-ds": "",
176
+ "data-ds-component": "accordion-item",
177
+ ...rest,
178
+ children
179
+ }
180
+ );
181
+ });
182
+ AccordionItem.displayName = "AccordionItem";
183
+ const AccordionTrigger = (0, import_react.forwardRef)(function AccordionTrigger2({ className, hideChevron = false, children, ...rest }, ref) {
184
+ const { size } = useAccordionContext();
185
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_radix_ui.Accordion.Header, { className: "flex", children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
186
+ import_radix_ui.Accordion.Trigger,
187
+ {
188
+ ref,
189
+ className: (0, import_cn.cn)(accordionTriggerVariants({ size }), className),
190
+ "data-ds": "",
191
+ "data-ds-component": "accordion-trigger",
192
+ ...rest,
193
+ children: [
194
+ children,
195
+ !hideChevron && /* @__PURE__ */ (0, import_jsx_runtime.jsx)(ChevronDownIcon, { className: "size-4 shrink-0 text-muted-foreground" })
196
+ ]
197
+ }
198
+ ) });
199
+ });
200
+ AccordionTrigger.displayName = "AccordionTrigger";
201
+ const AccordionContent = (0, import_react.forwardRef)(function AccordionContent2({ className, children, ...rest }, ref) {
202
+ const { size } = useAccordionContext();
203
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
204
+ import_radix_ui.Accordion.Content,
205
+ {
206
+ ref,
207
+ className: (0, import_cn.cn)(accordionContentVariants({ size }), className),
208
+ "data-ds": "",
209
+ "data-ds-component": "accordion-content",
210
+ ...rest,
211
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: (0, import_cn.cn)(accordionContentInnerVariants({ size })), children })
212
+ }
213
+ );
214
+ });
215
+ AccordionContent.displayName = "AccordionContent";
216
+ // Annotate the CommonJS export names for ESM import in node:
217
+ 0 && (module.exports = {
218
+ Accordion,
219
+ AccordionContent,
220
+ AccordionItem,
221
+ AccordionTrigger,
222
+ accordionContentVariants,
223
+ accordionRootVariants,
224
+ accordionTriggerVariants
225
+ });
@@ -0,0 +1,157 @@
1
+ import * as react from 'react';
2
+ import { ComponentPropsWithoutRef, ReactNode } from 'react';
3
+ import * as class_variance_authority_types from 'class-variance-authority/types';
4
+ import { VariantProps } from 'class-variance-authority';
5
+ import { Accordion as Accordion$1 } from 'radix-ui';
6
+
7
+ declare const accordionRootVariants: (props?: ({
8
+ variant?: "bordered" | "borderless" | null | undefined;
9
+ } & class_variance_authority_types.ClassProp) | undefined) => string;
10
+ declare const accordionTriggerVariants: (props?: ({
11
+ size?: "sm" | "md" | null | undefined;
12
+ } & class_variance_authority_types.ClassProp) | undefined) => string;
13
+ declare const accordionContentVariants: (props?: ({
14
+ size?: "sm" | "md" | null | undefined;
15
+ } & class_variance_authority_types.ClassProp) | undefined) => string;
16
+ type AccordionVariant = "bordered" | "borderless";
17
+ type AccordionSize = "sm" | "md";
18
+ /**
19
+ * Props for a single-mode accordion (only one item open at a time).
20
+ */
21
+ interface AccordionSingleProps extends Omit<ComponentPropsWithoutRef<typeof Accordion$1.Root>, "type" | "asChild">, VariantProps<typeof accordionRootVariants> {
22
+ type: "single";
23
+ /** Visual variant of the accordion. @default "bordered" */
24
+ variant?: AccordionVariant;
25
+ /** Size of the accordion items. @default "md" */
26
+ size?: AccordionSize;
27
+ /** Additional CSS classes. */
28
+ className?: string;
29
+ children: ReactNode;
30
+ }
31
+ /**
32
+ * Props for a multiple-mode accordion (multiple items can be open).
33
+ */
34
+ interface AccordionMultipleProps extends Omit<ComponentPropsWithoutRef<typeof Accordion$1.Root>, "type" | "asChild">, VariantProps<typeof accordionRootVariants> {
35
+ type: "multiple";
36
+ /** Visual variant of the accordion. @default "bordered" */
37
+ variant?: AccordionVariant;
38
+ /** Size of the accordion items. @default "md" */
39
+ size?: AccordionSize;
40
+ /** Additional CSS classes. */
41
+ className?: string;
42
+ children: ReactNode;
43
+ }
44
+ type AccordionProps = AccordionSingleProps | AccordionMultipleProps;
45
+ interface AccordionItemProps extends ComponentPropsWithoutRef<typeof Accordion$1.Item> {
46
+ /** Additional CSS classes. */
47
+ className?: string;
48
+ children: ReactNode;
49
+ }
50
+ interface AccordionTriggerProps extends ComponentPropsWithoutRef<typeof Accordion$1.Trigger> {
51
+ /** Additional CSS classes. */
52
+ className?: string;
53
+ /** Whether to hide the chevron icon. @default false */
54
+ hideChevron?: boolean;
55
+ children: ReactNode;
56
+ }
57
+ interface AccordionContentProps extends ComponentPropsWithoutRef<typeof Accordion$1.Content> {
58
+ /** Additional CSS classes. */
59
+ className?: string;
60
+ children: ReactNode;
61
+ }
62
+ /**
63
+ * Accordion — a vertically stacked set of interactive headings that each
64
+ * reveal a section of content.
65
+ *
66
+ * Built on Radix UI's Accordion primitive for full keyboard navigation
67
+ * and ARIA compliance. All colors, radii, and transitions come from CSS
68
+ * custom properties defined in design-system.css.
69
+ *
70
+ * Accessibility:
71
+ * - Radix handles `aria-expanded`, `aria-controls`, arrow key navigation
72
+ * - Focus ring visible on keyboard navigation (focus-visible)
73
+ * - Disabled items are skipped in keyboard navigation
74
+ * - Supports both single and multiple expand modes
75
+ *
76
+ * @example
77
+ * ```tsx
78
+ * // Single mode (only one open at a time)
79
+ * <Accordion type="single" collapsible>
80
+ * <AccordionItem value="faq-1">
81
+ * <AccordionTrigger>What is Unified UI?</AccordionTrigger>
82
+ * <AccordionContent>
83
+ * A token-driven design system for React applications.
84
+ * </AccordionContent>
85
+ * </AccordionItem>
86
+ * </Accordion>
87
+ *
88
+ * // Multiple mode
89
+ * <Accordion type="multiple" variant="borderless" size="sm">
90
+ * <AccordionItem value="a">
91
+ * <AccordionTrigger>Section A</AccordionTrigger>
92
+ * <AccordionContent>Content A</AccordionContent>
93
+ * </AccordionItem>
94
+ * <AccordionItem value="b">
95
+ * <AccordionTrigger>Section B</AccordionTrigger>
96
+ * <AccordionContent>Content B</AccordionContent>
97
+ * </AccordionItem>
98
+ * </Accordion>
99
+ * ```
100
+ */
101
+ declare const Accordion: react.ForwardRefExoticComponent<AccordionProps & react.RefAttributes<HTMLDivElement>>;
102
+ /**
103
+ * AccordionItem — a single collapsible section within the Accordion.
104
+ *
105
+ * Must be used as a direct child of `Accordion`.
106
+ *
107
+ * @example
108
+ * ```tsx
109
+ * <AccordionItem value="unique-value">
110
+ * <AccordionTrigger>Click to expand</AccordionTrigger>
111
+ * <AccordionContent>Expanded content here</AccordionContent>
112
+ * </AccordionItem>
113
+ * ```
114
+ */
115
+ declare const AccordionItem: react.ForwardRefExoticComponent<AccordionItemProps & react.RefAttributes<HTMLDivElement>>;
116
+ /**
117
+ * AccordionTrigger — the clickable heading that toggles an AccordionItem.
118
+ *
119
+ * Must be used inside an `AccordionItem`. Renders as a button within a
120
+ * heading element for proper accessibility semantics.
121
+ *
122
+ * @example
123
+ * ```tsx
124
+ * <AccordionTrigger>Frequently asked question?</AccordionTrigger>
125
+ * <AccordionTrigger hideChevron>No arrow here</AccordionTrigger>
126
+ * ```
127
+ */
128
+ declare const AccordionTrigger: react.ForwardRefExoticComponent<AccordionTriggerProps & react.RefAttributes<HTMLButtonElement>>;
129
+ /**
130
+ * AccordionContent — the collapsible content area of an AccordionItem.
131
+ *
132
+ * Uses CSS `animate-accordion-down` / `animate-accordion-up` keyframes
133
+ * for smooth expand/collapse animation. This relies on the Radix
134
+ * `--radix-accordion-content-height` CSS variable.
135
+ *
136
+ * Note: You must define the following keyframes and animation utilities
137
+ * in your Tailwind / CSS configuration for the animations to work:
138
+ *
139
+ * @keyframes accordion-down {
140
+ * from { height: 0; }
141
+ * to { height: var(--radix-accordion-content-height); }
142
+ * }
143
+ * @keyframes accordion-up {
144
+ * from { height: var(--radix-accordion-content-height); }
145
+ * to { height: 0; }
146
+ * }
147
+ *
148
+ * @example
149
+ * ```tsx
150
+ * <AccordionContent>
151
+ * <p>This content expands and collapses smoothly.</p>
152
+ * </AccordionContent>
153
+ * ```
154
+ */
155
+ declare const AccordionContent: react.ForwardRefExoticComponent<AccordionContentProps & react.RefAttributes<HTMLDivElement>>;
156
+
157
+ export { Accordion, AccordionContent, type AccordionContentProps, AccordionItem, type AccordionItemProps, type AccordionMultipleProps, type AccordionProps, type AccordionSingleProps, type AccordionSize, AccordionTrigger, type AccordionTriggerProps, type AccordionVariant, accordionContentVariants, accordionRootVariants, accordionTriggerVariants };
@@ -0,0 +1,157 @@
1
+ import * as react from 'react';
2
+ import { ComponentPropsWithoutRef, ReactNode } from 'react';
3
+ import * as class_variance_authority_types from 'class-variance-authority/types';
4
+ import { VariantProps } from 'class-variance-authority';
5
+ import { Accordion as Accordion$1 } from 'radix-ui';
6
+
7
+ declare const accordionRootVariants: (props?: ({
8
+ variant?: "bordered" | "borderless" | null | undefined;
9
+ } & class_variance_authority_types.ClassProp) | undefined) => string;
10
+ declare const accordionTriggerVariants: (props?: ({
11
+ size?: "sm" | "md" | null | undefined;
12
+ } & class_variance_authority_types.ClassProp) | undefined) => string;
13
+ declare const accordionContentVariants: (props?: ({
14
+ size?: "sm" | "md" | null | undefined;
15
+ } & class_variance_authority_types.ClassProp) | undefined) => string;
16
+ type AccordionVariant = "bordered" | "borderless";
17
+ type AccordionSize = "sm" | "md";
18
+ /**
19
+ * Props for a single-mode accordion (only one item open at a time).
20
+ */
21
+ interface AccordionSingleProps extends Omit<ComponentPropsWithoutRef<typeof Accordion$1.Root>, "type" | "asChild">, VariantProps<typeof accordionRootVariants> {
22
+ type: "single";
23
+ /** Visual variant of the accordion. @default "bordered" */
24
+ variant?: AccordionVariant;
25
+ /** Size of the accordion items. @default "md" */
26
+ size?: AccordionSize;
27
+ /** Additional CSS classes. */
28
+ className?: string;
29
+ children: ReactNode;
30
+ }
31
+ /**
32
+ * Props for a multiple-mode accordion (multiple items can be open).
33
+ */
34
+ interface AccordionMultipleProps extends Omit<ComponentPropsWithoutRef<typeof Accordion$1.Root>, "type" | "asChild">, VariantProps<typeof accordionRootVariants> {
35
+ type: "multiple";
36
+ /** Visual variant of the accordion. @default "bordered" */
37
+ variant?: AccordionVariant;
38
+ /** Size of the accordion items. @default "md" */
39
+ size?: AccordionSize;
40
+ /** Additional CSS classes. */
41
+ className?: string;
42
+ children: ReactNode;
43
+ }
44
+ type AccordionProps = AccordionSingleProps | AccordionMultipleProps;
45
+ interface AccordionItemProps extends ComponentPropsWithoutRef<typeof Accordion$1.Item> {
46
+ /** Additional CSS classes. */
47
+ className?: string;
48
+ children: ReactNode;
49
+ }
50
+ interface AccordionTriggerProps extends ComponentPropsWithoutRef<typeof Accordion$1.Trigger> {
51
+ /** Additional CSS classes. */
52
+ className?: string;
53
+ /** Whether to hide the chevron icon. @default false */
54
+ hideChevron?: boolean;
55
+ children: ReactNode;
56
+ }
57
+ interface AccordionContentProps extends ComponentPropsWithoutRef<typeof Accordion$1.Content> {
58
+ /** Additional CSS classes. */
59
+ className?: string;
60
+ children: ReactNode;
61
+ }
62
+ /**
63
+ * Accordion — a vertically stacked set of interactive headings that each
64
+ * reveal a section of content.
65
+ *
66
+ * Built on Radix UI's Accordion primitive for full keyboard navigation
67
+ * and ARIA compliance. All colors, radii, and transitions come from CSS
68
+ * custom properties defined in design-system.css.
69
+ *
70
+ * Accessibility:
71
+ * - Radix handles `aria-expanded`, `aria-controls`, arrow key navigation
72
+ * - Focus ring visible on keyboard navigation (focus-visible)
73
+ * - Disabled items are skipped in keyboard navigation
74
+ * - Supports both single and multiple expand modes
75
+ *
76
+ * @example
77
+ * ```tsx
78
+ * // Single mode (only one open at a time)
79
+ * <Accordion type="single" collapsible>
80
+ * <AccordionItem value="faq-1">
81
+ * <AccordionTrigger>What is Unified UI?</AccordionTrigger>
82
+ * <AccordionContent>
83
+ * A token-driven design system for React applications.
84
+ * </AccordionContent>
85
+ * </AccordionItem>
86
+ * </Accordion>
87
+ *
88
+ * // Multiple mode
89
+ * <Accordion type="multiple" variant="borderless" size="sm">
90
+ * <AccordionItem value="a">
91
+ * <AccordionTrigger>Section A</AccordionTrigger>
92
+ * <AccordionContent>Content A</AccordionContent>
93
+ * </AccordionItem>
94
+ * <AccordionItem value="b">
95
+ * <AccordionTrigger>Section B</AccordionTrigger>
96
+ * <AccordionContent>Content B</AccordionContent>
97
+ * </AccordionItem>
98
+ * </Accordion>
99
+ * ```
100
+ */
101
+ declare const Accordion: react.ForwardRefExoticComponent<AccordionProps & react.RefAttributes<HTMLDivElement>>;
102
+ /**
103
+ * AccordionItem — a single collapsible section within the Accordion.
104
+ *
105
+ * Must be used as a direct child of `Accordion`.
106
+ *
107
+ * @example
108
+ * ```tsx
109
+ * <AccordionItem value="unique-value">
110
+ * <AccordionTrigger>Click to expand</AccordionTrigger>
111
+ * <AccordionContent>Expanded content here</AccordionContent>
112
+ * </AccordionItem>
113
+ * ```
114
+ */
115
+ declare const AccordionItem: react.ForwardRefExoticComponent<AccordionItemProps & react.RefAttributes<HTMLDivElement>>;
116
+ /**
117
+ * AccordionTrigger — the clickable heading that toggles an AccordionItem.
118
+ *
119
+ * Must be used inside an `AccordionItem`. Renders as a button within a
120
+ * heading element for proper accessibility semantics.
121
+ *
122
+ * @example
123
+ * ```tsx
124
+ * <AccordionTrigger>Frequently asked question?</AccordionTrigger>
125
+ * <AccordionTrigger hideChevron>No arrow here</AccordionTrigger>
126
+ * ```
127
+ */
128
+ declare const AccordionTrigger: react.ForwardRefExoticComponent<AccordionTriggerProps & react.RefAttributes<HTMLButtonElement>>;
129
+ /**
130
+ * AccordionContent — the collapsible content area of an AccordionItem.
131
+ *
132
+ * Uses CSS `animate-accordion-down` / `animate-accordion-up` keyframes
133
+ * for smooth expand/collapse animation. This relies on the Radix
134
+ * `--radix-accordion-content-height` CSS variable.
135
+ *
136
+ * Note: You must define the following keyframes and animation utilities
137
+ * in your Tailwind / CSS configuration for the animations to work:
138
+ *
139
+ * @keyframes accordion-down {
140
+ * from { height: 0; }
141
+ * to { height: var(--radix-accordion-content-height); }
142
+ * }
143
+ * @keyframes accordion-up {
144
+ * from { height: var(--radix-accordion-content-height); }
145
+ * to { height: 0; }
146
+ * }
147
+ *
148
+ * @example
149
+ * ```tsx
150
+ * <AccordionContent>
151
+ * <p>This content expands and collapses smoothly.</p>
152
+ * </AccordionContent>
153
+ * ```
154
+ */
155
+ declare const AccordionContent: react.ForwardRefExoticComponent<AccordionContentProps & react.RefAttributes<HTMLDivElement>>;
156
+
157
+ export { Accordion, AccordionContent, type AccordionContentProps, AccordionItem, type AccordionItemProps, type AccordionMultipleProps, type AccordionProps, type AccordionSingleProps, type AccordionSize, AccordionTrigger, type AccordionTriggerProps, type AccordionVariant, accordionContentVariants, accordionRootVariants, accordionTriggerVariants };