@kamod-ui/core 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (415) hide show
  1. package/LICENSE.md +9 -0
  2. package/dist/Accordion-D1PiNspd.d.ts +39 -0
  3. package/dist/AlertDialog-CpnCfDdN.d.ts +64 -0
  4. package/dist/Button-tRKMr8-H.d.ts +84 -0
  5. package/dist/CalendarDateTimePanel-B3J8OlSc.d.ts +79 -0
  6. package/dist/Carousel-DvlcMPpB.d.ts +41 -0
  7. package/dist/Chart-Ax22S5_N.d.ts +10 -0
  8. package/dist/Checkbox-DBbLYq6Q.d.ts +12 -0
  9. package/dist/Collapsible-DSZCp0tm.d.ts +34 -0
  10. package/dist/ComboboxInlineInput-CB7CEXzy.d.ts +135 -0
  11. package/dist/CommandSeparator-pJQnB9Lu.d.ts +47 -0
  12. package/dist/DataTable-zNTTdYVU.d.ts +13 -0
  13. package/dist/DatePicker-AFAYh5Ca.d.ts +20 -0
  14. package/dist/Dialog-CqCI4s9U.d.ts +28 -0
  15. package/dist/DialogContent-9VJGDt5l.d.ts +24 -0
  16. package/dist/DialogHeader-CYT7iUDq.d.ts +13 -0
  17. package/dist/DialogTitle-CvcRlZ_Z.d.ts +13 -0
  18. package/dist/Direction-25ZOt0gW.d.ts +24 -0
  19. package/dist/Drawer-BOPihYBJ.d.ts +41 -0
  20. package/dist/Dropdown-uPFaMqkB.d.ts +143 -0
  21. package/dist/EmptyTitle-J8rVLcJ3.d.ts +59 -0
  22. package/dist/FieldTitle-aSgThW-B.d.ts +100 -0
  23. package/dist/HoverCard-OSnOE6pE.d.ts +52 -0
  24. package/dist/Input-Cem05el9.d.ts +27 -0
  25. package/dist/Menubar-DwYDW4w2.d.ts +88 -0
  26. package/dist/PopoverTrigger-B6kK73gh.d.ts +43 -0
  27. package/dist/Progress-BGij8Hob.d.ts +13 -0
  28. package/dist/RadioGroup-BaElzLwa.d.ts +40 -0
  29. package/dist/ScrollArea-B-vILe3g.d.ts +16 -0
  30. package/dist/Select-B_mNVh70.d.ts +51 -0
  31. package/dist/Separator-DCQYrnpB.d.ts +9 -0
  32. package/dist/Sheet-B41Emmis.d.ts +29 -0
  33. package/dist/SidebarProvider-IAihmyD7.d.ts +46 -0
  34. package/dist/Slider-BQLMBpYs.d.ts +16 -0
  35. package/dist/Switch-CTTkNdqF.d.ts +31 -0
  36. package/dist/Tabs-DFJR_P2D.d.ts +47 -0
  37. package/dist/Textarea-DbKkduOG.d.ts +27 -0
  38. package/dist/ThemeToggle-DfiEM1dZ.d.ts +9 -0
  39. package/dist/Toggle-CseZl7XN.d.ts +49 -0
  40. package/dist/ToggleGroup-UeYHzQe7.d.ts +137 -0
  41. package/dist/Tooltip-BtRWVyCA.d.ts +40 -0
  42. package/dist/Typography-ccTtE182.d.ts +64 -0
  43. package/dist/chunk-2UHCXHAX.js +119 -0
  44. package/dist/chunk-2UHCXHAX.js.map +1 -0
  45. package/dist/chunk-2XNWLXG2.js +12 -0
  46. package/dist/chunk-2XNWLXG2.js.map +1 -0
  47. package/dist/chunk-3EHH62ZA.js +175 -0
  48. package/dist/chunk-3EHH62ZA.js.map +1 -0
  49. package/dist/chunk-3GKUUTSA.js +586 -0
  50. package/dist/chunk-3GKUUTSA.js.map +1 -0
  51. package/dist/chunk-3IT2RVO6.js +151 -0
  52. package/dist/chunk-3IT2RVO6.js.map +1 -0
  53. package/dist/chunk-3WAPI4KR.js +36 -0
  54. package/dist/chunk-3WAPI4KR.js.map +1 -0
  55. package/dist/chunk-44YLIQIS.js +15 -0
  56. package/dist/chunk-44YLIQIS.js.map +1 -0
  57. package/dist/chunk-4AJM7IA4.js +9 -0
  58. package/dist/chunk-4AJM7IA4.js.map +1 -0
  59. package/dist/chunk-4HX6SEWP.js +24 -0
  60. package/dist/chunk-4HX6SEWP.js.map +1 -0
  61. package/dist/chunk-6FTWMOHU.js +478 -0
  62. package/dist/chunk-6FTWMOHU.js.map +1 -0
  63. package/dist/chunk-6ZXYDBPR.js +304 -0
  64. package/dist/chunk-6ZXYDBPR.js.map +1 -0
  65. package/dist/chunk-7E2ZPDVI.js +224 -0
  66. package/dist/chunk-7E2ZPDVI.js.map +1 -0
  67. package/dist/chunk-7HZUM5ZQ.js +85 -0
  68. package/dist/chunk-7HZUM5ZQ.js.map +1 -0
  69. package/dist/chunk-7MECYLKS.js +375 -0
  70. package/dist/chunk-7MECYLKS.js.map +1 -0
  71. package/dist/chunk-7TDS7TC6.js +49 -0
  72. package/dist/chunk-7TDS7TC6.js.map +1 -0
  73. package/dist/chunk-7ZXJRNJO.js +26 -0
  74. package/dist/chunk-7ZXJRNJO.js.map +1 -0
  75. package/dist/chunk-AVCG4W6D.js +122 -0
  76. package/dist/chunk-AVCG4W6D.js.map +1 -0
  77. package/dist/chunk-BF3F5SJX.js +89 -0
  78. package/dist/chunk-BF3F5SJX.js.map +1 -0
  79. package/dist/chunk-BHMKSFES.js +195 -0
  80. package/dist/chunk-BHMKSFES.js.map +1 -0
  81. package/dist/chunk-BMF5SGYP.js +45 -0
  82. package/dist/chunk-BMF5SGYP.js.map +1 -0
  83. package/dist/chunk-D25ZQ36E.js +273 -0
  84. package/dist/chunk-D25ZQ36E.js.map +1 -0
  85. package/dist/chunk-D5W5YHJZ.js +426 -0
  86. package/dist/chunk-D5W5YHJZ.js.map +1 -0
  87. package/dist/chunk-DHBILREV.js +70 -0
  88. package/dist/chunk-DHBILREV.js.map +1 -0
  89. package/dist/chunk-DJ4PFETN.js +17 -0
  90. package/dist/chunk-DJ4PFETN.js.map +1 -0
  91. package/dist/chunk-DKXUKLZT.js +342 -0
  92. package/dist/chunk-DKXUKLZT.js.map +1 -0
  93. package/dist/chunk-EL2HT25C.js +9 -0
  94. package/dist/chunk-EL2HT25C.js.map +1 -0
  95. package/dist/chunk-FDNPBI2Z.js +26 -0
  96. package/dist/chunk-FDNPBI2Z.js.map +1 -0
  97. package/dist/chunk-FWCN47RC.js +65 -0
  98. package/dist/chunk-FWCN47RC.js.map +1 -0
  99. package/dist/chunk-G6PBJZYF.js +114 -0
  100. package/dist/chunk-G6PBJZYF.js.map +1 -0
  101. package/dist/chunk-GFF5OT46.js +80 -0
  102. package/dist/chunk-GFF5OT46.js.map +1 -0
  103. package/dist/chunk-GLWYIUE5.js +242 -0
  104. package/dist/chunk-GLWYIUE5.js.map +1 -0
  105. package/dist/chunk-HEQRODRF.js +110 -0
  106. package/dist/chunk-HEQRODRF.js.map +1 -0
  107. package/dist/chunk-HGTFOOUL.js +61 -0
  108. package/dist/chunk-HGTFOOUL.js.map +1 -0
  109. package/dist/chunk-HNESOMVN.js +18 -0
  110. package/dist/chunk-HNESOMVN.js.map +1 -0
  111. package/dist/chunk-I2PR3HXC.js +51 -0
  112. package/dist/chunk-I2PR3HXC.js.map +1 -0
  113. package/dist/chunk-IGGEBO7K.js +8 -0
  114. package/dist/chunk-IGGEBO7K.js.map +1 -0
  115. package/dist/chunk-J2Z2LSXM.js +26 -0
  116. package/dist/chunk-J2Z2LSXM.js.map +1 -0
  117. package/dist/chunk-JC7JMWSH.js +109 -0
  118. package/dist/chunk-JC7JMWSH.js.map +1 -0
  119. package/dist/chunk-JZRMLE4X.js +77 -0
  120. package/dist/chunk-JZRMLE4X.js.map +1 -0
  121. package/dist/chunk-KBXDU3G4.js +382 -0
  122. package/dist/chunk-KBXDU3G4.js.map +1 -0
  123. package/dist/chunk-KF34SFFZ.js +18 -0
  124. package/dist/chunk-KF34SFFZ.js.map +1 -0
  125. package/dist/chunk-L42B6QZS.js +524 -0
  126. package/dist/chunk-L42B6QZS.js.map +1 -0
  127. package/dist/chunk-LGO5HXMG.js +592 -0
  128. package/dist/chunk-LGO5HXMG.js.map +1 -0
  129. package/dist/chunk-LVK44RMS.js +78 -0
  130. package/dist/chunk-LVK44RMS.js.map +1 -0
  131. package/dist/chunk-N2LRB6TA.js +8 -0
  132. package/dist/chunk-N2LRB6TA.js.map +1 -0
  133. package/dist/chunk-NHTY2HD2.js +8 -0
  134. package/dist/chunk-NHTY2HD2.js.map +1 -0
  135. package/dist/chunk-NJUXP5FM.js +392 -0
  136. package/dist/chunk-NJUXP5FM.js.map +1 -0
  137. package/dist/chunk-NPHECLV5.js +94 -0
  138. package/dist/chunk-NPHECLV5.js.map +1 -0
  139. package/dist/chunk-NXVAR6P2.js +79 -0
  140. package/dist/chunk-NXVAR6P2.js.map +1 -0
  141. package/dist/chunk-OMXWBB67.js +9 -0
  142. package/dist/chunk-OMXWBB67.js.map +1 -0
  143. package/dist/chunk-PE5QQIV5.js +69 -0
  144. package/dist/chunk-PE5QQIV5.js.map +1 -0
  145. package/dist/chunk-QAUGWXGJ.js +158 -0
  146. package/dist/chunk-QAUGWXGJ.js.map +1 -0
  147. package/dist/chunk-QCYFSBZ7.js +81 -0
  148. package/dist/chunk-QCYFSBZ7.js.map +1 -0
  149. package/dist/chunk-QJT5UAL2.js +714 -0
  150. package/dist/chunk-QJT5UAL2.js.map +1 -0
  151. package/dist/chunk-QRLVOM3E.js +83 -0
  152. package/dist/chunk-QRLVOM3E.js.map +1 -0
  153. package/dist/chunk-RBVGV7VO.js +26 -0
  154. package/dist/chunk-RBVGV7VO.js.map +1 -0
  155. package/dist/chunk-RD6VXGVY.js +340 -0
  156. package/dist/chunk-RD6VXGVY.js.map +1 -0
  157. package/dist/chunk-RSPI2A4W.js +106 -0
  158. package/dist/chunk-RSPI2A4W.js.map +1 -0
  159. package/dist/chunk-RT26RZ7W.js +79 -0
  160. package/dist/chunk-RT26RZ7W.js.map +1 -0
  161. package/dist/chunk-RXAIDZ33.js +522 -0
  162. package/dist/chunk-RXAIDZ33.js.map +1 -0
  163. package/dist/chunk-S6TO62GJ.js +53 -0
  164. package/dist/chunk-S6TO62GJ.js.map +1 -0
  165. package/dist/chunk-SJ5MYJ7L.js +283 -0
  166. package/dist/chunk-SJ5MYJ7L.js.map +1 -0
  167. package/dist/chunk-SZ2I2SRP.js +156 -0
  168. package/dist/chunk-SZ2I2SRP.js.map +1 -0
  169. package/dist/chunk-UGOQKTHL.js +23 -0
  170. package/dist/chunk-UGOQKTHL.js.map +1 -0
  171. package/dist/chunk-UGQ756Z6.js +92 -0
  172. package/dist/chunk-UGQ756Z6.js.map +1 -0
  173. package/dist/chunk-UNPCAFLS.js +22 -0
  174. package/dist/chunk-UNPCAFLS.js.map +1 -0
  175. package/dist/chunk-V27UIXBD.js +36 -0
  176. package/dist/chunk-V27UIXBD.js.map +1 -0
  177. package/dist/chunk-VB5LDR7C.js +97 -0
  178. package/dist/chunk-VB5LDR7C.js.map +1 -0
  179. package/dist/chunk-VJ26PA3U.js +9 -0
  180. package/dist/chunk-VJ26PA3U.js.map +1 -0
  181. package/dist/chunk-VKB4VUN7.js +164 -0
  182. package/dist/chunk-VKB4VUN7.js.map +1 -0
  183. package/dist/chunk-Y37OHTAO.js +208 -0
  184. package/dist/chunk-Y37OHTAO.js.map +1 -0
  185. package/dist/chunk-Y4OW24IS.js +18 -0
  186. package/dist/chunk-Y4OW24IS.js.map +1 -0
  187. package/dist/chunk-YDMMDO2W.js +141 -0
  188. package/dist/chunk-YDMMDO2W.js.map +1 -0
  189. package/dist/chunk-YENXORWK.js +9 -0
  190. package/dist/chunk-YENXORWK.js.map +1 -0
  191. package/dist/chunk-YLTIB224.js +76 -0
  192. package/dist/chunk-YLTIB224.js.map +1 -0
  193. package/dist/chunk-YVA6PAML.js +63 -0
  194. package/dist/chunk-YVA6PAML.js.map +1 -0
  195. package/dist/chunk-YWUMX4JR.js +9 -0
  196. package/dist/chunk-YWUMX4JR.js.map +1 -0
  197. package/dist/chunk-ZDXR2SWG.js +32 -0
  198. package/dist/chunk-ZDXR2SWG.js.map +1 -0
  199. package/dist/chunk-ZIFL6GXH.js +187 -0
  200. package/dist/chunk-ZIFL6GXH.js.map +1 -0
  201. package/dist/chunk-ZM4VJOGF.js +40 -0
  202. package/dist/chunk-ZM4VJOGF.js.map +1 -0
  203. package/dist/chunk-ZVKIJLNO.js +9 -0
  204. package/dist/chunk-ZVKIJLNO.js.map +1 -0
  205. package/dist/components/accordion/index.d.ts +12 -0
  206. package/dist/components/accordion/index.js +4 -0
  207. package/dist/components/accordion/index.js.map +1 -0
  208. package/dist/components/alert/index.d.ts +64 -0
  209. package/dist/components/alert/index.js +4 -0
  210. package/dist/components/alert/index.js.map +1 -0
  211. package/dist/components/alert-dialog/index.d.ts +22 -0
  212. package/dist/components/alert-dialog/index.js +9 -0
  213. package/dist/components/alert-dialog/index.js.map +1 -0
  214. package/dist/components/aspect-ratio/index.d.ts +11 -0
  215. package/dist/components/aspect-ratio/index.js +4 -0
  216. package/dist/components/aspect-ratio/index.js.map +1 -0
  217. package/dist/components/avatar/index.d.ts +53 -0
  218. package/dist/components/avatar/index.js +4 -0
  219. package/dist/components/avatar/index.js.map +1 -0
  220. package/dist/components/badge/index.d.ts +175 -0
  221. package/dist/components/badge/index.js +4 -0
  222. package/dist/components/badge/index.js.map +1 -0
  223. package/dist/components/breadcrumb/index.d.ts +38 -0
  224. package/dist/components/breadcrumb/index.js +4 -0
  225. package/dist/components/breadcrumb/index.js.map +1 -0
  226. package/dist/components/button/index.d.ts +72 -0
  227. package/dist/components/button/index.js +5 -0
  228. package/dist/components/button/index.js.map +1 -0
  229. package/dist/components/button-group/index.d.ts +21 -0
  230. package/dist/components/button-group/index.js +4 -0
  231. package/dist/components/button-group/index.js.map +1 -0
  232. package/dist/components/calendar/index.d.ts +7 -0
  233. package/dist/components/calendar/index.js +12 -0
  234. package/dist/components/calendar/index.js.map +1 -0
  235. package/dist/components/card/index.d.ts +80 -0
  236. package/dist/components/card/index.js +3 -0
  237. package/dist/components/card/index.js.map +1 -0
  238. package/dist/components/carousel/index.d.ts +14 -0
  239. package/dist/components/carousel/index.js +5 -0
  240. package/dist/components/carousel/index.js.map +1 -0
  241. package/dist/components/chart/index.d.ts +6 -0
  242. package/dist/components/chart/index.js +4 -0
  243. package/dist/components/chart/index.js.map +1 -0
  244. package/dist/components/checkbox/index.d.ts +7 -0
  245. package/dist/components/checkbox/index.js +4 -0
  246. package/dist/components/checkbox/index.js.map +1 -0
  247. package/dist/components/collapsible/index.d.ts +11 -0
  248. package/dist/components/collapsible/index.js +4 -0
  249. package/dist/components/collapsible/index.js.map +1 -0
  250. package/dist/components/combobox/index.d.ts +13 -0
  251. package/dist/components/combobox/index.js +7 -0
  252. package/dist/components/combobox/index.js.map +1 -0
  253. package/dist/components/command/index.d.ts +21 -0
  254. package/dist/components/command/index.js +10 -0
  255. package/dist/components/command/index.js.map +1 -0
  256. package/dist/components/context-menu/index.d.ts +114 -0
  257. package/dist/components/context-menu/index.js +5 -0
  258. package/dist/components/context-menu/index.js.map +1 -0
  259. package/dist/components/data-table/index.d.ts +6 -0
  260. package/dist/components/data-table/index.js +5 -0
  261. package/dist/components/data-table/index.js.map +1 -0
  262. package/dist/components/date-picker/index.d.ts +7 -0
  263. package/dist/components/date-picker/index.js +8 -0
  264. package/dist/components/date-picker/index.js.map +1 -0
  265. package/dist/components/dialog/index.d.ts +22 -0
  266. package/dist/components/dialog/index.js +8 -0
  267. package/dist/components/dialog/index.js.map +1 -0
  268. package/dist/components/direction/index.d.ts +7 -0
  269. package/dist/components/direction/index.js +4 -0
  270. package/dist/components/direction/index.js.map +1 -0
  271. package/dist/components/drawer/index.d.ts +19 -0
  272. package/dist/components/drawer/index.js +8 -0
  273. package/dist/components/drawer/index.js.map +1 -0
  274. package/dist/components/dropdown/index.d.ts +24 -0
  275. package/dist/components/dropdown/index.js +5 -0
  276. package/dist/components/dropdown/index.js.map +1 -0
  277. package/dist/components/dropzone/index.d.ts +26 -0
  278. package/dist/components/dropzone/index.js +5 -0
  279. package/dist/components/dropzone/index.js.map +1 -0
  280. package/dist/components/empty/index.d.ts +8 -0
  281. package/dist/components/empty/index.js +4 -0
  282. package/dist/components/empty/index.js.map +1 -0
  283. package/dist/components/field/index.d.ts +8 -0
  284. package/dist/components/field/index.js +6 -0
  285. package/dist/components/field/index.js.map +1 -0
  286. package/dist/components/hover-card/index.d.ts +12 -0
  287. package/dist/components/hover-card/index.js +3 -0
  288. package/dist/components/hover-card/index.js.map +1 -0
  289. package/dist/components/image/index.d.ts +6 -0
  290. package/dist/components/image/index.js +4 -0
  291. package/dist/components/image/index.js.map +1 -0
  292. package/dist/components/input/index.d.ts +27 -0
  293. package/dist/components/input/index.js +4 -0
  294. package/dist/components/input/index.js.map +1 -0
  295. package/dist/components/input-group/index.d.ts +132 -0
  296. package/dist/components/input-group/index.js +7 -0
  297. package/dist/components/input-group/index.js.map +1 -0
  298. package/dist/components/input-otp/index.d.ts +39 -0
  299. package/dist/components/input-otp/index.js +4 -0
  300. package/dist/components/input-otp/index.js.map +1 -0
  301. package/dist/components/item/index.d.ts +108 -0
  302. package/dist/components/item/index.js +5 -0
  303. package/dist/components/item/index.js.map +1 -0
  304. package/dist/components/kbd/index.d.ts +31 -0
  305. package/dist/components/kbd/index.js +4 -0
  306. package/dist/components/kbd/index.js.map +1 -0
  307. package/dist/components/label/index.d.ts +49 -0
  308. package/dist/components/label/index.js +4 -0
  309. package/dist/components/label/index.js.map +1 -0
  310. package/dist/components/locale-segment-group/index.d.ts +15 -0
  311. package/dist/components/locale-segment-group/index.js +4 -0
  312. package/dist/components/locale-segment-group/index.js.map +1 -0
  313. package/dist/components/menubar/index.d.ts +23 -0
  314. package/dist/components/menubar/index.js +5 -0
  315. package/dist/components/menubar/index.js.map +1 -0
  316. package/dist/components/native-select/index.d.ts +89 -0
  317. package/dist/components/native-select/index.js +3 -0
  318. package/dist/components/native-select/index.js.map +1 -0
  319. package/dist/components/navigation-menu/index.d.ts +15 -0
  320. package/dist/components/navigation-menu/index.js +5 -0
  321. package/dist/components/navigation-menu/index.js.map +1 -0
  322. package/dist/components/pagination/index.d.ts +44 -0
  323. package/dist/components/pagination/index.js +5 -0
  324. package/dist/components/pagination/index.js.map +1 -0
  325. package/dist/components/popover/index.d.ts +76 -0
  326. package/dist/components/popover/index.js +5 -0
  327. package/dist/components/popover/index.js.map +1 -0
  328. package/dist/components/progress/index.d.ts +6 -0
  329. package/dist/components/progress/index.js +4 -0
  330. package/dist/components/progress/index.js.map +1 -0
  331. package/dist/components/prose/index.d.ts +8 -0
  332. package/dist/components/prose/index.js +4 -0
  333. package/dist/components/prose/index.js.map +1 -0
  334. package/dist/components/radio-group/index.d.ts +11 -0
  335. package/dist/components/radio-group/index.js +5 -0
  336. package/dist/components/radio-group/index.js.map +1 -0
  337. package/dist/components/scroll-area/index.d.ts +11 -0
  338. package/dist/components/scroll-area/index.js +4 -0
  339. package/dist/components/scroll-area/index.js.map +1 -0
  340. package/dist/components/select/index.d.ts +17 -0
  341. package/dist/components/select/index.js +5 -0
  342. package/dist/components/select/index.js.map +1 -0
  343. package/dist/components/selectable-card/index.d.ts +11 -0
  344. package/dist/components/selectable-card/index.js +5 -0
  345. package/dist/components/selectable-card/index.js.map +1 -0
  346. package/dist/components/separator/index.d.ts +24 -0
  347. package/dist/components/separator/index.js +4 -0
  348. package/dist/components/separator/index.js.map +1 -0
  349. package/dist/components/sheet/index.d.ts +20 -0
  350. package/dist/components/sheet/index.js +8 -0
  351. package/dist/components/sheet/index.js.map +1 -0
  352. package/dist/components/sidebar/index.d.ts +16 -0
  353. package/dist/components/sidebar/index.js +3 -0
  354. package/dist/components/sidebar/index.js.map +1 -0
  355. package/dist/components/skeleton/index.d.ts +52 -0
  356. package/dist/components/skeleton/index.js +3 -0
  357. package/dist/components/skeleton/index.js.map +1 -0
  358. package/dist/components/slider/index.d.ts +7 -0
  359. package/dist/components/slider/index.js +4 -0
  360. package/dist/components/slider/index.js.map +1 -0
  361. package/dist/components/sonner/index.d.ts +7 -0
  362. package/dist/components/sonner/index.js +3 -0
  363. package/dist/components/sonner/index.js.map +1 -0
  364. package/dist/components/spinner/index.d.ts +10 -0
  365. package/dist/components/spinner/index.js +4 -0
  366. package/dist/components/spinner/index.js.map +1 -0
  367. package/dist/components/switch/index.d.ts +7 -0
  368. package/dist/components/switch/index.js +4 -0
  369. package/dist/components/switch/index.js.map +1 -0
  370. package/dist/components/table/index.d.ts +45 -0
  371. package/dist/components/table/index.js +5 -0
  372. package/dist/components/table/index.js.map +1 -0
  373. package/dist/components/tabs/index.d.ts +13 -0
  374. package/dist/components/tabs/index.js +4 -0
  375. package/dist/components/tabs/index.js.map +1 -0
  376. package/dist/components/textarea/index.d.ts +27 -0
  377. package/dist/components/textarea/index.js +4 -0
  378. package/dist/components/textarea/index.js.map +1 -0
  379. package/dist/components/theme-toggle/index.d.ts +6 -0
  380. package/dist/components/theme-toggle/index.js +6 -0
  381. package/dist/components/theme-toggle/index.js.map +1 -0
  382. package/dist/components/toast/index.d.ts +27 -0
  383. package/dist/components/toast/index.js +3 -0
  384. package/dist/components/toast/index.js.map +1 -0
  385. package/dist/components/toggle/index.d.ts +7 -0
  386. package/dist/components/toggle/index.js +4 -0
  387. package/dist/components/toggle/index.js.map +1 -0
  388. package/dist/components/toggle-group/index.d.ts +11 -0
  389. package/dist/components/toggle-group/index.js +4 -0
  390. package/dist/components/toggle-group/index.js.map +1 -0
  391. package/dist/components/tooltip/index.d.ts +12 -0
  392. package/dist/components/tooltip/index.js +3 -0
  393. package/dist/components/tooltip/index.js.map +1 -0
  394. package/dist/components/typography/index.d.ts +8 -0
  395. package/dist/components/typography/index.js +4 -0
  396. package/dist/components/typography/index.js.map +1 -0
  397. package/dist/components/video/index.d.ts +8 -0
  398. package/dist/components/video/index.js +4 -0
  399. package/dist/components/video/index.js.map +1 -0
  400. package/dist/index.d.ts +82 -0
  401. package/dist/index.js +83 -0
  402. package/dist/index.js.map +1 -0
  403. package/dist/lib/interactive/index.d.ts +34 -0
  404. package/dist/lib/interactive/index.js +3 -0
  405. package/dist/lib/interactive/index.js.map +1 -0
  406. package/dist/lib/signals/index.d.ts +15 -0
  407. package/dist/lib/signals/index.js +3 -0
  408. package/dist/lib/signals/index.js.map +1 -0
  409. package/dist/lib/utils.d.ts +5 -0
  410. package/dist/lib/utils.js +3 -0
  411. package/dist/lib/utils.js.map +1 -0
  412. package/dist/navigationMenuTriggerStyle-MrMOOgmr.d.ts +48 -0
  413. package/dist/sonner-store-Dfdxy8ba.d.ts +11 -0
  414. package/dist/theme.css +81 -0
  415. package/package.json +360 -0
