@gv-tech/design-system 2.4.0 → 2.5.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1371) hide show
  1. package/dist/accordion.cjs.js +1 -1
  2. package/dist/accordion.cjs.js.map +1 -1
  3. package/dist/accordion.es.js +2 -2
  4. package/dist/accordion.es.js.map +1 -1
  5. package/dist/alert-dialog.cjs.js +1 -1
  6. package/dist/alert-dialog.cjs.js.map +1 -1
  7. package/dist/alert-dialog.es.js +10 -4
  8. package/dist/alert-dialog.es.js.map +1 -1
  9. package/dist/alert.cjs.js +1 -1
  10. package/dist/alert.cjs.js.map +1 -1
  11. package/dist/alert.es.js +14 -14
  12. package/dist/alert.es.js.map +1 -1
  13. package/dist/aspect-ratio.cjs.js +1 -1
  14. package/dist/aspect-ratio.cjs.js.map +1 -1
  15. package/dist/aspect-ratio.es.js +1 -1
  16. package/dist/aspect-ratio.es.js.map +1 -1
  17. package/dist/avatar.cjs.js +1 -1
  18. package/dist/avatar.cjs.js.map +1 -1
  19. package/dist/avatar.es.js +2 -2
  20. package/dist/avatar.es.js.map +1 -1
  21. package/dist/badge.cjs.js +1 -1
  22. package/dist/badge.cjs.js.map +1 -1
  23. package/dist/badge.es.js +2 -2
  24. package/dist/badge.es.js.map +1 -1
  25. package/dist/breadcrumb.cjs.js +1 -1
  26. package/dist/breadcrumb.cjs.js.map +1 -1
  27. package/dist/breadcrumb.es.js +29 -29
  28. package/dist/breadcrumb.es.js.map +1 -1
  29. package/dist/button.cjs.js +1 -1
  30. package/dist/button.cjs.js.map +1 -1
  31. package/dist/button.es.js +2 -2
  32. package/dist/button.es.js.map +1 -1
  33. package/dist/calendar.cjs.js +1 -1
  34. package/dist/calendar.cjs.js.map +1 -1
  35. package/dist/calendar.es.js +2 -2
  36. package/dist/calendar.es.js.map +1 -1
  37. package/dist/card.cjs.js +1 -1
  38. package/dist/card.cjs.js.map +1 -1
  39. package/dist/card.es.js +2 -2
  40. package/dist/card.es.js.map +1 -1
  41. package/dist/carousel.cjs.js +1 -1
  42. package/dist/carousel.cjs.js.map +1 -1
  43. package/dist/carousel.es.js +36 -40
  44. package/dist/carousel.es.js.map +1 -1
  45. package/dist/chart.cjs.js +1 -1
  46. package/dist/chart.cjs.js.map +1 -1
  47. package/dist/chart.es.js +2 -2
  48. package/dist/chart.es.js.map +1 -1
  49. package/dist/checkbox.cjs.js +1 -1
  50. package/dist/checkbox.cjs.js.map +1 -1
  51. package/dist/checkbox.es.js +16 -14
  52. package/dist/checkbox.es.js.map +1 -1
  53. package/dist/collapsible.cjs.js +1 -1
  54. package/dist/collapsible.cjs.js.map +1 -1
  55. package/dist/collapsible.es.js +1 -1
  56. package/dist/collapsible.es.js.map +1 -1
  57. package/dist/command.cjs.js +1 -1
  58. package/dist/command.cjs.js.map +1 -1
  59. package/dist/command.es.js +2 -2
  60. package/dist/command.es.js.map +1 -1
  61. package/dist/context-menu.cjs.js +1 -1
  62. package/dist/context-menu.cjs.js.map +1 -1
  63. package/dist/context-menu.es.js +6 -3
  64. package/dist/context-menu.es.js.map +1 -1
  65. package/dist/design-system.css +1 -1
  66. package/dist/dialog.cjs.js +1 -1
  67. package/dist/dialog.cjs.js.map +1 -1
  68. package/dist/dialog.es.js +11 -11
  69. package/dist/dialog.es.js.map +1 -1
  70. package/dist/drawer.cjs.js +1 -1
  71. package/dist/drawer.cjs.js.map +1 -1
  72. package/dist/drawer.es.js +2 -2
  73. package/dist/drawer.es.js.map +1 -1
  74. package/dist/dropdown-menu.cjs.js +1 -1
  75. package/dist/dropdown-menu.cjs.js.map +1 -1
  76. package/dist/dropdown-menu.es.js +6 -3
  77. package/dist/dropdown-menu.es.js.map +1 -1
  78. package/dist/form.cjs.js +1 -1
  79. package/dist/form.cjs.js.map +1 -1
  80. package/dist/form.es.js +10 -23
  81. package/dist/form.es.js.map +1 -1
  82. package/dist/hover-card.cjs.js +1 -1
  83. package/dist/hover-card.cjs.js.map +1 -1
  84. package/dist/hover-card.es.js +2 -2
  85. package/dist/hover-card.es.js.map +1 -1
  86. package/dist/index.cjs.js +1 -1
  87. package/dist/index.cjs.js.map +1 -1
  88. package/dist/index.es.js +419 -284
  89. package/dist/index.es.js.map +1 -1
  90. package/dist/input.cjs.js +1 -1
  91. package/dist/input.cjs.js.map +1 -1
  92. package/dist/input.es.js +14 -16
  93. package/dist/input.es.js.map +1 -1
  94. package/dist/label.cjs.js +1 -1
  95. package/dist/label.cjs.js.map +1 -1
  96. package/dist/label.es.js +2 -2
  97. package/dist/label.es.js.map +1 -1
  98. package/dist/menubar.cjs.js +1 -1
  99. package/dist/menubar.cjs.js.map +1 -1
  100. package/dist/menubar.es.js +2 -2
  101. package/dist/menubar.es.js.map +1 -1
  102. package/dist/navigation-menu.cjs.js +1 -1
  103. package/dist/navigation-menu.cjs.js.map +1 -1
  104. package/dist/navigation-menu.es.js +2 -2
  105. package/dist/navigation-menu.es.js.map +1 -1
  106. package/dist/packages/design-tokens/src/index.d.ts +91 -0
  107. package/dist/packages/design-tokens/src/index.d.ts.map +1 -0
  108. package/dist/packages/design-tokens/src/index.js +21 -0
  109. package/dist/packages/design-tokens/src/palette.d.ts +32 -0
  110. package/dist/packages/design-tokens/src/palette.d.ts.map +1 -0
  111. package/dist/packages/design-tokens/src/palette.js +33 -0
  112. package/dist/packages/design-tokens/src/radii.d.ts +21 -0
  113. package/dist/packages/design-tokens/src/radii.d.ts.map +1 -0
  114. package/dist/packages/design-tokens/src/radii.js +21 -0
  115. package/dist/packages/design-tokens/src/shadows.d.ts +12 -0
  116. package/dist/packages/design-tokens/src/shadows.d.ts.map +1 -0
  117. package/dist/packages/design-tokens/src/shadows.js +13 -0
  118. package/dist/packages/design-tokens/src/spacing.d.ts +30 -0
  119. package/dist/packages/design-tokens/src/spacing.d.ts.map +1 -0
  120. package/dist/packages/design-tokens/src/spacing.js +30 -0
  121. package/dist/packages/design-tokens/src/theme.d.ts +48 -0
  122. package/dist/packages/design-tokens/src/theme.d.ts.map +1 -0
  123. package/dist/packages/design-tokens/src/theme.js +50 -0
  124. package/dist/packages/design-tokens/src/typography.d.ts +33 -0
  125. package/dist/packages/design-tokens/src/typography.d.ts.map +1 -0
  126. package/dist/packages/design-tokens/src/typography.js +33 -0
  127. package/dist/packages/ui-core/src/contracts/accordion.d.ts +20 -0
  128. package/dist/packages/ui-core/src/contracts/accordion.d.ts.map +1 -0
  129. package/dist/packages/ui-core/src/contracts/accordion.js +1 -0
  130. package/dist/packages/ui-core/src/contracts/alert-dialog.d.ts +40 -0
  131. package/dist/packages/ui-core/src/contracts/alert-dialog.d.ts.map +1 -0
  132. package/dist/packages/ui-core/src/contracts/alert-dialog.js +1 -0
  133. package/dist/packages/ui-core/src/contracts/alert.d.ts +15 -0
  134. package/dist/packages/ui-core/src/contracts/alert.d.ts.map +1 -0
  135. package/dist/packages/ui-core/src/contracts/alert.js +1 -0
  136. package/dist/packages/ui-core/src/contracts/aspect-ratio.d.ts +7 -0
  137. package/dist/packages/ui-core/src/contracts/aspect-ratio.d.ts.map +1 -0
  138. package/dist/packages/ui-core/src/contracts/aspect-ratio.js +1 -0
  139. package/dist/packages/ui-core/src/contracts/avatar.d.ts +15 -0
  140. package/dist/packages/ui-core/src/contracts/avatar.d.ts.map +1 -0
  141. package/dist/packages/ui-core/src/contracts/avatar.js +1 -0
  142. package/dist/packages/ui-core/src/contracts/badge.d.ts +7 -0
  143. package/dist/packages/ui-core/src/contracts/badge.d.ts.map +1 -0
  144. package/dist/packages/ui-core/src/contracts/badge.js +1 -0
  145. package/dist/packages/ui-core/src/contracts/breadcrumb.d.ts +31 -0
  146. package/dist/packages/ui-core/src/contracts/breadcrumb.d.ts.map +1 -0
  147. package/dist/packages/ui-core/src/contracts/breadcrumb.js +1 -0
  148. package/dist/packages/ui-core/src/contracts/button.d.ts +10 -0
  149. package/dist/packages/ui-core/src/contracts/button.d.ts.map +1 -0
  150. package/dist/packages/ui-core/src/contracts/button.js +4 -0
  151. package/dist/packages/ui-core/src/contracts/calendar.d.ts +5 -0
  152. package/dist/packages/ui-core/src/contracts/calendar.d.ts.map +1 -0
  153. package/dist/packages/ui-core/src/contracts/calendar.js +1 -0
  154. package/dist/packages/ui-core/src/contracts/card.d.ts +6 -0
  155. package/dist/packages/ui-core/src/contracts/card.d.ts.map +1 -0
  156. package/dist/packages/ui-core/src/contracts/card.js +3 -0
  157. package/dist/packages/ui-core/src/contracts/carousel.d.ts +25 -0
  158. package/dist/packages/ui-core/src/contracts/carousel.d.ts.map +1 -0
  159. package/dist/packages/ui-core/src/contracts/carousel.js +1 -0
  160. package/dist/packages/ui-core/src/contracts/chart.d.ts +34 -0
  161. package/dist/packages/ui-core/src/contracts/chart.d.ts.map +1 -0
  162. package/dist/packages/ui-core/src/contracts/chart.js +1 -0
  163. package/dist/packages/ui-core/src/contracts/checkbox.d.ts +8 -0
  164. package/dist/packages/ui-core/src/contracts/checkbox.d.ts.map +1 -0
  165. package/dist/packages/ui-core/src/contracts/checkbox.js +3 -0
  166. package/dist/packages/ui-core/src/contracts/collapsible.d.ts +19 -0
  167. package/dist/packages/ui-core/src/contracts/collapsible.d.ts.map +1 -0
  168. package/dist/packages/ui-core/src/contracts/collapsible.js +1 -0
  169. package/dist/packages/ui-core/src/contracts/command.d.ts +36 -0
  170. package/dist/packages/ui-core/src/contracts/command.d.ts.map +1 -0
  171. package/dist/packages/ui-core/src/contracts/command.js +1 -0
  172. package/dist/packages/ui-core/src/contracts/context-menu.d.ts +65 -0
  173. package/dist/packages/ui-core/src/contracts/context-menu.d.ts.map +1 -0
  174. package/dist/packages/ui-core/src/contracts/context-menu.js +1 -0
  175. package/dist/packages/ui-core/src/contracts/dialog.d.ts +14 -0
  176. package/dist/packages/ui-core/src/contracts/dialog.d.ts.map +1 -0
  177. package/dist/packages/ui-core/src/contracts/dialog.js +3 -0
  178. package/dist/packages/ui-core/src/contracts/drawer.d.ts +32 -0
  179. package/dist/packages/ui-core/src/contracts/drawer.d.ts.map +1 -0
  180. package/dist/packages/ui-core/src/contracts/drawer.js +1 -0
  181. package/dist/packages/ui-core/src/contracts/dropdown-menu.d.ts +74 -0
  182. package/dist/packages/ui-core/src/contracts/dropdown-menu.d.ts.map +1 -0
  183. package/dist/packages/ui-core/src/contracts/dropdown-menu.js +1 -0
  184. package/dist/packages/ui-core/src/contracts/form.d.ts +24 -0
  185. package/dist/packages/ui-core/src/contracts/form.d.ts.map +1 -0
  186. package/dist/packages/ui-core/src/contracts/form.js +1 -0
  187. package/dist/packages/ui-core/src/contracts/hover-card.d.ts +19 -0
  188. package/dist/packages/ui-core/src/contracts/hover-card.d.ts.map +1 -0
  189. package/dist/packages/ui-core/src/contracts/hover-card.js +1 -0
  190. package/dist/packages/ui-core/src/contracts/input.d.ts +6 -0
  191. package/dist/packages/ui-core/src/contracts/input.d.ts.map +1 -0
  192. package/dist/packages/ui-core/src/contracts/input.js +3 -0
  193. package/dist/packages/ui-core/src/contracts/label.d.ts +7 -0
  194. package/dist/packages/ui-core/src/contracts/label.d.ts.map +1 -0
  195. package/dist/packages/ui-core/src/contracts/label.js +1 -0
  196. package/dist/packages/ui-core/src/contracts/menubar.d.ts +74 -0
  197. package/dist/packages/ui-core/src/contracts/menubar.d.ts.map +1 -0
  198. package/dist/packages/ui-core/src/contracts/menubar.js +1 -0
  199. package/dist/packages/ui-core/src/contracts/navigation-menu.d.ts +48 -0
  200. package/dist/packages/ui-core/src/contracts/navigation-menu.d.ts.map +1 -0
  201. package/dist/packages/ui-core/src/contracts/navigation-menu.js +1 -0
  202. package/dist/packages/ui-core/src/contracts/pagination.d.ts +32 -0
  203. package/dist/packages/ui-core/src/contracts/pagination.d.ts.map +1 -0
  204. package/dist/packages/ui-core/src/contracts/pagination.js +1 -0
  205. package/dist/packages/ui-core/src/contracts/popover.d.ts +25 -0
  206. package/dist/packages/ui-core/src/contracts/popover.d.ts.map +1 -0
  207. package/dist/packages/ui-core/src/contracts/popover.js +1 -0
  208. package/dist/packages/ui-core/src/contracts/progress.d.ts +5 -0
  209. package/dist/packages/ui-core/src/contracts/progress.d.ts.map +1 -0
  210. package/dist/packages/ui-core/src/contracts/progress.js +1 -0
  211. package/dist/packages/ui-core/src/contracts/radio.d.ts +10 -0
  212. package/dist/packages/ui-core/src/contracts/radio.d.ts.map +1 -0
  213. package/dist/packages/ui-core/src/contracts/radio.js +3 -0
  214. package/dist/packages/ui-core/src/contracts/resizable.d.ts +39 -0
  215. package/dist/packages/ui-core/src/contracts/resizable.d.ts.map +1 -0
  216. package/dist/packages/ui-core/src/contracts/resizable.js +1 -0
  217. package/dist/packages/ui-core/src/contracts/scroll-area.d.ts +14 -0
  218. package/dist/packages/ui-core/src/contracts/scroll-area.d.ts.map +1 -0
  219. package/dist/packages/ui-core/src/contracts/scroll-area.js +1 -0
  220. package/dist/packages/ui-core/src/contracts/search.d.ts +12 -0
  221. package/dist/packages/ui-core/src/contracts/search.d.ts.map +1 -0
  222. package/dist/packages/ui-core/src/contracts/search.js +1 -0
  223. package/dist/packages/ui-core/src/contracts/select.d.ts +55 -0
  224. package/dist/packages/ui-core/src/contracts/select.d.ts.map +1 -0
  225. package/dist/packages/ui-core/src/contracts/select.js +1 -0
  226. package/dist/packages/ui-core/src/contracts/separator.d.ts +6 -0
  227. package/dist/packages/ui-core/src/contracts/separator.d.ts.map +1 -0
  228. package/dist/packages/ui-core/src/contracts/separator.js +1 -0
  229. package/dist/packages/ui-core/src/contracts/sheet.d.ts +49 -0
  230. package/dist/packages/ui-core/src/contracts/sheet.d.ts.map +1 -0
  231. package/dist/packages/ui-core/src/contracts/sheet.js +1 -0
  232. package/dist/packages/ui-core/src/contracts/skeleton.d.ts +6 -0
  233. package/dist/packages/ui-core/src/contracts/skeleton.d.ts.map +1 -0
  234. package/dist/packages/ui-core/src/contracts/skeleton.js +1 -0
  235. package/dist/packages/ui-core/src/contracts/slider.d.ts +16 -0
  236. package/dist/packages/ui-core/src/contracts/slider.d.ts.map +1 -0
  237. package/dist/packages/ui-core/src/contracts/slider.js +1 -0
  238. package/dist/packages/ui-core/src/contracts/sonner.d.ts +16 -0
  239. package/dist/packages/ui-core/src/contracts/sonner.d.ts.map +1 -0
  240. package/dist/packages/ui-core/src/contracts/sonner.js +1 -0
  241. package/dist/packages/ui-core/src/contracts/switch.d.ts +12 -0
  242. package/dist/packages/ui-core/src/contracts/switch.d.ts.map +1 -0
  243. package/dist/packages/ui-core/src/contracts/switch.js +1 -0
  244. package/dist/packages/ui-core/src/contracts/table.d.ts +34 -0
  245. package/dist/packages/ui-core/src/contracts/table.d.ts.map +1 -0
  246. package/dist/packages/ui-core/src/contracts/table.js +1 -0
  247. package/dist/packages/ui-core/src/contracts/tabs.d.ts +28 -0
  248. package/dist/packages/ui-core/src/contracts/tabs.d.ts.map +1 -0
  249. package/dist/packages/ui-core/src/contracts/tabs.js +1 -0
  250. package/dist/packages/ui-core/src/contracts/text.d.ts +7 -0
  251. package/dist/packages/ui-core/src/contracts/text.d.ts.map +1 -0
  252. package/dist/packages/ui-core/src/contracts/text.js +3 -0
  253. package/dist/packages/ui-core/src/contracts/textarea.d.ts +8 -0
  254. package/dist/packages/ui-core/src/contracts/textarea.d.ts.map +1 -0
  255. package/dist/packages/ui-core/src/contracts/textarea.js +1 -0
  256. package/dist/packages/ui-core/src/contracts/theme-provider.d.ts +14 -0
  257. package/dist/packages/ui-core/src/contracts/theme-provider.d.ts.map +1 -0
  258. package/dist/packages/ui-core/src/contracts/theme-provider.js +1 -0
  259. package/dist/packages/ui-core/src/contracts/theme-toggle.d.ts +16 -0
  260. package/dist/packages/ui-core/src/contracts/theme-toggle.d.ts.map +1 -0
  261. package/dist/packages/ui-core/src/contracts/theme-toggle.js +1 -0
  262. package/dist/packages/ui-core/src/contracts/toast.d.ts +11 -0
  263. package/dist/packages/ui-core/src/contracts/toast.d.ts.map +1 -0
  264. package/dist/packages/ui-core/src/contracts/toast.js +3 -0
  265. package/dist/packages/ui-core/src/contracts/toaster.d.ts +4 -0
  266. package/dist/packages/ui-core/src/contracts/toaster.d.ts.map +1 -0
  267. package/dist/packages/ui-core/src/contracts/toaster.js +1 -0
  268. package/dist/packages/ui-core/src/contracts/toggle-group.d.ts +22 -0
  269. package/dist/packages/ui-core/src/contracts/toggle-group.d.ts.map +1 -0
  270. package/dist/packages/ui-core/src/contracts/toggle-group.js +1 -0
  271. package/dist/packages/ui-core/src/contracts/toggle.d.ts +29 -0
  272. package/dist/packages/ui-core/src/contracts/toggle.d.ts.map +1 -0
  273. package/dist/packages/ui-core/src/contracts/toggle.js +29 -0
  274. package/dist/packages/ui-core/src/contracts/tooltip.d.ts +25 -0
  275. package/dist/packages/ui-core/src/contracts/tooltip.d.ts.map +1 -0
  276. package/dist/packages/ui-core/src/contracts/tooltip.js +1 -0
  277. package/dist/packages/ui-core/src/index.d.ts +55 -0
  278. package/dist/packages/ui-core/src/index.d.ts.map +1 -0
  279. package/dist/packages/ui-core/src/index.js +12 -0
  280. package/dist/packages/ui-native/src/accordion.d.ts +46 -0
  281. package/dist/packages/ui-native/src/accordion.d.ts.map +1 -0
  282. package/dist/packages/ui-native/src/accordion.js +34 -0
  283. package/dist/packages/ui-native/src/alert-dialog.d.ts +59 -0
  284. package/dist/packages/ui-native/src/alert-dialog.d.ts.map +1 -0
  285. package/dist/packages/ui-native/src/alert-dialog.js +31 -0
  286. package/dist/packages/ui-native/src/alert.d.ts +10 -0
  287. package/dist/packages/ui-native/src/alert.d.ts.map +1 -0
  288. package/dist/packages/ui-native/src/alert.js +26 -0
  289. package/dist/packages/ui-native/src/aspect-ratio.d.ts +2 -0
  290. package/dist/packages/ui-native/src/aspect-ratio.d.ts.map +1 -0
  291. package/dist/packages/ui-native/src/aspect-ratio.js +5 -0
  292. package/dist/packages/ui-native/src/avatar.d.ts +15 -0
  293. package/dist/packages/ui-native/src/avatar.d.ts.map +1 -0
  294. package/dist/packages/ui-native/src/avatar.js +11 -0
  295. package/dist/packages/ui-native/src/badge.d.ts +12 -0
  296. package/dist/packages/ui-native/src/badge.d.ts.map +1 -0
  297. package/dist/packages/ui-native/src/badge.js +37 -0
  298. package/dist/packages/ui-native/src/breadcrumb.d.ts +2 -0
  299. package/dist/packages/ui-native/src/breadcrumb.d.ts.map +1 -0
  300. package/dist/packages/ui-native/src/breadcrumb.js +5 -0
  301. package/dist/packages/ui-native/src/button.d.ts +14 -0
  302. package/dist/packages/ui-native/src/button.d.ts.map +1 -0
  303. package/dist/packages/ui-native/src/button.js +50 -0
  304. package/dist/packages/ui-native/src/calendar.d.ts +2 -0
  305. package/dist/packages/ui-native/src/calendar.d.ts.map +1 -0
  306. package/dist/packages/ui-native/src/calendar.js +5 -0
  307. package/dist/packages/ui-native/src/card.d.ts +13 -0
  308. package/dist/packages/ui-native/src/card.d.ts.map +1 -0
  309. package/dist/packages/ui-native/src/card.js +18 -0
  310. package/dist/packages/ui-native/src/carousel.d.ts +2 -0
  311. package/dist/packages/ui-native/src/carousel.d.ts.map +1 -0
  312. package/dist/packages/ui-native/src/carousel.js +5 -0
  313. package/dist/packages/ui-native/src/chart.d.ts +2 -0
  314. package/dist/packages/ui-native/src/chart.d.ts.map +1 -0
  315. package/dist/packages/ui-native/src/chart.js +5 -0
  316. package/dist/packages/ui-native/src/checkbox.d.ts +15 -0
  317. package/dist/packages/ui-native/src/checkbox.d.ts.map +1 -0
  318. package/dist/packages/ui-native/src/checkbox.js +11 -0
  319. package/dist/packages/ui-native/src/collapsible.d.ts +21 -0
  320. package/dist/packages/ui-native/src/collapsible.d.ts.map +1 -0
  321. package/dist/packages/ui-native/src/collapsible.js +5 -0
  322. package/dist/packages/ui-native/src/command.d.ts +2 -0
  323. package/dist/packages/ui-native/src/command.d.ts.map +1 -0
  324. package/dist/packages/ui-native/src/command.js +5 -0
  325. package/dist/packages/ui-native/src/context-menu.d.ts +2 -0
  326. package/dist/packages/ui-native/src/context-menu.d.ts.map +1 -0
  327. package/dist/packages/ui-native/src/context-menu.js +5 -0
  328. package/dist/packages/ui-native/src/dialog.d.ts +56 -0
  329. package/dist/packages/ui-native/src/dialog.d.ts.map +1 -0
  330. package/dist/packages/ui-native/src/dialog.js +28 -0
  331. package/dist/packages/ui-native/src/drawer.d.ts +2 -0
  332. package/dist/packages/ui-native/src/drawer.d.ts.map +1 -0
  333. package/dist/packages/ui-native/src/drawer.js +5 -0
  334. package/dist/packages/ui-native/src/dropdown-menu.d.ts +2 -0
  335. package/dist/packages/ui-native/src/dropdown-menu.d.ts.map +1 -0
  336. package/dist/packages/ui-native/src/dropdown-menu.js +5 -0
  337. package/dist/packages/ui-native/src/form.d.ts +2 -0
  338. package/dist/packages/ui-native/src/form.d.ts.map +1 -0
  339. package/dist/packages/ui-native/src/form.js +5 -0
  340. package/dist/packages/ui-native/src/hover-card.d.ts +2 -0
  341. package/dist/packages/ui-native/src/hover-card.d.ts.map +1 -0
  342. package/dist/packages/ui-native/src/hover-card.js +5 -0
  343. package/dist/packages/ui-native/src/index.d.ts +61 -0
  344. package/dist/packages/ui-native/src/index.d.ts.map +1 -0
  345. package/dist/packages/ui-native/src/index.js +107 -0
  346. package/dist/packages/ui-native/src/input.d.ts +8 -0
  347. package/dist/packages/ui-native/src/input.d.ts.map +1 -0
  348. package/dist/packages/ui-native/src/input.js +9 -0
  349. package/dist/packages/ui-native/src/label.d.ts +9 -0
  350. package/dist/packages/ui-native/src/label.d.ts.map +1 -0
  351. package/dist/packages/ui-native/src/label.js +7 -0
  352. package/dist/packages/ui-native/src/lib/render-native.d.ts +4 -0
  353. package/dist/packages/ui-native/src/lib/render-native.d.ts.map +1 -0
  354. package/dist/packages/ui-native/src/lib/render-native.js +13 -0
  355. package/dist/packages/ui-native/src/lib/utils.d.ts.map +1 -0
  356. package/dist/packages/ui-native/src/lib/utils.js +5 -0
  357. package/dist/packages/ui-native/src/menubar.d.ts +2 -0
  358. package/dist/packages/ui-native/src/menubar.d.ts.map +1 -0
  359. package/dist/packages/ui-native/src/menubar.js +5 -0
  360. package/dist/packages/ui-native/src/navigation-menu.d.ts +2 -0
  361. package/dist/packages/ui-native/src/navigation-menu.d.ts.map +1 -0
  362. package/dist/packages/ui-native/src/navigation-menu.js +5 -0
  363. package/dist/packages/ui-native/src/pagination.d.ts +2 -0
  364. package/dist/packages/ui-native/src/pagination.d.ts.map +1 -0
  365. package/dist/packages/ui-native/src/pagination.js +5 -0
  366. package/dist/packages/ui-native/src/popover.d.ts +2 -0
  367. package/dist/packages/ui-native/src/popover.d.ts.map +1 -0
  368. package/dist/packages/ui-native/src/popover.js +5 -0
  369. package/dist/packages/ui-native/src/progress.d.ts +2 -0
  370. package/dist/packages/ui-native/src/progress.d.ts.map +1 -0
  371. package/dist/packages/ui-native/src/progress.js +5 -0
  372. package/dist/packages/ui-native/src/radio-group.d.ts +11 -0
  373. package/dist/packages/ui-native/src/radio-group.d.ts.map +1 -0
  374. package/dist/packages/ui-native/src/radio-group.js +14 -0
  375. package/dist/packages/ui-native/src/resizable.d.ts +4 -0
  376. package/dist/packages/ui-native/src/resizable.d.ts.map +1 -0
  377. package/dist/packages/ui-native/src/resizable.js +11 -0
  378. package/dist/packages/ui-native/src/scroll-area.d.ts +2 -0
  379. package/dist/packages/ui-native/src/scroll-area.d.ts.map +1 -0
  380. package/dist/packages/ui-native/src/scroll-area.js +5 -0
  381. package/dist/packages/ui-native/src/search.d.ts +3 -0
  382. package/dist/packages/ui-native/src/search.d.ts.map +1 -0
  383. package/dist/packages/ui-native/src/search.js +8 -0
  384. package/dist/packages/ui-native/src/select.d.ts +57 -0
  385. package/dist/packages/ui-native/src/select.d.ts.map +1 -0
  386. package/dist/packages/ui-native/src/select.js +45 -0
  387. package/dist/packages/ui-native/src/separator.d.ts +9 -0
  388. package/dist/packages/ui-native/src/separator.d.ts.map +1 -0
  389. package/dist/packages/ui-native/src/separator.js +7 -0
  390. package/dist/packages/ui-native/src/sheet.d.ts +53 -0
  391. package/dist/packages/ui-native/src/sheet.d.ts.map +1 -0
  392. package/dist/packages/ui-native/src/sheet.js +37 -0
  393. package/dist/packages/ui-native/src/skeleton.d.ts +5 -0
  394. package/dist/packages/ui-native/src/skeleton.d.ts.map +1 -0
  395. package/dist/packages/ui-native/src/skeleton.js +15 -0
  396. package/dist/packages/ui-native/src/slider.d.ts +2 -0
  397. package/dist/packages/ui-native/src/slider.d.ts.map +1 -0
  398. package/dist/packages/ui-native/src/slider.js +5 -0
  399. package/dist/packages/ui-native/src/sonner.d.ts +2 -0
  400. package/dist/packages/ui-native/src/sonner.d.ts.map +1 -0
  401. package/dist/packages/ui-native/src/sonner.js +5 -0
  402. package/dist/packages/ui-native/src/switch.d.ts +8 -0
  403. package/dist/packages/ui-native/src/switch.d.ts.map +1 -0
  404. package/dist/packages/ui-native/src/switch.js +7 -0
  405. package/dist/packages/ui-native/src/table.d.ts +12 -0
  406. package/dist/packages/ui-native/src/table.d.ts.map +1 -0
  407. package/dist/packages/ui-native/src/table.js +22 -0
  408. package/dist/packages/ui-native/src/tabs.d.ts +25 -0
  409. package/dist/packages/ui-native/src/tabs.d.ts.map +1 -0
  410. package/dist/packages/ui-native/src/tabs.js +16 -0
  411. package/dist/packages/ui-native/src/text.d.ts +13 -0
  412. package/dist/packages/ui-native/src/text.d.ts.map +1 -0
  413. package/dist/packages/ui-native/src/text.js +29 -0
  414. package/dist/packages/ui-native/src/textarea.d.ts +6 -0
  415. package/dist/packages/ui-native/src/textarea.d.ts.map +1 -0
  416. package/dist/packages/ui-native/src/textarea.js +9 -0
  417. package/dist/packages/ui-native/src/theme-provider.d.ts +5 -0
  418. package/dist/packages/ui-native/src/theme-provider.d.ts.map +1 -0
  419. package/dist/packages/ui-native/src/theme-provider.js +5 -0
  420. package/dist/packages/ui-native/src/theme-toggle.d.ts +2 -0
  421. package/dist/packages/ui-native/src/theme-toggle.d.ts.map +1 -0
  422. package/dist/packages/ui-native/src/theme-toggle.js +5 -0
  423. package/dist/packages/ui-native/src/toast.d.ts +35 -0
  424. package/dist/packages/ui-native/src/toast.d.ts.map +1 -0
  425. package/dist/packages/ui-native/src/toast.js +23 -0
  426. package/dist/packages/ui-native/src/toaster.d.ts.map +1 -0
  427. package/dist/packages/ui-native/src/toaster.js +5 -0
  428. package/dist/packages/ui-native/src/toggle-group.d.ts +11 -0
  429. package/dist/packages/ui-native/src/toggle-group.d.ts.map +1 -0
  430. package/dist/packages/ui-native/src/toggle-group.js +25 -0
  431. package/dist/packages/ui-native/src/toggle.d.ts +8 -0
  432. package/dist/packages/ui-native/src/toggle.d.ts.map +1 -0
  433. package/dist/packages/ui-native/src/toggle.js +9 -0
  434. package/dist/packages/ui-native/src/tooltip.d.ts +27 -0
  435. package/dist/packages/ui-native/src/tooltip.d.ts.map +1 -0
  436. package/dist/packages/ui-native/src/tooltip.js +15 -0
  437. package/dist/packages/ui-web/src/accordion.d.ts +10 -0
  438. package/dist/packages/ui-web/src/accordion.d.ts.map +1 -0
  439. package/dist/packages/ui-web/src/accordion.js +13 -0
  440. package/dist/packages/ui-web/src/alert-dialog.d.ts +23 -0
  441. package/dist/packages/ui-web/src/alert-dialog.d.ts.map +1 -0
  442. package/dist/packages/ui-web/src/alert-dialog.js +25 -0
  443. package/dist/packages/ui-web/src/alert.d.ts +11 -0
  444. package/dist/packages/ui-web/src/alert.d.ts.map +1 -0
  445. package/dist/packages/ui-web/src/alert.js +24 -0
  446. package/dist/packages/ui-web/src/aspect-ratio.d.ts +6 -0
  447. package/dist/packages/ui-web/src/aspect-ratio.d.ts.map +1 -0
  448. package/dist/packages/ui-web/src/aspect-ratio.js +3 -0
  449. package/dist/packages/ui-web/src/avatar.d.ts +9 -0
  450. package/dist/packages/ui-web/src/avatar.d.ts.map +1 -0
  451. package/dist/packages/ui-web/src/avatar.js +11 -0
  452. package/dist/packages/ui-web/src/badge.d.ts +11 -0
  453. package/dist/packages/ui-web/src/badge.d.ts.map +1 -0
  454. package/dist/packages/ui-web/src/badge.js +20 -0
  455. package/dist/packages/ui-web/src/breadcrumb.d.ts +20 -0
  456. package/dist/packages/ui-web/src/breadcrumb.d.ts.map +1 -0
  457. package/dist/packages/ui-web/src/breadcrumb.js +23 -0
  458. package/dist/packages/ui-web/src/button.d.ts +13 -0
  459. package/dist/packages/ui-web/src/button.d.ts.map +1 -0
  460. package/dist/packages/ui-web/src/button.js +33 -0
  461. package/dist/packages/ui-web/src/calendar.d.ts +11 -0
  462. package/dist/packages/ui-web/src/calendar.d.ts.map +1 -0
  463. package/dist/packages/ui-web/src/calendar.js +70 -0
  464. package/dist/packages/ui-web/src/card.d.ts +12 -0
  465. package/dist/packages/ui-web/src/card.d.ts.map +1 -0
  466. package/dist/packages/ui-web/src/card.js +16 -0
  467. package/dist/packages/ui-web/src/carousel.d.ts +24 -0
  468. package/dist/packages/ui-web/src/carousel.d.ts.map +1 -0
  469. package/dist/packages/ui-web/src/carousel.js +98 -0
  470. package/dist/packages/ui-web/src/chart.d.ts +39 -0
  471. package/dist/packages/ui-web/src/chart.d.ts.map +1 -0
  472. package/dist/packages/ui-web/src/chart.js +120 -0
  473. package/dist/packages/ui-web/src/checkbox.d.ts +8 -0
  474. package/dist/packages/ui-web/src/checkbox.d.ts.map +1 -0
  475. package/dist/packages/ui-web/src/checkbox.js +8 -0
  476. package/dist/packages/ui-web/src/collapsible.d.ts +8 -0
  477. package/dist/packages/ui-web/src/collapsible.d.ts.map +1 -0
  478. package/dist/packages/ui-web/src/collapsible.js +5 -0
  479. package/dist/packages/ui-web/src/command.d.ts +83 -0
  480. package/dist/packages/ui-web/src/command.d.ts.map +1 -0
  481. package/dist/packages/ui-web/src/command.js +29 -0
  482. package/dist/packages/ui-web/src/context-menu.d.ts +24 -0
  483. package/dist/packages/ui-web/src/context-menu.d.ts.map +1 -0
  484. package/dist/packages/ui-web/src/context-menu.js +32 -0
  485. package/dist/packages/ui-web/src/dialog.d.ts.map +1 -0
  486. package/dist/packages/ui-web/src/dialog.js +22 -0
  487. package/dist/packages/ui-web/src/drawer.d.ts +25 -0
  488. package/dist/packages/ui-web/src/drawer.d.ts.map +1 -0
  489. package/dist/packages/ui-web/src/drawer.js +23 -0
  490. package/dist/packages/ui-web/src/dropdown-menu.d.ts +24 -0
  491. package/dist/packages/ui-web/src/dropdown-menu.d.ts.map +1 -0
  492. package/dist/packages/ui-web/src/dropdown-menu.js +33 -0
  493. package/dist/packages/ui-web/src/form.d.ts +26 -0
  494. package/dist/packages/ui-web/src/form.d.ts.map +1 -0
  495. package/dist/packages/ui-web/src/form.js +64 -0
  496. package/dist/packages/ui-web/src/hooks/use-theme.d.ts.map +1 -0
  497. package/dist/packages/ui-web/src/hooks/use-theme.js +12 -0
  498. package/dist/packages/ui-web/src/hooks/use-toast.d.ts +45 -0
  499. package/dist/packages/ui-web/src/hooks/use-toast.d.ts.map +1 -0
  500. package/dist/packages/ui-web/src/hooks/use-toast.js +128 -0
  501. package/dist/packages/ui-web/src/hover-card.d.ts +9 -0
  502. package/dist/packages/ui-web/src/hover-card.d.ts.map +1 -0
  503. package/dist/packages/ui-web/src/hover-card.js +10 -0
  504. package/dist/packages/ui-web/src/index.d.ts +101 -0
  505. package/dist/packages/ui-web/src/index.d.ts.map +1 -0
  506. package/dist/packages/ui-web/src/index.js +106 -0
  507. package/dist/packages/ui-web/src/input.d.ts +7 -0
  508. package/dist/packages/ui-web/src/input.d.ts.map +1 -0
  509. package/dist/packages/ui-web/src/input.js +8 -0
  510. package/dist/packages/ui-web/src/label.d.ts +8 -0
  511. package/dist/packages/ui-web/src/label.d.ts.map +1 -0
  512. package/dist/packages/ui-web/src/label.js +10 -0
  513. package/dist/packages/ui-web/src/lib/utils.d.ts +3 -0
  514. package/dist/packages/ui-web/src/lib/utils.d.ts.map +1 -0
  515. package/dist/packages/ui-web/src/lib/utils.js +5 -0
  516. package/dist/packages/ui-web/src/menubar.d.ts +25 -0
  517. package/dist/packages/ui-web/src/menubar.d.ts.map +1 -0
  518. package/dist/packages/ui-web/src/menubar.js +46 -0
  519. package/dist/packages/ui-web/src/navigation-menu.d.ts +15 -0
  520. package/dist/packages/ui-web/src/navigation-menu.d.ts.map +1 -0
  521. package/dist/packages/ui-web/src/navigation-menu.js +23 -0
  522. package/dist/packages/ui-web/src/pagination.d.ts +31 -0
  523. package/dist/packages/ui-web/src/pagination.d.ts.map +1 -0
  524. package/dist/packages/ui-web/src/pagination.js +23 -0
  525. package/dist/packages/ui-web/src/popover.d.ts +10 -0
  526. package/dist/packages/ui-web/src/popover.d.ts.map +1 -0
  527. package/dist/packages/ui-web/src/popover.js +11 -0
  528. package/dist/packages/ui-web/src/progress.d.ts +7 -0
  529. package/dist/packages/ui-web/src/progress.d.ts.map +1 -0
  530. package/dist/packages/ui-web/src/progress.js +8 -0
  531. package/dist/packages/ui-web/src/radio-group.d.ts +11 -0
  532. package/dist/packages/ui-web/src/radio-group.d.ts.map +1 -0
  533. package/dist/packages/ui-web/src/radio-group.js +14 -0
  534. package/dist/packages/ui-web/src/resizable.d.ts +9 -0
  535. package/dist/packages/ui-web/src/resizable.d.ts.map +1 -0
  536. package/dist/packages/ui-web/src/resizable.js +17 -0
  537. package/dist/packages/ui-web/src/scroll-area.d.ts +8 -0
  538. package/dist/packages/ui-web/src/scroll-area.d.ts.map +1 -0
  539. package/dist/packages/ui-web/src/scroll-area.js +10 -0
  540. package/dist/packages/ui-web/src/search.d.ts +8 -0
  541. package/dist/packages/ui-web/src/search.d.ts.map +1 -0
  542. package/dist/packages/ui-web/src/search.js +48 -0
  543. package/dist/packages/ui-web/src/select.d.ts +16 -0
  544. package/dist/packages/ui-web/src/select.d.ts.map +1 -0
  545. package/dist/packages/ui-web/src/select.js +26 -0
  546. package/dist/packages/ui-web/src/separator.d.ts +7 -0
  547. package/dist/packages/ui-web/src/separator.d.ts.map +1 -0
  548. package/dist/packages/ui-web/src/separator.js +8 -0
  549. package/dist/packages/ui-web/src/sheet.d.ts +28 -0
  550. package/dist/packages/ui-web/src/sheet.d.ts.map +1 -0
  551. package/dist/packages/ui-web/src/sheet.js +37 -0
  552. package/dist/packages/ui-web/src/skeleton.d.ts +6 -0
  553. package/dist/packages/ui-web/src/skeleton.d.ts.map +1 -0
  554. package/dist/packages/ui-web/src/skeleton.js +6 -0
  555. package/dist/packages/ui-web/src/slider.d.ts +7 -0
  556. package/dist/packages/ui-web/src/slider.d.ts.map +1 -0
  557. package/dist/packages/ui-web/src/slider.js +8 -0
  558. package/dist/packages/ui-web/src/sonner.d.ts +8 -0
  559. package/dist/packages/ui-web/src/sonner.d.ts.map +1 -0
  560. package/dist/packages/ui-web/src/sonner.js +16 -0
  561. package/dist/packages/ui-web/src/switch.d.ts +7 -0
  562. package/dist/packages/ui-web/src/switch.d.ts.map +1 -0
  563. package/dist/packages/ui-web/src/switch.js +8 -0
  564. package/dist/packages/ui-web/src/table.d.ts +13 -0
  565. package/dist/packages/ui-web/src/table.d.ts.map +1 -0
  566. package/dist/packages/ui-web/src/table.js +21 -0
  567. package/dist/packages/ui-web/src/tabs.d.ts +10 -0
  568. package/dist/packages/ui-web/src/tabs.d.ts.map +1 -0
  569. package/dist/packages/ui-web/src/tabs.js +13 -0
  570. package/dist/packages/ui-web/src/text.d.ts +12 -0
  571. package/dist/packages/ui-web/src/text.d.ts.map +1 -0
  572. package/dist/packages/ui-web/src/text.js +40 -0
  573. package/dist/packages/ui-web/src/textarea.d.ts +7 -0
  574. package/dist/packages/ui-web/src/textarea.d.ts.map +1 -0
  575. package/dist/packages/ui-web/src/textarea.js +9 -0
  576. package/dist/packages/ui-web/src/theme-provider.d.ts +5 -0
  577. package/dist/packages/ui-web/src/theme-provider.d.ts.map +1 -0
  578. package/dist/packages/ui-web/src/theme-provider.js +6 -0
  579. package/dist/packages/ui-web/src/theme-toggle.d.ts +4 -0
  580. package/dist/packages/ui-web/src/theme-toggle.d.ts.map +1 -0
  581. package/dist/packages/ui-web/src/theme-toggle.js +29 -0
  582. package/dist/packages/ui-web/src/toast.d.ts.map +1 -0
  583. package/dist/packages/ui-web/src/toast.js +33 -0
  584. package/dist/packages/ui-web/src/toaster.d.ts +3 -0
  585. package/dist/packages/ui-web/src/toaster.d.ts.map +1 -0
  586. package/dist/packages/ui-web/src/toaster.js +10 -0
  587. package/dist/packages/ui-web/src/toggle-group.d.ts +13 -0
  588. package/dist/packages/ui-web/src/toggle-group.d.ts.map +1 -0
  589. package/dist/packages/ui-web/src/toggle-group.js +21 -0
  590. package/dist/packages/ui-web/src/toggle.d.ts +9 -0
  591. package/dist/packages/ui-web/src/toggle.d.ts.map +1 -0
  592. package/dist/packages/ui-web/src/toggle.js +9 -0
  593. package/dist/packages/ui-web/src/tooltip.d.ts +13 -0
  594. package/dist/packages/ui-web/src/tooltip.d.ts.map +1 -0
  595. package/dist/packages/ui-web/src/tooltip.js +12 -0
  596. package/dist/pagination.cjs.js +1 -1
  597. package/dist/pagination.cjs.js.map +1 -1
  598. package/dist/pagination.es.js +13 -5
  599. package/dist/pagination.es.js.map +1 -1
  600. package/dist/popover.cjs.js +1 -1
  601. package/dist/popover.cjs.js.map +1 -1
  602. package/dist/popover.es.js +2 -2
  603. package/dist/popover.es.js.map +1 -1
  604. package/dist/progress.cjs.js +1 -1
  605. package/dist/progress.cjs.js.map +1 -1
  606. package/dist/progress.es.js +2 -2
  607. package/dist/progress.es.js.map +1 -1
  608. package/dist/radio-group.cjs.js +1 -1
  609. package/dist/radio-group.cjs.js.map +1 -1
  610. package/dist/radio-group.es.js +19 -15
  611. package/dist/radio-group.es.js.map +1 -1
  612. package/dist/resizable.cjs.js +1 -1
  613. package/dist/resizable.cjs.js.map +1 -1
  614. package/dist/resizable.es.js +2 -2
  615. package/dist/resizable.es.js.map +1 -1
  616. package/dist/scroll-area.cjs.js +1 -1
  617. package/dist/scroll-area.cjs.js.map +1 -1
  618. package/dist/scroll-area.es.js +2 -2
  619. package/dist/scroll-area.es.js.map +1 -1
  620. package/dist/search.cjs.js +1 -1
  621. package/dist/search.cjs.js.map +1 -1
  622. package/dist/search.es.js +20 -29
  623. package/dist/search.es.js.map +1 -1
  624. package/dist/select.cjs.js +1 -1
  625. package/dist/select.cjs.js.map +1 -1
  626. package/dist/select.es.js +2 -2
  627. package/dist/select.es.js.map +1 -1
  628. package/dist/separator.cjs.js +1 -1
  629. package/dist/separator.cjs.js.map +1 -1
  630. package/dist/separator.es.js +2 -2
  631. package/dist/separator.es.js.map +1 -1
  632. package/dist/sheet.cjs.js +1 -1
  633. package/dist/sheet.cjs.js.map +1 -1
  634. package/dist/sheet.es.js +7 -7
  635. package/dist/sheet.es.js.map +1 -1
  636. package/dist/skeleton.cjs.js +1 -1
  637. package/dist/skeleton.cjs.js.map +1 -1
  638. package/dist/skeleton.es.js +2 -2
  639. package/dist/skeleton.es.js.map +1 -1
  640. package/dist/slider.cjs.js +1 -1
  641. package/dist/slider.cjs.js.map +1 -1
  642. package/dist/slider.es.js +2 -2
  643. package/dist/slider.es.js.map +1 -1
  644. package/dist/sonner.cjs.js +1 -1
  645. package/dist/sonner.cjs.js.map +1 -1
  646. package/dist/sonner.es.js +1 -1
  647. package/dist/sonner.es.js.map +1 -1
  648. package/dist/src/index.d.ts +4 -0
  649. package/dist/src/index.d.ts.map +1 -0
  650. package/dist/src/index.js +3 -0
  651. package/dist/switch.cjs.js +1 -1
  652. package/dist/switch.cjs.js.map +1 -1
  653. package/dist/switch.es.js +2 -2
  654. package/dist/switch.es.js.map +1 -1
  655. package/dist/table.cjs.js +1 -1
  656. package/dist/table.cjs.js.map +1 -1
  657. package/dist/table.es.js +25 -37
  658. package/dist/table.es.js.map +1 -1
  659. package/dist/tabs.cjs.js +1 -1
  660. package/dist/tabs.cjs.js.map +1 -1
  661. package/dist/tabs.es.js +2 -2
  662. package/dist/tabs.es.js.map +1 -1
  663. package/dist/text.cjs.js +2 -0
  664. package/dist/text.cjs.js.map +1 -0
  665. package/dist/text.es.js +42 -0
  666. package/dist/text.es.js.map +1 -0
  667. package/dist/textarea.cjs.js +1 -1
  668. package/dist/textarea.cjs.js.map +1 -1
  669. package/dist/textarea.es.js +13 -15
  670. package/dist/textarea.es.js.map +1 -1
  671. package/dist/theme-provider.cjs.js +1 -1
  672. package/dist/theme-provider.cjs.js.map +1 -1
  673. package/dist/theme-provider.es.js +1 -1
  674. package/dist/theme-provider.es.js.map +1 -1
  675. package/dist/theme-toggle-BTT5z37-.js +2 -0
  676. package/dist/theme-toggle-BTT5z37-.js.map +1 -0
  677. package/dist/theme-toggle-Dhc53hqa.mjs +176 -0
  678. package/dist/theme-toggle-Dhc53hqa.mjs.map +1 -0
  679. package/dist/theme-toggle.cjs.js +1 -1
  680. package/dist/theme-toggle.es.js +3 -3
  681. package/dist/toast.cjs.js +1 -1
  682. package/dist/toast.cjs.js.map +1 -1
  683. package/dist/toast.es.js +2 -2
  684. package/dist/toast.es.js.map +1 -1
  685. package/dist/toaster-BOqCGbZ6.js +2 -0
  686. package/dist/toaster-BOqCGbZ6.js.map +1 -0
  687. package/dist/toaster-CmNmQ6jI.mjs +119 -0
  688. package/dist/toaster-CmNmQ6jI.mjs.map +1 -0
  689. package/dist/toaster.cjs.js +1 -1
  690. package/dist/toaster.es.js +2 -2
  691. package/dist/toggle-CYawMoye.mjs +25 -0
  692. package/dist/toggle-CYawMoye.mjs.map +1 -0
  693. package/dist/toggle-Dmzk_m4r.js +2 -0
  694. package/dist/toggle-Dmzk_m4r.js.map +1 -0
  695. package/dist/toggle-group.cjs.js +1 -1
  696. package/dist/toggle-group.cjs.js.map +1 -1
  697. package/dist/toggle-group.es.js +26 -22
  698. package/dist/toggle-group.es.js.map +1 -1
  699. package/dist/toggle.cjs.js +1 -1
  700. package/dist/toggle.cjs.js.map +1 -1
  701. package/dist/toggle.es.js +10 -26
  702. package/dist/toggle.es.js.map +1 -1
  703. package/dist/tooltip.cjs.js +1 -1
  704. package/dist/tooltip.cjs.js.map +1 -1
  705. package/dist/tooltip.es.js +25 -19
  706. package/dist/tooltip.es.js.map +1 -1
  707. package/dist/utils-5NfNUIaP.js +2 -0
  708. package/dist/utils-5NfNUIaP.js.map +1 -0
  709. package/dist/utils-BfGqxkzX.mjs +8 -0
  710. package/dist/utils-BfGqxkzX.mjs.map +1 -0
  711. package/dist/vendor-B8N-rYkV.mjs +25431 -0
  712. package/dist/vendor-B8N-rYkV.mjs.map +1 -0
  713. package/dist/vendor-D51Wvbw-.js +68 -0
  714. package/dist/vendor-D51Wvbw-.js.map +1 -0
  715. package/package.json +68 -302
  716. package/.agent/skills/dogfood-components/SKILL.md +0 -34
  717. package/.agent/skills/maintain-component/SKILL.md +0 -42
  718. package/.github/CODEOWNERS +0 -2
  719. package/.github/CONTRIBUTING.md +0 -42
  720. package/.github/FUNDING.yml +0 -4
  721. package/.github/PULL_REQUEST_TEMPLATE/build.md +0 -5
  722. package/.github/PULL_REQUEST_TEMPLATE/standard.md +0 -3
  723. package/.github/RELEASING.md +0 -37
  724. package/.github/copilot-instructions.md +0 -61
  725. package/.github/workflows/ci.yml +0 -73
  726. package/.github/workflows/codeql-analysis.yml +0 -34
  727. package/.github/workflows/release-please.yml +0 -53
  728. package/.husky/pre-commit +0 -1
  729. package/.prettierignore +0 -3
  730. package/.release-please-manifest.json +0 -3
  731. package/.tool-versions +0 -1
  732. package/.vscode/launch.json +0 -22
  733. package/.vscode/mcp.json +0 -8
  734. package/.vscode/settings.json +0 -30
  735. package/.yarn/releases/yarn-4.12.0.cjs +0 -942
  736. package/.yarnrc.yml +0 -7
  737. package/CHANGELOG.md +0 -672
  738. package/SECURITY.md +0 -9
  739. package/components.json +0 -20
  740. package/dist/App.d.ts +0 -2
  741. package/dist/App.d.ts.map +0 -1
  742. package/dist/components/docs/CodeBlock.d.ts +0 -8
  743. package/dist/components/docs/CodeBlock.d.ts.map +0 -1
  744. package/dist/components/docs/ComponentShowcase.d.ts +0 -17
  745. package/dist/components/docs/ComponentShowcase.d.ts.map +0 -1
  746. package/dist/components/docs/Footer.d.ts +0 -2
  747. package/dist/components/docs/Footer.d.ts.map +0 -1
  748. package/dist/components/docs/PropsTable.d.ts +0 -13
  749. package/dist/components/docs/PropsTable.d.ts.map +0 -1
  750. package/dist/components/docs/Sidebar.d.ts +0 -15
  751. package/dist/components/docs/Sidebar.d.ts.map +0 -1
  752. package/dist/components/docs/ThemeToggle.d.ts +0 -2
  753. package/dist/components/docs/ThemeToggle.d.ts.map +0 -1
  754. package/dist/components/docs/index.d.ts +0 -7
  755. package/dist/components/docs/index.d.ts.map +0 -1
  756. package/dist/components/ui/accordion.d.ts +0 -8
  757. package/dist/components/ui/accordion.d.ts.map +0 -1
  758. package/dist/components/ui/accordion.test.d.ts +0 -2
  759. package/dist/components/ui/accordion.test.d.ts.map +0 -1
  760. package/dist/components/ui/alert-dialog.d.ts +0 -21
  761. package/dist/components/ui/alert-dialog.d.ts.map +0 -1
  762. package/dist/components/ui/alert-dialog.test.d.ts +0 -2
  763. package/dist/components/ui/alert-dialog.test.d.ts.map +0 -1
  764. package/dist/components/ui/alert.d.ts +0 -9
  765. package/dist/components/ui/alert.d.ts.map +0 -1
  766. package/dist/components/ui/alert.test.d.ts +0 -2
  767. package/dist/components/ui/alert.test.d.ts.map +0 -1
  768. package/dist/components/ui/aspect-ratio.d.ts +0 -4
  769. package/dist/components/ui/aspect-ratio.d.ts.map +0 -1
  770. package/dist/components/ui/aspect-ratio.test.d.ts +0 -2
  771. package/dist/components/ui/aspect-ratio.test.d.ts.map +0 -1
  772. package/dist/components/ui/avatar.d.ts +0 -7
  773. package/dist/components/ui/avatar.d.ts.map +0 -1
  774. package/dist/components/ui/avatar.test.d.ts +0 -2
  775. package/dist/components/ui/avatar.test.d.ts.map +0 -1
  776. package/dist/components/ui/badge.d.ts +0 -10
  777. package/dist/components/ui/badge.d.ts.map +0 -1
  778. package/dist/components/ui/badge.test.d.ts +0 -2
  779. package/dist/components/ui/badge.test.d.ts.map +0 -1
  780. package/dist/components/ui/breadcrumb.d.ts +0 -20
  781. package/dist/components/ui/breadcrumb.d.ts.map +0 -1
  782. package/dist/components/ui/breadcrumb.test.d.ts +0 -2
  783. package/dist/components/ui/breadcrumb.test.d.ts.map +0 -1
  784. package/dist/components/ui/button.d.ts +0 -12
  785. package/dist/components/ui/button.d.ts.map +0 -1
  786. package/dist/components/ui/button.test.d.ts +0 -2
  787. package/dist/components/ui/button.test.d.ts.map +0 -1
  788. package/dist/components/ui/calendar.d.ts +0 -9
  789. package/dist/components/ui/calendar.d.ts.map +0 -1
  790. package/dist/components/ui/calendar.test.d.ts +0 -2
  791. package/dist/components/ui/calendar.test.d.ts.map +0 -1
  792. package/dist/components/ui/card.d.ts +0 -9
  793. package/dist/components/ui/card.d.ts.map +0 -1
  794. package/dist/components/ui/card.test.d.ts +0 -2
  795. package/dist/components/ui/card.test.d.ts.map +0 -1
  796. package/dist/components/ui/carousel.d.ts +0 -19
  797. package/dist/components/ui/carousel.d.ts.map +0 -1
  798. package/dist/components/ui/carousel.test.d.ts +0 -2
  799. package/dist/components/ui/carousel.test.d.ts.map +0 -1
  800. package/dist/components/ui/chart.d.ts +0 -63
  801. package/dist/components/ui/chart.d.ts.map +0 -1
  802. package/dist/components/ui/chart.test.d.ts +0 -2
  803. package/dist/components/ui/chart.test.d.ts.map +0 -1
  804. package/dist/components/ui/checkbox.d.ts +0 -5
  805. package/dist/components/ui/checkbox.d.ts.map +0 -1
  806. package/dist/components/ui/checkbox.test.d.ts +0 -2
  807. package/dist/components/ui/checkbox.test.d.ts.map +0 -1
  808. package/dist/components/ui/collapsible.d.ts +0 -6
  809. package/dist/components/ui/collapsible.d.ts.map +0 -1
  810. package/dist/components/ui/collapsible.test.d.ts +0 -2
  811. package/dist/components/ui/collapsible.test.d.ts.map +0 -1
  812. package/dist/components/ui/command.d.ts +0 -81
  813. package/dist/components/ui/command.d.ts.map +0 -1
  814. package/dist/components/ui/command.test.d.ts +0 -2
  815. package/dist/components/ui/command.test.d.ts.map +0 -1
  816. package/dist/components/ui/context-menu.d.ts +0 -28
  817. package/dist/components/ui/context-menu.d.ts.map +0 -1
  818. package/dist/components/ui/context-menu.test.d.ts +0 -2
  819. package/dist/components/ui/context-menu.test.d.ts.map +0 -1
  820. package/dist/components/ui/dialog.d.ts.map +0 -1
  821. package/dist/components/ui/dialog.test.d.ts +0 -2
  822. package/dist/components/ui/dialog.test.d.ts.map +0 -1
  823. package/dist/components/ui/drawer.d.ts +0 -23
  824. package/dist/components/ui/drawer.d.ts.map +0 -1
  825. package/dist/components/ui/drawer.test.d.ts +0 -2
  826. package/dist/components/ui/drawer.test.d.ts.map +0 -1
  827. package/dist/components/ui/dropdown-menu.d.ts +0 -28
  828. package/dist/components/ui/dropdown-menu.d.ts.map +0 -1
  829. package/dist/components/ui/dropdown-menu.test.d.ts +0 -2
  830. package/dist/components/ui/dropdown-menu.test.d.ts.map +0 -1
  831. package/dist/components/ui/form.d.ts +0 -24
  832. package/dist/components/ui/form.d.ts.map +0 -1
  833. package/dist/components/ui/form.test.d.ts +0 -2
  834. package/dist/components/ui/form.test.d.ts.map +0 -1
  835. package/dist/components/ui/hover-card.d.ts +0 -7
  836. package/dist/components/ui/hover-card.d.ts.map +0 -1
  837. package/dist/components/ui/hover-card.test.d.ts +0 -2
  838. package/dist/components/ui/hover-card.test.d.ts.map +0 -1
  839. package/dist/components/ui/input.d.ts +0 -4
  840. package/dist/components/ui/input.d.ts.map +0 -1
  841. package/dist/components/ui/input.test.d.ts +0 -2
  842. package/dist/components/ui/input.test.d.ts.map +0 -1
  843. package/dist/components/ui/label.d.ts +0 -6
  844. package/dist/components/ui/label.d.ts.map +0 -1
  845. package/dist/components/ui/label.test.d.ts +0 -2
  846. package/dist/components/ui/label.test.d.ts.map +0 -1
  847. package/dist/components/ui/menubar.d.ts +0 -29
  848. package/dist/components/ui/menubar.d.ts.map +0 -1
  849. package/dist/components/ui/menubar.test.d.ts +0 -2
  850. package/dist/components/ui/menubar.test.d.ts.map +0 -1
  851. package/dist/components/ui/navigation-menu.d.ts +0 -13
  852. package/dist/components/ui/navigation-menu.d.ts.map +0 -1
  853. package/dist/components/ui/navigation-menu.test.d.ts +0 -2
  854. package/dist/components/ui/navigation-menu.test.d.ts.map +0 -1
  855. package/dist/components/ui/pagination.d.ts +0 -29
  856. package/dist/components/ui/pagination.d.ts.map +0 -1
  857. package/dist/components/ui/pagination.test.d.ts +0 -2
  858. package/dist/components/ui/pagination.test.d.ts.map +0 -1
  859. package/dist/components/ui/popover.d.ts +0 -8
  860. package/dist/components/ui/popover.d.ts.map +0 -1
  861. package/dist/components/ui/popover.test.d.ts +0 -2
  862. package/dist/components/ui/popover.test.d.ts.map +0 -1
  863. package/dist/components/ui/progress.d.ts +0 -5
  864. package/dist/components/ui/progress.d.ts.map +0 -1
  865. package/dist/components/ui/progress.test.d.ts +0 -2
  866. package/dist/components/ui/progress.test.d.ts.map +0 -1
  867. package/dist/components/ui/radio-group.d.ts +0 -6
  868. package/dist/components/ui/radio-group.d.ts.map +0 -1
  869. package/dist/components/ui/radio-group.test.d.ts +0 -2
  870. package/dist/components/ui/radio-group.test.d.ts.map +0 -1
  871. package/dist/components/ui/resizable.d.ts +0 -11
  872. package/dist/components/ui/resizable.d.ts.map +0 -1
  873. package/dist/components/ui/resizable.test.d.ts +0 -2
  874. package/dist/components/ui/resizable.test.d.ts.map +0 -1
  875. package/dist/components/ui/scroll-area.d.ts +0 -6
  876. package/dist/components/ui/scroll-area.d.ts.map +0 -1
  877. package/dist/components/ui/scroll-area.test.d.ts +0 -2
  878. package/dist/components/ui/scroll-area.test.d.ts.map +0 -1
  879. package/dist/components/ui/search.d.ts +0 -16
  880. package/dist/components/ui/search.d.ts.map +0 -1
  881. package/dist/components/ui/search.test.d.ts +0 -2
  882. package/dist/components/ui/search.test.d.ts.map +0 -1
  883. package/dist/components/ui/select.d.ts +0 -14
  884. package/dist/components/ui/select.d.ts.map +0 -1
  885. package/dist/components/ui/select.test.d.ts +0 -2
  886. package/dist/components/ui/select.test.d.ts.map +0 -1
  887. package/dist/components/ui/separator.d.ts +0 -5
  888. package/dist/components/ui/separator.d.ts.map +0 -1
  889. package/dist/components/ui/separator.test.d.ts +0 -2
  890. package/dist/components/ui/separator.test.d.ts.map +0 -1
  891. package/dist/components/ui/sheet.d.ts +0 -26
  892. package/dist/components/ui/sheet.d.ts.map +0 -1
  893. package/dist/components/ui/sheet.test.d.ts +0 -2
  894. package/dist/components/ui/sheet.test.d.ts.map +0 -1
  895. package/dist/components/ui/skeleton.d.ts +0 -4
  896. package/dist/components/ui/skeleton.d.ts.map +0 -1
  897. package/dist/components/ui/skeleton.test.d.ts +0 -2
  898. package/dist/components/ui/skeleton.test.d.ts.map +0 -1
  899. package/dist/components/ui/slider.d.ts +0 -5
  900. package/dist/components/ui/slider.d.ts.map +0 -1
  901. package/dist/components/ui/slider.test.d.ts +0 -2
  902. package/dist/components/ui/slider.test.d.ts.map +0 -1
  903. package/dist/components/ui/sonner.d.ts +0 -6
  904. package/dist/components/ui/sonner.d.ts.map +0 -1
  905. package/dist/components/ui/sonner.test.d.ts +0 -2
  906. package/dist/components/ui/sonner.test.d.ts.map +0 -1
  907. package/dist/components/ui/switch.d.ts +0 -5
  908. package/dist/components/ui/switch.d.ts.map +0 -1
  909. package/dist/components/ui/switch.test.d.ts +0 -2
  910. package/dist/components/ui/switch.test.d.ts.map +0 -1
  911. package/dist/components/ui/table.d.ts +0 -11
  912. package/dist/components/ui/table.d.ts.map +0 -1
  913. package/dist/components/ui/table.test.d.ts +0 -2
  914. package/dist/components/ui/table.test.d.ts.map +0 -1
  915. package/dist/components/ui/tabs.d.ts +0 -8
  916. package/dist/components/ui/tabs.d.ts.map +0 -1
  917. package/dist/components/ui/tabs.test.d.ts +0 -2
  918. package/dist/components/ui/tabs.test.d.ts.map +0 -1
  919. package/dist/components/ui/textarea.d.ts +0 -4
  920. package/dist/components/ui/textarea.d.ts.map +0 -1
  921. package/dist/components/ui/textarea.test.d.ts +0 -2
  922. package/dist/components/ui/textarea.test.d.ts.map +0 -1
  923. package/dist/components/ui/theme-provider.d.ts +0 -4
  924. package/dist/components/ui/theme-provider.d.ts.map +0 -1
  925. package/dist/components/ui/theme-provider.test.d.ts +0 -2
  926. package/dist/components/ui/theme-provider.test.d.ts.map +0 -1
  927. package/dist/components/ui/theme-toggle.d.ts +0 -17
  928. package/dist/components/ui/theme-toggle.d.ts.map +0 -1
  929. package/dist/components/ui/theme-toggle.test.d.ts +0 -2
  930. package/dist/components/ui/theme-toggle.test.d.ts.map +0 -1
  931. package/dist/components/ui/toast.d.ts.map +0 -1
  932. package/dist/components/ui/toast.test.d.ts +0 -2
  933. package/dist/components/ui/toast.test.d.ts.map +0 -1
  934. package/dist/components/ui/toaster.d.ts.map +0 -1
  935. package/dist/components/ui/toggle-group.d.ts +0 -13
  936. package/dist/components/ui/toggle-group.d.ts.map +0 -1
  937. package/dist/components/ui/toggle-group.test.d.ts +0 -2
  938. package/dist/components/ui/toggle-group.test.d.ts.map +0 -1
  939. package/dist/components/ui/toggle.d.ts +0 -13
  940. package/dist/components/ui/toggle.d.ts.map +0 -1
  941. package/dist/components/ui/toggle.test.d.ts +0 -2
  942. package/dist/components/ui/toggle.test.d.ts.map +0 -1
  943. package/dist/components/ui/tooltip.d.ts +0 -8
  944. package/dist/components/ui/tooltip.d.ts.map +0 -1
  945. package/dist/components/ui/tooltip.test.d.ts +0 -2
  946. package/dist/components/ui/tooltip.test.d.ts.map +0 -1
  947. package/dist/favicon.png +0 -0
  948. package/dist/hooks/use-theme.d.ts.map +0 -1
  949. package/dist/hooks/use-theme.test.d.ts +0 -2
  950. package/dist/hooks/use-theme.test.d.ts.map +0 -1
  951. package/dist/hooks/use-toast.d.ts +0 -45
  952. package/dist/hooks/use-toast.d.ts.map +0 -1
  953. package/dist/index.d.ts +0 -54
  954. package/dist/index.d.ts.map +0 -1
  955. package/dist/index.demo.html +0 -40
  956. package/dist/lib/utils.d.ts.map +0 -1
  957. package/dist/logo192.png +0 -0
  958. package/dist/logo512.png +0 -0
  959. package/dist/main.d.ts +0 -2
  960. package/dist/main.d.ts.map +0 -1
  961. package/dist/manifest.json +0 -25
  962. package/dist/pages/ColorTokensDocs.d.ts +0 -2
  963. package/dist/pages/ColorTokensDocs.d.ts.map +0 -1
  964. package/dist/pages/GettingStarted.d.ts +0 -3
  965. package/dist/pages/GettingStarted.d.ts.map +0 -1
  966. package/dist/pages/components/AccordionDocs.d.ts +0 -2
  967. package/dist/pages/components/AccordionDocs.d.ts.map +0 -1
  968. package/dist/pages/components/AlertDialogDocs.d.ts +0 -2
  969. package/dist/pages/components/AlertDialogDocs.d.ts.map +0 -1
  970. package/dist/pages/components/AlertDocs.d.ts +0 -2
  971. package/dist/pages/components/AlertDocs.d.ts.map +0 -1
  972. package/dist/pages/components/AspectRatioDocs.d.ts +0 -2
  973. package/dist/pages/components/AspectRatioDocs.d.ts.map +0 -1
  974. package/dist/pages/components/AvatarDocs.d.ts +0 -2
  975. package/dist/pages/components/AvatarDocs.d.ts.map +0 -1
  976. package/dist/pages/components/BadgeDocs.d.ts +0 -2
  977. package/dist/pages/components/BadgeDocs.d.ts.map +0 -1
  978. package/dist/pages/components/BreadcrumbDocs.d.ts +0 -2
  979. package/dist/pages/components/BreadcrumbDocs.d.ts.map +0 -1
  980. package/dist/pages/components/ButtonDocs.d.ts +0 -2
  981. package/dist/pages/components/ButtonDocs.d.ts.map +0 -1
  982. package/dist/pages/components/CalendarDocs.d.ts +0 -2
  983. package/dist/pages/components/CalendarDocs.d.ts.map +0 -1
  984. package/dist/pages/components/CardDocs.d.ts +0 -2
  985. package/dist/pages/components/CardDocs.d.ts.map +0 -1
  986. package/dist/pages/components/CarouselDocs.d.ts +0 -2
  987. package/dist/pages/components/CarouselDocs.d.ts.map +0 -1
  988. package/dist/pages/components/ChartDocs.d.ts +0 -2
  989. package/dist/pages/components/ChartDocs.d.ts.map +0 -1
  990. package/dist/pages/components/CheckboxDocs.d.ts +0 -2
  991. package/dist/pages/components/CheckboxDocs.d.ts.map +0 -1
  992. package/dist/pages/components/CollapsibleDocs.d.ts +0 -2
  993. package/dist/pages/components/CollapsibleDocs.d.ts.map +0 -1
  994. package/dist/pages/components/CommandDocs.d.ts +0 -2
  995. package/dist/pages/components/CommandDocs.d.ts.map +0 -1
  996. package/dist/pages/components/ContextMenuDocs.d.ts +0 -2
  997. package/dist/pages/components/ContextMenuDocs.d.ts.map +0 -1
  998. package/dist/pages/components/DialogDocs.d.ts +0 -2
  999. package/dist/pages/components/DialogDocs.d.ts.map +0 -1
  1000. package/dist/pages/components/DrawerDocs.d.ts +0 -2
  1001. package/dist/pages/components/DrawerDocs.d.ts.map +0 -1
  1002. package/dist/pages/components/DropdownMenuDocs.d.ts +0 -2
  1003. package/dist/pages/components/DropdownMenuDocs.d.ts.map +0 -1
  1004. package/dist/pages/components/FormDocs.d.ts +0 -2
  1005. package/dist/pages/components/FormDocs.d.ts.map +0 -1
  1006. package/dist/pages/components/HoverCardDocs.d.ts +0 -2
  1007. package/dist/pages/components/HoverCardDocs.d.ts.map +0 -1
  1008. package/dist/pages/components/InputDocs.d.ts +0 -2
  1009. package/dist/pages/components/InputDocs.d.ts.map +0 -1
  1010. package/dist/pages/components/LabelDocs.d.ts +0 -2
  1011. package/dist/pages/components/LabelDocs.d.ts.map +0 -1
  1012. package/dist/pages/components/MenubarDocs.d.ts +0 -2
  1013. package/dist/pages/components/MenubarDocs.d.ts.map +0 -1
  1014. package/dist/pages/components/NavigationMenuDocs.d.ts +0 -2
  1015. package/dist/pages/components/NavigationMenuDocs.d.ts.map +0 -1
  1016. package/dist/pages/components/PaginationDocs.d.ts +0 -2
  1017. package/dist/pages/components/PaginationDocs.d.ts.map +0 -1
  1018. package/dist/pages/components/PopoverDocs.d.ts +0 -2
  1019. package/dist/pages/components/PopoverDocs.d.ts.map +0 -1
  1020. package/dist/pages/components/ProgressDocs.d.ts +0 -2
  1021. package/dist/pages/components/ProgressDocs.d.ts.map +0 -1
  1022. package/dist/pages/components/RadioGroupDocs.d.ts +0 -2
  1023. package/dist/pages/components/RadioGroupDocs.d.ts.map +0 -1
  1024. package/dist/pages/components/ResizableDocs.d.ts +0 -2
  1025. package/dist/pages/components/ResizableDocs.d.ts.map +0 -1
  1026. package/dist/pages/components/ScrollAreaDocs.d.ts +0 -2
  1027. package/dist/pages/components/ScrollAreaDocs.d.ts.map +0 -1
  1028. package/dist/pages/components/SearchDocs.d.ts +0 -2
  1029. package/dist/pages/components/SearchDocs.d.ts.map +0 -1
  1030. package/dist/pages/components/SelectDocs.d.ts +0 -2
  1031. package/dist/pages/components/SelectDocs.d.ts.map +0 -1
  1032. package/dist/pages/components/SeparatorDocs.d.ts +0 -2
  1033. package/dist/pages/components/SeparatorDocs.d.ts.map +0 -1
  1034. package/dist/pages/components/SheetDocs.d.ts +0 -2
  1035. package/dist/pages/components/SheetDocs.d.ts.map +0 -1
  1036. package/dist/pages/components/SkeletonDocs.d.ts +0 -2
  1037. package/dist/pages/components/SkeletonDocs.d.ts.map +0 -1
  1038. package/dist/pages/components/SliderDocs.d.ts +0 -2
  1039. package/dist/pages/components/SliderDocs.d.ts.map +0 -1
  1040. package/dist/pages/components/SonnerDocs.d.ts +0 -2
  1041. package/dist/pages/components/SonnerDocs.d.ts.map +0 -1
  1042. package/dist/pages/components/SwitchDocs.d.ts +0 -2
  1043. package/dist/pages/components/SwitchDocs.d.ts.map +0 -1
  1044. package/dist/pages/components/TableDocs.d.ts +0 -2
  1045. package/dist/pages/components/TableDocs.d.ts.map +0 -1
  1046. package/dist/pages/components/TabsDocs.d.ts +0 -2
  1047. package/dist/pages/components/TabsDocs.d.ts.map +0 -1
  1048. package/dist/pages/components/TextareaDocs.d.ts +0 -2
  1049. package/dist/pages/components/TextareaDocs.d.ts.map +0 -1
  1050. package/dist/pages/components/ThemeToggleDocs.d.ts +0 -2
  1051. package/dist/pages/components/ThemeToggleDocs.d.ts.map +0 -1
  1052. package/dist/pages/components/ToastDocs.d.ts +0 -2
  1053. package/dist/pages/components/ToastDocs.d.ts.map +0 -1
  1054. package/dist/pages/components/ToggleDocs.d.ts +0 -2
  1055. package/dist/pages/components/ToggleDocs.d.ts.map +0 -1
  1056. package/dist/pages/components/ToggleGroupDocs.d.ts +0 -2
  1057. package/dist/pages/components/ToggleGroupDocs.d.ts.map +0 -1
  1058. package/dist/pages/components/TooltipDocs.d.ts +0 -2
  1059. package/dist/pages/components/TooltipDocs.d.ts.map +0 -1
  1060. package/dist/pages/index.d.ts +0 -50
  1061. package/dist/pages/index.d.ts.map +0 -1
  1062. package/dist/registry/accordion.json +0 -13
  1063. package/dist/registry/accordion.test.json +0 -13
  1064. package/dist/registry/alert-dialog.json +0 -13
  1065. package/dist/registry/alert-dialog.test.json +0 -13
  1066. package/dist/registry/alert.json +0 -13
  1067. package/dist/registry/alert.test.json +0 -13
  1068. package/dist/registry/aspect-ratio.json +0 -13
  1069. package/dist/registry/aspect-ratio.test.json +0 -13
  1070. package/dist/registry/avatar.json +0 -13
  1071. package/dist/registry/avatar.test.json +0 -13
  1072. package/dist/registry/badge.json +0 -13
  1073. package/dist/registry/badge.test.json +0 -13
  1074. package/dist/registry/breadcrumb.json +0 -13
  1075. package/dist/registry/breadcrumb.test.json +0 -13
  1076. package/dist/registry/button.json +0 -13
  1077. package/dist/registry/button.test.json +0 -13
  1078. package/dist/registry/calendar.json +0 -13
  1079. package/dist/registry/calendar.test.json +0 -13
  1080. package/dist/registry/card.json +0 -13
  1081. package/dist/registry/card.test.json +0 -13
  1082. package/dist/registry/carousel.json +0 -13
  1083. package/dist/registry/carousel.test.json +0 -13
  1084. package/dist/registry/chart.json +0 -13
  1085. package/dist/registry/chart.test.json +0 -13
  1086. package/dist/registry/checkbox.json +0 -13
  1087. package/dist/registry/checkbox.test.json +0 -13
  1088. package/dist/registry/collapsible.json +0 -13
  1089. package/dist/registry/collapsible.test.json +0 -13
  1090. package/dist/registry/command.json +0 -13
  1091. package/dist/registry/command.test.json +0 -13
  1092. package/dist/registry/context-menu.json +0 -13
  1093. package/dist/registry/context-menu.test.json +0 -13
  1094. package/dist/registry/dialog.json +0 -13
  1095. package/dist/registry/dialog.test.json +0 -13
  1096. package/dist/registry/drawer.json +0 -13
  1097. package/dist/registry/drawer.test.json +0 -13
  1098. package/dist/registry/dropdown-menu.json +0 -13
  1099. package/dist/registry/dropdown-menu.test.json +0 -13
  1100. package/dist/registry/form.json +0 -13
  1101. package/dist/registry/form.test.json +0 -13
  1102. package/dist/registry/hover-card.json +0 -13
  1103. package/dist/registry/hover-card.test.json +0 -13
  1104. package/dist/registry/index.json +0 -681
  1105. package/dist/registry/input.json +0 -13
  1106. package/dist/registry/input.test.json +0 -13
  1107. package/dist/registry/label.json +0 -13
  1108. package/dist/registry/label.test.json +0 -13
  1109. package/dist/registry/menubar.json +0 -13
  1110. package/dist/registry/menubar.test.json +0 -13
  1111. package/dist/registry/navigation-menu.json +0 -13
  1112. package/dist/registry/navigation-menu.test.json +0 -13
  1113. package/dist/registry/pagination.json +0 -13
  1114. package/dist/registry/pagination.test.json +0 -13
  1115. package/dist/registry/popover.json +0 -13
  1116. package/dist/registry/popover.test.json +0 -13
  1117. package/dist/registry/progress.json +0 -13
  1118. package/dist/registry/progress.test.json +0 -13
  1119. package/dist/registry/radio-group.json +0 -13
  1120. package/dist/registry/radio-group.test.json +0 -13
  1121. package/dist/registry/resizable.json +0 -13
  1122. package/dist/registry/resizable.test.json +0 -13
  1123. package/dist/registry/scroll-area.json +0 -13
  1124. package/dist/registry/scroll-area.test.json +0 -13
  1125. package/dist/registry/search.json +0 -13
  1126. package/dist/registry/search.test.json +0 -13
  1127. package/dist/registry/select.json +0 -13
  1128. package/dist/registry/select.test.json +0 -13
  1129. package/dist/registry/separator.json +0 -13
  1130. package/dist/registry/separator.test.json +0 -13
  1131. package/dist/registry/sheet.json +0 -13
  1132. package/dist/registry/sheet.test.json +0 -13
  1133. package/dist/registry/skeleton.json +0 -13
  1134. package/dist/registry/skeleton.test.json +0 -13
  1135. package/dist/registry/slider.json +0 -13
  1136. package/dist/registry/slider.test.json +0 -13
  1137. package/dist/registry/sonner.json +0 -13
  1138. package/dist/registry/sonner.test.json +0 -13
  1139. package/dist/registry/switch.json +0 -13
  1140. package/dist/registry/switch.test.json +0 -13
  1141. package/dist/registry/table.json +0 -13
  1142. package/dist/registry/table.test.json +0 -13
  1143. package/dist/registry/tabs.json +0 -13
  1144. package/dist/registry/tabs.test.json +0 -13
  1145. package/dist/registry/textarea.json +0 -13
  1146. package/dist/registry/textarea.test.json +0 -13
  1147. package/dist/registry/theme-provider.json +0 -13
  1148. package/dist/registry/theme-provider.test.json +0 -13
  1149. package/dist/registry/theme-toggle.json +0 -13
  1150. package/dist/registry/theme-toggle.test.json +0 -13
  1151. package/dist/registry/toast.json +0 -13
  1152. package/dist/registry/toast.test.json +0 -13
  1153. package/dist/registry/toaster.json +0 -13
  1154. package/dist/registry/toggle-group.json +0 -13
  1155. package/dist/registry/toggle-group.test.json +0 -13
  1156. package/dist/registry/toggle.json +0 -13
  1157. package/dist/registry/toggle.test.json +0 -13
  1158. package/dist/registry/tooltip.json +0 -13
  1159. package/dist/registry/tooltip.test.json +0 -13
  1160. package/dist/robots.txt +0 -2
  1161. package/dist/setupTests.d.ts +0 -2
  1162. package/dist/setupTests.d.ts.map +0 -1
  1163. package/dist/theme/tokens.d.ts +0 -161
  1164. package/dist/theme/tokens.d.ts.map +0 -1
  1165. package/dist/theme-toggle-CCUkxY6o.mjs +0 -181
  1166. package/dist/theme-toggle-CCUkxY6o.mjs.map +0 -1
  1167. package/dist/theme-toggle-Dc_nm_32.js +0 -2
  1168. package/dist/theme-toggle-Dc_nm_32.js.map +0 -1
  1169. package/dist/toaster-BjPc-lId.js +0 -2
  1170. package/dist/toaster-BjPc-lId.js.map +0 -1
  1171. package/dist/toaster-Bk6a4gIz.mjs +0 -120
  1172. package/dist/toaster-Bk6a4gIz.mjs.map +0 -1
  1173. package/dist/utils-C9QGdMaH.mjs +0 -8
  1174. package/dist/utils-C9QGdMaH.mjs.map +0 -1
  1175. package/dist/utils-CUFNKXRW.js +0 -2
  1176. package/dist/utils-CUFNKXRW.js.map +0 -1
  1177. package/dist/vendor-CCQzmGyD.mjs +0 -25810
  1178. package/dist/vendor-CCQzmGyD.mjs.map +0 -1
  1179. package/dist/vendor-CIyDEr7H.js +0 -73
  1180. package/dist/vendor-CIyDEr7H.js.map +0 -1
  1181. package/docs/MIGRATE_TO_GVTECH_SCOPE.md +0 -74
  1182. package/eslint.config.mjs +0 -13
  1183. package/index.html +0 -13
  1184. package/postcss.config.mjs +0 -5
  1185. package/public/favicon.png +0 -0
  1186. package/public/index.demo.html +0 -40
  1187. package/public/logo192.png +0 -0
  1188. package/public/logo512.png +0 -0
  1189. package/public/manifest.json +0 -25
  1190. package/public/robots.txt +0 -2
  1191. package/release-please-config.json +0 -36
  1192. package/scripts/build-registry.ts +0 -47
  1193. package/scripts/import-all-shadcn.ts +0 -68
  1194. package/scripts/sync-exports.ts +0 -52
  1195. package/scripts/sync-tokens.ts +0 -73
  1196. package/scripts/validate.ts +0 -61
  1197. package/src/App.tsx +0 -311
  1198. package/src/components/docs/CodeBlock.tsx +0 -34
  1199. package/src/components/docs/ComponentShowcase.tsx +0 -68
  1200. package/src/components/docs/Footer.tsx +0 -138
  1201. package/src/components/docs/PropsTable.tsx +0 -43
  1202. package/src/components/docs/Sidebar.tsx +0 -176
  1203. package/src/components/docs/ThemeToggle.tsx +0 -19
  1204. package/src/components/docs/index.ts +0 -6
  1205. package/src/components/ui/accordion.test.tsx +0 -86
  1206. package/src/components/ui/accordion.tsx +0 -51
  1207. package/src/components/ui/alert-dialog.test.tsx +0 -91
  1208. package/src/components/ui/alert-dialog.tsx +0 -104
  1209. package/src/components/ui/alert.test.tsx +0 -33
  1210. package/src/components/ui/alert.tsx +0 -43
  1211. package/src/components/ui/aspect-ratio.test.tsx +0 -34
  1212. package/src/components/ui/aspect-ratio.tsx +0 -5
  1213. package/src/components/ui/avatar.test.tsx +0 -33
  1214. package/src/components/ui/avatar.tsx +0 -38
  1215. package/src/components/ui/badge.test.tsx +0 -24
  1216. package/src/components/ui/badge.tsx +0 -29
  1217. package/src/components/ui/breadcrumb.test.tsx +0 -55
  1218. package/src/components/ui/breadcrumb.tsx +0 -90
  1219. package/src/components/ui/button.test.tsx +0 -62
  1220. package/src/components/ui/button.tsx +0 -46
  1221. package/src/components/ui/calendar.test.tsx +0 -23
  1222. package/src/components/ui/calendar.tsx +0 -160
  1223. package/src/components/ui/card.test.tsx +0 -35
  1224. package/src/components/ui/card.tsx +0 -43
  1225. package/src/components/ui/carousel.test.tsx +0 -37
  1226. package/src/components/ui/carousel.tsx +0 -224
  1227. package/src/components/ui/chart.test.tsx +0 -62
  1228. package/src/components/ui/chart.tsx +0 -307
  1229. package/src/components/ui/checkbox.test.tsx +0 -30
  1230. package/src/components/ui/checkbox.tsx +0 -26
  1231. package/src/components/ui/collapsible.test.tsx +0 -51
  1232. package/src/components/ui/collapsible.tsx +0 -9
  1233. package/src/components/ui/command.test.tsx +0 -79
  1234. package/src/components/ui/command.tsx +0 -134
  1235. package/src/components/ui/context-menu.test.tsx +0 -37
  1236. package/src/components/ui/context-menu.tsx +0 -178
  1237. package/src/components/ui/dialog.test.tsx +0 -66
  1238. package/src/components/ui/dialog.tsx +0 -95
  1239. package/src/components/ui/drawer.test.tsx +0 -68
  1240. package/src/components/ui/drawer.tsx +0 -87
  1241. package/src/components/ui/dropdown-menu.test.tsx +0 -93
  1242. package/src/components/ui/dropdown-menu.tsx +0 -180
  1243. package/src/components/ui/form.test.tsx +0 -85
  1244. package/src/components/ui/form.tsx +0 -149
  1245. package/src/components/ui/hover-card.test.tsx +0 -48
  1246. package/src/components/ui/hover-card.tsx +0 -27
  1247. package/src/components/ui/input.test.tsx +0 -33
  1248. package/src/components/ui/input.tsx +0 -22
  1249. package/src/components/ui/label.test.tsx +0 -27
  1250. package/src/components/ui/label.tsx +0 -17
  1251. package/src/components/ui/menubar.test.tsx +0 -92
  1252. package/src/components/ui/menubar.tsx +0 -217
  1253. package/src/components/ui/navigation-menu.test.tsx +0 -53
  1254. package/src/components/ui/navigation-menu.tsx +0 -120
  1255. package/src/components/ui/pagination.test.tsx +0 -57
  1256. package/src/components/ui/pagination.tsx +0 -81
  1257. package/src/components/ui/popover.test.tsx +0 -31
  1258. package/src/components/ui/popover.tsx +0 -31
  1259. package/src/components/ui/progress.test.tsx +0 -18
  1260. package/src/components/ui/progress.tsx +0 -24
  1261. package/src/components/ui/radio-group.test.tsx +0 -39
  1262. package/src/components/ui/radio-group.tsx +0 -36
  1263. package/src/components/ui/resizable.test.tsx +0 -23
  1264. package/src/components/ui/resizable.tsx +0 -45
  1265. package/src/components/ui/scroll-area.test.tsx +0 -15
  1266. package/src/components/ui/scroll-area.tsx +0 -38
  1267. package/src/components/ui/search.test.tsx +0 -77
  1268. package/src/components/ui/search.tsx +0 -93
  1269. package/src/components/ui/select.test.tsx +0 -42
  1270. package/src/components/ui/select.tsx +0 -142
  1271. package/src/components/ui/separator.test.tsx +0 -16
  1272. package/src/components/ui/separator.tsx +0 -20
  1273. package/src/components/ui/sheet.test.tsx +0 -48
  1274. package/src/components/ui/sheet.tsx +0 -106
  1275. package/src/components/ui/skeleton.test.tsx +0 -13
  1276. package/src/components/ui/skeleton.tsx +0 -8
  1277. package/src/components/ui/slider.test.tsx +0 -18
  1278. package/src/components/ui/slider.tsx +0 -23
  1279. package/src/components/ui/sonner.test.tsx +0 -13
  1280. package/src/components/ui/sonner.tsx +0 -28
  1281. package/src/components/ui/switch.test.tsx +0 -22
  1282. package/src/components/ui/switch.tsx +0 -27
  1283. package/src/components/ui/table.test.tsx +0 -29
  1284. package/src/components/ui/table.tsx +0 -76
  1285. package/src/components/ui/tabs.test.tsx +0 -43
  1286. package/src/components/ui/tabs.tsx +0 -53
  1287. package/src/components/ui/textarea.test.tsx +0 -21
  1288. package/src/components/ui/textarea.tsx +0 -21
  1289. package/src/components/ui/theme-provider.test.tsx +0 -47
  1290. package/src/components/ui/theme-provider.tsx +0 -12
  1291. package/src/components/ui/theme-toggle.test.tsx +0 -49
  1292. package/src/components/ui/theme-toggle.tsx +0 -108
  1293. package/src/components/ui/toast.test.tsx +0 -42
  1294. package/src/components/ui/toast.tsx +0 -111
  1295. package/src/components/ui/toaster.tsx +0 -24
  1296. package/src/components/ui/toggle-group.test.tsx +0 -40
  1297. package/src/components/ui/toggle-group.tsx +0 -51
  1298. package/src/components/ui/toggle.test.tsx +0 -21
  1299. package/src/components/ui/toggle.tsx +0 -37
  1300. package/src/components/ui/tooltip.test.tsx +0 -25
  1301. package/src/components/ui/tooltip.tsx +0 -30
  1302. package/src/globals.css +0 -146
  1303. package/src/hooks/use-theme.test.tsx +0 -27
  1304. package/src/hooks/use-theme.ts +0 -15
  1305. package/src/hooks/use-toast.ts +0 -189
  1306. package/src/index.ts +0 -58
  1307. package/src/lib/utils.ts +0 -6
  1308. package/src/main.tsx +0 -10
  1309. package/src/pages/ColorTokensDocs.tsx +0 -218
  1310. package/src/pages/GettingStarted.tsx +0 -304
  1311. package/src/pages/components/AccordionDocs.tsx +0 -164
  1312. package/src/pages/components/AlertDialogDocs.tsx +0 -151
  1313. package/src/pages/components/AlertDocs.tsx +0 -65
  1314. package/src/pages/components/AspectRatioDocs.tsx +0 -85
  1315. package/src/pages/components/AvatarDocs.tsx +0 -82
  1316. package/src/pages/components/BadgeDocs.tsx +0 -56
  1317. package/src/pages/components/BreadcrumbDocs.tsx +0 -87
  1318. package/src/pages/components/ButtonDocs.tsx +0 -120
  1319. package/src/pages/components/CalendarDocs.tsx +0 -72
  1320. package/src/pages/components/CardDocs.tsx +0 -101
  1321. package/src/pages/components/CarouselDocs.tsx +0 -163
  1322. package/src/pages/components/ChartDocs.tsx +0 -145
  1323. package/src/pages/components/CheckboxDocs.tsx +0 -107
  1324. package/src/pages/components/CollapsibleDocs.tsx +0 -103
  1325. package/src/pages/components/CommandDocs.tsx +0 -209
  1326. package/src/pages/components/ContextMenuDocs.tsx +0 -158
  1327. package/src/pages/components/DialogDocs.tsx +0 -167
  1328. package/src/pages/components/DrawerDocs.tsx +0 -274
  1329. package/src/pages/components/DropdownMenuDocs.tsx +0 -313
  1330. package/src/pages/components/FormDocs.tsx +0 -163
  1331. package/src/pages/components/HoverCardDocs.tsx +0 -136
  1332. package/src/pages/components/InputDocs.tsx +0 -99
  1333. package/src/pages/components/LabelDocs.tsx +0 -54
  1334. package/src/pages/components/MenubarDocs.tsx +0 -290
  1335. package/src/pages/components/NavigationMenuDocs.tsx +0 -254
  1336. package/src/pages/components/PaginationDocs.tsx +0 -93
  1337. package/src/pages/components/PopoverDocs.tsx +0 -183
  1338. package/src/pages/components/ProgressDocs.tsx +0 -64
  1339. package/src/pages/components/RadioGroupDocs.tsx +0 -132
  1340. package/src/pages/components/ResizableDocs.tsx +0 -137
  1341. package/src/pages/components/ScrollAreaDocs.tsx +0 -102
  1342. package/src/pages/components/SearchDocs.tsx +0 -194
  1343. package/src/pages/components/SelectDocs.tsx +0 -158
  1344. package/src/pages/components/SeparatorDocs.tsx +0 -79
  1345. package/src/pages/components/SheetDocs.tsx +0 -178
  1346. package/src/pages/components/SkeletonDocs.tsx +0 -44
  1347. package/src/pages/components/SliderDocs.tsx +0 -110
  1348. package/src/pages/components/SonnerDocs.tsx +0 -117
  1349. package/src/pages/components/SwitchDocs.tsx +0 -86
  1350. package/src/pages/components/TableDocs.tsx +0 -139
  1351. package/src/pages/components/TabsDocs.tsx +0 -223
  1352. package/src/pages/components/TextareaDocs.tsx +0 -60
  1353. package/src/pages/components/ThemeToggleDocs.tsx +0 -296
  1354. package/src/pages/components/ToastDocs.tsx +0 -141
  1355. package/src/pages/components/ToggleDocs.tsx +0 -76
  1356. package/src/pages/components/ToggleGroupDocs.tsx +0 -131
  1357. package/src/pages/components/TooltipDocs.tsx +0 -147
  1358. package/src/pages/index.ts +0 -52
  1359. package/src/setupTests.ts +0 -47
  1360. package/src/theme/tokens.ts +0 -90
  1361. package/tsconfig.build.json +0 -12
  1362. package/tsconfig.json +0 -24
  1363. package/tsconfig.node.json +0 -11
  1364. package/vite.config.ts +0 -72
  1365. package/vitest.config.ts +0 -17
  1366. package/wrangler.toml +0 -22
  1367. /package/dist/{lib → packages/ui-native/src/lib}/utils.d.ts +0 -0
  1368. /package/dist/{components/ui → packages/ui-native/src}/toaster.d.ts +0 -0
  1369. /package/dist/{components/ui → packages/ui-web/src}/dialog.d.ts +0 -0
  1370. /package/dist/{hooks → packages/ui-web/src/hooks}/use-theme.d.ts +0 -0
  1371. /package/dist/{components/ui → packages/ui-web/src}/toast.d.ts +0 -0
