@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,85 @@
1
+ import { Dialog, useDialog, dialogViewportBleedClass, DialogClose } from './chunk-KBXDU3G4.js';
2
+ import { cn } from './chunk-OMXWBB67.js';
3
+ import { jsx, jsxs, Fragment } from 'preact/jsx-runtime';
4
+ import { createPortal } from 'preact/compat';
5
+
6
+ var Sheet = ({ children, lockBodyScroll = true, ...rest }) => /* @__PURE__ */ jsx(Dialog, { "data-slot": "sheet", lockBodyScroll, ...rest, children });
7
+ var sidePanelClass = {
8
+ right: "inset-y-0 right-0 h-full w-full max-w-md border-l data-[state=open]:slide-in-from-right data-[state=closed]:slide-out-to-right",
9
+ left: "inset-y-0 left-0 h-full w-full max-w-md border-r data-[state=open]:slide-in-from-left data-[state=closed]:slide-out-to-left",
10
+ top: "inset-x-0 top-0 max-h-[85dvh] h-auto w-full min-w-0 border-b rounded-b-xl data-[state=open]:slide-in-from-top data-[state=closed]:slide-out-to-top",
11
+ bottom: "inset-x-0 bottom-0 max-h-[85dvh] h-auto w-full min-w-0 border-t rounded-t-xl data-[state=open]:slide-in-from-bottom data-[state=closed]:slide-out-to-bottom"
12
+ };
13
+ var SheetContent = ({
14
+ side = "right",
15
+ showCloseButton = true,
16
+ children,
17
+ class: className,
18
+ forceMount = false,
19
+ "data-slot": dataSlot = "sheet-content",
20
+ ...rest
21
+ }) => {
22
+ const dialog = useDialog();
23
+ if (!dialog.open.value && !forceMount) return null;
24
+ const state = dialog.open.value ? "open" : "closed";
25
+ const isHorizontalEdge = side === "top" || side === "bottom";
26
+ const edgePadding = side === "top" ? "px-6 pb-6 pt-[calc(1.5rem+env(safe-area-inset-top,0px))]" : side === "bottom" ? "px-6 pt-6 pb-[calc(1.5rem+env(safe-area-inset-bottom,0px))]" : "p-6";
27
+ const tree = /* @__PURE__ */ jsxs(Fragment, { children: [
28
+ /* @__PURE__ */ jsx(
29
+ "div",
30
+ {
31
+ "aria-hidden": "true",
32
+ "data-slot": "sheet-overlay",
33
+ "data-state": state,
34
+ class: cn(
35
+ "fade-in fade-out",
36
+ dialogViewportBleedClass,
37
+ "z-40 bg-black/50 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fill-mode-forwards"
38
+ )
39
+ }
40
+ ),
41
+ /* @__PURE__ */ jsxs(
42
+ "div",
43
+ {
44
+ ...rest,
45
+ role: "dialog",
46
+ "aria-modal": "true",
47
+ "data-side": side,
48
+ "data-state": state,
49
+ "data-slot": dataSlot,
50
+ class: cn(
51
+ "fixed z-50 flex min-h-0 min-w-0 flex-col gap-4 overflow-y-auto border bg-background shadow-lg outline-none",
52
+ edgePadding,
53
+ "data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fill-mode-forwards duration-300",
54
+ sidePanelClass[side],
55
+ className,
56
+ // Top/bottom sheets must span the viewport width; a consumer `max-w-*` (e.g. from copy-pasted right-sheet examples) would otherwise narrow them.
57
+ isHorizontalEdge && "w-full !max-w-none"
58
+ ),
59
+ children: [
60
+ showCloseButton ? /* @__PURE__ */ jsx(
61
+ DialogClose,
62
+ {
63
+ "data-slot": "sheet-close",
64
+ "aria-label": "Close sheet",
65
+ class: cn(
66
+ "absolute right-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",
67
+ side === "top" ? "top-[calc(1rem+env(safe-area-inset-top,0px))]" : "top-4"
68
+ ),
69
+ children: "Close"
70
+ }
71
+ ) : null,
72
+ children
73
+ ]
74
+ }
75
+ )
76
+ ] });
77
+ if (typeof document === "undefined") return tree;
78
+ return createPortal(tree, document.body);
79
+ };
80
+ var SheetFooter = ({ children, ...rest }) => /* @__PURE__ */ jsx("div", { "data-slot": "sheet-footer", ...rest, children });
81
+ var SheetHeader = ({ children, ...rest }) => /* @__PURE__ */ jsx("div", { "data-slot": "sheet-header", ...rest, children });
82
+
83
+ export { Sheet, SheetContent, SheetFooter, SheetHeader };
84
+ //# sourceMappingURL=chunk-7HZUM5ZQ.js.map
85
+ //# sourceMappingURL=chunk-7HZUM5ZQ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/sheet/Sheet.tsx","../src/components/sheet/SheetContent.tsx","../src/components/sheet/SheetFooter.tsx","../src/components/sheet/SheetHeader.tsx"],"names":["jsx"],"mappings":"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","file":"chunk-7HZUM5ZQ.js","sourcesContent":["import type { ComponentChildren } from \"preact\";\nimport { Dialog, type DialogProps } from \"../dialog/Dialog\";\n\nexport type SheetProps = DialogProps & { children?: ComponentChildren };\n\nexport const Sheet = ({ children, lockBodyScroll = true, ...rest }: SheetProps) => (\n <Dialog data-slot=\"sheet\" lockBodyScroll={lockBodyScroll} {...rest}>\n {children}\n </Dialog>\n);\n\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { createPortal } from \"preact/compat\";\nimport { cn } from \"../../lib/utils\";\nimport { useDialog } from \"../dialog/Dialog\";\nimport { dialogViewportBleedClass } from \"../dialog/DialogContent\";\nimport { SheetClose } from \"./SheetClose\";\n\nexport type SheetContentProps = JSX.HTMLAttributes<HTMLDivElement> & {\n side?: \"left\" | \"right\" | \"top\" | \"bottom\";\n forceMount?: boolean;\n showCloseButton?: boolean;\n children?: ComponentChildren;\n \"data-slot\"?: string;\n};\n\nconst sidePanelClass: Record<NonNullable<SheetContentProps[\"side\"]>, string> = {\n right:\n \"inset-y-0 right-0 h-full w-full max-w-md border-l data-[state=open]:slide-in-from-right data-[state=closed]:slide-out-to-right\",\n left:\n \"inset-y-0 left-0 h-full w-full max-w-md border-r data-[state=open]:slide-in-from-left data-[state=closed]:slide-out-to-left\",\n top:\n \"inset-x-0 top-0 max-h-[85dvh] h-auto w-full min-w-0 border-b rounded-b-xl data-[state=open]:slide-in-from-top data-[state=closed]:slide-out-to-top\",\n bottom:\n \"inset-x-0 bottom-0 max-h-[85dvh] h-auto w-full min-w-0 border-t rounded-t-xl data-[state=open]:slide-in-from-bottom data-[state=closed]:slide-out-to-bottom\"\n};\n\nexport const SheetContent = ({\n side = \"right\",\n showCloseButton = true,\n children,\n class: className,\n forceMount = false,\n \"data-slot\": dataSlot = \"sheet-content\",\n ...rest\n}: SheetContentProps) => {\n const dialog = useDialog();\n if (!dialog.open.value && !forceMount) return null;\n\n const state = dialog.open.value ? \"open\" : \"closed\";\n const isHorizontalEdge = side === \"top\" || side === \"bottom\";\n const edgePadding =\n side === \"top\"\n ? \"px-6 pb-6 pt-[calc(1.5rem+env(safe-area-inset-top,0px))]\"\n : side === \"bottom\"\n ? \"px-6 pt-6 pb-[calc(1.5rem+env(safe-area-inset-bottom,0px))]\"\n : \"p-6\";\n\n const tree = (\n <>\n <div\n aria-hidden=\"true\"\n data-slot=\"sheet-overlay\"\n data-state={state}\n class={cn(\n \"fade-in fade-out\",\n dialogViewportBleedClass,\n \"z-40 bg-black/50 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fill-mode-forwards\"\n )}\n />\n <div\n {...rest}\n role=\"dialog\"\n aria-modal=\"true\"\n data-side={side}\n data-state={state}\n data-slot={dataSlot}\n class={cn(\n \"fixed z-50 flex min-h-0 min-w-0 flex-col gap-4 overflow-y-auto border bg-background shadow-lg outline-none\",\n edgePadding,\n \"data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fill-mode-forwards duration-300\",\n sidePanelClass[side],\n className,\n // Top/bottom sheets must span the viewport width; a consumer `max-w-*` (e.g. from copy-pasted right-sheet examples) would otherwise narrow them.\n isHorizontalEdge && \"w-full !max-w-none\"\n )}\n >\n {showCloseButton ? (\n <SheetClose\n data-slot=\"sheet-close\"\n aria-label=\"Close sheet\"\n class={cn(\n \"absolute right-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\",\n side === \"top\" ? \"top-[calc(1rem+env(safe-area-inset-top,0px))]\" : \"top-4\"\n )}\n >\n Close\n </SheetClose>\n ) : null}\n {children}\n </div>\n </>\n );\n\n if (typeof document === \"undefined\") return tree;\n return createPortal(tree, document.body);\n};\n\n","import type { ComponentChildren, JSX } from \"preact\";\n\nexport type SheetFooterProps = JSX.HTMLAttributes<HTMLDivElement> & { children?: ComponentChildren };\n\nexport const SheetFooter = ({ children, ...rest }: SheetFooterProps) => (\n <div data-slot=\"sheet-footer\" {...rest}>\n {children}\n </div>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\n\nexport type SheetHeaderProps = JSX.HTMLAttributes<HTMLDivElement> & { children?: ComponentChildren };\n\nexport const SheetHeader = ({ children, ...rest }: SheetHeaderProps) => (\n <div data-slot=\"sheet-header\" {...rest}>\n {children}\n </div>\n);\n"]}
@@ -0,0 +1,375 @@
1
+ import { cn } from './chunk-OMXWBB67.js';
2
+ import { signal } from '@preact/signals';
3
+ import { createContext } from 'preact';
4
+ import { useMemo, useRef, useState, useLayoutEffect, useContext } from 'preact/hooks';
5
+ import { jsx, jsxs } from 'preact/jsx-runtime';
6
+
7
+ var AccordionContext = createContext(null);
8
+ var useAccordion = () => {
9
+ const context = useContext(AccordionContext);
10
+ if (!context) throw new Error("Accordion subcomponents must be used within Accordion");
11
+ return context;
12
+ };
13
+ var Accordion = ({
14
+ type = "single",
15
+ collapsible = true,
16
+ defaultValue,
17
+ children,
18
+ ...rest
19
+ }) => {
20
+ const openValues = useMemo(() => {
21
+ const initialSet = new Set(
22
+ defaultValue ? Array.isArray(defaultValue) ? defaultValue : [defaultValue] : []
23
+ );
24
+ return signal(initialSet);
25
+ }, []);
26
+ const context = {
27
+ type,
28
+ openValues,
29
+ toggleValue: (value) => {
30
+ const next = new Set(openValues.value);
31
+ const isOpen = next.has(value);
32
+ if (type === "single") {
33
+ if (isOpen && !collapsible) {
34
+ return;
35
+ }
36
+ next.clear();
37
+ if (!isOpen) next.add(value);
38
+ } else if (isOpen) {
39
+ next.delete(value);
40
+ } else {
41
+ next.add(value);
42
+ }
43
+ openValues.value = next;
44
+ }
45
+ };
46
+ return /* @__PURE__ */ jsx(AccordionContext.Provider, { value: context, children: /* @__PURE__ */ jsx("div", { "data-slot": "accordion", ...rest, children }) });
47
+ };
48
+ var AccordionItemContext = createContext(null);
49
+ var useAccordionItem = () => {
50
+ const context = useContext(AccordionItemContext);
51
+ if (!context) throw new Error("Accordion item subcomponents must be used within AccordionItem");
52
+ return context;
53
+ };
54
+ var AccordionItem = ({ value, disabled = false, children, ...rest }) => {
55
+ const { openValues } = useAccordion();
56
+ const isOpen = openValues.value.has(value);
57
+ return /* @__PURE__ */ jsx(AccordionItemContext.Provider, { value: { value, isOpen, disabled }, children: /* @__PURE__ */ jsx(
58
+ "div",
59
+ {
60
+ "data-slot": "accordion-item",
61
+ "data-state": isOpen ? "open" : "closed",
62
+ "data-disabled": disabled ? "" : void 0,
63
+ ...rest,
64
+ children
65
+ }
66
+ ) });
67
+ };
68
+ var AccordionContent = ({
69
+ forceMount = false,
70
+ duration = "320ms",
71
+ timingFunction = "cubic-bezier(0.22, 1, 0.36, 1)",
72
+ largeContentThreshold = 560,
73
+ children,
74
+ class: className,
75
+ style,
76
+ ...rest
77
+ }) => {
78
+ const { isOpen } = useAccordionItem();
79
+ const innerRef = useRef(null);
80
+ const outerRef = useRef(null);
81
+ const isOpenRef = useRef(isOpen);
82
+ isOpenRef.current = isOpen;
83
+ const hasInitializedRef = useRef(false);
84
+ const [mounted, setMounted] = useState(() => isOpen || forceMount);
85
+ const [isAnimatingClose, setIsAnimatingClose] = useState(false);
86
+ const [isAnimatingOpen, setIsAnimatingOpen] = useState(false);
87
+ const prefersReducedMotionRef = useRef(false);
88
+ const rafRef = useRef(null);
89
+ const rafSecondRef = useRef(null);
90
+ const resizeObserverRef = useRef(null);
91
+ const usesMaxHeightRef = useRef(false);
92
+ useLayoutEffect(() => {
93
+ if (typeof window !== "undefined") {
94
+ prefersReducedMotionRef.current = window.matchMedia("(prefers-reduced-motion: reduce)").matches;
95
+ }
96
+ const outer = outerRef.current;
97
+ const inner = innerRef.current;
98
+ if (!outer || !inner) return;
99
+ if (rafRef.current !== null) {
100
+ cancelAnimationFrame(rafRef.current);
101
+ rafRef.current = null;
102
+ }
103
+ if (rafSecondRef.current !== null) {
104
+ cancelAnimationFrame(rafSecondRef.current);
105
+ rafSecondRef.current = null;
106
+ }
107
+ if (resizeObserverRef.current) {
108
+ resizeObserverRef.current.disconnect();
109
+ resizeObserverRef.current = null;
110
+ }
111
+ const syncOpenStyles = () => {
112
+ outer.style.transition = "none";
113
+ outer.style.height = "auto";
114
+ outer.style.maxHeight = "none";
115
+ outer.style.overflow = "";
116
+ outer.style.willChange = "";
117
+ };
118
+ const syncClosedStyles = () => {
119
+ outer.style.transition = "none";
120
+ outer.style.height = "0px";
121
+ outer.style.maxHeight = "0px";
122
+ outer.style.overflow = "hidden";
123
+ outer.style.willChange = "";
124
+ };
125
+ const measureExpandedHeight = () => {
126
+ const contentHeight = inner.getBoundingClientRect().height;
127
+ const computed = window.getComputedStyle(inner);
128
+ const marginTop = Number.parseFloat(computed.marginTop || "0") || 0;
129
+ const marginBottom = Number.parseFloat(computed.marginBottom || "0") || 0;
130
+ return Math.ceil(contentHeight + marginTop + marginBottom);
131
+ };
132
+ if (!hasInitializedRef.current) {
133
+ hasInitializedRef.current = true;
134
+ if (isOpen) {
135
+ setMounted(true);
136
+ syncOpenStyles();
137
+ } else {
138
+ syncClosedStyles();
139
+ }
140
+ return;
141
+ }
142
+ if (isOpen) {
143
+ if (!mounted) {
144
+ setMounted(true);
145
+ return;
146
+ }
147
+ setIsAnimatingClose(false);
148
+ const endHeight = measureExpandedHeight();
149
+ const startHeight2 = outer.getBoundingClientRect().height;
150
+ usesMaxHeightRef.current = endHeight >= largeContentThreshold;
151
+ const animateProperty2 = usesMaxHeightRef.current ? "max-height" : "height";
152
+ const transitionValue2 = `${animateProperty2} ${duration} ${timingFunction}`;
153
+ if (prefersReducedMotionRef.current || Math.abs(endHeight - startHeight2) < 1) {
154
+ setIsAnimatingOpen(false);
155
+ syncOpenStyles();
156
+ return;
157
+ }
158
+ setIsAnimatingOpen(true);
159
+ outer.style.transition = "none";
160
+ outer.style.overflow = "hidden";
161
+ outer.style.willChange = animateProperty2;
162
+ outer.style.height = usesMaxHeightRef.current ? "auto" : `${startHeight2}px`;
163
+ outer.style.maxHeight = `${startHeight2}px`;
164
+ rafRef.current = requestAnimationFrame(() => {
165
+ rafRef.current = null;
166
+ rafSecondRef.current = requestAnimationFrame(() => {
167
+ rafSecondRef.current = null;
168
+ outer.style.transition = transitionValue2;
169
+ if (usesMaxHeightRef.current) {
170
+ outer.style.maxHeight = `${endHeight}px`;
171
+ } else {
172
+ outer.style.height = `${endHeight}px`;
173
+ outer.style.maxHeight = `${endHeight}px`;
174
+ }
175
+ });
176
+ });
177
+ if (typeof ResizeObserver !== "undefined") {
178
+ resizeObserverRef.current = new ResizeObserver(() => {
179
+ if (!isOpenRef.current) return;
180
+ const nextHeight = measureExpandedHeight();
181
+ if (nextHeight <= 0) return;
182
+ if (usesMaxHeightRef.current) {
183
+ outer.style.maxHeight = `${nextHeight}px`;
184
+ } else {
185
+ outer.style.height = `${nextHeight}px`;
186
+ outer.style.maxHeight = `${nextHeight}px`;
187
+ }
188
+ });
189
+ resizeObserverRef.current.observe(inner);
190
+ }
191
+ return;
192
+ }
193
+ if (!mounted) {
194
+ if (forceMount) syncClosedStyles();
195
+ return;
196
+ }
197
+ const startHeight = outer.getBoundingClientRect().height || measureExpandedHeight();
198
+ usesMaxHeightRef.current = startHeight >= largeContentThreshold;
199
+ const animateProperty = usesMaxHeightRef.current ? "max-height" : "height";
200
+ const transitionValue = `${animateProperty} ${duration} ${timingFunction}`;
201
+ if (prefersReducedMotionRef.current || startHeight < 1) {
202
+ setIsAnimatingOpen(false);
203
+ setIsAnimatingClose(false);
204
+ if (!forceMount) {
205
+ setMounted(false);
206
+ } else {
207
+ syncClosedStyles();
208
+ }
209
+ return;
210
+ }
211
+ setIsAnimatingOpen(false);
212
+ setIsAnimatingClose(true);
213
+ outer.style.transition = "none";
214
+ outer.style.overflow = "hidden";
215
+ outer.style.willChange = animateProperty;
216
+ outer.style.height = usesMaxHeightRef.current ? "auto" : `${startHeight}px`;
217
+ outer.style.maxHeight = `${startHeight}px`;
218
+ rafRef.current = requestAnimationFrame(() => {
219
+ rafRef.current = null;
220
+ rafSecondRef.current = requestAnimationFrame(() => {
221
+ rafSecondRef.current = null;
222
+ outer.style.transition = transitionValue;
223
+ if (usesMaxHeightRef.current) {
224
+ outer.style.maxHeight = "0px";
225
+ } else {
226
+ outer.style.height = "0px";
227
+ outer.style.maxHeight = "0px";
228
+ }
229
+ });
230
+ });
231
+ return () => {
232
+ if (rafRef.current !== null) {
233
+ cancelAnimationFrame(rafRef.current);
234
+ rafRef.current = null;
235
+ }
236
+ if (rafSecondRef.current !== null) {
237
+ cancelAnimationFrame(rafSecondRef.current);
238
+ rafSecondRef.current = null;
239
+ }
240
+ if (resizeObserverRef.current) {
241
+ resizeObserverRef.current.disconnect();
242
+ resizeObserverRef.current = null;
243
+ }
244
+ };
245
+ }, [forceMount, isOpen, mounted, timingFunction, duration, largeContentThreshold]);
246
+ const handleTransitionEnd = (e) => {
247
+ if (e.target !== outerRef.current) return;
248
+ if (e.propertyName !== "height" && e.propertyName !== "max-height") return;
249
+ const outer = outerRef.current;
250
+ if (!outer) return;
251
+ if (isOpenRef.current) {
252
+ setIsAnimatingOpen(false);
253
+ outer.style.transition = "none";
254
+ outer.style.height = "auto";
255
+ outer.style.maxHeight = "none";
256
+ outer.style.overflow = "";
257
+ outer.style.willChange = "";
258
+ if (resizeObserverRef.current) {
259
+ resizeObserverRef.current.disconnect();
260
+ resizeObserverRef.current = null;
261
+ }
262
+ return;
263
+ }
264
+ setIsAnimatingClose(false);
265
+ if (!forceMount) {
266
+ outer.style.willChange = "";
267
+ setMounted(false);
268
+ } else {
269
+ outer.style.transition = "none";
270
+ outer.style.height = "0px";
271
+ outer.style.maxHeight = "0px";
272
+ outer.style.overflow = "hidden";
273
+ outer.style.willChange = "";
274
+ }
275
+ };
276
+ const allowRender = mounted || forceMount || isOpen;
277
+ if (!allowRender) return null;
278
+ const mergedStyle = {
279
+ ...typeof style === "object" && style !== null && !Array.isArray(style) ? style : {},
280
+ ["--kamodui-accordion-duration"]: duration,
281
+ ["--kamodui-accordion-timing-function"]: timingFunction
282
+ };
283
+ return /* @__PURE__ */ jsx(
284
+ "div",
285
+ {
286
+ ref: outerRef,
287
+ "data-slot": "accordion-content",
288
+ "data-state": isOpen ? "open" : "closed",
289
+ onTransitionEnd: handleTransitionEnd,
290
+ style: mergedStyle,
291
+ class: cn("min-h-0 overflow-hidden", (isAnimatingOpen || isAnimatingClose) && "will-change-[height]"),
292
+ "aria-hidden": !isOpen && !isAnimatingClose,
293
+ inert: !isOpen || void 0,
294
+ ...rest,
295
+ children: /* @__PURE__ */ jsx(
296
+ "div",
297
+ {
298
+ ref: innerRef,
299
+ "data-slot": "accordion-content-inner",
300
+ class: cn("min-h-0 min-w-0", className),
301
+ children
302
+ }
303
+ )
304
+ }
305
+ );
306
+ };
307
+ var DefaultIndicator = () => /* @__PURE__ */ jsx("svg", { viewBox: "0 0 16 16", width: "16", height: "16", fill: "none", "aria-hidden": "true", focusable: "false", children: /* @__PURE__ */ jsx(
308
+ "path",
309
+ {
310
+ d: "M4 6l4 4 4-4",
311
+ stroke: "currentColor",
312
+ strokeWidth: "1.5",
313
+ strokeLinecap: "round",
314
+ strokeLinejoin: "round"
315
+ }
316
+ ) });
317
+ var AccordionTrigger = ({
318
+ hideIndicator = false,
319
+ indicator,
320
+ children,
321
+ class: className,
322
+ onClick,
323
+ ...rest
324
+ }) => {
325
+ const { toggleValue } = useAccordion();
326
+ const { value, isOpen, disabled } = useAccordionItem();
327
+ return /* @__PURE__ */ jsxs(
328
+ "button",
329
+ {
330
+ type: "button",
331
+ "data-slot": "accordion-trigger",
332
+ "aria-expanded": isOpen,
333
+ disabled,
334
+ "data-state": isOpen ? "open" : "closed",
335
+ class: cn(
336
+ "flex w-full items-center justify-between gap-2 rounded-md py-4 text-left text-sm font-medium outline-none transition-colors focus-visible:border-ring focus-visible:ring-2 focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50",
337
+ !isOpen && "hover:bg-muted/40",
338
+ className
339
+ ),
340
+ onClick: (event) => {
341
+ if (disabled) return;
342
+ toggleValue(value);
343
+ onClick?.(event);
344
+ },
345
+ ...rest,
346
+ children: [
347
+ /* @__PURE__ */ jsx("span", { "data-slot": "accordion-trigger-label", class: "min-w-0 flex-1 text-start", children }),
348
+ !hideIndicator ? /* @__PURE__ */ jsx(
349
+ "span",
350
+ {
351
+ "data-slot": "accordion-trigger-indicator",
352
+ "data-state": isOpen ? "open" : "closed",
353
+ class: cn(
354
+ "shrink-0 text-muted-foreground transition-transform duration-200",
355
+ isOpen && "rotate-180"
356
+ ),
357
+ children: indicator ?? /* @__PURE__ */ jsx(DefaultIndicator, {})
358
+ }
359
+ ) : null
360
+ ]
361
+ }
362
+ );
363
+ };
364
+
365
+ // src/components/accordion/index.ts
366
+ var accordion_default = {
367
+ Root: Accordion,
368
+ Item: AccordionItem,
369
+ Trigger: AccordionTrigger,
370
+ Content: AccordionContent
371
+ };
372
+
373
+ export { Accordion, AccordionContent, AccordionItem, AccordionTrigger, accordion_default };
374
+ //# sourceMappingURL=chunk-7MECYLKS.js.map
375
+ //# sourceMappingURL=chunk-7MECYLKS.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/accordion/Accordion.tsx","../src/components/accordion/AccordionItem.tsx","../src/components/accordion/AccordionContent.tsx","../src/components/accordion/AccordionTrigger.tsx","../src/components/accordion/index.ts"],"names":["createContext","useContext","jsx","startHeight","animateProperty","transitionValue"],"mappings":"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","file":"chunk-7MECYLKS.js","sourcesContent":["import { signal, type Signal } from \"@preact/signals\";\nimport { createContext } from \"preact\";\nimport { useContext, useMemo } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\n\ntype AccordionType = \"single\" | \"multiple\";\n\ntype AccordionContextValue = {\n type: AccordionType;\n openValues: Signal<Set<string>>;\n toggleValue: (value: string) => void;\n};\n\nconst AccordionContext = createContext<AccordionContextValue | null>(null);\n\nexport const useAccordion = () => {\n const context = useContext(AccordionContext);\n if (!context) throw new Error(\"Accordion subcomponents must be used within Accordion\");\n return context;\n};\n\nexport type AccordionProps = JSX.HTMLAttributes<HTMLDivElement> & {\n type?: AccordionType;\n /** When `type=\"single\"`, `false` keeps one panel always open (clicking the open trigger does not close it). Default `true` matches common shadcn examples. */\n collapsible?: boolean;\n defaultValue?: string | string[];\n children?: ComponentChildren;\n};\n\nexport const Accordion = ({\n type = \"single\",\n collapsible = true,\n defaultValue,\n children,\n ...rest\n}: AccordionProps) => {\n const openValues = useMemo(() => {\n const initialSet = new Set<string>(\n defaultValue ? (Array.isArray(defaultValue) ? defaultValue : [defaultValue]) : []\n );\n return signal(initialSet);\n }, []);\n\n const context: AccordionContextValue = {\n type,\n openValues,\n toggleValue: (value) => {\n const next = new Set(openValues.value);\n const isOpen = next.has(value);\n\n if (type === \"single\") {\n if (isOpen && !collapsible) {\n return;\n }\n next.clear();\n if (!isOpen) next.add(value);\n } else if (isOpen) {\n next.delete(value);\n } else {\n next.add(value);\n }\n\n openValues.value = next;\n }\n };\n\n return (\n <AccordionContext.Provider value={context}>\n <div data-slot=\"accordion\" {...rest}>\n {children}\n </div>\n </AccordionContext.Provider>\n );\n};\n","import { createContext } from \"preact\";\nimport { useContext } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { useAccordion } from \"./Accordion\";\n\ntype AccordionItemContextValue = {\n value: string;\n isOpen: boolean;\n disabled: boolean;\n};\n\nconst AccordionItemContext = createContext<AccordionItemContextValue | null>(null);\n\nexport const useAccordionItem = () => {\n const context = useContext(AccordionItemContext);\n if (!context) throw new Error(\"Accordion item subcomponents must be used within AccordionItem\");\n return context;\n};\n\nexport type AccordionItemProps = JSX.HTMLAttributes<HTMLDivElement> & {\n value: string;\n disabled?: boolean;\n children?: ComponentChildren;\n};\n\nexport const AccordionItem = ({ value, disabled = false, children, ...rest }: AccordionItemProps) => {\n const { openValues } = useAccordion();\n const isOpen = openValues.value.has(value);\n\n return (\n <AccordionItemContext.Provider value={{ value, isOpen, disabled }}>\n <div\n data-slot=\"accordion-item\"\n data-state={isOpen ? \"open\" : \"closed\"}\n data-disabled={disabled ? \"\" : undefined}\n {...rest}\n >\n {children}\n </div>\n </AccordionItemContext.Provider>\n );\n};\n\n","import { useLayoutEffect, useRef, useState } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { useAccordionItem } from \"./AccordionItem\";\nimport { cn } from \"../../lib/utils\";\n\nexport type AccordionContentProps = JSX.HTMLAttributes<HTMLDivElement> & {\n forceMount?: boolean;\n /** Grid transition duration, e.g. `400ms` */\n duration?: string;\n /** CSS timing function, e.g. `cubic-bezier(0.4, 0, 0.2, 1)` */\n timingFunction?: string;\n /** Use max-height animation for very tall content to reduce micro-jank. */\n largeContentThreshold?: number;\n children?: ComponentChildren;\n};\n\nexport const AccordionContent = ({\n forceMount = false,\n duration = \"320ms\",\n timingFunction = \"cubic-bezier(0.22, 1, 0.36, 1)\",\n largeContentThreshold = 560,\n children,\n class: className,\n style,\n ...rest\n}: AccordionContentProps) => {\n const { isOpen } = useAccordionItem();\n const innerRef = useRef<HTMLDivElement>(null);\n const outerRef = useRef<HTMLDivElement>(null);\n const isOpenRef = useRef(isOpen);\n isOpenRef.current = isOpen;\n const hasInitializedRef = useRef(false);\n\n const [mounted, setMounted] = useState(() => isOpen || forceMount);\n const [isAnimatingClose, setIsAnimatingClose] = useState(false);\n const [isAnimatingOpen, setIsAnimatingOpen] = useState(false);\n const prefersReducedMotionRef = useRef(false);\n const rafRef = useRef<number | null>(null);\n const rafSecondRef = useRef<number | null>(null);\n const resizeObserverRef = useRef<ResizeObserver | null>(null);\n const usesMaxHeightRef = useRef(false);\n\n useLayoutEffect(() => {\n if (typeof window !== \"undefined\") {\n prefersReducedMotionRef.current = window.matchMedia(\"(prefers-reduced-motion: reduce)\").matches;\n }\n\n const outer = outerRef.current;\n const inner = innerRef.current;\n if (!outer || !inner) return;\n\n if (rafRef.current !== null) {\n cancelAnimationFrame(rafRef.current);\n rafRef.current = null;\n }\n if (rafSecondRef.current !== null) {\n cancelAnimationFrame(rafSecondRef.current);\n rafSecondRef.current = null;\n }\n if (resizeObserverRef.current) {\n resizeObserverRef.current.disconnect();\n resizeObserverRef.current = null;\n }\n\n const syncOpenStyles = () => {\n outer.style.transition = \"none\";\n outer.style.height = \"auto\";\n outer.style.maxHeight = \"none\";\n outer.style.overflow = \"\";\n outer.style.willChange = \"\";\n };\n\n const syncClosedStyles = () => {\n outer.style.transition = \"none\";\n outer.style.height = \"0px\";\n outer.style.maxHeight = \"0px\";\n outer.style.overflow = \"hidden\";\n outer.style.willChange = \"\";\n };\n\n const measureExpandedHeight = () => {\n const contentHeight = inner.getBoundingClientRect().height;\n const computed = window.getComputedStyle(inner);\n const marginTop = Number.parseFloat(computed.marginTop || \"0\") || 0;\n const marginBottom = Number.parseFloat(computed.marginBottom || \"0\") || 0;\n return Math.ceil(contentHeight + marginTop + marginBottom);\n };\n\n if (!hasInitializedRef.current) {\n hasInitializedRef.current = true;\n if (isOpen) {\n setMounted(true);\n syncOpenStyles();\n } else {\n syncClosedStyles();\n }\n return;\n }\n\n if (isOpen) {\n if (!mounted) {\n // First render closed content into the DOM, then animate on the next layout pass.\n setMounted(true);\n return;\n }\n\n setIsAnimatingClose(false);\n const endHeight = measureExpandedHeight();\n const startHeight = outer.getBoundingClientRect().height;\n usesMaxHeightRef.current = endHeight >= largeContentThreshold;\n const animateProperty = usesMaxHeightRef.current ? \"max-height\" : \"height\";\n const transitionValue = `${animateProperty} ${duration} ${timingFunction}`;\n\n if (prefersReducedMotionRef.current || Math.abs(endHeight - startHeight) < 1) {\n setIsAnimatingOpen(false);\n syncOpenStyles();\n return;\n }\n\n setIsAnimatingOpen(true);\n outer.style.transition = \"none\";\n outer.style.overflow = \"hidden\";\n outer.style.willChange = animateProperty;\n outer.style.height = usesMaxHeightRef.current ? \"auto\" : `${startHeight}px`;\n outer.style.maxHeight = `${startHeight}px`;\n rafRef.current = requestAnimationFrame(() => {\n rafRef.current = null;\n rafSecondRef.current = requestAnimationFrame(() => {\n rafSecondRef.current = null;\n outer.style.transition = transitionValue;\n if (usesMaxHeightRef.current) {\n outer.style.maxHeight = `${endHeight}px`;\n } else {\n outer.style.height = `${endHeight}px`;\n outer.style.maxHeight = `${endHeight}px`;\n }\n });\n });\n\n if (typeof ResizeObserver !== \"undefined\") {\n resizeObserverRef.current = new ResizeObserver(() => {\n if (!isOpenRef.current) return;\n const nextHeight = measureExpandedHeight();\n if (nextHeight <= 0) return;\n if (usesMaxHeightRef.current) {\n outer.style.maxHeight = `${nextHeight}px`;\n } else {\n outer.style.height = `${nextHeight}px`;\n outer.style.maxHeight = `${nextHeight}px`;\n }\n });\n resizeObserverRef.current.observe(inner);\n }\n return;\n }\n\n if (!mounted) {\n if (forceMount) syncClosedStyles();\n return;\n }\n\n const startHeight = outer.getBoundingClientRect().height || measureExpandedHeight();\n usesMaxHeightRef.current = startHeight >= largeContentThreshold;\n const animateProperty = usesMaxHeightRef.current ? \"max-height\" : \"height\";\n const transitionValue = `${animateProperty} ${duration} ${timingFunction}`;\n if (prefersReducedMotionRef.current || startHeight < 1) {\n setIsAnimatingOpen(false);\n setIsAnimatingClose(false);\n if (!forceMount) {\n setMounted(false);\n } else {\n syncClosedStyles();\n }\n return;\n }\n\n setIsAnimatingOpen(false);\n setIsAnimatingClose(true);\n outer.style.transition = \"none\";\n outer.style.overflow = \"hidden\";\n outer.style.willChange = animateProperty;\n outer.style.height = usesMaxHeightRef.current ? \"auto\" : `${startHeight}px`;\n outer.style.maxHeight = `${startHeight}px`;\n rafRef.current = requestAnimationFrame(() => {\n rafRef.current = null;\n rafSecondRef.current = requestAnimationFrame(() => {\n rafSecondRef.current = null;\n outer.style.transition = transitionValue;\n if (usesMaxHeightRef.current) {\n outer.style.maxHeight = \"0px\";\n } else {\n outer.style.height = \"0px\";\n outer.style.maxHeight = \"0px\";\n }\n });\n });\n return () => {\n if (rafRef.current !== null) {\n cancelAnimationFrame(rafRef.current);\n rafRef.current = null;\n }\n if (rafSecondRef.current !== null) {\n cancelAnimationFrame(rafSecondRef.current);\n rafSecondRef.current = null;\n }\n if (resizeObserverRef.current) {\n resizeObserverRef.current.disconnect();\n resizeObserverRef.current = null;\n }\n };\n }, [forceMount, isOpen, mounted, timingFunction, duration, largeContentThreshold]);\n\n const handleTransitionEnd = (e: TransitionEvent) => {\n if (e.target !== outerRef.current) return;\n if (e.propertyName !== \"height\" && e.propertyName !== \"max-height\") return;\n const outer = outerRef.current;\n if (!outer) return;\n\n if (isOpenRef.current) {\n setIsAnimatingOpen(false);\n outer.style.transition = \"none\";\n outer.style.height = \"auto\";\n outer.style.maxHeight = \"none\";\n outer.style.overflow = \"\";\n outer.style.willChange = \"\";\n if (resizeObserverRef.current) {\n resizeObserverRef.current.disconnect();\n resizeObserverRef.current = null;\n }\n return;\n }\n setIsAnimatingClose(false);\n if (!forceMount) {\n outer.style.willChange = \"\";\n setMounted(false);\n } else {\n outer.style.transition = \"none\";\n outer.style.height = \"0px\";\n outer.style.maxHeight = \"0px\";\n outer.style.overflow = \"hidden\";\n outer.style.willChange = \"\";\n }\n };\n\n const allowRender = mounted || forceMount || isOpen;\n if (!allowRender) return null;\n\n const mergedStyle: JSX.CSSProperties = {\n ...(typeof style === \"object\" && style !== null && !Array.isArray(style)\n ? (style as JSX.CSSProperties)\n : {}),\n [\"--kamodui-accordion-duration\" as string]: duration,\n [\"--kamodui-accordion-timing-function\" as string]: timingFunction\n };\n\n return (\n <div\n ref={outerRef}\n data-slot=\"accordion-content\"\n data-state={isOpen ? \"open\" : \"closed\"}\n onTransitionEnd={handleTransitionEnd}\n style={mergedStyle}\n class={cn(\"min-h-0 overflow-hidden\", (isAnimatingOpen || isAnimatingClose) && \"will-change-[height]\")}\n aria-hidden={!isOpen && !isAnimatingClose}\n inert={!isOpen || undefined}\n {...rest}\n >\n <div\n ref={innerRef}\n data-slot=\"accordion-content-inner\"\n class={cn(\"min-h-0 min-w-0\", className)}\n >\n {children}\n </div>\n </div>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { useAccordion } from \"./Accordion\";\nimport { useAccordionItem } from \"./AccordionItem\";\nimport { cn } from \"../../lib/utils\";\n\nexport type AccordionTriggerProps = JSX.ButtonHTMLAttributes<HTMLButtonElement> & {\n hideIndicator?: boolean;\n indicator?: ComponentChildren;\n children?: ComponentChildren;\n};\n\nconst DefaultIndicator = () => (\n <svg viewBox=\"0 0 16 16\" width=\"16\" height=\"16\" fill=\"none\" aria-hidden=\"true\" focusable=\"false\">\n <path\n d=\"M4 6l4 4 4-4\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\nexport const AccordionTrigger = ({\n hideIndicator = false,\n indicator,\n children,\n class: className,\n onClick,\n ...rest\n}: AccordionTriggerProps) => {\n const { toggleValue } = useAccordion();\n const { value, isOpen, disabled } = useAccordionItem();\n\n return (\n <button\n type=\"button\"\n data-slot=\"accordion-trigger\"\n aria-expanded={isOpen}\n disabled={disabled}\n data-state={isOpen ? \"open\" : \"closed\"}\n class={cn(\n \"flex w-full items-center justify-between gap-2 rounded-md py-4 text-left text-sm font-medium outline-none transition-colors focus-visible:border-ring focus-visible:ring-2 focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50\",\n !isOpen && \"hover:bg-muted/40\",\n className\n )}\n onClick={(event) => {\n if (disabled) return;\n toggleValue(value);\n onClick?.(event);\n }}\n {...rest}\n >\n <span data-slot=\"accordion-trigger-label\" class=\"min-w-0 flex-1 text-start\">\n {children}\n </span>\n {!hideIndicator ? (\n <span\n data-slot=\"accordion-trigger-indicator\"\n data-state={isOpen ? \"open\" : \"closed\"}\n class={cn(\n \"shrink-0 text-muted-foreground transition-transform duration-200\",\n isOpen && \"rotate-180\"\n )}\n >\n {indicator ?? <DefaultIndicator />}\n </span>\n ) : null}\n </button>\n );\n};\n","import { Accordion } from \"./Accordion\";\nimport { AccordionContent } from \"./AccordionContent\";\nimport { AccordionItem } from \"./AccordionItem\";\nimport { AccordionTrigger } from \"./AccordionTrigger\";\n\nexport { Accordion, AccordionContent, AccordionItem, AccordionTrigger };\n\nexport default {\n Root: Accordion,\n Item: AccordionItem,\n Trigger: AccordionTrigger,\n Content: AccordionContent\n};\n"]}
@@ -0,0 +1,49 @@
1
+ import { cn } from './chunk-OMXWBB67.js';
2
+ import { useSignal } from '@preact/signals';
3
+ import { createContext } from 'preact';
4
+ import { useContext, useId, useEffect } from 'preact/hooks';
5
+ import { jsx } from 'preact/jsx-runtime';
6
+
7
+ var RadioGroupContext = createContext(null);
8
+ var useRadioGroup = () => {
9
+ const context = useContext(RadioGroupContext);
10
+ if (!context) throw new Error("RadioGroupItem must be used inside RadioGroup");
11
+ return context;
12
+ };
13
+ var RadioGroup = ({
14
+ name: nameProp,
15
+ defaultValue,
16
+ value: valueProp,
17
+ onValueChange,
18
+ class: className,
19
+ children,
20
+ ...rest
21
+ }) => {
22
+ const autoId = useId();
23
+ const name = nameProp ?? `radio-group-${autoId}`;
24
+ const internal = useSignal(
25
+ valueProp !== void 0 ? valueProp : defaultValue ?? null
26
+ );
27
+ useEffect(() => {
28
+ if (valueProp !== void 0) {
29
+ internal.value = valueProp;
30
+ }
31
+ }, [valueProp]);
32
+ const setValue = (next) => {
33
+ if (valueProp === void 0) {
34
+ internal.value = next;
35
+ }
36
+ onValueChange?.(next);
37
+ };
38
+ return /* @__PURE__ */ jsx(
39
+ RadioGroupContext.Provider,
40
+ {
41
+ value: { value: internal, controlledValue: valueProp, setValue, name },
42
+ children: /* @__PURE__ */ jsx("div", { role: "radiogroup", "data-slot": "radio-group", class: cn("grid gap-3", className), ...rest, children })
43
+ }
44
+ );
45
+ };
46
+
47
+ export { RadioGroup, useRadioGroup };
48
+ //# sourceMappingURL=chunk-7TDS7TC6.js.map
49
+ //# sourceMappingURL=chunk-7TDS7TC6.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/radio-group/RadioGroup.tsx"],"names":[],"mappings":";;;;;;AAeA,IAAM,iBAAA,GAAoB,cAA6C,IAAI,CAAA;AAEpE,IAAM,gBAAgB,MAAM;AACjC,EAAA,MAAM,OAAA,GAAU,WAAW,iBAAiB,CAAA;AAC5C,EAAA,IAAI,CAAC,OAAA,EAAS,MAAM,IAAI,MAAM,+CAA+C,CAAA;AAC7E,EAAA,OAAO,OAAA;AACT;AAYO,IAAM,aAAa,CAAC;AAAA,EACzB,IAAA,EAAM,QAAA;AAAA,EACN,YAAA;AAAA,EACA,KAAA,EAAO,SAAA;AAAA,EACP,aAAA;AAAA,EACA,KAAA,EAAO,SAAA;AAAA,EACP,QAAA;AAAA,EACA,GAAG;AACL,CAAA,KAAuB;AACrB,EAAA,MAAM,SAAS,KAAA,EAAM;AACrB,EAAA,MAAM,IAAA,GAAO,QAAA,IAAY,CAAA,YAAA,EAAe,MAAM,CAAA,CAAA;AAC9C,EAAA,MAAM,QAAA,GAAW,SAAA;AAAA,IACf,SAAA,KAAc,MAAA,GAAY,SAAA,GAAa,YAAA,IAAgB;AAAA,GACzD;AAEA,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,IAAI,cAAc,MAAA,EAAW;AAC3B,MAAA,QAAA,CAAS,KAAA,GAAQ,SAAA;AAAA,IACnB;AAAA,EACF,CAAA,EAAG,CAAC,SAAS,CAAC,CAAA;AAEd,EAAA,MAAM,QAAA,GAAW,CAAC,IAAA,KAAiB;AACjC,IAAA,IAAI,cAAc,MAAA,EAAW;AAC3B,MAAA,QAAA,CAAS,KAAA,GAAQ,IAAA;AAAA,IACnB;AACA,IAAA,aAAA,GAAgB,IAAI,CAAA;AAAA,EACtB,CAAA;AAEA,EAAA,uBACE,GAAA;AAAA,IAAC,iBAAA,CAAkB,QAAA;AAAA,IAAlB;AAAA,MACC,OAAO,EAAE,KAAA,EAAO,UAAU,eAAA,EAAiB,SAAA,EAAW,UAAU,IAAA,EAAK;AAAA,MAErE,QAAA,kBAAA,GAAA,CAAC,KAAA,EAAA,EAAI,IAAA,EAAK,YAAA,EAAa,WAAA,EAAU,aAAA,EAAc,KAAA,EAAO,EAAA,CAAG,YAAA,EAAc,SAAS,CAAA,EAAI,GAAG,MACpF,QAAA,EACH;AAAA;AAAA,GACF;AAEJ","file":"chunk-7TDS7TC6.js","sourcesContent":["import { type Signal, useSignal } from \"@preact/signals\";\nimport { createContext } from \"preact\";\nimport { useEffect, useId } from \"preact/hooks\";\nimport { useContext } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\ntype RadioGroupContextValue = {\n value: Signal<string | null>;\n /** When set, selection follows this prop (controlled); otherwise `value` signal is used. */\n controlledValue: string | undefined;\n setValue: (next: string) => void;\n name: string;\n};\n\nconst RadioGroupContext = createContext<RadioGroupContextValue | null>(null);\n\nexport const useRadioGroup = () => {\n const context = useContext(RadioGroupContext);\n if (!context) throw new Error(\"RadioGroupItem must be used inside RadioGroup\");\n return context;\n};\n\nexport type RadioGroupProps = Omit<JSX.HTMLAttributes<HTMLDivElement>, \"class\"> & {\n /** When omitted, a stable unique name is generated (forms can still submit if you add name to inputs manually). */\n name?: string;\n defaultValue?: string;\n value?: string;\n onValueChange?: (next: string) => void;\n class?: string;\n children?: ComponentChildren;\n};\n\nexport const RadioGroup = ({\n name: nameProp,\n defaultValue,\n value: valueProp,\n onValueChange,\n class: className,\n children,\n ...rest\n}: RadioGroupProps) => {\n const autoId = useId();\n const name = nameProp ?? `radio-group-${autoId}`;\n const internal = useSignal<string | null>(\n valueProp !== undefined ? valueProp : (defaultValue ?? null)\n );\n\n useEffect(() => {\n if (valueProp !== undefined) {\n internal.value = valueProp;\n }\n }, [valueProp]);\n\n const setValue = (next: string) => {\n if (valueProp === undefined) {\n internal.value = next;\n }\n onValueChange?.(next);\n };\n\n return (\n <RadioGroupContext.Provider\n value={{ value: internal, controlledValue: valueProp, setValue, name }}\n >\n <div role=\"radiogroup\" data-slot=\"radio-group\" class={cn(\"grid gap-3\", className)} {...rest}>\n {children}\n </div>\n </RadioGroupContext.Provider>\n );\n};\n"]}
@@ -0,0 +1,26 @@
1
+ import { cn } from './chunk-OMXWBB67.js';
2
+ import { tv } from 'tailwind-variants';
3
+ import { jsx } from 'preact/jsx-runtime';
4
+
5
+ var kbd = tv({
6
+ base: [
7
+ "pointer-events-none inline-flex select-none items-center justify-center gap-1 whitespace-nowrap",
8
+ "rounded-md border border-border bg-muted font-mono font-medium text-muted-foreground shadow-xs",
9
+ "data-[icon=inline-end]:translate-x-0.5"
10
+ ],
11
+ variants: {
12
+ size: {
13
+ sm: "h-5 min-h-5 min-w-5 px-1.5 text-[11px] leading-none",
14
+ md: "h-6 min-h-6 min-w-6 px-2 text-xs leading-none"
15
+ }
16
+ },
17
+ defaultVariants: {
18
+ size: "md"
19
+ }
20
+ });
21
+ var Kbd = ({ class: className, size, children, ...rest }) => /* @__PURE__ */ jsx("kbd", { "data-slot": "kbd", class: kbd({ size, class: className }), ...rest, children });
22
+ var KbdGroup = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("span", { "data-slot": "kbd-group", class: cn("inline-flex items-center gap-1", className), ...rest, children });
23
+
24
+ export { Kbd, KbdGroup };
25
+ //# sourceMappingURL=chunk-7ZXJRNJO.js.map
26
+ //# sourceMappingURL=chunk-7ZXJRNJO.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/kbd/Kbd.tsx","../src/components/kbd/KbdGroup.tsx"],"names":["jsx"],"mappings":";;;;AAGO,IAAM,MAAM,EAAA,CAAG;AAAA,EACpB,IAAA,EAAM;AAAA,IACJ,iGAAA;AAAA,IACA,gGAAA;AAAA,IACA;AAAA,GACF;AAAA,EACA,QAAA,EAAU;AAAA,IACR,IAAA,EAAM;AAAA,MACJ,EAAA,EAAI,qDAAA;AAAA,MACJ,EAAA,EAAI;AAAA;AACN,GACF;AAAA,EACA,eAAA,EAAiB;AAAA,IACf,IAAA,EAAM;AAAA;AAEV,CAAC,CAAA;AAOM,IAAM,GAAA,GAAM,CAAC,EAAE,KAAA,EAAO,SAAA,EAAW,MAAM,QAAA,EAAU,GAAG,IAAA,EAAK,qBAC9D,GAAA,CAAC,KAAA,EAAA,EAAI,aAAU,KAAA,EAAM,KAAA,EAAO,GAAA,CAAI,EAAE,IAAA,EAAM,KAAA,EAAO,WAAiC,CAAA,EAAI,GAAG,IAAA,EACpF,QAAA,EACH;ACrBK,IAAM,QAAA,GAAW,CAAC,EAAE,KAAA,EAAO,WAAW,QAAA,EAAU,GAAG,MAAK,qBAC7DA,IAAC,MAAA,EAAA,EAAK,WAAA,EAAU,aAAY,KAAA,EAAO,EAAA,CAAG,kCAAkC,SAAS,CAAA,EAAI,GAAG,IAAA,EACrF,QAAA,EACH","file":"chunk-7ZXJRNJO.js","sourcesContent":["import type { ComponentChildren, JSX } from \"preact\";\nimport { tv, type VariantProps } from \"tailwind-variants\";\n\nexport const kbd = tv({\n base: [\n \"pointer-events-none inline-flex select-none items-center justify-center gap-1 whitespace-nowrap\",\n \"rounded-md border border-border bg-muted font-mono font-medium text-muted-foreground shadow-xs\",\n \"data-[icon=inline-end]:translate-x-0.5\"\n ],\n variants: {\n size: {\n sm: \"h-5 min-h-5 min-w-5 px-1.5 text-[11px] leading-none\",\n md: \"h-6 min-h-6 min-w-6 px-2 text-xs leading-none\"\n }\n },\n defaultVariants: {\n size: \"md\"\n }\n});\n\nexport type KbdProps = Omit<JSX.HTMLAttributes<HTMLElement>, \"size\"> &\n VariantProps<typeof kbd> & {\n children?: ComponentChildren;\n };\n\nexport const Kbd = ({ class: className, size, children, ...rest }: KbdProps) => (\n <kbd data-slot=\"kbd\" class={kbd({ size, class: className as string | undefined })} {...rest}>\n {children}\n </kbd>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type KbdGroupProps = JSX.HTMLAttributes<HTMLSpanElement> & {\n children?: ComponentChildren;\n};\n\nexport const KbdGroup = ({ class: className, children, ...rest }: KbdGroupProps) => (\n <span data-slot=\"kbd-group\" class={cn(\"inline-flex items-center gap-1\", className)} {...rest}>\n {children}\n </span>\n);\n"]}