@@ -0,0 +1,283 @@
1
+ import { Button } from './chunk-UGQ756Z6.js';
2
+ import { cn } from './chunk-OMXWBB67.js';
3
+ import EmblaCarousel from 'embla-carousel';
4
+ import Autoplay from 'embla-carousel-autoplay';
5
+ import { signal } from '@preact/signals';
6
+ import { createContext } from 'preact';
7
+ import { useState, useRef, useCallback, useMemo, useLayoutEffect, useContext } from 'preact/hooks';
8
+ import { jsx, jsxs, Fragment } from 'preact/jsx-runtime';
9
+
10
+ var CarouselContext = createContext(null);
11
+ var useCarousel = (strict = true) => {
12
+ const context = useContext(CarouselContext);
13
+ if (!context && strict) throw new Error("Carousel subcomponents must be used within Carousel");
14
+ return context;
15
+ };
16
+ var Carousel = ({
17
+ opts,
18
+ orientation = "horizontal",
19
+ setApi,
20
+ plugins,
21
+ autoplay = false,
22
+ dir,
23
+ class: className,
24
+ children,
25
+ ...rest
26
+ }) => {
27
+ const [viewport, setViewport] = useState(null);
28
+ const lastViewport = useRef(null);
29
+ const setCarouselViewport = useCallback((el) => {
30
+ if (lastViewport.current === el) return;
31
+ lastViewport.current = el;
32
+ setViewport(el);
33
+ }, []);
34
+ const signalsRef = useRef(null);
35
+ if (!signalsRef.current) {
36
+ signalsRef.current = {
37
+ embla: signal(null),
38
+ canScrollPrev: signal(false),
39
+ canScrollNext: signal(false)
40
+ };
41
+ }
42
+ const { embla, canScrollPrev, canScrollNext } = signalsRef.current;
43
+ const optsKey = JSON.stringify(opts ?? {});
44
+ const mergedOpts = useMemo(() => {
45
+ const base = opts ?? {};
46
+ return {
47
+ ...base,
48
+ align: base.align ?? (orientation === "vertical" ? "start" : "center"),
49
+ axis: orientation === "vertical" ? "y" : "x",
50
+ ...dir ? { direction: dir } : {}
51
+ };
52
+ }, [optsKey, orientation, dir]);
53
+ const effectivePlugins = useMemo(() => {
54
+ if (plugins !== void 0) return plugins;
55
+ if (!autoplay) return [];
56
+ return [Autoplay(typeof autoplay === "object" ? autoplay : {})];
57
+ }, [plugins, autoplay]);
58
+ const pluginsKey = useMemo(() => effectivePlugins.map((p) => p.name).join(","), [effectivePlugins]);
59
+ useLayoutEffect(() => {
60
+ if (!viewport) return;
61
+ const api = EmblaCarousel(viewport, mergedOpts, effectivePlugins);
62
+ embla.value = api;
63
+ const updateScroll = () => {
64
+ canScrollPrev.value = api.canScrollPrev();
65
+ canScrollNext.value = api.canScrollNext();
66
+ };
67
+ const onSelect = () => updateScroll();
68
+ const onReInit = () => updateScroll();
69
+ api.on("select", onSelect);
70
+ api.on("reInit", onReInit);
71
+ updateScroll();
72
+ setApi?.(api);
73
+ return () => {
74
+ api.off("select", onSelect);
75
+ api.off("reInit", onReInit);
76
+ setApi?.(null);
77
+ api.destroy();
78
+ embla.value = null;
79
+ canScrollPrev.value = false;
80
+ canScrollNext.value = false;
81
+ };
82
+ }, [viewport, mergedOpts, pluginsKey, optsKey, orientation, dir]);
83
+ return /* @__PURE__ */ jsx(
84
+ CarouselContext.Provider,
85
+ {
86
+ value: {
87
+ setCarouselViewport,
88
+ embla,
89
+ canScrollPrev,
90
+ canScrollNext,
91
+ scrollPrev: () => embla.value?.scrollPrev(),
92
+ scrollNext: () => embla.value?.scrollNext(),
93
+ orientation
94
+ },
95
+ children: /* @__PURE__ */ jsx(
96
+ "div",
97
+ {
98
+ role: "region",
99
+ "aria-roledescription": "carousel",
100
+ "data-slot": "carousel",
101
+ "data-carousel-orientation": orientation,
102
+ class: cn("relative", className),
103
+ dir,
104
+ ...rest,
105
+ children
106
+ }
107
+ )
108
+ }
109
+ );
110
+ };
111
+ var CarouselContent = ({ class: className, children, ...rest }) => {
112
+ const ctx = useCarousel(true);
113
+ if (!ctx) throw new Error("CarouselContent requires Carousel");
114
+ const vertical = ctx.orientation === "vertical";
115
+ return /* @__PURE__ */ jsx(
116
+ "div",
117
+ {
118
+ ref: (el) => {
119
+ ctx.setCarouselViewport(el);
120
+ },
121
+ "data-slot": "carousel-viewport",
122
+ "data-carousel-axis": vertical ? "y" : "x",
123
+ class: cn(
124
+ "overflow-hidden",
125
+ vertical && "min-h-0 touch-pan-y",
126
+ className
127
+ ),
128
+ ...rest,
129
+ children: /* @__PURE__ */ jsx(
130
+ "div",
131
+ {
132
+ "data-slot": "carousel-container",
133
+ class: cn("flex", vertical ? "h-full min-h-0 flex-col" : "flex-row"),
134
+ children
135
+ }
136
+ )
137
+ }
138
+ );
139
+ };
140
+ var CarouselItem = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx(
141
+ "div",
142
+ {
143
+ role: "group",
144
+ "aria-roledescription": "slide",
145
+ "data-slot": "carousel-item",
146
+ class: cn("min-h-0 min-w-0 shrink-0 grow-0 basis-full", className),
147
+ ...rest,
148
+ children
149
+ }
150
+ );
151
+ var ChevronRight = ({ class: className }) => /* @__PURE__ */ jsx(
152
+ "svg",
153
+ {
154
+ xmlns: "http://www.w3.org/2000/svg",
155
+ viewBox: "0 0 24 24",
156
+ fill: "none",
157
+ stroke: "currentColor",
158
+ "stroke-width": "2",
159
+ "stroke-linecap": "round",
160
+ "stroke-linejoin": "round",
161
+ class: cn("size-4", className),
162
+ "aria-hidden": true,
163
+ children: /* @__PURE__ */ jsx("path", { d: "m9 18 6-6-6-6" })
164
+ }
165
+ );
166
+ var ChevronDown = ({ class: className }) => /* @__PURE__ */ jsx(
167
+ "svg",
168
+ {
169
+ xmlns: "http://www.w3.org/2000/svg",
170
+ viewBox: "0 0 24 24",
171
+ fill: "none",
172
+ stroke: "currentColor",
173
+ "stroke-width": "2",
174
+ "stroke-linecap": "round",
175
+ "stroke-linejoin": "round",
176
+ class: cn("size-4", className),
177
+ "aria-hidden": true,
178
+ children: /* @__PURE__ */ jsx("path", { d: "m6 9 6 6 6-6" })
179
+ }
180
+ );
181
+ var CarouselNext = ({ children, class: className, onClick, disabled, ...rest }) => {
182
+ const ctx = useCarousel(false);
183
+ const vertical = ctx?.orientation === "vertical";
184
+ const canNext = ctx?.canScrollNext.value ?? false;
185
+ return /* @__PURE__ */ jsx(
186
+ Button,
187
+ {
188
+ ...rest,
189
+ type: "button",
190
+ variant: "outline",
191
+ size: "icon",
192
+ "data-slot": "carousel-next",
193
+ "aria-label": "Next slide",
194
+ disabled: disabled ?? !canNext,
195
+ class: cn(
196
+ "absolute z-10 size-8 rounded-full shadow-xs",
197
+ vertical ? "-bottom-12 left-1/2 -translate-x-1/2" : "-end-12 top-1/2 -translate-y-1/2 rtl:-rotate-180",
198
+ className
199
+ ),
200
+ onClick: (event) => {
201
+ ctx?.scrollNext();
202
+ onClick?.(event);
203
+ },
204
+ children: children ?? /* @__PURE__ */ jsxs(Fragment, { children: [
205
+ /* @__PURE__ */ jsx("span", { class: "sr-only", children: "Next slide" }),
206
+ vertical ? /* @__PURE__ */ jsx(ChevronDown, {}) : /* @__PURE__ */ jsx(ChevronRight, {})
207
+ ] })
208
+ }
209
+ );
210
+ };
211
+ var ChevronLeft = ({ class: className }) => /* @__PURE__ */ jsx(
212
+ "svg",
213
+ {
214
+ xmlns: "http://www.w3.org/2000/svg",
215
+ viewBox: "0 0 24 24",
216
+ fill: "none",
217
+ stroke: "currentColor",
218
+ "stroke-width": "2",
219
+ "stroke-linecap": "round",
220
+ "stroke-linejoin": "round",
221
+ class: cn("size-4", className),
222
+ "aria-hidden": true,
223
+ children: /* @__PURE__ */ jsx("path", { d: "m15 18-6-6 6-6" })
224
+ }
225
+ );
226
+ var ChevronUp = ({ class: className }) => /* @__PURE__ */ jsx(
227
+ "svg",
228
+ {
229
+ xmlns: "http://www.w3.org/2000/svg",
230
+ viewBox: "0 0 24 24",
231
+ fill: "none",
232
+ stroke: "currentColor",
233
+ "stroke-width": "2",
234
+ "stroke-linecap": "round",
235
+ "stroke-linejoin": "round",
236
+ class: cn("size-4", className),
237
+ "aria-hidden": true,
238
+ children: /* @__PURE__ */ jsx("path", { d: "m18 15-6-6-6 6" })
239
+ }
240
+ );
241
+ var CarouselPrevious = ({ children, class: className, onClick, disabled, ...rest }) => {
242
+ const ctx = useCarousel(false);
243
+ const vertical = ctx?.orientation === "vertical";
244
+ const canPrev = ctx?.canScrollPrev.value ?? false;
245
+ return /* @__PURE__ */ jsx(
246
+ Button,
247
+ {
248
+ ...rest,
249
+ type: "button",
250
+ variant: "outline",
251
+ size: "icon",
252
+ "data-slot": "carousel-previous",
253
+ "aria-label": "Previous slide",
254
+ disabled: disabled ?? !canPrev,
255
+ class: cn(
256
+ "absolute z-10 size-8 rounded-full shadow-xs",
257
+ vertical ? "-top-12 left-1/2 -translate-x-1/2" : "-start-12 top-1/2 -translate-y-1/2 rtl:-rotate-180",
258
+ className
259
+ ),
260
+ onClick: (event) => {
261
+ ctx?.scrollPrev();
262
+ onClick?.(event);
263
+ },
264
+ children: children ?? /* @__PURE__ */ jsxs(Fragment, { children: [
265
+ /* @__PURE__ */ jsx("span", { class: "sr-only", children: "Previous slide" }),
266
+ vertical ? /* @__PURE__ */ jsx(ChevronUp, {}) : /* @__PURE__ */ jsx(ChevronLeft, {})
267
+ ] })
268
+ }
269
+ );
270
+ };
271
+
272
+ // src/components/carousel/index.ts
273
+ var carousel_default = {
274
+ Root: Carousel,
275
+ Content: CarouselContent,
276
+ Item: CarouselItem,
277
+ Previous: CarouselPrevious,
278
+ Next: CarouselNext
279
+ };
280
+
281
+ export { Carousel, CarouselContent, CarouselItem, CarouselNext, CarouselPrevious, carousel_default };
282
+ //# sourceMappingURL=chunk-SJ5MYJ7L.js.map
283
+ //# sourceMappingURL=chunk-SJ5MYJ7L.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/carousel/Carousel.tsx","../src/components/carousel/CarouselContent.tsx","../src/components/carousel/CarouselItem.tsx","../src/components/carousel/CarouselNext.tsx","../src/components/carousel/CarouselPrevious.tsx","../src/components/carousel/index.ts"],"names":["jsx","jsxs","Fragment"],"mappings":"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","file":"chunk-SJ5MYJ7L.js","sourcesContent":["import EmblaCarousel, {\n type EmblaCarouselType,\n type EmblaOptionsType,\n type EmblaPluginType\n} from \"embla-carousel\";\nimport Autoplay from \"embla-carousel-autoplay\";\nimport { signal } from \"@preact/signals\";\nimport { createContext } from \"preact\";\nimport { useCallback, useContext, useLayoutEffect, useMemo, useRef, useState } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type CarouselApi = EmblaCarouselType;\n\nexport type CarouselOrientation = \"horizontal\" | \"vertical\";\n\ntype CarouselContextValue = {\n setCarouselViewport: (el: HTMLDivElement | null) => void;\n embla: ReturnType<typeof signal<EmblaCarouselType | null>>;\n canScrollPrev: ReturnType<typeof signal<boolean>>;\n canScrollNext: ReturnType<typeof signal<boolean>>;\n scrollPrev: () => void;\n scrollNext: () => void;\n orientation: CarouselOrientation;\n};\n\nconst CarouselContext = createContext<CarouselContextValue | null>(null);\n\nexport const useCarousel = (strict = true) => {\n const context = useContext(CarouselContext);\n if (!context && strict) throw new Error(\"Carousel subcomponents must be used within Carousel\");\n return context;\n};\n\nexport type CarouselProps = Omit<JSX.HTMLAttributes<HTMLDivElement>, \"dir\"> & {\n opts?: EmblaOptionsType;\n orientation?: CarouselOrientation;\n setApi?: (api: CarouselApi | null) => void;\n plugins?: EmblaPluginType[];\n /** When `plugins` is omitted, adds `embla-carousel-autoplay`. Ignored if `plugins` is set. */\n autoplay?: boolean | { delay?: number; stopOnInteraction?: boolean };\n dir?: \"ltr\" | \"rtl\";\n children?: ComponentChildren;\n};\n\nexport const Carousel = ({\n opts,\n orientation = \"horizontal\",\n setApi,\n plugins,\n autoplay = false,\n dir,\n class: className,\n children,\n ...rest\n}: CarouselProps) => {\n const [viewport, setViewport] = useState<HTMLDivElement | null>(null);\n const lastViewport = useRef<HTMLDivElement | null>(null);\n const setCarouselViewport = useCallback((el: HTMLDivElement | null) => {\n if (lastViewport.current === el) return;\n lastViewport.current = el;\n setViewport(el);\n }, []);\n const signalsRef = useRef<{\n embla: ReturnType<typeof signal<EmblaCarouselType | null>>;\n canScrollPrev: ReturnType<typeof signal<boolean>>;\n canScrollNext: ReturnType<typeof signal<boolean>>;\n } | null>(null);\n if (!signalsRef.current) {\n signalsRef.current = {\n embla: signal<EmblaCarouselType | null>(null),\n canScrollPrev: signal(false),\n canScrollNext: signal(false)\n };\n }\n const { embla, canScrollPrev, canScrollNext } = signalsRef.current;\n\n const optsKey = JSON.stringify(opts ?? {});\n\n const mergedOpts = useMemo<EmblaOptionsType>(() => {\n const base = opts ?? {};\n return {\n ...base,\n align: base.align ?? (orientation === \"vertical\" ? \"start\" : \"center\"),\n axis: orientation === \"vertical\" ? \"y\" : \"x\",\n ...(dir ? { direction: dir } : {})\n };\n }, [optsKey, orientation, dir]);\n\n const effectivePlugins = useMemo<EmblaPluginType[]>(() => {\n if (plugins !== undefined) return plugins;\n if (!autoplay) return [];\n return [Autoplay(typeof autoplay === \"object\" ? autoplay : {})];\n }, [plugins, autoplay]);\n\n const pluginsKey = useMemo(() => effectivePlugins.map((p) => p.name).join(\",\"), [effectivePlugins]);\n\n useLayoutEffect(() => {\n if (!viewport) return;\n\n const api = EmblaCarousel(viewport, mergedOpts, effectivePlugins);\n embla.value = api;\n\n const updateScroll = () => {\n canScrollPrev.value = api.canScrollPrev();\n canScrollNext.value = api.canScrollNext();\n };\n\n const onSelect = () => updateScroll();\n const onReInit = () => updateScroll();\n\n api.on(\"select\", onSelect);\n api.on(\"reInit\", onReInit);\n updateScroll();\n setApi?.(api);\n\n return () => {\n api.off(\"select\", onSelect);\n api.off(\"reInit\", onReInit);\n setApi?.(null);\n api.destroy();\n embla.value = null;\n canScrollPrev.value = false;\n canScrollNext.value = false;\n };\n }, [viewport, mergedOpts, pluginsKey, optsKey, orientation, dir]);\n\n return (\n <CarouselContext.Provider\n value={{\n setCarouselViewport,\n embla,\n canScrollPrev,\n canScrollNext,\n scrollPrev: () => embla.value?.scrollPrev(),\n scrollNext: () => embla.value?.scrollNext(),\n orientation\n }}\n >\n <div\n role=\"region\"\n aria-roledescription=\"carousel\"\n data-slot=\"carousel\"\n data-carousel-orientation={orientation}\n class={cn(\"relative\", className)}\n dir={dir}\n {...rest}\n >\n {children}\n </div>\n </CarouselContext.Provider>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useCarousel } from \"./Carousel\";\n\nexport type CarouselContentProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const CarouselContent = ({ class: className, children, ...rest }: CarouselContentProps) => {\n const ctx = useCarousel(true);\n if (!ctx) throw new Error(\"CarouselContent requires Carousel\");\n const vertical = ctx.orientation === \"vertical\";\n\n return (\n <div\n ref={(el) => {\n ctx.setCarouselViewport(el);\n }}\n data-slot=\"carousel-viewport\"\n data-carousel-axis={vertical ? \"y\" : \"x\"}\n class={cn(\n \"overflow-hidden\",\n vertical && \"min-h-0 touch-pan-y\",\n className\n )}\n {...rest}\n >\n <div\n data-slot=\"carousel-container\"\n class={cn(\"flex\", vertical ? \"h-full min-h-0 flex-col\" : \"flex-row\")}\n >\n {children}\n </div>\n </div>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type CarouselItemProps = JSX.HTMLAttributes<HTMLDivElement> & { children?: ComponentChildren };\n\nexport const CarouselItem = ({ class: className, children, ...rest }: CarouselItemProps) => (\n <div\n role=\"group\"\n aria-roledescription=\"slide\"\n data-slot=\"carousel-item\"\n class={cn(\"min-h-0 min-w-0 shrink-0 grow-0 basis-full\", className)}\n {...rest}\n >\n {children}\n </div>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { Button } from \"../button/Button\";\nimport { useCarousel } from \"./Carousel\";\n\nconst ChevronRight = ({ class: className }: { class?: string }) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class={cn(\"size-4\", className)}\n aria-hidden\n >\n <path d=\"m9 18 6-6-6-6\" />\n </svg>\n);\n\nconst ChevronDown = ({ class: className }: { class?: string }) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class={cn(\"size-4\", className)}\n aria-hidden\n >\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n);\n\nexport type CarouselNextProps = Omit<JSX.ButtonHTMLAttributes<HTMLButtonElement>, \"size\"> & {\n children?: ComponentChildren;\n};\n\nexport const CarouselNext = ({ children, class: className, onClick, disabled, ...rest }: CarouselNextProps) => {\n const ctx = useCarousel(false);\n const vertical = ctx?.orientation === \"vertical\";\n const canNext = ctx?.canScrollNext.value ?? false;\n\n return (\n <Button\n {...rest}\n type=\"button\"\n variant=\"outline\"\n size=\"icon\"\n data-slot=\"carousel-next\"\n aria-label=\"Next slide\"\n disabled={disabled ?? !canNext}\n class={cn(\n \"absolute z-10 size-8 rounded-full shadow-xs\",\n vertical\n ? \"-bottom-12 left-1/2 -translate-x-1/2\"\n : \"-end-12 top-1/2 -translate-y-1/2 rtl:-rotate-180\",\n className\n )}\n onClick={(event) => {\n ctx?.scrollNext();\n onClick?.(event);\n }}\n >\n {children ?? (\n <>\n <span class=\"sr-only\">Next slide</span>\n {vertical ? <ChevronDown /> : <ChevronRight />}\n </>\n )}\n </Button>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { Button } from \"../button/Button\";\nimport { useCarousel } from \"./Carousel\";\n\nconst ChevronLeft = ({ class: className }: { class?: string }) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class={cn(\"size-4\", className)}\n aria-hidden\n >\n <path d=\"m15 18-6-6 6-6\" />\n </svg>\n);\n\nconst ChevronUp = ({ class: className }: { class?: string }) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class={cn(\"size-4\", className)}\n aria-hidden\n >\n <path d=\"m18 15-6-6-6 6\" />\n </svg>\n);\n\nexport type CarouselPreviousProps = Omit<JSX.ButtonHTMLAttributes<HTMLButtonElement>, \"size\"> & {\n children?: ComponentChildren;\n};\n\nexport const CarouselPrevious = ({ children, class: className, onClick, disabled, ...rest }: CarouselPreviousProps) => {\n const ctx = useCarousel(false);\n const vertical = ctx?.orientation === \"vertical\";\n const canPrev = ctx?.canScrollPrev.value ?? false;\n\n return (\n <Button\n {...rest}\n type=\"button\"\n variant=\"outline\"\n size=\"icon\"\n data-slot=\"carousel-previous\"\n aria-label=\"Previous slide\"\n disabled={disabled ?? !canPrev}\n class={cn(\n \"absolute z-10 size-8 rounded-full shadow-xs\",\n vertical\n ? \"-top-12 left-1/2 -translate-x-1/2\"\n : \"-start-12 top-1/2 -translate-y-1/2 rtl:-rotate-180\",\n className\n )}\n onClick={(event) => {\n ctx?.scrollPrev();\n onClick?.(event);\n }}\n >\n {children ?? (\n <>\n <span class=\"sr-only\">Previous slide</span>\n {vertical ? <ChevronUp /> : <ChevronLeft />}\n </>\n )}\n </Button>\n );\n};\n","export {\n Carousel,\n type CarouselApi,\n type CarouselOrientation,\n type CarouselProps\n} from \"./Carousel\";\nexport { CarouselContent, type CarouselContentProps } from \"./CarouselContent\";\nexport { CarouselItem, type CarouselItemProps } from \"./CarouselItem\";\nexport { CarouselNext, type CarouselNextProps } from \"./CarouselNext\";\nexport { CarouselPrevious, type CarouselPreviousProps } from \"./CarouselPrevious\";\n\nimport { Carousel } from \"./Carousel\";\nimport { CarouselContent } from \"./CarouselContent\";\nimport { CarouselItem } from \"./CarouselItem\";\nimport { CarouselNext } from \"./CarouselNext\";\nimport { CarouselPrevious } from \"./CarouselPrevious\";\n\nexport default {\n Root: Carousel,\n Content: CarouselContent,\n Item: CarouselItem,\n Previous: CarouselPrevious,\n Next: CarouselNext\n};\n"]}
@@ -0,0 +1,156 @@
1
+ import { Separator } from './chunk-3WAPI4KR.js';
2
+ import { label } from './chunk-Y4OW24IS.js';
3
+ import { cn } from './chunk-OMXWBB67.js';
4
+ import { tv } from 'tailwind-variants';
5
+ import { jsxs, jsx } from 'preact/jsx-runtime';
6
+ import { useMemo } from 'preact/hooks';
7
+
8
+ var fieldRoot = tv({
9
+ base: [
10
+ "group/field flex w-full gap-3",
11
+ "data-[invalid]:text-destructive"
12
+ ],
13
+ variants: {
14
+ orientation: {
15
+ vertical: "flex-col *:w-full [.sr-only]:w-auto",
16
+ horizontal: [
17
+ "flex-row flex-wrap items-center",
18
+ "[&>[data-slot=field-label]]:flex-1",
19
+ "has-[>[data-slot=field-content]]:items-start",
20
+ "has-[>[data-slot=field-content]]:[&>[data-slot=checkbox],[role=checkbox],[role=radio]]:mt-px"
21
+ ],
22
+ responsive: [
23
+ "flex-col *:w-full [.sr-only]:w-auto",
24
+ "@md/field-group:flex-row @md/field-group:flex-wrap @md/field-group:items-center",
25
+ "@md/field-group:[&>*]:w-auto @md/field-group:[&>[data-slot=field-label]]:flex-1",
26
+ "@md/field-group:has-[>[data-slot=field-content]]:items-start",
27
+ "@md/field-group:has-[>[data-slot=field-content]]:[&>[data-slot=checkbox],[role=checkbox],[role=radio]]:mt-px"
28
+ ]
29
+ }
30
+ },
31
+ defaultVariants: {
32
+ orientation: "vertical"
33
+ }
34
+ });
35
+ var Field = ({
36
+ class: className,
37
+ label: label2,
38
+ description,
39
+ error,
40
+ required = false,
41
+ orientation = "vertical",
42
+ disabled = false,
43
+ invalid = false,
44
+ children,
45
+ ...rest
46
+ }) => {
47
+ const legacy = label2 != null || description != null || error != null;
48
+ const resolvedRequired = required && label2 != null;
49
+ if (legacy) {
50
+ const isHorizontal = orientation === "horizontal";
51
+ return /* @__PURE__ */ jsxs(
52
+ "div",
53
+ {
54
+ ...rest,
55
+ "data-slot": "field",
56
+ "data-orientation": orientation,
57
+ "data-disabled": disabled ? "" : void 0,
58
+ class: cn(
59
+ "group/field",
60
+ !isHorizontal && "grid gap-2",
61
+ isHorizontal && label2 != null && "flex flex-col gap-2",
62
+ isHorizontal && label2 == null && fieldRoot({ orientation: "horizontal" }),
63
+ disabled ? "opacity-80" : null,
64
+ className
65
+ ),
66
+ ...invalid ? { "data-invalid": "" } : {},
67
+ children: [
68
+ label2 != null ? /* @__PURE__ */ jsxs("label", { "data-slot": "field-label", class: "text-sm leading-none font-medium", children: [
69
+ label2,
70
+ resolvedRequired ? /* @__PURE__ */ jsx("span", { "aria-hidden": "true", class: "ms-1 text-destructive", children: "*" }) : null
71
+ ] }) : null,
72
+ isHorizontal && label2 != null ? /* @__PURE__ */ jsx("div", { class: "flex min-w-0 flex-row flex-wrap items-center gap-3", children }) : children,
73
+ description != null ? /* @__PURE__ */ jsx("p", { "data-slot": "field-description", class: "text-muted-foreground text-sm leading-normal", children: description }) : null,
74
+ error != null ? /* @__PURE__ */ jsx("p", { "data-slot": "field-error", role: "alert", class: "text-destructive text-sm", children: error }) : null
75
+ ]
76
+ }
77
+ );
78
+ }
79
+ const orient = orientation === "responsive" ? "responsive" : orientation;
80
+ return /* @__PURE__ */ jsx(
81
+ "div",
82
+ {
83
+ ...rest,
84
+ "data-slot": "field",
85
+ "data-orientation": orientation,
86
+ "data-disabled": disabled ? "" : void 0,
87
+ class: cn(fieldRoot({ orientation: orient }), disabled ? "opacity-80" : null, className),
88
+ ...invalid ? { "data-invalid": "" } : {},
89
+ children
90
+ }
91
+ );
92
+ };
93
+ var FieldContent = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("div", { class: cn("flex flex-1 flex-col gap-1", className), "data-slot": "field-content", ...rest, children });
94
+ var FieldDescription = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("p", { class: cn("text-muted-foreground text-sm leading-normal font-normal", className), "data-slot": "field-description", ...rest, children });
95
+ var FieldError = ({ class: className, children, errors, ...rest }) => {
96
+ const content = useMemo(() => {
97
+ if (children) return children;
98
+ if (!errors?.length) return null;
99
+ const uniqueErrors = [...new Map(errors.map((error) => [error?.message, error])).values()].filter(Boolean);
100
+ if (uniqueErrors.length === 0) return null;
101
+ if (uniqueErrors.length === 1) {
102
+ return uniqueErrors[0]?.message ?? null;
103
+ }
104
+ return /* @__PURE__ */ jsx("ul", { class: "ml-4 list-disc space-y-0.5", children: uniqueErrors.map(
105
+ (error, index) => error?.message ? /* @__PURE__ */ jsx("li", { children: error.message }, `${error.message}-${index}`) : null
106
+ ) });
107
+ }, [children, errors]);
108
+ if (content == null) return null;
109
+ return /* @__PURE__ */ jsx(
110
+ "div",
111
+ {
112
+ role: "alert",
113
+ class: cn("text-destructive text-sm font-normal", className),
114
+ "data-slot": "field-error",
115
+ ...rest,
116
+ children: content
117
+ }
118
+ );
119
+ };
120
+ var FieldGroup = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("div", { class: cn("flex flex-col gap-6 @container/field-group", className), "data-slot": "field-group", ...rest, children });
121
+ var FieldLabel = ({ class: className, ...rest }) => /* @__PURE__ */ jsx(
122
+ "label",
123
+ {
124
+ class: cn(
125
+ label({ size: "sm" }),
126
+ "group-data-[disabled]/field:pointer-events-none group-data-[disabled]/field:opacity-50",
127
+ className
128
+ ),
129
+ "data-slot": "field-label",
130
+ ...rest
131
+ }
132
+ );
133
+ var fieldLegend = tv({
134
+ base: "",
135
+ variants: {
136
+ variant: {
137
+ legend: "text-base font-semibold",
138
+ label: "text-sm font-medium"
139
+ }
140
+ },
141
+ defaultVariants: { variant: "legend" }
142
+ });
143
+ var FieldLegend = ({ class: className, variant, ...rest }) => /* @__PURE__ */ jsx("legend", { class: cn(fieldLegend({ variant }), className), "data-slot": "field-legend", ...rest });
144
+ var FieldSeparator = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsxs("div", { class: cn("flex items-center gap-3 py-2", className), "data-slot": "field-separator", ...rest, children: [
145
+ /* @__PURE__ */ jsx(Separator, { class: "min-w-0 flex-1 shrink", orientation: "horizontal" }),
146
+ children ? /* @__PURE__ */ jsx("span", { class: "text-muted-foreground shrink-0 text-xs font-medium whitespace-nowrap", children }) : null
147
+ ] });
148
+ var FieldSet = ({ class: className, ...rest }) => /* @__PURE__ */ jsx("fieldset", { class: cn("m-0 min-w-0 space-y-6 border-0 p-0", className), "data-slot": "field-set", ...rest });
149
+ var FieldTitle = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("div", { class: cn("text-sm leading-none font-medium", className), "data-slot": "field-title", ...rest, children });
150
+
151
+ // src/components/field/index.ts
152
+ var field_default = Field;
153
+
154
+ export { Field, FieldContent, FieldDescription, FieldError, FieldGroup, FieldLabel, FieldLegend, FieldSeparator, FieldSet, FieldTitle, fieldRoot, field_default };
155
+ //# sourceMappingURL=chunk-SZ2I2SRP.js.map
156
+ //# sourceMappingURL=chunk-SZ2I2SRP.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/field/field-variants.ts","../src/components/field/Field.tsx","../src/components/field/FieldContent.tsx","../src/components/field/FieldDescription.tsx","../src/components/field/FieldError.tsx","../src/components/field/FieldGroup.tsx","../src/components/field/FieldLabel.tsx","../src/components/field/FieldLegend.tsx","../src/components/field/FieldSeparator.tsx","../src/components/field/FieldSet.tsx","../src/components/field/FieldTitle.tsx","../src/components/field/index.ts"],"names":["label","jsx","tv","jsxs"],"mappings":";;;;;;;AAGO,IAAM,YAAY,EAAA,CAAG;AAAA,EAC1B,IAAA,EAAM;AAAA,IACJ,+BAAA;AAAA,IACA;AAAA,GACF;AAAA,EACA,QAAA,EAAU;AAAA,IACR,WAAA,EAAa;AAAA,MACX,QAAA,EAAU,qCAAA;AAAA,MACV,UAAA,EAAY;AAAA,QACV,iCAAA;AAAA,QACA,oCAAA;AAAA,QACA,8CAAA;AAAA,QACA;AAAA,OACF;AAAA,MACA,UAAA,EAAY;AAAA,QACV,qCAAA;AAAA,QACA,iFAAA;AAAA,QACA,iFAAA;AAAA,QACA,8DAAA;AAAA,QACA;AAAA;AACF;AACF,GACF;AAAA,EACA,eAAA,EAAiB;AAAA,IACf,WAAA,EAAa;AAAA;AAEjB,CAAC;ACVM,IAAM,QAAQ,CAAC;AAAA,EACpB,KAAA,EAAO,SAAA;AAAA,EACP,KAAA,EAAAA,MAAAA;AAAA,EACA,WAAA;AAAA,EACA,KAAA;AAAA,EACA,QAAA,GAAW,KAAA;AAAA,EACX,WAAA,GAAc,UAAA;AAAA,EACd,QAAA,GAAW,KAAA;AAAA,EACX,OAAA,GAAU,KAAA;AAAA,EACV,QAAA;AAAA,EACA,GAAG;AACL,CAAA,KAAkB;AAChB,EAAA,MAAM,MAAA,GAASA,MAAAA,IAAS,IAAA,IAAQ,WAAA,IAAe,QAAQ,KAAA,IAAS,IAAA;AAChE,EAAA,MAAM,gBAAA,GAAmB,YAAYA,MAAAA,IAAS,IAAA;AAE9C,EAAA,IAAI,MAAA,EAAQ;AACV,IAAA,MAAM,eAAe,WAAA,KAAgB,YAAA;AAErC,IAAA,uBACE,IAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACE,GAAG,IAAA;AAAA,QACJ,WAAA,EAAU,OAAA;AAAA,QACV,kBAAA,EAAkB,WAAA;AAAA,QAClB,eAAA,EAAe,WAAW,EAAA,GAAK,MAAA;AAAA,QAC/B,KAAA,EAAO,EAAA;AAAA,UACL,aAAA;AAAA,UACA,CAAC,YAAA,IAAgB,YAAA;AAAA,UACjB,YAAA,IAAgBA,UAAS,IAAA,IAAQ,qBAAA;AAAA,UACjC,gBAAgBA,MAAAA,IAAS,IAAA,IAAQ,UAAU,EAAE,WAAA,EAAa,cAAc,CAAA;AAAA,UACxE,WAAW,YAAA,GAAe,IAAA;AAAA,UAC1B;AAAA,SACF;AAAA,QACC,GAAI,OAAA,GAAU,EAAE,cAAA,EAAgB,EAAA,KAAO,EAAC;AAAA,QAExC,QAAA,EAAA;AAAA,UAAAA,UAAS,IAAA,mBACR,IAAA,CAAC,WAAM,WAAA,EAAU,aAAA,EAAc,OAAM,kCAAA,EAClC,QAAA,EAAA;AAAA,YAAAA,MAAAA;AAAA,YACA,gBAAA,uBAAoB,MAAA,EAAA,EAAK,aAAA,EAAY,QAAO,KAAA,EAAM,uBAAA,EAAwB,eAAC,CAAA,GAAU;AAAA,WAAA,EACxF,CAAA,GACE,IAAA;AAAA,UACH,YAAA,IAAgBA,UAAS,IAAA,mBACxB,GAAA,CAAC,SAAI,KAAA,EAAM,oDAAA,EAAsD,UAAS,CAAA,GAE1E,QAAA;AAAA,UAED,WAAA,IAAe,uBACd,GAAA,CAAC,GAAA,EAAA,EAAE,aAAU,mBAAA,EAAoB,KAAA,EAAM,8CAAA,EACpC,QAAA,EAAA,WAAA,EACH,CAAA,GACE,IAAA;AAAA,UACH,KAAA,IAAS,IAAA,mBACR,GAAA,CAAC,GAAA,EAAA,EAAE,WAAA,EAAU,aAAA,EAAc,IAAA,EAAK,OAAA,EAAQ,KAAA,EAAM,0BAAA,EAC3C,QAAA,EAAA,KAAA,EACH,CAAA,GACE;AAAA;AAAA;AAAA,KACN;AAAA,EAEJ;AAEA,EAAA,MAAM,MAAA,GAAS,WAAA,KAAgB,YAAA,GAAe,YAAA,GAAe,WAAA;AAE7D,EAAA,uBACE,GAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACE,GAAG,IAAA;AAAA,MACJ,WAAA,EAAU,OAAA;AAAA,MACV,kBAAA,EAAkB,WAAA;AAAA,MAClB,eAAA,EAAe,WAAW,EAAA,GAAK,MAAA;AAAA,MAC/B,KAAA,EAAO,EAAA,CAAG,SAAA,CAAU,EAAE,WAAA,EAAa,MAAA,EAAQ,CAAA,EAAG,QAAA,GAAW,YAAA,GAAe,IAAA,EAAM,SAAS,CAAA;AAAA,MACtF,GAAI,OAAA,GAAU,EAAE,cAAA,EAAgB,EAAA,KAAO,EAAC;AAAA,MAExC;AAAA;AAAA,GACH;AAEJ;ACrFO,IAAM,YAAA,GAAe,CAAC,EAAE,KAAA,EAAO,WAAW,QAAA,EAAU,GAAG,MAAK,qBACjEC,IAAC,KAAA,EAAA,EAAI,KAAA,EAAO,GAAG,4BAAA,EAA8B,SAAS,GAAG,WAAA,EAAU,eAAA,EAAiB,GAAG,IAAA,EACpF,QAAA,EACH;ACHK,IAAM,gBAAA,GAAmB,CAAC,EAAE,KAAA,EAAO,WAAW,QAAA,EAAU,GAAG,MAAK,qBACrEA,IAAC,GAAA,EAAA,EAAE,KAAA,EAAO,GAAG,0DAAA,EAA4D,SAAS,GAAG,WAAA,EAAU,mBAAA,EAAqB,GAAG,IAAA,EACpH,QAAA,EACH;ACDK,IAAM,UAAA,GAAa,CAAC,EAAE,KAAA,EAAO,WAAW,QAAA,EAAU,MAAA,EAAQ,GAAG,IAAA,EAAK,KAAuB;AAC9F,EAAA,MAAM,OAAA,GAAU,QAAQ,MAAM;AAC5B,IAAA,IAAI,UAAU,OAAO,QAAA;AACrB,IAAA,IAAI,CAAC,MAAA,EAAQ,MAAA,EAAQ,OAAO,IAAA;AAE5B,IAAA,MAAM,YAAA,GAAe,CAAC,GAAG,IAAI,IAAI,MAAA,CAAO,GAAA,CAAI,CAAC,KAAA,KAAU,CAAC,OAAO,OAAA,EAAS,KAAK,CAAC,CAAC,CAAA,CAAE,QAAQ,CAAA,CAAE,OAAO,OAAO,CAAA;AAEzG,IAAA,IAAI,YAAA,CAAa,MAAA,KAAW,CAAA,EAAG,OAAO,IAAA;AACtC,IAAA,IAAI,YAAA,CAAa,WAAW,CAAA,EAAG;AAC7B,MAAA,OAAO,YAAA,CAAa,CAAC,CAAA,EAAG,OAAA,IAAW,IAAA;AAAA,IACrC;AAEA,IAAA,uBACEA,GAAAA,CAAC,IAAA,EAAA,EAAG,KAAA,EAAM,8BACP,QAAA,EAAA,YAAA,CAAa,GAAA;AAAA,MAAI,CAAC,KAAA,EAAO,KAAA,KACxB,KAAA,EAAO,OAAA,mBACLA,GAAAA,CAAC,IAAA,EAAA,EAAsC,QAAA,EAAA,KAAA,CAAM,OAAA,EAAA,EAApC,GAAG,KAAA,CAAM,OAAO,CAAA,CAAA,EAAI,KAAK,EAAmB,CAAA,GACnD;AAAA,KACN,EACF,CAAA;AAAA,EAEJ,CAAA,EAAG,CAAC,QAAA,EAAU,MAAM,CAAC,CAAA;AAErB,EAAA,IAAI,OAAA,IAAW,MAAM,OAAO,IAAA;AAE5B,EAAA,uBACEA,GAAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,IAAA,EAAK,OAAA;AAAA,MACL,KAAA,EAAO,EAAA,CAAG,sCAAA,EAAwC,SAAS,CAAA;AAAA,MAC3D,WAAA,EAAU,aAAA;AAAA,MACT,GAAG,IAAA;AAAA,MAEH,QAAA,EAAA;AAAA;AAAA,GACH;AAEJ;ACrCO,IAAM,UAAA,GAAa,CAAC,EAAE,KAAA,EAAO,WAAW,QAAA,EAAU,GAAG,MAAK,qBAC/DA,IAAC,KAAA,EAAA,EAAI,KAAA,EAAO,GAAG,4CAAA,EAA8C,SAAS,GAAG,WAAA,EAAU,aAAA,EAAe,GAAG,IAAA,EAClG,QAAA,EACH;ACJK,IAAM,UAAA,GAAa,CAAC,EAAE,KAAA,EAAO,WAAW,GAAG,IAAA,uBAChDA,GAAAA;AAAA,EAAC,OAAA;AAAA,EAAA;AAAA,IACC,KAAA,EAAO,EAAA;AAAA,MACL,KAAA,CAAY,EAAE,IAAA,EAAM,IAAA,EAAM,CAAA;AAAA,MAC1B,wFAAA;AAAA,MACA;AAAA,KACF;AAAA,IACA,WAAA,EAAU,aAAA;AAAA,IACT,GAAG;AAAA;AACN;ACXK,IAAM,cAAcC,EAAAA,CAAG;AAAA,EAC5B,IAAA,EAAM,EAAA;AAAA,EACN,QAAA,EAAU;AAAA,IACR,OAAA,EAAS;AAAA,MACP,MAAA,EAAQ,yBAAA;AAAA,MACR,KAAA,EAAO;AAAA;AACT,GACF;AAAA,EACA,eAAA,EAAiB,EAAE,OAAA,EAAS,QAAA;AAC9B,CAAC,CAAA;AAIM,IAAM,WAAA,GAAc,CAAC,EAAE,KAAA,EAAO,SAAA,EAAW,SAAS,GAAG,IAAA,EAAK,qBAC/DD,GAAAA,CAAC,QAAA,EAAA,EAAO,OAAO,EAAA,CAAG,WAAA,CAAY,EAAE,OAAA,EAAS,CAAA,EAAG,SAAS,CAAA,EAAG,WAAA,EAAU,cAAA,EAAgB,GAAG,IAAA,EAAM;ACVtF,IAAM,cAAA,GAAiB,CAAC,EAAE,KAAA,EAAO,WAAW,QAAA,EAAU,GAAG,MAAK,qBACnEE,KAAC,KAAA,EAAA,EAAI,KAAA,EAAO,GAAG,8BAAA,EAAgC,SAAS,GAAG,WAAA,EAAU,iBAAA,EAAmB,GAAG,IAAA,EACzF,QAAA,EAAA;AAAA,kBAAAF,GAAAA,CAAC,SAAA,EAAA,EAAU,KAAA,EAAM,uBAAA,EAAwB,aAAY,YAAA,EAAa,CAAA;AAAA,EACjE,2BACCA,GAAAA,CAAC,UAAK,KAAA,EAAM,sEAAA,EAAwE,UAAS,CAAA,GAC3F;AAAA,CAAA,EACN;ACTK,IAAM,WAAW,CAAC,EAAE,OAAO,SAAA,EAAW,GAAG,MAAK,qBACnDA,IAAC,UAAA,EAAA,EAAS,KAAA,EAAO,GAAG,oCAAA,EAAsC,SAAS,GAAG,WAAA,EAAU,WAAA,EAAa,GAAG,IAAA,EAAM;ACCjG,IAAM,UAAA,GAAa,CAAC,EAAE,KAAA,EAAO,WAAW,QAAA,EAAU,GAAG,MAAK,qBAC/DA,IAAC,KAAA,EAAA,EAAI,KAAA,EAAO,GAAG,kCAAA,EAAoC,SAAS,GAAG,WAAA,EAAU,aAAA,EAAe,GAAG,IAAA,EACxF,QAAA,EACH;;;ACKF,IAAO,aAAA,GAAQ","file":"chunk-SZ2I2SRP.js","sourcesContent":["import { tv, type VariantProps } from \"tailwind-variants\";\n\n/** Root layout for composable Field (shadcn fieldVariants). */\nexport const fieldRoot = tv({\n base: [\n \"group/field flex w-full gap-3\",\n \"data-[invalid]:text-destructive\"\n ],\n variants: {\n orientation: {\n vertical: \"flex-col *:w-full [.sr-only]:w-auto\",\n horizontal: [\n \"flex-row flex-wrap items-center\",\n \"[&>[data-slot=field-label]]:flex-1\",\n \"has-[>[data-slot=field-content]]:items-start\",\n \"has-[>[data-slot=field-content]]:[&>[data-slot=checkbox],[role=checkbox],[role=radio]]:mt-px\"\n ],\n responsive: [\n \"flex-col *:w-full [.sr-only]:w-auto\",\n \"@md/field-group:flex-row @md/field-group:flex-wrap @md/field-group:items-center\",\n \"@md/field-group:[&>*]:w-auto @md/field-group:[&>[data-slot=field-label]]:flex-1\",\n \"@md/field-group:has-[>[data-slot=field-content]]:items-start\",\n \"@md/field-group:has-[>[data-slot=field-content]]:[&>[data-slot=checkbox],[role=checkbox],[role=radio]]:mt-px\"\n ]\n }\n },\n defaultVariants: {\n orientation: \"vertical\"\n }\n});\n\nexport type FieldRootVariants = VariantProps<typeof fieldRoot>;\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { fieldRoot, type FieldRootVariants } from \"./field-variants\";\n\nexport type FieldProps = JSX.HTMLAttributes<HTMLDivElement> &\n FieldRootVariants & {\n /** Legacy: label text/node (composition: use FieldLabel instead). */\n label?: ComponentChildren;\n /** Legacy: helper below control. */\n description?: ComponentChildren;\n /** Legacy: error below control. */\n error?: ComponentChildren;\n required?: boolean;\n orientation?: \"vertical\" | \"horizontal\" | \"responsive\";\n disabled?: boolean;\n invalid?: boolean;\n children?: ComponentChildren;\n };\n\nexport const Field = ({\n class: className,\n label,\n description,\n error,\n required = false,\n orientation = \"vertical\",\n disabled = false,\n invalid = false,\n children,\n ...rest\n}: FieldProps) => {\n const legacy = label != null || description != null || error != null;\n const resolvedRequired = required && label != null;\n\n if (legacy) {\n const isHorizontal = orientation === \"horizontal\";\n\n return (\n <div\n {...rest}\n data-slot=\"field\"\n data-orientation={orientation}\n data-disabled={disabled ? \"\" : undefined}\n class={cn(\n \"group/field\",\n !isHorizontal && \"grid gap-2\",\n isHorizontal && label != null && \"flex flex-col gap-2\",\n isHorizontal && label == null && fieldRoot({ orientation: \"horizontal\" }),\n disabled ? \"opacity-80\" : null,\n className\n )}\n {...(invalid ? { \"data-invalid\": \"\" } : {})}\n >\n {label != null ? (\n <label data-slot=\"field-label\" class=\"text-sm leading-none font-medium\">\n {label}\n {resolvedRequired ? <span aria-hidden=\"true\" class=\"ms-1 text-destructive\">*</span> : null}\n </label>\n ) : null}\n {isHorizontal && label != null ? (\n <div class=\"flex min-w-0 flex-row flex-wrap items-center gap-3\">{children}</div>\n ) : (\n children\n )}\n {description != null ? (\n <p data-slot=\"field-description\" class=\"text-muted-foreground text-sm leading-normal\">\n {description}\n </p>\n ) : null}\n {error != null ? (\n <p data-slot=\"field-error\" role=\"alert\" class=\"text-destructive text-sm\">\n {error}\n </p>\n ) : null}\n </div>\n );\n }\n\n const orient = orientation === \"responsive\" ? \"responsive\" : orientation;\n\n return (\n <div\n {...rest}\n data-slot=\"field\"\n data-orientation={orientation}\n data-disabled={disabled ? \"\" : undefined}\n class={cn(fieldRoot({ orientation: orient }), disabled ? \"opacity-80\" : null, className)}\n {...(invalid ? { \"data-invalid\": \"\" } : {})}\n >\n {children}\n </div>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type FieldContentProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const FieldContent = ({ class: className, children, ...rest }: FieldContentProps) => (\n <div class={cn(\"flex flex-1 flex-col gap-1\", className)} data-slot=\"field-content\" {...rest}>\n {children}\n </div>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type FieldDescriptionProps = JSX.HTMLAttributes<HTMLParagraphElement> & {\n children?: ComponentChildren;\n};\n\nexport const FieldDescription = ({ class: className, children, ...rest }: FieldDescriptionProps) => (\n <p class={cn(\"text-muted-foreground text-sm leading-normal font-normal\", className)} data-slot=\"field-description\" {...rest}>\n {children}\n </p>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { useMemo } from \"preact/hooks\";\nimport { cn } from \"../../lib/utils\";\n\nexport type FieldErrorProps = JSX.HTMLAttributes<HTMLDivElement> & {\n errors?: Array<{ message?: string } | undefined>;\n children?: ComponentChildren;\n};\n\nexport const FieldError = ({ class: className, children, errors, ...rest }: FieldErrorProps) => {\n const content = useMemo(() => {\n if (children) return children;\n if (!errors?.length) return null;\n\n const uniqueErrors = [...new Map(errors.map((error) => [error?.message, error])).values()].filter(Boolean);\n\n if (uniqueErrors.length === 0) return null;\n if (uniqueErrors.length === 1) {\n return uniqueErrors[0]?.message ?? null;\n }\n\n return (\n <ul class=\"ml-4 list-disc space-y-0.5\">\n {uniqueErrors.map((error, index) =>\n error?.message ? (\n <li key={`${error.message}-${index}`}>{error.message}</li>\n ) : null\n )}\n </ul>\n );\n }, [children, errors]);\n\n if (content == null) return null;\n\n return (\n <div\n role=\"alert\"\n class={cn(\"text-destructive text-sm font-normal\", className)}\n data-slot=\"field-error\"\n {...rest}\n >\n {content}\n </div>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type FieldGroupProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const FieldGroup = ({ class: className, children, ...rest }: FieldGroupProps) => (\n <div class={cn(\"flex flex-col gap-6 @container/field-group\", className)} data-slot=\"field-group\" {...rest}>\n {children}\n </div>\n);\n","import type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { label as labelStyles } from \"../label/Label\";\n\nexport type FieldLabelProps = JSX.LabelHTMLAttributes<HTMLLabelElement>;\n\nexport const FieldLabel = ({ class: className, ...rest }: FieldLabelProps) => (\n <label\n class={cn(\n labelStyles({ size: \"sm\" }),\n \"group-data-[disabled]/field:pointer-events-none group-data-[disabled]/field:opacity-50\",\n className\n )}\n data-slot=\"field-label\"\n {...rest}\n />\n);\n","import type { JSX } from \"preact\";\nimport { tv, type VariantProps } from \"tailwind-variants\";\nimport { cn } from \"../../lib/utils\";\n\nexport const fieldLegend = tv({\n base: \"\",\n variants: {\n variant: {\n legend: \"text-base font-semibold\",\n label: \"text-sm font-medium\"\n }\n },\n defaultVariants: { variant: \"legend\" }\n});\n\nexport type FieldLegendProps = JSX.HTMLAttributes<HTMLLegendElement> & VariantProps<typeof fieldLegend>;\n\nexport const FieldLegend = ({ class: className, variant, ...rest }: FieldLegendProps) => (\n <legend class={cn(fieldLegend({ variant }), className)} data-slot=\"field-legend\" {...rest} />\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { Separator } from \"../separator/Separator\";\n\nexport type FieldSeparatorProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const FieldSeparator = ({ class: className, children, ...rest }: FieldSeparatorProps) => (\n <div class={cn(\"flex items-center gap-3 py-2\", className)} data-slot=\"field-separator\" {...rest}>\n <Separator class=\"min-w-0 flex-1 shrink\" orientation=\"horizontal\" />\n {children ? (\n <span class=\"text-muted-foreground shrink-0 text-xs font-medium whitespace-nowrap\">{children}</span>\n ) : null}\n </div>\n);\n","import type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type FieldSetProps = JSX.FieldsetHTMLAttributes<HTMLFieldSetElement>;\n\nexport const FieldSet = ({ class: className, ...rest }: FieldSetProps) => (\n <fieldset class={cn(\"m-0 min-w-0 space-y-6 border-0 p-0\", className)} data-slot=\"field-set\" {...rest} />\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type FieldTitleProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const FieldTitle = ({ class: className, children, ...rest }: FieldTitleProps) => (\n <div class={cn(\"text-sm leading-none font-medium\", className)} data-slot=\"field-title\" {...rest}>\n {children}\n </div>\n);\n","import { Field } from \"./Field\";\n\nexport { Field };\nexport { fieldRoot } from \"./field-variants\";\nexport type { FieldRootVariants } from \"./field-variants\";\nexport { FieldContent } from \"./FieldContent\";\nexport { FieldDescription } from \"./FieldDescription\";\nexport { FieldError } from \"./FieldError\";\nexport { FieldGroup } from \"./FieldGroup\";\nexport { FieldLabel } from \"./FieldLabel\";\nexport { FieldLegend } from \"./FieldLegend\";\nexport { FieldSeparator } from \"./FieldSeparator\";\nexport { FieldSet } from \"./FieldSet\";\nexport { FieldTitle } from \"./FieldTitle\";\n\nexport default Field;\n"]}
@@ -0,0 +1,23 @@
1
+ import { cn } from './chunk-OMXWBB67.js';
2
+ import { jsx } from 'preact/jsx-runtime';
3
+
4
+ var AspectRatio = ({ ratio, class: className, style, children, ...rest }) => {
5
+ const styleObject = typeof style === "object" && style !== null && !Array.isArray(style) ? style : void 0;
6
+ return /* @__PURE__ */ jsx(
7
+ "div",
8
+ {
9
+ "data-slot": "aspect-ratio",
10
+ class: cn("relative w-full min-h-0 overflow-hidden", className),
11
+ style: {
12
+ ...styleObject,
13
+ aspectRatio: ratio
14
+ },
15
+ ...rest,
16
+ children
17
+ }
18
+ );
19
+ };
20
+
21
+ export { AspectRatio };
22
+ //# sourceMappingURL=chunk-UGOQKTHL.js.map
23
+ //# sourceMappingURL=chunk-UGOQKTHL.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/aspect-ratio/AspectRatio.tsx"],"names":[],"mappings":";;;AAUO,IAAM,WAAA,GAAc,CAAC,EAAE,KAAA,EAAO,KAAA,EAAO,WAAW,KAAA,EAAO,QAAA,EAAU,GAAG,IAAA,EAAK,KAAwB;AACtG,EAAA,MAAM,WAAA,GAAc,OAAO,KAAA,KAAU,QAAA,IAAY,KAAA,KAAU,IAAA,IAAQ,CAAC,KAAA,CAAM,OAAA,CAAQ,KAAK,CAAA,GAAI,KAAA,GAAQ,MAAA;AAEnG,EAAA,uBACE,GAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,WAAA,EAAU,cAAA;AAAA,MACV,KAAA,EAAO,EAAA,CAAG,yCAAA,EAA2C,SAAS,CAAA;AAAA,MAC9D,KAAA,EAAO;AAAA,QACL,GAAG,WAAA;AAAA,QACH,WAAA,EAAa;AAAA,OACf;AAAA,MACC,GAAG,IAAA;AAAA,MAEH;AAAA;AAAA,GACH;AAEJ","file":"chunk-UGOQKTHL.js","sourcesContent":["import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type AspectRatioProps = JSX.HTMLAttributes<HTMLDivElement> & {\n /** Width ÷ height (e.g. `16 / 9`, `1`, `9 / 16`). Applied as CSS `aspect-ratio`. */\n ratio: number;\n children?: ComponentChildren;\n};\n\n/** Fixed-ratio box for media (CSS `aspect-ratio`; no Radix dependency). Children should use `h-full w-full object-cover` to fill. */\nexport const AspectRatio = ({ ratio, class: className, style, children, ...rest }: AspectRatioProps) => {\n const styleObject = typeof style === \"object\" && style !== null && !Array.isArray(style) ? style : undefined;\n\n return (\n <div\n data-slot=\"aspect-ratio\"\n class={cn(\"relative w-full min-h-0 overflow-hidden\", className)}\n style={{\n ...styleObject,\n aspectRatio: ratio\n }}\n {...rest}\n >\n {children}\n </div>\n );\n};\n\n"]}
@@ -0,0 +1,92 @@
1
+ import { cn } from './chunk-OMXWBB67.js';
2
+ import { isValidElement, cloneElement } from 'preact';
3
+ import { tv } from 'tailwind-variants';
4
+ import { jsx } from 'preact/jsx-runtime';
5
+
6
+ var button = tv({
7
+ base: [
8
+ "group/button inline-flex shrink-0 cursor-pointer items-center justify-center rounded-lg bg-clip-padding text-sm font-medium whitespace-nowrap",
9
+ "select-none transition-all outline-none focus-visible:border-ring focus-visible:ring-3 focus-visible:ring-ring/50",
10
+ "active:translate-y-px disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50",
11
+ "aria-invalid:border-destructive aria-invalid:ring-3 aria-invalid:ring-destructive/20",
12
+ "dark:aria-invalid:border-destructive/50 dark:aria-invalid:ring-destructive/40",
13
+ "[&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
14
+ "has-data-[icon=inline-end]:pr-2 has-data-[icon=inline-start]:pl-2"
15
+ ],
16
+ variants: {
17
+ variant: {
18
+ default: "bg-primary text-background hover:bg-foreground/90 focus-visible:ring-outline/50",
19
+ secondary: "bg-secondary text-secondary-foreground hover:bg-secondary/90 focus-visible:ring-secondary/50",
20
+ inverse: "bg-foreground text-background hover:opacity-[0.85] focus-visible:ring-outline/50",
21
+ outline: "border-border bg-background hover:bg-muted hover:text-foreground aria-expanded:bg-muted aria-expanded:text-foreground dark:border-input dark:bg-input/30 dark:hover:bg-input/50 border",
22
+ ghost: "hover:bg-muted hover:text-foreground focus-visible:ring-outline/50",
23
+ destructive: "bg-destructive text-destructive-foreground hover:bg-destructive/90 focus-visible:ring-outline/50",
24
+ link: "h-auto p-0 text-primary underline-offset-4 hover:underline active:translate-y-0 focus-visible:ring-0"
25
+ },
26
+ size: {
27
+ xxs: "h-5 gap-1 px-1.5 text-[10px]",
28
+ xs: "h-6 gap-1 px-2 text-xs",
29
+ sm: "h-7 gap-1.5 px-3",
30
+ default: "h-8 gap-1.5 px-2.5",
31
+ lg: "h-9 gap-2 px-5 text-base has-[>svg]:px-4 [&_svg:not([class*='size-'])]:size-4.5",
32
+ icon: "size-8",
33
+ "icon-xs": "size-6 [&_svg:not([class*='size-'])]:size-3.5",
34
+ "icon-sm": "size-7 [&_svg:not([class*='size-'])]:size-4",
35
+ "icon-lg": "size-9 [&_svg:not([class*='size-'])]:size-5"
36
+ }
37
+ },
38
+ defaultVariants: { variant: "default", size: "default" }
39
+ });
40
+ var Button = ({ variant, size, asChild = false, class: className, children, ...rest }) => {
41
+ const resolvedVariant = variant ?? "default";
42
+ const resolvedSize = size ?? "default";
43
+ const resolvedClassName = button({ variant: resolvedVariant, size: resolvedSize, class: className });
44
+ if (asChild) {
45
+ if (!isValidElement(children)) {
46
+ const env = globalThis.process?.env?.NODE_ENV;
47
+ if (env !== "production") {
48
+ console.warn(
49
+ "[kamod-ui] <Button asChild> expects a single valid element child. Received: " + typeof children + ". Falling back to rendering nothing."
50
+ );
51
+ }
52
+ return null;
53
+ }
54
+ const childProps = children.props ?? {};
55
+ return cloneElement(children, {
56
+ ...childProps ?? {},
57
+ ...rest,
58
+ class: cn(childProps.class, childProps.className, resolvedClassName),
59
+ "data-slot": "button",
60
+ "data-variant": resolvedVariant,
61
+ "data-size": resolvedSize
62
+ });
63
+ }
64
+ if ("href" in rest && typeof rest.href === "string") {
65
+ return /* @__PURE__ */ jsx(
66
+ "a",
67
+ {
68
+ class: resolvedClassName,
69
+ "data-slot": "button",
70
+ "data-variant": resolvedVariant,
71
+ "data-size": resolvedSize,
72
+ ...rest,
73
+ children
74
+ }
75
+ );
76
+ }
77
+ return /* @__PURE__ */ jsx(
78
+ "button",
79
+ {
80
+ class: resolvedClassName,
81
+ "data-slot": "button",
82
+ "data-variant": resolvedVariant,
83
+ "data-size": resolvedSize,
84
+ ...rest,
85
+ children
86
+ }
87
+ );
88
+ };
89
+
90
+ export { Button, button };
91
+ //# sourceMappingURL=chunk-UGQ756Z6.js.map
92
+ //# sourceMappingURL=chunk-UGQ756Z6.js.map