@@ -1,13 +0,0 @@
1
- {
2
- "name": "aspect-ratio",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/aspect-ratio.tsx",
9
- "content": "import * as AspectRatioPrimitive from '@radix-ui/react-aspect-ratio';\n\nconst AspectRatio = AspectRatioPrimitive.Root;\n\nexport { AspectRatio };\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "aspect-ratio.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/aspect-ratio.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport { describe, expect, it } from 'vitest';\nimport { AspectRatio } from './aspect-ratio';\n\ndescribe('AspectRatio', () => {\n it('renders correctly', () => {\n const { container } = render(\n <AspectRatio ratio={16 / 9}>\n <img src=\"test.jpg\" alt=\"test\" />\n </AspectRatio>,\n );\n\n const img = screen.getByRole('img');\n expect(img).toBeInTheDocument();\n\n // Radix AspectRatio renders a wrapper with padding-bottom based on ratio\n // We can check if the wrapper style is applied\n const wrapper = container.firstChild;\n expect(wrapper).toHaveStyle({ paddingBottom: expect.stringMatching(/%$/) });\n });\n\n it('renders with custom ratio', () => {\n const { container } = render(\n <AspectRatio ratio={1 / 1}>\n <div>Square</div>\n </AspectRatio>,\n );\n\n expect(screen.getByText('Square')).toBeInTheDocument();\n const wrapper = container.firstChild;\n // 1/1 ratio should be 100% padding-bottom\n expect(wrapper).toHaveStyle({ paddingBottom: '100%' });\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "avatar",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/avatar.tsx",
9
- "content": "import * as AvatarPrimitive from '@radix-ui/react-avatar';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst Avatar = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Root>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Root\n ref={ref}\n className={cn('relative flex h-10 w-10 shrink-0 overflow-hidden rounded-full', className)}\n {...props}\n />\n));\nAvatar.displayName = AvatarPrimitive.Root.displayName;\n\nconst AvatarImage = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Image>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Image>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Image ref={ref} className={cn('aspect-square h-full w-full', className)} {...props} />\n));\nAvatarImage.displayName = AvatarPrimitive.Image.displayName;\n\nconst AvatarFallback = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Fallback>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Fallback>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Fallback\n ref={ref}\n className={cn('flex h-full w-full items-center justify-center rounded-full bg-muted', className)}\n {...props}\n />\n));\nAvatarFallback.displayName = AvatarPrimitive.Fallback.displayName;\n\nexport { Avatar, AvatarFallback, AvatarImage };\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "avatar.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/avatar.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport { describe, expect, it } from 'vitest';\nimport { Avatar, AvatarFallback, AvatarImage } from './avatar';\n\ndescribe('Avatar', () => {\n it('renders correctly', () => {\n render(\n <Avatar>\n <AvatarImage src=\"https://github.com/shadcn.png\" alt=\"@shadcn\" />\n <AvatarFallback>CN</AvatarFallback>\n </Avatar>,\n );\n\n // In JSDOM, image loading might not happen immediately or at all without mocking.\n // However, the elements should be in the DOM.\n // Radix conditionally renders Image or Fallback.\n // By default, it might render Image and hide Fallback, or vice versa depending on loading.\n\n // Let's check that the root is present\n const avatar = screen.getByText('CN')?.parentElement || screen.getByRole('img').parentElement;\n expect(avatar).toBeInTheDocument();\n });\n\n it('renders fallback when image is missing', () => {\n render(\n <Avatar>\n <AvatarFallback>CN</AvatarFallback>\n </Avatar>,\n );\n\n expect(screen.getByText('CN')).toBeInTheDocument();\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "badge",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/badge.tsx",
9
- "content": "import { cva, type VariantProps } from 'class-variance-authority';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst badgeVariants = cva(\n 'inline-flex items-center rounded-md border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2',\n {\n variants: {\n variant: {\n default: 'border-transparent bg-primary text-primary-foreground shadow hover:bg-primary/80',\n secondary: 'border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80',\n destructive: 'border-transparent bg-destructive text-destructive-foreground shadow hover:bg-destructive/80',\n outline: 'text-foreground',\n },\n },\n defaultVariants: {\n variant: 'default',\n },\n },\n);\n\nexport interface BadgeProps extends React.HTMLAttributes<HTMLDivElement>, VariantProps<typeof badgeVariants> {}\n\nfunction Badge({ className, variant, ...props }: BadgeProps) {\n return <div className={cn(badgeVariants({ variant }), className)} {...props} />;\n}\n\nexport { Badge, badgeVariants };\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "badge.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/badge.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport { describe, expect, it } from 'vitest';\nimport { Badge } from './badge';\n\ndescribe('Badge', () => {\n it('renders correctly', () => {\n render(<Badge>Test Badge</Badge>);\n expect(screen.getByText('Test Badge')).toBeInTheDocument();\n });\n\n it('renders variants', () => {\n const { rerender, getByText } = render(<Badge variant=\"default\">Default</Badge>);\n expect(getByText('Default')).toHaveClass('bg-primary');\n\n rerender(<Badge variant=\"secondary\">Secondary</Badge>);\n expect(getByText('Secondary')).toHaveClass('bg-secondary');\n\n rerender(<Badge variant=\"destructive\">Destructive</Badge>);\n expect(getByText('Destructive')).toHaveClass('bg-destructive');\n\n rerender(<Badge variant=\"outline\">Outline</Badge>);\n expect(getByText('Outline')).toHaveClass('text-foreground');\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "breadcrumb",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/breadcrumb.tsx",
9
- "content": "import { Slot } from '@radix-ui/react-slot';\nimport { ChevronRight, MoreHorizontal } from 'lucide-react';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst Breadcrumb = React.forwardRef<\n HTMLElement,\n React.ComponentPropsWithoutRef<'nav'> & {\n separator?: React.ReactNode;\n }\n>(({ ...props }, ref) => <nav ref={ref} aria-label=\"breadcrumb\" {...props} />);\nBreadcrumb.displayName = 'Breadcrumb';\n\nconst BreadcrumbList = React.forwardRef<HTMLOListElement, React.ComponentPropsWithoutRef<'ol'>>(\n ({ className, ...props }, ref) => (\n <ol\n ref={ref}\n className={cn(\n 'flex flex-wrap items-center gap-1.5 break-words text-sm text-muted-foreground sm:gap-2.5',\n className,\n )}\n {...props}\n />\n ),\n);\nBreadcrumbList.displayName = 'BreadcrumbList';\n\nconst BreadcrumbItem = React.forwardRef<HTMLLIElement, React.ComponentPropsWithoutRef<'li'>>(\n ({ className, ...props }, ref) => (\n <li ref={ref} className={cn('inline-flex items-center gap-1.5', className)} {...props} />\n ),\n);\nBreadcrumbItem.displayName = 'BreadcrumbItem';\n\nconst BreadcrumbLink = React.forwardRef<\n HTMLAnchorElement,\n React.ComponentPropsWithoutRef<'a'> & {\n asChild?: boolean;\n }\n>(({ asChild, className, ...props }, ref) => {\n const Comp = asChild ? Slot : 'a';\n\n return <Comp ref={ref} className={cn('transition-colors hover:text-foreground', className)} {...props} />;\n});\nBreadcrumbLink.displayName = 'BreadcrumbLink';\n\nconst BreadcrumbPage = React.forwardRef<HTMLSpanElement, React.ComponentPropsWithoutRef<'span'>>(\n ({ className, ...props }, ref) => (\n <span\n ref={ref}\n role=\"link\"\n aria-disabled=\"true\"\n aria-current=\"page\"\n className={cn('font-normal text-foreground', className)}\n {...props}\n />\n ),\n);\nBreadcrumbPage.displayName = 'BreadcrumbPage';\n\nconst BreadcrumbSeparator = ({ children, className, ...props }: React.ComponentProps<'li'>) => (\n <li role=\"presentation\" aria-hidden=\"true\" className={cn('[&>svg]:w-3.5 [&>svg]:h-3.5', className)} {...props}>\n {children ?? <ChevronRight />}\n </li>\n);\nBreadcrumbSeparator.displayName = 'BreadcrumbSeparator';\n\nconst BreadcrumbEllipsis = ({ className, ...props }: React.ComponentProps<'span'>) => (\n <span\n role=\"presentation\"\n aria-hidden=\"true\"\n className={cn('flex h-9 w-9 items-center justify-center', className)}\n {...props}\n >\n <MoreHorizontal className=\"h-4 w-4\" />\n <span className=\"sr-only\">More</span>\n </span>\n);\nBreadcrumbEllipsis.displayName = 'BreadcrumbElipssis';\n\nexport {\n Breadcrumb,\n BreadcrumbEllipsis,\n BreadcrumbItem,\n BreadcrumbLink,\n BreadcrumbList,\n BreadcrumbPage,\n BreadcrumbSeparator,\n};\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "breadcrumb.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/breadcrumb.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport { describe, expect, it } from 'vitest';\nimport {\n Breadcrumb,\n BreadcrumbItem,\n BreadcrumbLink,\n BreadcrumbList,\n BreadcrumbPage,\n BreadcrumbSeparator,\n} from './breadcrumb';\n\ndescribe('Breadcrumb', () => {\n it('renders correctly', () => {\n render(\n <Breadcrumb>\n <BreadcrumbList>\n <BreadcrumbItem>\n <BreadcrumbLink href=\"/\">Home</BreadcrumbLink>\n </BreadcrumbItem>\n <BreadcrumbSeparator />\n <BreadcrumbItem>\n <BreadcrumbPage>Page</BreadcrumbPage>\n </BreadcrumbItem>\n </BreadcrumbList>\n </Breadcrumb>,\n );\n\n const nav = screen.getByRole('navigation');\n expect(nav).toBeInTheDocument();\n expect(nav).toHaveAttribute('aria-label', 'breadcrumb');\n\n const links = screen.getAllByRole('link');\n expect(links).toHaveLength(2); // Link and Page (span role=\"link\")\n expect(links[0]).toHaveAttribute('href', '/');\n expect(links[1]).toHaveTextContent('Page');\n });\n\n it('renders custom separator', () => {\n render(\n <Breadcrumb>\n <BreadcrumbList>\n <BreadcrumbItem>\n <BreadcrumbLink>Home</BreadcrumbLink>\n </BreadcrumbItem>\n <BreadcrumbSeparator>/</BreadcrumbSeparator>\n <BreadcrumbItem>\n <BreadcrumbPage>Page</BreadcrumbPage>\n </BreadcrumbItem>\n </BreadcrumbList>\n </Breadcrumb>,\n );\n\n expect(screen.getByText('/')).toBeInTheDocument();\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "button",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/button.tsx",
9
- "content": "import { Slot } from '@radix-ui/react-slot';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst buttonVariants = cva(\n 'inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0',\n {\n variants: {\n variant: {\n default: 'bg-primary text-primary-foreground shadow hover:bg-primary/90',\n destructive: 'bg-destructive text-destructive-foreground shadow-sm hover:bg-destructive/90',\n outline: 'border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground',\n secondary: 'bg-secondary text-secondary-foreground shadow-sm hover:bg-secondary/80',\n ghost: 'hover:bg-accent hover:text-accent-foreground',\n link: 'text-primary underline-offset-4 hover:underline',\n },\n size: {\n default: 'h-9 px-4 py-2',\n sm: 'h-8 rounded-md px-3 text-xs',\n lg: 'h-10 rounded-md px-8',\n icon: 'h-9 w-9',\n },\n },\n defaultVariants: {\n variant: 'default',\n size: 'default',\n },\n },\n);\n\nexport interface ButtonProps\n extends React.ButtonHTMLAttributes<HTMLButtonElement>, VariantProps<typeof buttonVariants> {\n asChild?: boolean;\n}\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n ({ className, variant, size, asChild = false, ...props }, ref) => {\n const Comp = asChild ? Slot : 'button';\n return <Comp className={cn(buttonVariants({ variant, size, className }))} ref={ref} {...props} />;\n },\n);\nButton.displayName = 'Button';\n\nexport { Button, buttonVariants };\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "button.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/button.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { describe, expect, it, vi } from 'vitest';\nimport { Button } from './button';\n\ndescribe('Button', () => {\n it('renders correctly', () => {\n render(<Button>Click me</Button>);\n expect(screen.getByRole('button', { name: /click me/i })).toBeInTheDocument();\n });\n\n it('handles click events', async () => {\n const handleClick = vi.fn();\n render(<Button onClick={handleClick}>Click me</Button>);\n\n await userEvent.click(screen.getByRole('button', { name: /click me/i }));\n expect(handleClick).toHaveBeenCalledTimes(1);\n });\n\n it('can be disabled', () => {\n render(<Button disabled>Click me</Button>);\n expect(screen.getByRole('button', { name: /click me/i })).toBeDisabled();\n });\n\n it('supports asChild prop', () => {\n render(\n <Button asChild>\n <a href=\"/test\">Link Button</a>\n </Button>,\n );\n\n const link = screen.getByRole('link', { name: /link button/i });\n expect(link).toBeInTheDocument();\n expect(link).toHaveAttribute('href', '/test');\n });\n\n describe('Variants', () => {\n const variants = ['default', 'destructive', 'outline', 'secondary', 'ghost', 'link'] as const;\n\n variants.forEach((variant) => {\n it(`renders ${variant} variant`, () => {\n render(<Button variant={variant}>{variant}</Button>);\n const button = screen.getByRole('button', { name: variant });\n expect(button).toBeInTheDocument();\n // We could check for specific classes here, but that might make tests too brittle\n // checking the role and content presence is a good baseline\n });\n });\n });\n\n describe('Sizes', () => {\n const sizes = ['default', 'sm', 'lg', 'icon'] as const;\n\n sizes.forEach((size) => {\n it(`renders ${size} size`, () => {\n render(<Button size={size}>{size}</Button>);\n const button = screen.getByRole('button', { name: size });\n expect(button).toBeInTheDocument();\n });\n });\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "calendar",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/calendar.tsx",
9
- "content": "import { ChevronDownIcon, ChevronLeftIcon, ChevronRightIcon } from 'lucide-react';\nimport * as React from 'react';\nimport { DayButton, DayPicker, getDefaultClassNames } from 'react-day-picker';\n\nimport { Button, buttonVariants } from '@/components/ui/button';\nimport { cn } from '@/lib/utils';\n\nfunction Calendar({\n className,\n classNames,\n showOutsideDays = true,\n captionLayout = 'label',\n buttonVariant = 'ghost',\n formatters,\n components,\n ...props\n}: React.ComponentProps<typeof DayPicker> & {\n buttonVariant?: React.ComponentProps<typeof Button>['variant'];\n}) {\n const defaultClassNames = getDefaultClassNames();\n\n return (\n <DayPicker\n showOutsideDays={showOutsideDays}\n className={cn(\n 'bg-background group/calendar p-3 [--cell-size:2.5rem] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent',\n String.raw`rtl:**:[.rdp-button\\_next>svg]:rotate-180`,\n String.raw`rtl:**:[.rdp-button\\_previous>svg]:rotate-180`,\n 'relative',\n className,\n )}\n captionLayout={captionLayout}\n formatters={{\n formatMonthDropdown: (date) => date.toLocaleString('default', { month: 'short' }),\n ...formatters,\n }}\n classNames={{\n root: cn('w-fit', defaultClassNames.root),\n months: cn('relative flex flex-col gap-4 md:flex-row', defaultClassNames.months),\n month: cn('flex w-full flex-col gap-4', defaultClassNames.month),\n nav: cn(\n 'absolute inset-x-0 top-2 flex items-center justify-between pointer-events-none px-2',\n defaultClassNames.nav,\n ),\n button_previous: cn(\n buttonVariants({ variant: buttonVariant }),\n 'h-7 w-7 select-none p-0 aria-disabled:opacity-50 pointer-events-auto',\n defaultClassNames.button_previous,\n ),\n button_next: cn(\n buttonVariants({ variant: buttonVariant }),\n 'h-7 w-7 select-none p-0 aria-disabled:opacity-50 pointer-events-auto',\n defaultClassNames.button_next,\n ),\n month_caption: cn(\n 'flex h-[--cell-size] w-full items-center justify-center text-sm font-medium',\n defaultClassNames.month_caption,\n ),\n dropdowns: cn(\n 'flex h-[--cell-size] w-full items-center justify-center gap-1.5 text-sm font-medium',\n defaultClassNames.dropdowns,\n ),\n dropdown_root: cn(\n 'has-focus:border-ring border-input shadow-xs has-focus:ring-ring/50 has-focus:ring-[3px] relative rounded-md border',\n defaultClassNames.dropdown_root,\n ),\n dropdown: cn('bg-popover absolute inset-0 opacity-0', defaultClassNames.dropdown),\n caption_label: cn(\n 'select-none font-medium',\n captionLayout === 'label'\n ? 'text-sm'\n : '[&>svg]:text-muted-foreground flex h-8 items-center gap-1 rounded-md pl-2 pr-1 text-sm [&>svg]:size-3.5',\n defaultClassNames.caption_label,\n ),\n table: 'w-full border-collapse grow',\n weekdays: cn('flex', defaultClassNames.weekdays),\n weekday: cn(\n 'text-muted-foreground pt-1 flex-1 select-none rounded-md text-[0.8rem] font-normal uppercase',\n defaultClassNames.weekday,\n ),\n week: cn('flex w-full mt-2', defaultClassNames.week),\n week_number_header: cn('w-[--cell-size] select-none', defaultClassNames.week_number_header),\n week_number: cn('text-muted-foreground select-none text-[0.8rem]', defaultClassNames.week_number),\n day: cn(\n 'group/day relative flex aspect-square h-10 w-10 select-none items-center justify-center p-0 text-center [&:first-child[data-selected=true]_button]:rounded-l-md [&:last-child[data-selected=true]_button]:rounded-r-md',\n defaultClassNames.day,\n ),\n range_start: cn('bg-accent rounded-l-md', defaultClassNames.range_start),\n range_middle: cn('rounded-none', defaultClassNames.range_middle),\n range_end: cn('bg-accent rounded-r-md', defaultClassNames.range_end),\n today: cn(\n 'bg-accent text-accent-foreground rounded-md data-[selected=true]:rounded-none',\n defaultClassNames.today,\n ),\n outside: cn('text-muted-foreground aria-selected:text-muted-foreground', defaultClassNames.outside),\n disabled: cn('text-muted-foreground opacity-50', defaultClassNames.disabled),\n hidden: cn('invisible', defaultClassNames.hidden),\n ...classNames,\n }}\n components={{\n Root: ({ className, rootRef, ...props }) => {\n return <div data-slot=\"calendar\" ref={rootRef} className={cn(className)} {...props} />;\n },\n Chevron: ({ className, orientation, ...props }) => {\n if (orientation === 'left') {\n return <ChevronLeftIcon className={cn('size-4', className)} {...props} />;\n }\n\n if (orientation === 'right') {\n return <ChevronRightIcon className={cn('size-4', className)} {...props} />;\n }\n\n return <ChevronDownIcon className={cn('size-4', className)} {...props} />;\n },\n DayButton: CalendarDayButton,\n WeekNumber: ({ children, ...props }) => {\n return (\n <td {...props}>\n <div className=\"flex size-[--cell-size] items-center justify-center text-center\">{children}</div>\n </td>\n );\n },\n ...components,\n }}\n {...props}\n />\n );\n}\n\nfunction CalendarDayButton({ className, day, modifiers, ...props }: React.ComponentProps<typeof DayButton>) {\n const defaultClassNames = getDefaultClassNames();\n\n const ref = React.useRef<HTMLButtonElement>(null);\n React.useEffect(() => {\n if (modifiers.focused) ref.current?.focus();\n }, [modifiers.focused]);\n\n return (\n <Button\n ref={ref}\n variant=\"ghost\"\n size=\"icon\"\n data-day={day.date.toLocaleDateString()}\n data-selected-single={\n modifiers.selected && !modifiers.range_start && !modifiers.range_end && !modifiers.range_middle\n }\n data-range-start={modifiers.range_start}\n data-range-end={modifiers.range_end}\n data-range-middle={modifiers.range_middle}\n className={cn(\n 'data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-ring/50 flex aspect-square h-full w-full min-w-[--cell-size] items-center justify-center font-normal leading-none data-[range-end=true]:rounded-md data-[range-middle=true]:rounded-none data-[range-start=true]:rounded-md group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:ring-[3px] [&>span]:text-xs [&>span]:opacity-70',\n defaultClassNames.day,\n className,\n )}\n {...props}\n />\n );\n}\n\nexport { Calendar, CalendarDayButton };\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "calendar.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/calendar.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport { describe, expect, it } from 'vitest';\nimport { Calendar } from './calendar';\n\ndescribe('Calendar', () => {\n it('renders correctly', () => {\n // Mock date to consistent rendering\n const date = new Date(2023, 0, 1); // Jan 1, 2023\n\n render(<Calendar mode=\"single\" selected={date} month={date} />);\n\n expect(screen.getByText('January 2023')).toBeInTheDocument();\n const days = screen.getAllByText('1');\n expect(days.length).toBeGreaterThan(0);\n expect(screen.getByText('Su')).toBeInTheDocument(); // Sunday header\n });\n\n it('renders with class name', () => {\n const { container } = render(<Calendar className=\"test-class\" />);\n // DayPicker renders a div with the class\n expect(container.firstChild).toHaveClass('test-class');\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "card",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/card.tsx",
9
- "content": "import * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst Card = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(({ className, ...props }, ref) => (\n <div ref={ref} className={cn('rounded-xl border bg-card text-card-foreground shadow', className)} {...props} />\n));\nCard.displayName = 'Card';\n\nconst CardHeader = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div ref={ref} className={cn('flex flex-col space-y-1.5 p-6', className)} {...props} />\n ),\n);\nCardHeader.displayName = 'CardHeader';\n\nconst CardTitle = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div ref={ref} className={cn('font-semibold leading-none tracking-tight', className)} {...props} />\n ),\n);\nCardTitle.displayName = 'CardTitle';\n\nconst CardDescription = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div ref={ref} className={cn('text-sm text-muted-foreground', className)} {...props} />\n ),\n);\nCardDescription.displayName = 'CardDescription';\n\nconst CardContent = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => <div ref={ref} className={cn('p-6 pt-0', className)} {...props} />,\n);\nCardContent.displayName = 'CardContent';\n\nconst CardFooter = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div ref={ref} className={cn('flex items-center p-6 pt-0', className)} {...props} />\n ),\n);\nCardFooter.displayName = 'CardFooter';\n\nexport { Card, CardContent, CardDescription, CardFooter, CardHeader, CardTitle };\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "card.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/card.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport { describe, expect, it } from 'vitest';\nimport { Card, CardContent, CardDescription, CardFooter, CardHeader, CardTitle } from './card';\n\ndescribe('Card', () => {\n it('renders correctly', () => {\n render(\n <Card>\n <CardHeader>\n <CardTitle>Title</CardTitle>\n <CardDescription>Description</CardDescription>\n </CardHeader>\n <CardContent>Content</CardContent>\n <CardFooter>Footer</CardFooter>\n </Card>,\n );\n\n expect(screen.getByText('Title')).toBeInTheDocument();\n expect(screen.getByText('Description')).toBeInTheDocument();\n expect(screen.getByText('Content')).toBeInTheDocument();\n expect(screen.getByText('Footer')).toBeInTheDocument();\n });\n\n it('renders with class names', () => {\n const { container } = render(<Card className=\"test-class\" />);\n expect(container.firstChild).toHaveClass(\n 'test-class',\n 'rounded-xl',\n 'border',\n 'bg-card',\n 'text-card-foreground',\n 'shadow',\n );\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "carousel",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/carousel.tsx",
9
- "content": "import useEmblaCarousel, { type UseEmblaCarouselType } from 'embla-carousel-react';\nimport { ArrowLeft, ArrowRight } from 'lucide-react';\nimport * as React from 'react';\n\nimport { Button } from '@/components/ui/button';\nimport { cn } from '@/lib/utils';\n\ntype CarouselApi = UseEmblaCarouselType[1];\ntype UseCarouselParameters = Parameters<typeof useEmblaCarousel>;\ntype CarouselOptions = UseCarouselParameters[0];\ntype CarouselPlugin = UseCarouselParameters[1];\n\ntype CarouselProps = {\n opts?: CarouselOptions;\n plugins?: CarouselPlugin;\n orientation?: 'horizontal' | 'vertical';\n setApi?: (api: CarouselApi) => void;\n};\n\ntype CarouselContextProps = {\n carouselRef: ReturnType<typeof useEmblaCarousel>[0];\n api: ReturnType<typeof useEmblaCarousel>[1];\n scrollPrev: () => void;\n scrollNext: () => void;\n canScrollPrev: boolean;\n canScrollNext: boolean;\n} & CarouselProps;\n\nconst CarouselContext = React.createContext<CarouselContextProps | null>(null);\n\nfunction useCarousel() {\n const context = React.useContext(CarouselContext);\n\n if (!context) {\n throw new Error('useCarousel must be used within a <Carousel />');\n }\n\n return context;\n}\n\nconst Carousel = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement> & CarouselProps>(\n ({ orientation = 'horizontal', opts, setApi, plugins, className, children, ...props }, ref) => {\n const [carouselRef, api] = useEmblaCarousel(\n {\n ...opts,\n axis: orientation === 'horizontal' ? 'x' : 'y',\n },\n plugins,\n );\n const [canScrollPrev, setCanScrollPrev] = React.useState(false);\n const [canScrollNext, setCanScrollNext] = React.useState(false);\n\n const onSelect = React.useCallback((api: CarouselApi) => {\n if (!api) {\n return;\n }\n\n setCanScrollPrev(api.canScrollPrev());\n setCanScrollNext(api.canScrollNext());\n }, []);\n\n const scrollPrev = React.useCallback(() => {\n api?.scrollPrev();\n }, [api]);\n\n const scrollNext = React.useCallback(() => {\n api?.scrollNext();\n }, [api]);\n\n const handleKeyDown = React.useCallback(\n (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (event.key === 'ArrowLeft') {\n event.preventDefault();\n scrollPrev();\n } else if (event.key === 'ArrowRight') {\n event.preventDefault();\n scrollNext();\n }\n },\n [scrollPrev, scrollNext],\n );\n\n React.useEffect(() => {\n if (!api || !setApi) {\n return;\n }\n\n setApi(api);\n }, [api, setApi]);\n\n React.useEffect(() => {\n if (!api) {\n return;\n }\n\n onSelect(api);\n api.on('reInit', onSelect);\n api.on('select', onSelect);\n\n return () => {\n api?.off('select', onSelect);\n };\n }, [api, onSelect]);\n\n return (\n <CarouselContext.Provider\n value={{\n carouselRef,\n api: api,\n opts,\n orientation: orientation || (opts?.axis === 'y' ? 'vertical' : 'horizontal'),\n scrollPrev,\n scrollNext,\n canScrollPrev,\n canScrollNext,\n }}\n >\n <div\n ref={ref}\n onKeyDownCapture={handleKeyDown}\n className={cn('relative', className)}\n role=\"region\"\n aria-roledescription=\"carousel\"\n {...props}\n >\n {children}\n </div>\n </CarouselContext.Provider>\n );\n },\n);\nCarousel.displayName = 'Carousel';\n\nconst CarouselContent = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => {\n const { carouselRef, orientation } = useCarousel();\n\n return (\n <div ref={carouselRef} className=\"overflow-hidden\">\n <div\n ref={ref}\n className={cn('flex', orientation === 'horizontal' ? '-ml-4' : '-mt-4 flex-col', className)}\n {...props}\n />\n </div>\n );\n },\n);\nCarouselContent.displayName = 'CarouselContent';\n\nconst CarouselItem = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => {\n const { orientation } = useCarousel();\n\n return (\n <div\n ref={ref}\n role=\"group\"\n aria-roledescription=\"slide\"\n className={cn('min-w-0 shrink-0 grow-0 basis-full', orientation === 'horizontal' ? 'pl-4' : 'pt-4', className)}\n {...props}\n />\n );\n },\n);\nCarouselItem.displayName = 'CarouselItem';\n\nconst CarouselPrevious = React.forwardRef<HTMLButtonElement, React.ComponentProps<typeof Button>>(\n ({ className, variant = 'outline', size = 'icon', ...props }, ref) => {\n const { orientation, scrollPrev, canScrollPrev } = useCarousel();\n\n return (\n <Button\n ref={ref}\n variant={variant}\n size={size}\n className={cn(\n 'absolute h-8 w-8 rounded-full',\n orientation === 'horizontal'\n ? '-left-12 top-1/2 -translate-y-1/2'\n : '-top-12 left-1/2 -translate-x-1/2 rotate-90',\n className,\n )}\n disabled={!canScrollPrev}\n onClick={scrollPrev}\n {...props}\n >\n <ArrowLeft className=\"h-4 w-4\" />\n <span className=\"sr-only\">Previous slide</span>\n </Button>\n );\n },\n);\nCarouselPrevious.displayName = 'CarouselPrevious';\n\nconst CarouselNext = React.forwardRef<HTMLButtonElement, React.ComponentProps<typeof Button>>(\n ({ className, variant = 'outline', size = 'icon', ...props }, ref) => {\n const { orientation, scrollNext, canScrollNext } = useCarousel();\n\n return (\n <Button\n ref={ref}\n variant={variant}\n size={size}\n className={cn(\n 'absolute h-8 w-8 rounded-full',\n orientation === 'horizontal'\n ? '-right-12 top-1/2 -translate-y-1/2'\n : '-bottom-12 left-1/2 -translate-x-1/2 rotate-90',\n className,\n )}\n disabled={!canScrollNext}\n onClick={scrollNext}\n {...props}\n >\n <ArrowRight className=\"h-4 w-4\" />\n <span className=\"sr-only\">Next slide</span>\n </Button>\n );\n },\n);\nCarouselNext.displayName = 'CarouselNext';\n\nexport { Carousel, CarouselContent, CarouselItem, CarouselNext, CarouselPrevious, type CarouselApi };\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "carousel.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/carousel.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport { describe, expect, it } from 'vitest';\nimport { Carousel, CarouselContent, CarouselItem, CarouselNext, CarouselPrevious } from './carousel';\n\ndescribe('Carousel', () => {\n it('renders correctly', () => {\n render(\n <Carousel aria-label=\"carousel\">\n <CarouselContent>\n <CarouselItem>Slide 1</CarouselItem>\n <CarouselItem>Slide 2</CarouselItem>\n <CarouselItem>Slide 3</CarouselItem>\n </CarouselContent>\n <CarouselPrevious />\n <CarouselNext />\n </Carousel>,\n );\n\n expect(screen.getByRole('region', { name: 'carousel' })).toBeInTheDocument();\n expect(screen.getByText('Slide 1')).toBeInTheDocument();\n expect(screen.getByText('Slide 2')).toBeInTheDocument();\n expect(screen.getByText('Slide 3')).toBeInTheDocument();\n expect(screen.getByRole('button', { name: 'Previous slide' })).toBeInTheDocument();\n expect(screen.getByRole('button', { name: 'Next slide' })).toBeInTheDocument();\n });\n\n it('renders with orientation vertical', () => {\n render(\n <Carousel orientation=\"vertical\" aria-label=\"carousel\">\n <CarouselContent>\n <CarouselItem>Slide 1</CarouselItem>\n </CarouselContent>\n </Carousel>,\n );\n expect(screen.getByRole('region', { name: 'carousel' })).toBeInTheDocument();\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "chart",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/chart.tsx",
9
- "content": "import * as React from 'react';\nimport * as RechartsPrimitive from 'recharts';\n\nimport { cn } from '@/lib/utils';\n\n// Format: { THEME_NAME: CSS_SELECTOR }\nconst THEMES = { light: '', dark: '.dark' } as const;\n\nexport type ChartConfig = {\n [k in string]: {\n label?: React.ReactNode;\n icon?: React.ComponentType;\n } & ({ color?: string; theme?: never } | { color?: never; theme: Record<keyof typeof THEMES, string> });\n};\n\ntype ChartContextProps = {\n config: ChartConfig;\n};\n\nconst ChartContext = React.createContext<ChartContextProps | null>(null);\n\nfunction useChart() {\n const context = React.useContext(ChartContext);\n\n if (!context) {\n throw new Error('useChart must be used within a <ChartContainer />');\n }\n\n return context;\n}\n\nconst ChartContainer = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<'div'> & {\n config: ChartConfig;\n children: React.ComponentProps<typeof RechartsPrimitive.ResponsiveContainer>['children'];\n }\n>(({ id, className, children, config, ...props }, ref) => {\n const uniqueId = React.useId();\n const chartId = `chart-${id || uniqueId.replace(/:/g, '')}`;\n\n return (\n <ChartContext.Provider value={{ config }}>\n <div\n data-chart={chartId}\n ref={ref}\n className={cn(\n \"flex aspect-video justify-center text-xs [&_.recharts-cartesian-axis-tick_text]:fill-muted-foreground [&_.recharts-cartesian-grid_line[stroke='#ccc']]:stroke-border/50 [&_.recharts-curve.recharts-tooltip-cursor]:stroke-border [&_.recharts-dot[stroke='#fff']]:stroke-transparent [&_.recharts-layer]:outline-none [&_.recharts-polar-grid_[stroke='#ccc']]:stroke-border [&_.recharts-radial-bar-background-sector]:fill-muted [&_.recharts-rectangle.recharts-tooltip-cursor]:fill-muted [&_.recharts-reference-line_[stroke='#ccc']]:stroke-border [&_.recharts-sector[stroke='#fff']]:stroke-transparent [&_.recharts-sector]:outline-none [&_.recharts-surface]:outline-none\",\n className,\n )}\n {...props}\n >\n <ChartStyle id={chartId} config={config} />\n <RechartsPrimitive.ResponsiveContainer>{children}</RechartsPrimitive.ResponsiveContainer>\n </div>\n </ChartContext.Provider>\n );\n});\nChartContainer.displayName = 'Chart';\n\nconst ChartStyle = ({ id, config }: { id: string; config: ChartConfig }) => {\n const colorConfig = Object.entries(config).filter(([, config]) => config.theme || config.color);\n\n if (!colorConfig.length) {\n return null;\n }\n\n return (\n <style\n dangerouslySetInnerHTML={{\n __html: Object.entries(THEMES)\n .map(\n ([theme, prefix]) => `\n${prefix} [data-chart=${id}] {\n${colorConfig\n .map(([key, itemConfig]) => {\n const color = itemConfig.theme?.[theme as keyof typeof itemConfig.theme] || itemConfig.color;\n return color ? ` --color-${key}: ${color};` : null;\n })\n .join('\\n')}\n}\n`,\n )\n .join('\\n'),\n }}\n />\n );\n};\n\nconst ChartTooltip = RechartsPrimitive.Tooltip;\n\nconst ChartTooltipContent = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<typeof RechartsPrimitive.Tooltip> &\n React.ComponentProps<'div'> & {\n hideLabel?: boolean;\n hideIndicator?: boolean;\n indicator?: 'line' | 'dot' | 'dashed';\n nameKey?: string;\n labelKey?: string;\n }\n>(\n (\n {\n active,\n payload,\n className,\n indicator = 'dot',\n hideLabel = false,\n hideIndicator = false,\n label,\n labelFormatter,\n labelClassName,\n formatter,\n color,\n nameKey,\n labelKey,\n },\n ref,\n ) => {\n const { config } = useChart();\n\n const tooltipLabel = React.useMemo(() => {\n if (hideLabel || !payload?.length) {\n return null;\n }\n\n const [item] = payload;\n const key = `${labelKey || item?.dataKey || item?.name || 'value'}`;\n const itemConfig = getPayloadConfigFromPayload(config, item, key);\n const value =\n !labelKey && typeof label === 'string'\n ? config[label as keyof typeof config]?.label || label\n : itemConfig?.label;\n\n if (labelFormatter) {\n return <div className={cn('font-medium', labelClassName)}>{labelFormatter(value, payload)}</div>;\n }\n\n if (!value) {\n return null;\n }\n\n return <div className={cn('font-medium', labelClassName)}>{value}</div>;\n }, [label, labelFormatter, payload, hideLabel, labelClassName, config, labelKey]);\n\n if (!active || !payload?.length) {\n return null;\n }\n\n const nestLabel = payload.length === 1 && indicator !== 'dot';\n\n return (\n <div\n ref={ref}\n className={cn(\n 'grid min-w-[8rem] items-start gap-1.5 rounded-lg border border-border/50 bg-background px-2.5 py-1.5 text-xs shadow-xl',\n className,\n )}\n >\n {!nestLabel ? tooltipLabel : null}\n <div className=\"grid gap-1.5\">\n {payload\n .filter((item) => item.type !== 'none')\n .map((item, index) => {\n const key = `${nameKey || item.name || item.dataKey || 'value'}`;\n const itemConfig = getPayloadConfigFromPayload(config, item, key);\n const indicatorColor = color || item.payload.fill || item.color;\n\n return (\n <div\n key={item.dataKey}\n className={cn(\n 'flex w-full flex-wrap items-stretch gap-2 [&>svg]:h-2.5 [&>svg]:w-2.5 [&>svg]:text-muted-foreground',\n indicator === 'dot' && 'items-center',\n )}\n >\n {formatter && item?.value !== undefined && item.name ? (\n formatter(item.value, item.name, item, index, item.payload)\n ) : (\n <>\n {itemConfig?.icon ? (\n <itemConfig.icon />\n ) : (\n !hideIndicator && (\n <div\n className={cn('shrink-0 rounded-[2px] border-[--color-border] bg-[--color-bg]', {\n 'h-2.5 w-2.5': indicator === 'dot',\n 'w-1': indicator === 'line',\n 'w-0 border-[1.5px] border-dashed bg-transparent': indicator === 'dashed',\n 'my-0.5': nestLabel && indicator === 'dashed',\n })}\n style={\n {\n '--color-bg': indicatorColor,\n '--color-border': indicatorColor,\n } as React.CSSProperties\n }\n />\n )\n )}\n <div\n className={cn(\n 'flex flex-1 justify-between leading-none',\n nestLabel ? 'items-end' : 'items-center',\n )}\n >\n <div className=\"grid gap-1.5\">\n {nestLabel ? tooltipLabel : null}\n <span className=\"text-muted-foreground\">{itemConfig?.label || item.name}</span>\n </div>\n {item.value && (\n <span className=\"font-mono font-medium tabular-nums text-foreground\">\n {item.value.toLocaleString()}\n </span>\n )}\n </div>\n </>\n )}\n </div>\n );\n })}\n </div>\n </div>\n );\n },\n);\nChartTooltipContent.displayName = 'ChartTooltip';\n\nconst ChartLegend = RechartsPrimitive.Legend;\n\nconst ChartLegendContent = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<'div'> &\n Pick<RechartsPrimitive.LegendProps, 'payload' | 'verticalAlign'> & {\n hideIcon?: boolean;\n nameKey?: string;\n }\n>(({ className, hideIcon = false, payload, verticalAlign = 'bottom', nameKey }, ref) => {\n const { config } = useChart();\n\n if (!payload?.length) {\n return null;\n }\n\n return (\n <div\n ref={ref}\n className={cn('flex items-center justify-center gap-4', verticalAlign === 'top' ? 'pb-3' : 'pt-3', className)}\n >\n {payload\n .filter((item) => item.type !== 'none')\n .map((item) => {\n const key = `${nameKey || item.dataKey || 'value'}`;\n const itemConfig = getPayloadConfigFromPayload(config, item, key);\n\n return (\n <div\n key={item.value}\n className={cn('flex items-center gap-1.5 [&>svg]:h-3 [&>svg]:w-3 [&>svg]:text-muted-foreground')}\n >\n {itemConfig?.icon && !hideIcon ? (\n <itemConfig.icon />\n ) : (\n <div\n className=\"h-2 w-2 shrink-0 rounded-[2px]\"\n style={{\n backgroundColor: item.color,\n }}\n />\n )}\n {itemConfig?.label}\n </div>\n );\n })}\n </div>\n );\n});\nChartLegendContent.displayName = 'ChartLegend';\n\n// Helper to extract item config from a payload.\nfunction getPayloadConfigFromPayload(config: ChartConfig, payload: unknown, key: string) {\n if (typeof payload !== 'object' || payload === null) {\n return undefined;\n }\n\n const payloadPayload =\n 'payload' in payload && typeof payload.payload === 'object' && payload.payload !== null\n ? payload.payload\n : undefined;\n\n let configLabelKey: string = key;\n\n if (key in payload && typeof payload[key as keyof typeof payload] === 'string') {\n configLabelKey = payload[key as keyof typeof payload] as string;\n } else if (\n payloadPayload &&\n key in payloadPayload &&\n typeof payloadPayload[key as keyof typeof payloadPayload] === 'string'\n ) {\n configLabelKey = payloadPayload[key as keyof typeof payloadPayload] as string;\n }\n\n return configLabelKey in config ? config[configLabelKey] : config[key as keyof typeof config];\n}\n\nexport { ChartContainer, ChartLegend, ChartLegendContent, ChartStyle, ChartTooltip, ChartTooltipContent };\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "chart.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/chart.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport { Bar, BarChart, CartesianGrid, XAxis } from 'recharts';\nimport { describe, expect, it, vi } from 'vitest';\nimport { ChartContainer, ChartTooltip, ChartTooltipContent } from './chart';\n\n// Mock Recharts ResponsiveContainer to avoid ResizeObserver issues and render children immediately\nvi.mock('recharts', async (importOriginal) => {\n const original = await importOriginal();\n return {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ...(original as any),\n ResponsiveContainer: ({ children }: { children: React.ReactNode }) => (\n <div style={{ width: 500, height: 300 }}>{children}</div>\n ),\n };\n});\n\nconst chartConfig = {\n desktop: {\n label: 'Desktop',\n color: '#2563eb',\n },\n mobile: {\n label: 'Mobile',\n color: '#60a5fa',\n },\n};\n\nconst chartData = [\n { month: 'January', desktop: 186, mobile: 80 },\n { month: 'February', desktop: 305, mobile: 200 },\n];\n\ndescribe('Chart', () => {\n it('renders correctly', () => {\n render(\n <ChartContainer config={chartConfig} className=\"min-h-[200px] w-full\">\n <BarChart accessibilityLayer data={chartData} width={500} height={300}>\n <CartesianGrid vertical={false} />\n <XAxis\n dataKey=\"month\"\n tickLine={false}\n tickMargin={10}\n axisLine={false}\n tickFormatter={(value) => value.slice(0, 3)}\n />\n <ChartTooltip content={<ChartTooltipContent />} />\n <Bar dataKey=\"desktop\" fill=\"var(--color-desktop)\" radius={4} />\n <Bar dataKey=\"mobile\" fill=\"var(--color-mobile)\" radius={4} />\n </BarChart>\n </ChartContainer>,\n );\n\n // Recharts renders SVGs. We can check if the container renders.\n // The accessibilityLayer prop on BarChart adds role=\"application\" or similar?\n // Let's check for the chart container.\n // The ChartContainer adds data-chart attribute.\n // But we can check for text.\n expect(screen.getByText('Jan')).toBeInTheDocument();\n expect(screen.getByText('Feb')).toBeInTheDocument();\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "checkbox",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/checkbox.tsx",
9
- "content": "import * as CheckboxPrimitive from '@radix-ui/react-checkbox';\nimport { Check } from 'lucide-react';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst Checkbox = React.forwardRef<\n React.ElementRef<typeof CheckboxPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof CheckboxPrimitive.Root>\n>(({ className, ...props }, ref) => (\n <CheckboxPrimitive.Root\n ref={ref}\n className={cn(\n 'grid place-content-center peer h-4 w-4 shrink-0 rounded-sm border border-primary shadow focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground',\n className,\n )}\n {...props}\n >\n <CheckboxPrimitive.Indicator className={cn('grid place-content-center text-current')}>\n <Check className=\"h-4 w-4\" />\n </CheckboxPrimitive.Indicator>\n </CheckboxPrimitive.Root>\n));\nCheckbox.displayName = CheckboxPrimitive.Root.displayName;\n\nexport { Checkbox };\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "checkbox.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/checkbox.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { describe, expect, it } from 'vitest';\nimport { Checkbox } from './checkbox';\n\ndescribe('Checkbox', () => {\n it('renders correctly', () => {\n render(<Checkbox />);\n expect(screen.getByRole('checkbox')).toBeInTheDocument();\n });\n\n it('toggles checked state on click', async () => {\n const user = userEvent.setup();\n render(<Checkbox />);\n\n const checkbox = screen.getByRole('checkbox');\n expect(checkbox).not.toBeChecked();\n\n await user.click(checkbox);\n expect(checkbox).toBeChecked();\n\n await user.click(checkbox);\n expect(checkbox).not.toBeChecked();\n });\n\n it('renders disabled state', () => {\n render(<Checkbox disabled />);\n expect(screen.getByRole('checkbox')).toBeDisabled();\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "collapsible",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/collapsible.tsx",
9
- "content": "import * as CollapsiblePrimitive from '@radix-ui/react-collapsible';\n\nconst Collapsible = CollapsiblePrimitive.Root;\n\nconst CollapsibleTrigger = CollapsiblePrimitive.CollapsibleTrigger;\n\nconst CollapsibleContent = CollapsiblePrimitive.CollapsibleContent;\n\nexport { Collapsible, CollapsibleContent, CollapsibleTrigger };\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "collapsible.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/collapsible.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { describe, expect, it } from 'vitest';\nimport { Collapsible, CollapsibleContent, CollapsibleTrigger } from './collapsible';\n\ndescribe('Collapsible', () => {\n it('renders correctly', () => {\n render(\n <Collapsible>\n <CollapsibleTrigger>Toggle</CollapsibleTrigger>\n <CollapsibleContent>Content</CollapsibleContent>\n </Collapsible>,\n );\n\n expect(screen.getByRole('button', { name: 'Toggle' })).toBeInTheDocument();\n });\n\n it('toggles content visibility', async () => {\n const user = userEvent.setup();\n render(\n <Collapsible>\n <CollapsibleTrigger>Toggle</CollapsibleTrigger>\n <CollapsibleContent>Content</CollapsibleContent>\n </Collapsible>,\n );\n\n const trigger = screen.getByRole('button', { name: 'Toggle' });\n\n // Initial state: Content might be hidden or not present depending on implementation details of Radix\n // But Radix Collapsible adds data-state attribute\n expect(trigger).toHaveAttribute('data-state', 'closed');\n\n await user.click(trigger);\n expect(trigger).toHaveAttribute('data-state', 'open');\n expect(screen.getByText('Content')).toBeVisible();\n\n await user.click(trigger);\n expect(trigger).toHaveAttribute('data-state', 'closed');\n });\n\n it('renders open by default', () => {\n render(\n <Collapsible defaultOpen>\n <CollapsibleTrigger>Toggle</CollapsibleTrigger>\n <CollapsibleContent>Content</CollapsibleContent>\n </Collapsible>,\n );\n expect(screen.getByRole('button', { name: 'Toggle' })).toHaveAttribute('data-state', 'open');\n expect(screen.getByText('Content')).toBeVisible();\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "command",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/command.tsx",
9
- "content": "'use client';\n\nimport { type DialogProps } from '@radix-ui/react-dialog';\nimport { Command as CommandPrimitive } from 'cmdk';\nimport { Search } from 'lucide-react';\nimport * as React from 'react';\n\nimport { Dialog, DialogContent, DialogDescription, DialogTitle } from '@/components/ui/dialog';\nimport { cn } from '@/lib/utils';\n\nconst Command = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive\n ref={ref}\n className={cn(\n 'flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground',\n className,\n )}\n {...props}\n />\n));\nCommand.displayName = CommandPrimitive.displayName;\n\nconst CommandDialog = ({ children, ...props }: DialogProps) => {\n return (\n <Dialog {...props}>\n <DialogContent className=\"overflow-hidden p-0\">\n <DialogTitle className=\"sr-only\">Search</DialogTitle>\n <DialogDescription className=\"sr-only\">Search for documentation and components.</DialogDescription>\n <Command className=\"[&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-group]]:px-2 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5\">\n {children}\n </Command>\n </DialogContent>\n </Dialog>\n );\n};\n\nconst CommandInput = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Input>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Input>\n>(({ className, ...props }, ref) => (\n <div className=\"flex items-center border-b px-3\" cmdk-input-wrapper=\"\">\n <Search className=\"mr-2 h-4 w-4 shrink-0 opacity-50\" />\n <CommandPrimitive.Input\n ref={ref}\n className={cn(\n 'flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50',\n className,\n )}\n {...props}\n />\n </div>\n));\n\nCommandInput.displayName = CommandPrimitive.Input.displayName;\n\nconst CommandList = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.List>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.List>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.List\n ref={ref}\n className={cn('max-h-[300px] overflow-y-auto overflow-x-hidden', className)}\n {...props}\n />\n));\n\nCommandList.displayName = CommandPrimitive.List.displayName;\n\nconst CommandEmpty = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Empty>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Empty>\n>((props, ref) => <CommandPrimitive.Empty ref={ref} className=\"py-6 text-center text-sm\" {...props} />);\n\nCommandEmpty.displayName = CommandPrimitive.Empty.displayName;\n\nconst CommandGroup = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Group>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Group>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Group\n ref={ref}\n className={cn(\n 'overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground',\n className,\n )}\n {...props}\n />\n));\n\nCommandGroup.displayName = CommandPrimitive.Group.displayName;\n\nconst CommandSeparator = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Separator>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Separator ref={ref} className={cn('-mx-1 h-px bg-border', className)} {...props} />\n));\nCommandSeparator.displayName = CommandPrimitive.Separator.displayName;\n\nconst CommandItem = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Item>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Item\n ref={ref}\n className={cn(\n 'relative flex cursor-default gap-2 select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none data-[disabled=true]:pointer-events-none data-[selected=true]:bg-accent data-[selected=true]:text-accent-foreground data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0',\n className,\n )}\n {...props}\n />\n));\n\nCommandItem.displayName = CommandPrimitive.Item.displayName;\n\nconst CommandShortcut = ({ className, ...props }: React.HTMLAttributes<HTMLSpanElement>) => {\n return <span className={cn('ml-auto text-xs tracking-widest text-muted-foreground', className)} {...props} />;\n};\nCommandShortcut.displayName = 'CommandShortcut';\n\nexport {\n Command,\n CommandDialog,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n CommandSeparator,\n CommandShortcut,\n};\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "command.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/command.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { describe, expect, it } from 'vitest';\nimport { Command, CommandEmpty, CommandGroup, CommandInput, CommandItem, CommandList } from './command';\n\ndescribe('Command', () => {\n it('renders correctly', () => {\n render(\n <Command>\n <CommandInput placeholder=\"Search...\" />\n <CommandList>\n <CommandEmpty>No results found.</CommandEmpty>\n <CommandGroup heading=\"Suggestions\">\n <CommandItem>Calendar</CommandItem>\n <CommandItem>Search Emoji</CommandItem>\n <CommandItem>Calculator</CommandItem>\n </CommandGroup>\n </CommandList>\n </Command>,\n );\n\n expect(screen.getByPlaceholderText('Search...')).toBeInTheDocument();\n expect(screen.getByText('Suggestions')).toBeInTheDocument();\n expect(screen.getByText('Calendar')).toBeInTheDocument();\n });\n\n it('filters items based on input', async () => {\n const user = userEvent.setup();\n render(\n <Command>\n <CommandInput placeholder=\"Search...\" />\n <CommandList>\n <CommandGroup heading=\"Suggestions\">\n <CommandItem>Calendar</CommandItem>\n <CommandItem>Search Emoji</CommandItem>\n <CommandItem>Calculator</CommandItem>\n </CommandGroup>\n </CommandList>\n </Command>,\n );\n\n const input = screen.getByPlaceholderText('Search...');\n await user.type(input, 'Cal');\n\n expect(screen.getByText('Calendar')).toBeVisible();\n expect(screen.getByText('Calculator')).toBeVisible();\n // search emoji should be filtered out\n // Note: cmdk might just hide items, so we check if they are visible or not\n // or checks class names.\n // Let's check if Search Emoji is not visible or removed\n const emoji = screen.queryByText('Search Emoji');\n // If it's still in document but hidden, we check visibility\n if (emoji) {\n expect(emoji).not.toBeVisible();\n } else {\n expect(emoji).not.toBeInTheDocument();\n }\n });\n\n it('shows empty state when no results', async () => {\n const user = userEvent.setup();\n render(\n <Command>\n <CommandInput placeholder=\"Search...\" />\n <CommandList>\n <CommandEmpty>No results found.</CommandEmpty>\n <CommandGroup heading=\"Suggestions\">\n <CommandItem>Calendar</CommandItem>\n </CommandGroup>\n </CommandList>\n </Command>,\n );\n\n const input = screen.getByPlaceholderText('Search...');\n await user.type(input, 'XYZ');\n\n expect(screen.getByText('No results found.')).toBeVisible();\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "context-menu",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/context-menu.tsx",
9
- "content": "import * as ContextMenuPrimitive from '@radix-ui/react-context-menu';\nimport { Check, ChevronRight, Circle } from 'lucide-react';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst ContextMenu = ContextMenuPrimitive.Root;\n\nconst ContextMenuTrigger = ContextMenuPrimitive.Trigger;\n\nconst ContextMenuGroup = ContextMenuPrimitive.Group;\n\nconst ContextMenuPortal = ContextMenuPrimitive.Portal;\n\nconst ContextMenuSub = ContextMenuPrimitive.Sub;\n\nconst ContextMenuRadioGroup = ContextMenuPrimitive.RadioGroup;\n\nconst ContextMenuSubTrigger = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.SubTrigger>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.SubTrigger> & {\n inset?: boolean;\n }\n>(({ className, inset, children, ...props }, ref) => (\n <ContextMenuPrimitive.SubTrigger\n ref={ref}\n className={cn(\n 'flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[state=open]:bg-accent data-[state=open]:text-accent-foreground',\n inset && 'pl-8',\n className,\n )}\n {...props}\n >\n {children}\n <ChevronRight className=\"ml-auto h-4 w-4\" />\n </ContextMenuPrimitive.SubTrigger>\n));\nContextMenuSubTrigger.displayName = ContextMenuPrimitive.SubTrigger.displayName;\n\nconst ContextMenuSubContent = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.SubContent>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.SubContent>\n>(({ className, ...props }, ref) => (\n <ContextMenuPrimitive.SubContent\n ref={ref}\n className={cn(\n 'z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 origin-[--radix-context-menu-content-transform-origin]',\n className,\n )}\n {...props}\n />\n));\nContextMenuSubContent.displayName = ContextMenuPrimitive.SubContent.displayName;\n\nconst ContextMenuContent = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.Content>\n>(({ className, ...props }, ref) => (\n <ContextMenuPrimitive.Portal>\n <ContextMenuPrimitive.Content\n ref={ref}\n className={cn(\n 'z-50 max-h-[--radix-context-menu-content-available-height] min-w-[8rem] overflow-y-auto overflow-x-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 origin-[--radix-context-menu-content-transform-origin]',\n className,\n )}\n {...props}\n />\n </ContextMenuPrimitive.Portal>\n));\nContextMenuContent.displayName = ContextMenuPrimitive.Content.displayName;\n\nconst ContextMenuItem = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.Item> & {\n inset?: boolean;\n }\n>(({ className, inset, ...props }, ref) => (\n <ContextMenuPrimitive.Item\n ref={ref}\n className={cn(\n 'relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50',\n inset && 'pl-8',\n className,\n )}\n {...props}\n />\n));\nContextMenuItem.displayName = ContextMenuPrimitive.Item.displayName;\n\nconst ContextMenuCheckboxItem = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.CheckboxItem>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.CheckboxItem>\n>(({ className, children, checked, ...props }, ref) => (\n <ContextMenuPrimitive.CheckboxItem\n ref={ref}\n className={cn(\n 'relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50',\n className,\n )}\n checked={checked}\n {...props}\n >\n <span className=\"absolute left-2 flex h-3.5 w-3.5 items-center justify-center\">\n <ContextMenuPrimitive.ItemIndicator>\n <Check className=\"h-4 w-4\" />\n </ContextMenuPrimitive.ItemIndicator>\n </span>\n {children}\n </ContextMenuPrimitive.CheckboxItem>\n));\nContextMenuCheckboxItem.displayName = ContextMenuPrimitive.CheckboxItem.displayName;\n\nconst ContextMenuRadioItem = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.RadioItem>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.RadioItem>\n>(({ className, children, ...props }, ref) => (\n <ContextMenuPrimitive.RadioItem\n ref={ref}\n className={cn(\n 'relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50',\n className,\n )}\n {...props}\n >\n <span className=\"absolute left-2 flex h-3.5 w-3.5 items-center justify-center\">\n <ContextMenuPrimitive.ItemIndicator>\n <Circle className=\"h-4 w-4 fill-current\" />\n </ContextMenuPrimitive.ItemIndicator>\n </span>\n {children}\n </ContextMenuPrimitive.RadioItem>\n));\nContextMenuRadioItem.displayName = ContextMenuPrimitive.RadioItem.displayName;\n\nconst ContextMenuLabel = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.Label>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.Label> & {\n inset?: boolean;\n }\n>(({ className, inset, ...props }, ref) => (\n <ContextMenuPrimitive.Label\n ref={ref}\n className={cn('px-2 py-1.5 text-sm font-semibold text-foreground', inset && 'pl-8', className)}\n {...props}\n />\n));\nContextMenuLabel.displayName = ContextMenuPrimitive.Label.displayName;\n\nconst ContextMenuSeparator = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.Separator>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n <ContextMenuPrimitive.Separator ref={ref} className={cn('-mx-1 my-1 h-px bg-border', className)} {...props} />\n));\nContextMenuSeparator.displayName = ContextMenuPrimitive.Separator.displayName;\n\nconst ContextMenuShortcut = ({ className, ...props }: React.HTMLAttributes<HTMLSpanElement>) => {\n return <span className={cn('ml-auto text-xs tracking-widest text-muted-foreground', className)} {...props} />;\n};\nContextMenuShortcut.displayName = 'ContextMenuShortcut';\n\nexport {\n ContextMenu,\n ContextMenuCheckboxItem,\n ContextMenuContent,\n ContextMenuGroup,\n ContextMenuItem,\n ContextMenuLabel,\n ContextMenuPortal,\n ContextMenuRadioGroup,\n ContextMenuRadioItem,\n ContextMenuSeparator,\n ContextMenuShortcut,\n ContextMenuSub,\n ContextMenuSubContent,\n ContextMenuSubTrigger,\n ContextMenuTrigger,\n};\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "context-menu.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/context-menu.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { describe, expect, it } from 'vitest';\nimport { ContextMenu, ContextMenuContent, ContextMenuItem, ContextMenuTrigger } from './context-menu';\n\ndescribe('ContextMenu', () => {\n it('renders trigger', () => {\n render(\n <ContextMenu>\n <ContextMenuTrigger>Right click here</ContextMenuTrigger>\n <ContextMenuContent>\n <ContextMenuItem>Item 1</ContextMenuItem>\n </ContextMenuContent>\n </ContextMenu>,\n );\n\n expect(screen.getByText('Right click here')).toBeInTheDocument();\n });\n\n it('shows menu on right click', async () => {\n const user = userEvent.setup();\n render(\n <ContextMenu>\n <ContextMenuTrigger>Right click here</ContextMenuTrigger>\n <ContextMenuContent>\n <ContextMenuItem>Item 1</ContextMenuItem>\n </ContextMenuContent>\n </ContextMenu>,\n );\n\n const trigger = screen.getByText('Right click here');\n await user.pointer({ keys: '[MouseRight]', target: trigger });\n\n // Ensure item is visible. Radix UI ContextMenu might render it in a portal.\n expect(screen.getByText('Item 1')).toBeVisible();\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "dialog",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/dialog.tsx",
9
- "content": "import * as DialogPrimitive from '@radix-ui/react-dialog';\nimport { X } from 'lucide-react';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst Dialog = DialogPrimitive.Root;\n\nconst DialogTrigger = DialogPrimitive.Trigger;\n\nconst DialogPortal = DialogPrimitive.Portal;\n\nconst DialogClose = DialogPrimitive.Close;\n\nconst DialogOverlay = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Overlay>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Overlay\n ref={ref}\n className={cn(\n 'fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0',\n className,\n )}\n {...props}\n />\n));\nDialogOverlay.displayName = DialogPrimitive.Overlay.displayName;\n\nconst DialogContent = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Content>\n>(({ className, children, ...props }, ref) => (\n <DialogPortal>\n <DialogOverlay />\n <DialogPrimitive.Content\n ref={ref}\n className={cn(\n 'fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg',\n className,\n )}\n {...props}\n >\n {children}\n <DialogPrimitive.Close className=\"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground\">\n <X className=\"h-4 w-4\" />\n <span className=\"sr-only\">Close</span>\n </DialogPrimitive.Close>\n </DialogPrimitive.Content>\n </DialogPortal>\n));\nDialogContent.displayName = DialogPrimitive.Content.displayName;\n\nconst DialogHeader = ({ className, ...props }: React.HTMLAttributes<HTMLDivElement>) => (\n <div className={cn('flex flex-col space-y-1.5 text-center sm:text-left', className)} {...props} />\n);\nDialogHeader.displayName = 'DialogHeader';\n\nconst DialogFooter = ({ className, ...props }: React.HTMLAttributes<HTMLDivElement>) => (\n <div className={cn('flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2', className)} {...props} />\n);\nDialogFooter.displayName = 'DialogFooter';\n\nconst DialogTitle = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Title>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Title>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Title\n ref={ref}\n className={cn('text-lg font-semibold leading-none tracking-tight', className)}\n {...props}\n />\n));\nDialogTitle.displayName = DialogPrimitive.Title.displayName;\n\nconst DialogDescription = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Description>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Description>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Description ref={ref} className={cn('text-sm text-muted-foreground', className)} {...props} />\n));\nDialogDescription.displayName = DialogPrimitive.Description.displayName;\n\nexport {\n Dialog,\n DialogClose,\n DialogContent,\n DialogDescription,\n DialogFooter,\n DialogHeader,\n DialogOverlay,\n DialogPortal,\n DialogTitle,\n DialogTrigger,\n};\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "dialog.test",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/dialog.test.tsx",
9
- "content": "import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { describe, expect, it } from 'vitest';\nimport {\n Dialog,\n DialogClose,\n DialogContent,\n DialogDescription,\n DialogFooter,\n DialogHeader,\n DialogTitle,\n DialogTrigger,\n} from './dialog';\n\ndescribe('Dialog', () => {\n it('renders trigger correctly', () => {\n render(\n <Dialog>\n <DialogTrigger>Open Dialog</DialogTrigger>\n <DialogContent>\n <DialogHeader>\n <DialogTitle>Title</DialogTitle>\n <DialogDescription>Description</DialogDescription>\n </DialogHeader>\n </DialogContent>\n </Dialog>,\n );\n\n expect(screen.getByText('Open Dialog')).toBeInTheDocument();\n });\n\n it('opens and closes the dialog', async () => {\n const user = userEvent.setup();\n render(\n <Dialog>\n <DialogTrigger>Open Dialog</DialogTrigger>\n <DialogContent>\n <DialogHeader>\n <DialogTitle>Are you sure absolutely sure?</DialogTitle>\n <DialogDescription>This action cannot be undone.</DialogDescription>\n </DialogHeader>\n <DialogFooter>\n <DialogClose>Close Dialog</DialogClose>\n </DialogFooter>\n </DialogContent>\n </Dialog>,\n );\n\n // Dialog content should not be visible initially (or not in document)\n expect(screen.queryByText('Are you sure absolutely sure?')).not.toBeInTheDocument();\n\n // Open dialog\n await user.click(screen.getByText('Open Dialog'));\n\n expect(screen.getByRole('dialog')).toBeInTheDocument();\n expect(screen.getByText('Are you sure absolutely sure?')).toBeVisible();\n\n // Close dialog\n // We can use the close button we added\n await user.click(screen.getByText('Close Dialog'));\n\n // Should be closed\n // Radix UI Dialog unmounts content when closed\n expect(screen.queryByText('Are you sure absolutely sure?')).not.toBeInTheDocument();\n });\n});\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }
@@ -1,13 +0,0 @@
1
- {
2
- "name": "drawer",
3
- "type": "registry:ui",
4
- "dependencies": [],
5
- "registryDependencies": [],
6
- "files": [
7
- {
8
- "path": "ui/drawer.tsx",
9
- "content": "import * as React from 'react';\nimport { Drawer as DrawerPrimitive } from 'vaul';\n\nimport { cn } from '@/lib/utils';\n\nconst Drawer = ({ shouldScaleBackground = true, ...props }: React.ComponentProps<typeof DrawerPrimitive.Root>) => (\n <DrawerPrimitive.Root shouldScaleBackground={shouldScaleBackground} {...props} />\n);\nDrawer.displayName = 'Drawer';\n\nconst DrawerTrigger = DrawerPrimitive.Trigger;\n\nconst DrawerPortal = DrawerPrimitive.Portal;\n\nconst DrawerClose = DrawerPrimitive.Close;\n\nconst DrawerOverlay = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Overlay>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n <DrawerPrimitive.Overlay ref={ref} className={cn('fixed inset-0 z-50 bg-black/80', className)} {...props} />\n));\nDrawerOverlay.displayName = DrawerPrimitive.Overlay.displayName;\n\nconst DrawerContent = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Content>\n>(({ className, children, ...props }, ref) => (\n <DrawerPortal>\n <DrawerOverlay />\n <DrawerPrimitive.Content\n ref={ref}\n className={cn(\n 'fixed inset-x-0 bottom-0 z-50 mt-24 flex h-auto flex-col rounded-t-[10px] border bg-background',\n className,\n )}\n {...props}\n >\n <div className=\"mx-auto mt-4 h-2 w-[100px] rounded-full bg-muted\" />\n {children}\n </DrawerPrimitive.Content>\n </DrawerPortal>\n));\nDrawerContent.displayName = 'DrawerContent';\n\nconst DrawerHeader = ({ className, ...props }: React.HTMLAttributes<HTMLDivElement>) => (\n <div className={cn('grid gap-1.5 p-4 text-center sm:text-left', className)} {...props} />\n);\nDrawerHeader.displayName = 'DrawerHeader';\n\nconst DrawerFooter = ({ className, ...props }: React.HTMLAttributes<HTMLDivElement>) => (\n <div className={cn('mt-auto flex flex-col gap-2 p-4', className)} {...props} />\n);\nDrawerFooter.displayName = 'DrawerFooter';\n\nconst DrawerTitle = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Title>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Title>\n>(({ className, ...props }, ref) => (\n <DrawerPrimitive.Title\n ref={ref}\n className={cn('text-lg font-semibold leading-none tracking-tight', className)}\n {...props}\n />\n));\nDrawerTitle.displayName = DrawerPrimitive.Title.displayName;\n\nconst DrawerDescription = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Description>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Description>\n>(({ className, ...props }, ref) => (\n <DrawerPrimitive.Description ref={ref} className={cn('text-sm text-muted-foreground', className)} {...props} />\n));\nDrawerDescription.displayName = DrawerPrimitive.Description.displayName;\n\nexport {\n Drawer,\n DrawerClose,\n DrawerContent,\n DrawerDescription,\n DrawerFooter,\n DrawerHeader,\n DrawerOverlay,\n DrawerPortal,\n DrawerTitle,\n DrawerTrigger,\n};\n",
10
- "type": "registry:ui"
11
- }
12
- ]
13
- }