@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,342 @@
1
+ import { cn } from './chunk-OMXWBB67.js';
2
+ import { signal } from '@preact/signals';
3
+ import { createContext, isValidElement, cloneElement } from 'preact';
4
+ import { useMemo, useRef, useState, useLayoutEffect, useContext } from 'preact/hooks';
5
+ import { jsx } from 'preact/jsx-runtime';
6
+
7
+ var CollapsibleContext = createContext(null);
8
+ var useCollapsible = () => {
9
+ const context = useContext(CollapsibleContext);
10
+ if (!context) throw new Error("Collapsible subcomponents must be used within Collapsible");
11
+ return context;
12
+ };
13
+ var Collapsible = ({
14
+ defaultOpen = false,
15
+ open: openProp,
16
+ onOpenChange,
17
+ children,
18
+ ...rest
19
+ }) => {
20
+ const uncontrolled = useMemo(() => signal(defaultOpen), []);
21
+ const isControlled = openProp !== void 0;
22
+ const open = isControlled ? Boolean(openProp) : uncontrolled.value;
23
+ const setOpen = (next) => {
24
+ if (!isControlled) {
25
+ uncontrolled.value = next;
26
+ }
27
+ onOpenChange?.(next);
28
+ };
29
+ const context = { open, setOpen };
30
+ return /* @__PURE__ */ jsx(CollapsibleContext.Provider, { value: context, children: /* @__PURE__ */ jsx("div", { "data-slot": "collapsible", "data-state": open ? "open" : "closed", ...rest, children }) });
31
+ };
32
+ var CollapsibleContent = ({
33
+ forceMount = false,
34
+ duration = "320ms",
35
+ timingFunction = "cubic-bezier(0.22, 1, 0.36, 1)",
36
+ largeContentThreshold = 560,
37
+ children,
38
+ class: className,
39
+ style,
40
+ ...rest
41
+ }) => {
42
+ const { open } = useCollapsible();
43
+ const innerRef = useRef(null);
44
+ const outerRef = useRef(null);
45
+ const isOpenRef = useRef(open);
46
+ isOpenRef.current = open;
47
+ const hasInitializedRef = useRef(false);
48
+ const [mounted, setMounted] = useState(() => open || forceMount);
49
+ const [isAnimatingClose, setIsAnimatingClose] = useState(false);
50
+ const [isAnimatingOpen, setIsAnimatingOpen] = useState(false);
51
+ const prefersReducedMotionRef = useRef(false);
52
+ const rafRef = useRef(null);
53
+ const rafSecondRef = useRef(null);
54
+ const resizeObserverRef = useRef(null);
55
+ const usesMaxHeightRef = useRef(false);
56
+ useLayoutEffect(() => {
57
+ if (typeof window !== "undefined") {
58
+ prefersReducedMotionRef.current = window.matchMedia("(prefers-reduced-motion: reduce)").matches;
59
+ }
60
+ const outer = outerRef.current;
61
+ const inner = innerRef.current;
62
+ if (!outer || !inner) return;
63
+ if (rafRef.current !== null) {
64
+ cancelAnimationFrame(rafRef.current);
65
+ rafRef.current = null;
66
+ }
67
+ if (rafSecondRef.current !== null) {
68
+ cancelAnimationFrame(rafSecondRef.current);
69
+ rafSecondRef.current = null;
70
+ }
71
+ if (resizeObserverRef.current) {
72
+ resizeObserverRef.current.disconnect();
73
+ resizeObserverRef.current = null;
74
+ }
75
+ const syncOpenStyles = () => {
76
+ outer.style.transition = "none";
77
+ outer.style.height = "auto";
78
+ outer.style.maxHeight = "none";
79
+ outer.style.overflow = "";
80
+ outer.style.willChange = "";
81
+ };
82
+ const syncClosedStyles = () => {
83
+ outer.style.transition = "none";
84
+ outer.style.height = "0px";
85
+ outer.style.maxHeight = "0px";
86
+ outer.style.overflow = "hidden";
87
+ outer.style.willChange = "";
88
+ };
89
+ const measureExpandedHeight = () => {
90
+ const contentHeight = inner.getBoundingClientRect().height;
91
+ const computed = window.getComputedStyle(inner);
92
+ const marginTop = Number.parseFloat(computed.marginTop || "0") || 0;
93
+ const marginBottom = Number.parseFloat(computed.marginBottom || "0") || 0;
94
+ return Math.ceil(contentHeight + marginTop + marginBottom);
95
+ };
96
+ if (!hasInitializedRef.current) {
97
+ hasInitializedRef.current = true;
98
+ if (open) {
99
+ setMounted(true);
100
+ syncOpenStyles();
101
+ } else {
102
+ syncClosedStyles();
103
+ }
104
+ return;
105
+ }
106
+ if (open) {
107
+ if (!mounted) {
108
+ setMounted(true);
109
+ return;
110
+ }
111
+ setIsAnimatingClose(false);
112
+ const endHeight = measureExpandedHeight();
113
+ const startHeight2 = outer.getBoundingClientRect().height;
114
+ usesMaxHeightRef.current = endHeight >= largeContentThreshold;
115
+ const animateProperty2 = usesMaxHeightRef.current ? "max-height" : "height";
116
+ const transitionValue2 = `${animateProperty2} ${duration} ${timingFunction}`;
117
+ if (prefersReducedMotionRef.current || Math.abs(endHeight - startHeight2) < 1) {
118
+ setIsAnimatingOpen(false);
119
+ syncOpenStyles();
120
+ return;
121
+ }
122
+ setIsAnimatingOpen(true);
123
+ outer.style.transition = "none";
124
+ outer.style.overflow = "hidden";
125
+ outer.style.willChange = animateProperty2;
126
+ outer.style.height = usesMaxHeightRef.current ? "auto" : `${startHeight2}px`;
127
+ outer.style.maxHeight = `${startHeight2}px`;
128
+ rafRef.current = requestAnimationFrame(() => {
129
+ rafRef.current = null;
130
+ rafSecondRef.current = requestAnimationFrame(() => {
131
+ rafSecondRef.current = null;
132
+ outer.style.transition = transitionValue2;
133
+ if (usesMaxHeightRef.current) {
134
+ outer.style.maxHeight = `${endHeight}px`;
135
+ } else {
136
+ outer.style.height = `${endHeight}px`;
137
+ outer.style.maxHeight = `${endHeight}px`;
138
+ }
139
+ });
140
+ });
141
+ if (typeof ResizeObserver !== "undefined") {
142
+ resizeObserverRef.current = new ResizeObserver(() => {
143
+ if (!isOpenRef.current) return;
144
+ const nextHeight = measureExpandedHeight();
145
+ if (nextHeight <= 0) return;
146
+ if (usesMaxHeightRef.current) {
147
+ outer.style.maxHeight = `${nextHeight}px`;
148
+ } else {
149
+ outer.style.height = `${nextHeight}px`;
150
+ outer.style.maxHeight = `${nextHeight}px`;
151
+ }
152
+ });
153
+ resizeObserverRef.current.observe(inner);
154
+ }
155
+ return;
156
+ }
157
+ if (!mounted) {
158
+ if (forceMount) syncClosedStyles();
159
+ return;
160
+ }
161
+ const startHeight = outer.getBoundingClientRect().height || measureExpandedHeight();
162
+ usesMaxHeightRef.current = startHeight >= largeContentThreshold;
163
+ const animateProperty = usesMaxHeightRef.current ? "max-height" : "height";
164
+ const transitionValue = `${animateProperty} ${duration} ${timingFunction}`;
165
+ if (prefersReducedMotionRef.current || startHeight < 1) {
166
+ setIsAnimatingOpen(false);
167
+ setIsAnimatingClose(false);
168
+ if (!forceMount) {
169
+ setMounted(false);
170
+ } else {
171
+ syncClosedStyles();
172
+ }
173
+ return;
174
+ }
175
+ setIsAnimatingOpen(false);
176
+ setIsAnimatingClose(true);
177
+ outer.style.transition = "none";
178
+ outer.style.overflow = "hidden";
179
+ outer.style.willChange = animateProperty;
180
+ outer.style.height = usesMaxHeightRef.current ? "auto" : `${startHeight}px`;
181
+ outer.style.maxHeight = `${startHeight}px`;
182
+ rafRef.current = requestAnimationFrame(() => {
183
+ rafRef.current = null;
184
+ rafSecondRef.current = requestAnimationFrame(() => {
185
+ rafSecondRef.current = null;
186
+ outer.style.transition = transitionValue;
187
+ if (usesMaxHeightRef.current) {
188
+ outer.style.maxHeight = "0px";
189
+ } else {
190
+ outer.style.height = "0px";
191
+ outer.style.maxHeight = "0px";
192
+ }
193
+ });
194
+ });
195
+ return () => {
196
+ if (rafRef.current !== null) {
197
+ cancelAnimationFrame(rafRef.current);
198
+ rafRef.current = null;
199
+ }
200
+ if (rafSecondRef.current !== null) {
201
+ cancelAnimationFrame(rafSecondRef.current);
202
+ rafSecondRef.current = null;
203
+ }
204
+ if (resizeObserverRef.current) {
205
+ resizeObserverRef.current.disconnect();
206
+ resizeObserverRef.current = null;
207
+ }
208
+ };
209
+ }, [forceMount, open, mounted, timingFunction, duration, largeContentThreshold]);
210
+ const handleTransitionEnd = (e) => {
211
+ if (e.target !== outerRef.current) return;
212
+ if (e.propertyName !== "height" && e.propertyName !== "max-height") return;
213
+ const outer = outerRef.current;
214
+ if (!outer) return;
215
+ if (isOpenRef.current) {
216
+ setIsAnimatingOpen(false);
217
+ outer.style.transition = "none";
218
+ outer.style.height = "auto";
219
+ outer.style.maxHeight = "none";
220
+ outer.style.overflow = "";
221
+ outer.style.willChange = "";
222
+ if (resizeObserverRef.current) {
223
+ resizeObserverRef.current.disconnect();
224
+ resizeObserverRef.current = null;
225
+ }
226
+ return;
227
+ }
228
+ setIsAnimatingClose(false);
229
+ if (!forceMount) {
230
+ outer.style.willChange = "";
231
+ setMounted(false);
232
+ } else {
233
+ outer.style.transition = "none";
234
+ outer.style.height = "0px";
235
+ outer.style.maxHeight = "0px";
236
+ outer.style.overflow = "hidden";
237
+ outer.style.willChange = "";
238
+ }
239
+ };
240
+ const allowRender = mounted || forceMount || open;
241
+ if (!allowRender) return null;
242
+ const mergedStyle = {
243
+ ...typeof style === "object" && style !== null && !Array.isArray(style) ? style : {},
244
+ ["--kamodui-collapsible-duration"]: duration,
245
+ ["--kamodui-collapsible-timing-function"]: timingFunction
246
+ };
247
+ return /* @__PURE__ */ jsx(
248
+ "div",
249
+ {
250
+ ref: outerRef,
251
+ "data-slot": "collapsible-content",
252
+ "data-state": open ? "open" : "closed",
253
+ onTransitionEnd: handleTransitionEnd,
254
+ style: mergedStyle,
255
+ class: cn("min-h-0 overflow-hidden", (isAnimatingOpen || isAnimatingClose) && "will-change-[height]"),
256
+ "aria-hidden": !open && !isAnimatingClose,
257
+ inert: !open || void 0,
258
+ ...rest,
259
+ children: /* @__PURE__ */ jsx(
260
+ "div",
261
+ {
262
+ ref: innerRef,
263
+ "data-slot": "collapsible-content-inner",
264
+ class: cn("min-h-0 min-w-0", className),
265
+ children
266
+ }
267
+ )
268
+ }
269
+ );
270
+ };
271
+ var callRef = (ref, node) => {
272
+ if (typeof ref === "function") {
273
+ ref(node);
274
+ } else if (ref && typeof ref === "object" && "current" in ref) {
275
+ ref.current = node;
276
+ }
277
+ };
278
+ var CollapsibleTrigger = ({
279
+ asChild = false,
280
+ children,
281
+ onClick,
282
+ ref: outerRef,
283
+ "data-slot": dataSlot = "collapsible-trigger",
284
+ ...rest
285
+ }) => {
286
+ const { open, setOpen } = useCollapsible();
287
+ const toggle = () => setOpen(!open);
288
+ const handleClick = (event) => {
289
+ onClick?.(event);
290
+ if (event.defaultPrevented) return;
291
+ toggle();
292
+ };
293
+ if (asChild) {
294
+ if (!isValidElement(children)) {
295
+ return null;
296
+ }
297
+ const childProps = children.props ?? {};
298
+ return cloneElement(children, {
299
+ ...childProps,
300
+ ...rest,
301
+ "aria-expanded": open,
302
+ "data-state": open ? "open" : "closed",
303
+ "data-slot": dataSlot,
304
+ onClick: (event) => {
305
+ childProps.onClick?.(event);
306
+ handleClick(event);
307
+ },
308
+ ref: (node) => {
309
+ callRef(childProps.ref, node);
310
+ callRef(outerRef, node);
311
+ }
312
+ });
313
+ }
314
+ return /* @__PURE__ */ jsx(
315
+ "button",
316
+ {
317
+ type: "button",
318
+ "data-slot": dataSlot,
319
+ "aria-expanded": open,
320
+ "data-state": open ? "open" : "closed",
321
+ onClick: (event) => {
322
+ handleClick(event);
323
+ },
324
+ ref: (node) => {
325
+ callRef(outerRef, node);
326
+ },
327
+ ...rest,
328
+ children
329
+ }
330
+ );
331
+ };
332
+
333
+ // src/components/collapsible/index.ts
334
+ var collapsible_default = {
335
+ Root: Collapsible,
336
+ Trigger: CollapsibleTrigger,
337
+ Content: CollapsibleContent
338
+ };
339
+
340
+ export { Collapsible, CollapsibleContent, CollapsibleTrigger, collapsible_default };
341
+ //# sourceMappingURL=chunk-DKXUKLZT.js.map
342
+ //# sourceMappingURL=chunk-DKXUKLZT.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/collapsible/Collapsible.tsx","../src/components/collapsible/CollapsibleContent.tsx","../src/components/collapsible/CollapsibleTrigger.tsx","../src/components/collapsible/index.ts"],"names":["startHeight","animateProperty","transitionValue","jsx"],"mappings":"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","file":"chunk-DKXUKLZT.js","sourcesContent":["import { signal } from \"@preact/signals\";\nimport { createContext } from \"preact\";\nimport { useContext, useMemo } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\n\nexport type CollapsibleContextValue = {\n open: boolean;\n setOpen: (next: boolean) => void;\n};\n\nconst CollapsibleContext = createContext<CollapsibleContextValue | null>(null);\n\nexport const useCollapsible = () => {\n const context = useContext(CollapsibleContext);\n if (!context) throw new Error(\"Collapsible subcomponents must be used within Collapsible\");\n return context;\n};\n\nexport type CollapsibleProps = JSX.HTMLAttributes<HTMLDivElement> & {\n /** Uncontrolled initial state */\n defaultOpen?: boolean;\n /** Controlled open state */\n open?: boolean;\n /** Called when open state changes (toggle or programmatic) */\n onOpenChange?: (open: boolean) => void;\n children?: ComponentChildren;\n};\n\nexport const Collapsible = ({\n defaultOpen = false,\n open: openProp,\n onOpenChange,\n children,\n ...rest\n}: CollapsibleProps) => {\n const uncontrolled = useMemo(() => signal(defaultOpen), []);\n const isControlled = openProp !== undefined;\n const open = isControlled ? Boolean(openProp) : uncontrolled.value;\n\n const setOpen = (next: boolean) => {\n if (!isControlled) {\n uncontrolled.value = next;\n }\n onOpenChange?.(next);\n };\n\n const context: CollapsibleContextValue = { open, setOpen };\n\n return (\n <CollapsibleContext.Provider value={context}>\n <div data-slot=\"collapsible\" data-state={open ? \"open\" : \"closed\"} {...rest}>\n {children}\n </div>\n </CollapsibleContext.Provider>\n );\n};\n","import { useLayoutEffect, useRef, useState } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { useCollapsible } from \"./Collapsible\";\nimport { cn } from \"../../lib/utils\";\n\nexport type CollapsibleContentProps = 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 CollapsibleContent = ({\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}: CollapsibleContentProps) => {\n const { open } = useCollapsible();\n const innerRef = useRef<HTMLDivElement>(null);\n const outerRef = useRef<HTMLDivElement>(null);\n const isOpenRef = useRef(open);\n isOpenRef.current = open;\n const hasInitializedRef = useRef(false);\n\n const [mounted, setMounted] = useState(() => open || 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 (open) {\n setMounted(true);\n syncOpenStyles();\n } else {\n syncClosedStyles();\n }\n return;\n }\n\n if (open) {\n if (!mounted) {\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, open, 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 || open;\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-collapsible-duration\" as string]: duration,\n [\"--kamodui-collapsible-timing-function\" as string]: timingFunction\n };\n\n return (\n <div\n ref={outerRef}\n data-slot=\"collapsible-content\"\n data-state={open ? \"open\" : \"closed\"}\n onTransitionEnd={handleTransitionEnd}\n style={mergedStyle}\n class={cn(\"min-h-0 overflow-hidden\", (isAnimatingOpen || isAnimatingClose) && \"will-change-[height]\")}\n aria-hidden={!open && !isAnimatingClose}\n inert={!open || undefined}\n {...rest}\n >\n <div\n ref={innerRef}\n data-slot=\"collapsible-content-inner\"\n class={cn(\"min-h-0 min-w-0\", className)}\n >\n {children}\n </div>\n </div>\n );\n};\n","import { cloneElement, isValidElement, type ComponentChildren, type JSX } from \"preact\";\nimport { useCollapsible } from \"./Collapsible\";\n\nexport type CollapsibleTriggerProps = JSX.ButtonHTMLAttributes<HTMLButtonElement> & {\n asChild?: boolean;\n children?: ComponentChildren;\n \"data-slot\"?: string;\n};\n\nconst callRef = <T extends HTMLElement>(ref: unknown, node: T | null) => {\n if (typeof ref === \"function\") {\n ref(node);\n } else if (ref && typeof ref === \"object\" && \"current\" in ref) {\n (ref as { current: T | null }).current = node;\n }\n};\n\nexport const CollapsibleTrigger = ({\n asChild = false,\n children,\n onClick,\n ref: outerRef,\n \"data-slot\": dataSlot = \"collapsible-trigger\",\n ...rest\n}: CollapsibleTriggerProps) => {\n const { open, setOpen } = useCollapsible();\n\n const toggle = () => setOpen(!open);\n\n const handleClick = (event: JSX.TargetedMouseEvent<HTMLElement>) => {\n onClick?.(event as JSX.TargetedMouseEvent<HTMLButtonElement>);\n if (event.defaultPrevented) return;\n toggle();\n };\n\n if (asChild) {\n if (!isValidElement(children)) {\n return null;\n }\n\n const childProps = (children.props ?? {}) as JSX.HTMLAttributes<HTMLElement> & {\n ref?: unknown;\n onClick?: (event: JSX.TargetedMouseEvent<HTMLElement>) => void;\n };\n\n return cloneElement(children, {\n ...(childProps as Record<string, unknown>),\n ...(rest as Record<string, unknown>),\n \"aria-expanded\": open,\n \"data-state\": open ? \"open\" : \"closed\",\n \"data-slot\": dataSlot,\n onClick: (event: JSX.TargetedMouseEvent<HTMLElement>) => {\n childProps.onClick?.(event);\n handleClick(event);\n },\n ref: (node: HTMLElement | null) => {\n callRef(childProps.ref, node);\n callRef(outerRef, node);\n }\n } as never);\n }\n\n return (\n <button\n type=\"button\"\n data-slot={dataSlot}\n aria-expanded={open}\n data-state={open ? \"open\" : \"closed\"}\n onClick={(event) => {\n handleClick(event);\n }}\n ref={(node) => {\n callRef(outerRef, node);\n }}\n {...rest}\n >\n {children}\n </button>\n );\n};\n","import { Collapsible } from \"./Collapsible\";\nimport { CollapsibleContent } from \"./CollapsibleContent\";\nimport { CollapsibleTrigger } from \"./CollapsibleTrigger\";\n\nexport { Collapsible, CollapsibleContent, CollapsibleTrigger };\n\nexport default {\n Root: Collapsible,\n Trigger: CollapsibleTrigger,\n Content: CollapsibleContent\n};\n"]}
@@ -0,0 +1,9 @@
1
+ import { separator, Separator } from './chunk-3WAPI4KR.js';
2
+
3
+ // src/components/separator/index.ts
4
+ var SeparatorVariants = { separator };
5
+ var separator_default = Separator;
6
+
7
+ export { SeparatorVariants, separator_default };
8
+ //# sourceMappingURL=chunk-EL2HT25C.js.map
9
+ //# sourceMappingURL=chunk-EL2HT25C.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/separator/index.ts"],"names":[],"mappings":";;;AAEA,IAAM,iBAAA,GAAoB,EAAE,SAAA;AAI5B,IAAO,iBAAA,GAAQ","file":"chunk-EL2HT25C.js","sourcesContent":["import { Separator, separator } from \"./Separator\";\n\nconst SeparatorVariants = { separator };\n\nexport { Separator, SeparatorVariants };\n\nexport default Separator;\n"]}
@@ -0,0 +1,26 @@
1
+ import { tv } from 'tailwind-variants';
2
+ import { jsx } from 'preact/jsx-runtime';
3
+
4
+ // src/components/skeleton/Skeleton.tsx
5
+ var skeleton = tv({
6
+ base: "rounded-md",
7
+ variants: {
8
+ variant: {
9
+ pulse: "animate-pulse bg-muted/80",
10
+ shimmer: "animate-pulse bg-[linear-gradient(110deg,hsl(var(--muted)/0.68),hsl(var(--muted)/0.9),hsl(var(--muted)/0.68))] bg-[length:220%_100%]",
11
+ glass: "animate-pulse border border-border/40 bg-[linear-gradient(140deg,hsl(var(--muted)/0.34),hsl(var(--background)/0.78),hsl(var(--muted)/0.28))] backdrop-blur-[1px]"
12
+ }
13
+ },
14
+ defaultVariants: {
15
+ variant: "pulse"
16
+ }
17
+ });
18
+ var Skeleton = ({ class: className, variant, ...rest }) => /* @__PURE__ */ jsx("div", { class: skeleton({ class: className, variant }), "data-slot": "skeleton", ...rest });
19
+
20
+ // src/components/skeleton/index.ts
21
+ var SkeletonVariants = { skeleton };
22
+ var skeleton_default = Skeleton;
23
+
24
+ export { Skeleton, SkeletonVariants, skeleton_default };
25
+ //# sourceMappingURL=chunk-FDNPBI2Z.js.map
26
+ //# sourceMappingURL=chunk-FDNPBI2Z.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/skeleton/Skeleton.tsx","../src/components/skeleton/index.ts"],"names":[],"mappings":";;;;AAGO,IAAM,WAAW,EAAA,CAAG;AAAA,EACzB,IAAA,EAAM,YAAA;AAAA,EACN,QAAA,EAAU;AAAA,IACR,OAAA,EAAS;AAAA,MACP,KAAA,EAAO,2BAAA;AAAA,MACP,OAAA,EACE,sIAAA;AAAA,MACF,KAAA,EACE;AAAA;AACJ,GACF;AAAA,EACA,eAAA,EAAiB;AAAA,IACf,OAAA,EAAS;AAAA;AAEb,CAAC,CAAA;AASM,IAAM,QAAA,GAAW,CAAC,EAAE,KAAA,EAAO,WAAW,OAAA,EAAS,GAAG,IAAA,EAAK,qBAC5D,GAAA,CAAC,KAAA,EAAA,EAAI,OAAO,QAAA,CAAS,EAAE,OAAO,SAAA,EAAiC,OAAA,EAAS,CAAA,EAAG,WAAA,EAAU,UAAA,EAAY,GAAG,IAAA,EAAM;;;ACzB5G,IAAM,gBAAA,GAAmB,EAAE,QAAA;AAI3B,IAAO,gBAAA,GAAQ","file":"chunk-FDNPBI2Z.js","sourcesContent":["import type { JSX } from \"preact\";\nimport { tv } from \"tailwind-variants\";\n\nexport const skeleton = tv({\n base: \"rounded-md\",\n variants: {\n variant: {\n pulse: \"animate-pulse bg-muted/80\",\n shimmer:\n \"animate-pulse bg-[linear-gradient(110deg,hsl(var(--muted)/0.68),hsl(var(--muted)/0.9),hsl(var(--muted)/0.68))] bg-[length:220%_100%]\",\n glass:\n \"animate-pulse border border-border/40 bg-[linear-gradient(140deg,hsl(var(--muted)/0.34),hsl(var(--background)/0.78),hsl(var(--muted)/0.28))] backdrop-blur-[1px]\"\n }\n },\n defaultVariants: {\n variant: \"pulse\"\n }\n});\n\ntype SkeletonVariants = Parameters<typeof skeleton>[0];\ntype SkeletonVariant = NonNullable<SkeletonVariants>[\"variant\"];\n\nexport type SkeletonProps = JSX.HTMLAttributes<HTMLDivElement> & {\n variant?: SkeletonVariant;\n};\n\nexport const Skeleton = ({ class: className, variant, ...rest }: SkeletonProps) => (\n <div class={skeleton({ class: className as string | undefined, variant })} data-slot=\"skeleton\" {...rest} />\n);\n\n","import { Skeleton, skeleton } from \"./Skeleton\";\n\nconst SkeletonVariants = { skeleton };\n\nexport { Skeleton, SkeletonVariants };\n\nexport default Skeleton;\n"]}
@@ -0,0 +1,65 @@
1
+ import { signal } from '@preact/signals';
2
+ import { createContext } from 'preact';
3
+ import { useContext, useMemo } from 'preact/hooks';
4
+ import { jsx } from 'preact/jsx-runtime';
5
+
6
+ // src/components/sidebar/SidebarProvider.tsx
7
+ var SidebarContext = createContext(null);
8
+ var useSidebar = () => {
9
+ const context = useContext(SidebarContext);
10
+ if (!context) throw new Error("Sidebar components must be used within SidebarProvider");
11
+ return context;
12
+ };
13
+ var SidebarProvider = ({ defaultOpen = true, children }) => {
14
+ const open = useMemo(() => signal(defaultOpen), []);
15
+ return /* @__PURE__ */ jsx(SidebarContext.Provider, { value: { open, setOpen: (next) => open.value = next }, children });
16
+ };
17
+ var Sidebar = ({ children, ...rest }) => {
18
+ const sidebar = useSidebar();
19
+ return /* @__PURE__ */ jsx(
20
+ "aside",
21
+ {
22
+ "data-slot": "sidebar",
23
+ "data-state": sidebar.open.value ? "open" : "closed",
24
+ hidden: !sidebar.open.value,
25
+ ...rest,
26
+ children
27
+ }
28
+ );
29
+ };
30
+ var SidebarContent = ({ children, ...rest }) => /* @__PURE__ */ jsx("div", { "data-slot": "sidebar-content", ...rest, children });
31
+ var SidebarFooter = ({ children, ...rest }) => /* @__PURE__ */ jsx("div", { "data-slot": "sidebar-footer", ...rest, children });
32
+ var SidebarHeader = ({ children, ...rest }) => /* @__PURE__ */ jsx("div", { "data-slot": "sidebar-header", ...rest, children });
33
+ var SidebarInset = ({ children, ...rest }) => /* @__PURE__ */ jsx("div", { "data-slot": "sidebar-inset", ...rest, children });
34
+ var SidebarTrigger = ({ children = "Toggle Sidebar", onClick, ...rest }) => {
35
+ const sidebar = useSidebar();
36
+ return /* @__PURE__ */ jsx(
37
+ "button",
38
+ {
39
+ type: "button",
40
+ "data-slot": "sidebar-trigger",
41
+ "aria-expanded": sidebar.open.value,
42
+ onClick: (event) => {
43
+ sidebar.setOpen(!sidebar.open.value);
44
+ onClick?.(event);
45
+ },
46
+ ...rest,
47
+ children
48
+ }
49
+ );
50
+ };
51
+
52
+ // src/components/sidebar/index.ts
53
+ var sidebar_default = {
54
+ Provider: SidebarProvider,
55
+ Root: Sidebar,
56
+ Trigger: SidebarTrigger,
57
+ Header: SidebarHeader,
58
+ Content: SidebarContent,
59
+ Footer: SidebarFooter,
60
+ Inset: SidebarInset
61
+ };
62
+
63
+ export { Sidebar, SidebarContent, SidebarFooter, SidebarHeader, SidebarInset, SidebarProvider, SidebarTrigger, sidebar_default, useSidebar };
64
+ //# sourceMappingURL=chunk-FWCN47RC.js.map
65
+ //# sourceMappingURL=chunk-FWCN47RC.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/sidebar/SidebarProvider.tsx","../src/components/sidebar/Sidebar.tsx","../src/components/sidebar/SidebarContent.tsx","../src/components/sidebar/SidebarFooter.tsx","../src/components/sidebar/SidebarHeader.tsx","../src/components/sidebar/SidebarInset.tsx","../src/components/sidebar/SidebarTrigger.tsx","../src/components/sidebar/index.ts"],"names":["jsx"],"mappings":";;;;;;AAUA,IAAM,cAAA,GAAiB,cAA0C,IAAI,CAAA;AAE9D,IAAM,aAAa,MAAM;AAC9B,EAAA,MAAM,OAAA,GAAU,WAAW,cAAc,CAAA;AACzC,EAAA,IAAI,CAAC,OAAA,EAAS,MAAM,IAAI,MAAM,wDAAwD,CAAA;AACtF,EAAA,OAAO,OAAA;AACT;AAOO,IAAM,kBAAkB,CAAC,EAAE,WAAA,GAAc,IAAA,EAAM,UAAS,KAA4B;AACzF,EAAA,MAAM,OAAO,OAAA,CAAQ,MAAM,OAAO,WAAW,CAAA,EAAG,EAAE,CAAA;AAClD,EAAA,uBACE,GAAA,CAAC,cAAA,CAAe,QAAA,EAAf,EAAwB,OAAO,EAAE,IAAA,EAAM,OAAA,EAAS,CAAC,IAAA,KAAU,IAAA,CAAK,KAAA,GAAQ,IAAA,IACtE,QAAA,EACH,CAAA;AAEJ;ACzBO,IAAM,UAAU,CAAC,EAAE,QAAA,EAAU,GAAG,MAAK,KAAoB;AAC9D,EAAA,MAAM,UAAU,UAAA,EAAW;AAC3B,EAAA,uBACEA,GAAAA;AAAA,IAAC,OAAA;AAAA,IAAA;AAAA,MACC,WAAA,EAAU,SAAA;AAAA,MACV,YAAA,EAAY,OAAA,CAAQ,IAAA,CAAK,KAAA,GAAQ,MAAA,GAAS,QAAA;AAAA,MAC1C,MAAA,EAAQ,CAAC,OAAA,CAAQ,IAAA,CAAK,KAAA;AAAA,MACrB,GAAG,IAAA;AAAA,MAEH;AAAA;AAAA,GACH;AAEJ;ACbO,IAAM,cAAA,GAAiB,CAAC,EAAE,QAAA,EAAU,GAAG,IAAA,EAAK,qBACjDA,GAAAA,CAAC,KAAA,EAAA,EAAI,WAAA,EAAU,iBAAA,EAAmB,GAAG,MAClC,QAAA,EACH;ACHK,IAAM,aAAA,GAAgB,CAAC,EAAE,QAAA,EAAU,GAAG,IAAA,EAAK,qBAChDA,GAAAA,CAAC,KAAA,EAAA,EAAI,WAAA,EAAU,gBAAA,EAAkB,GAAG,MACjC,QAAA,EACH;ACHK,IAAM,aAAA,GAAgB,CAAC,EAAE,QAAA,EAAU,GAAG,IAAA,EAAK,qBAChDA,GAAAA,CAAC,KAAA,EAAA,EAAI,WAAA,EAAU,gBAAA,EAAkB,GAAG,MACjC,QAAA,EACH;ACHK,IAAM,YAAA,GAAe,CAAC,EAAE,QAAA,EAAU,GAAG,IAAA,EAAK,qBAC/CA,GAAAA,CAAC,KAAA,EAAA,EAAI,WAAA,EAAU,eAAA,EAAiB,GAAG,MAChC,QAAA,EACH;ACAK,IAAM,cAAA,GAAiB,CAAC,EAAE,QAAA,GAAW,kBAAkB,OAAA,EAAS,GAAG,MAAK,KAA2B;AACxG,EAAA,MAAM,UAAU,UAAA,EAAW;AAC3B,EAAA,uBACEA,GAAAA;AAAA,IAAC,QAAA;AAAA,IAAA;AAAA,MACC,IAAA,EAAK,QAAA;AAAA,MACL,WAAA,EAAU,iBAAA;AAAA,MACV,eAAA,EAAe,QAAQ,IAAA,CAAK,KAAA;AAAA,MAC5B,OAAA,EAAS,CAAC,KAAA,KAAU;AAClB,QAAA,OAAA,CAAQ,OAAA,CAAQ,CAAC,OAAA,CAAQ,IAAA,CAAK,KAAK,CAAA;AACnC,QAAA,OAAA,GAAU,KAAK,CAAA;AAAA,MACjB,CAAA;AAAA,MACC,GAAG,IAAA;AAAA,MAEH;AAAA;AAAA,GACH;AAEJ;;;ACJA,IAAO,eAAA,GAAQ;AAAA,EACb,QAAA,EAAU,eAAA;AAAA,EACV,IAAA,EAAM,OAAA;AAAA,EACN,OAAA,EAAS,cAAA;AAAA,EACT,MAAA,EAAQ,aAAA;AAAA,EACR,OAAA,EAAS,cAAA;AAAA,EACT,MAAA,EAAQ,aAAA;AAAA,EACR,KAAA,EAAO;AACT","file":"chunk-FWCN47RC.js","sourcesContent":["import { signal } from \"@preact/signals\";\nimport { createContext } from \"preact\";\nimport { useContext, useMemo } from \"preact/hooks\";\nimport type { ComponentChildren } from \"preact\";\n\ntype SidebarContextValue = {\n open: ReturnType<typeof signal<boolean>>;\n setOpen: (next: boolean) => void;\n};\n\nconst SidebarContext = createContext<SidebarContextValue | null>(null);\n\nexport const useSidebar = () => {\n const context = useContext(SidebarContext);\n if (!context) throw new Error(\"Sidebar components must be used within SidebarProvider\");\n return context;\n};\n\nexport type SidebarProviderProps = {\n defaultOpen?: boolean;\n children?: ComponentChildren;\n};\n\nexport const SidebarProvider = ({ defaultOpen = true, children }: SidebarProviderProps) => {\n const open = useMemo(() => signal(defaultOpen), []);\n return (\n <SidebarContext.Provider value={{ open, setOpen: (next) => (open.value = next) }}>\n {children}\n </SidebarContext.Provider>\n );\n};\n\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { useSidebar } from \"./SidebarProvider\";\n\nexport type SidebarProps = JSX.HTMLAttributes<HTMLElement> & { children?: ComponentChildren };\n\nexport const Sidebar = ({ children, ...rest }: SidebarProps) => {\n const sidebar = useSidebar();\n return (\n <aside\n data-slot=\"sidebar\"\n data-state={sidebar.open.value ? \"open\" : \"closed\"}\n hidden={!sidebar.open.value}\n {...rest}\n >\n {children}\n </aside>\n );\n};\n\n","import type { ComponentChildren, JSX } from \"preact\";\n\nexport type SidebarContentProps = JSX.HTMLAttributes<HTMLDivElement> & { children?: ComponentChildren };\n\nexport const SidebarContent = ({ children, ...rest }: SidebarContentProps) => (\n <div data-slot=\"sidebar-content\" {...rest}>\n {children}\n </div>\n);\n\n","import type { ComponentChildren, JSX } from \"preact\";\n\nexport type SidebarFooterProps = JSX.HTMLAttributes<HTMLDivElement> & { children?: ComponentChildren };\n\nexport const SidebarFooter = ({ children, ...rest }: SidebarFooterProps) => (\n <div data-slot=\"sidebar-footer\" {...rest}>\n {children}\n </div>\n);\n\n","import type { ComponentChildren, JSX } from \"preact\";\n\nexport type SidebarHeaderProps = JSX.HTMLAttributes<HTMLDivElement> & { children?: ComponentChildren };\n\nexport const SidebarHeader = ({ children, ...rest }: SidebarHeaderProps) => (\n <div data-slot=\"sidebar-header\" {...rest}>\n {children}\n </div>\n);\n\n","import type { ComponentChildren, JSX } from \"preact\";\n\nexport type SidebarInsetProps = JSX.HTMLAttributes<HTMLDivElement> & { children?: ComponentChildren };\n\nexport const SidebarInset = ({ children, ...rest }: SidebarInsetProps) => (\n <div data-slot=\"sidebar-inset\" {...rest}>\n {children}\n </div>\n);\n\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { useSidebar } from \"./SidebarProvider\";\n\nexport type SidebarTriggerProps = JSX.ButtonHTMLAttributes<HTMLButtonElement> & {\n children?: ComponentChildren;\n};\n\nexport const SidebarTrigger = ({ children = \"Toggle Sidebar\", onClick, ...rest }: SidebarTriggerProps) => {\n const sidebar = useSidebar();\n return (\n <button\n type=\"button\"\n data-slot=\"sidebar-trigger\"\n aria-expanded={sidebar.open.value}\n onClick={(event) => {\n sidebar.setOpen(!sidebar.open.value);\n onClick?.(event);\n }}\n {...rest}\n >\n {children}\n </button>\n );\n};\n\n","import { Sidebar } from \"./Sidebar\";\nimport { SidebarContent } from \"./SidebarContent\";\nimport { SidebarFooter } from \"./SidebarFooter\";\nimport { SidebarHeader } from \"./SidebarHeader\";\nimport { SidebarInset } from \"./SidebarInset\";\nimport { SidebarProvider, useSidebar } from \"./SidebarProvider\";\nimport { SidebarTrigger } from \"./SidebarTrigger\";\n\nexport {\n Sidebar,\n SidebarContent,\n SidebarFooter,\n SidebarHeader,\n SidebarInset,\n SidebarProvider,\n SidebarTrigger,\n useSidebar\n};\n\nexport default {\n Provider: SidebarProvider,\n Root: Sidebar,\n Trigger: SidebarTrigger,\n Header: SidebarHeader,\n Content: SidebarContent,\n Footer: SidebarFooter,\n Inset: SidebarInset\n};\n"]}
@@ -0,0 +1,114 @@
1
+ import { DialogFooter, DialogHeader } from './chunk-YWUMX4JR.js';
2
+ import { Dialog, DialogClose, DialogContent, dialogViewportBleedClass, DialogDescription, DialogTitle, DialogTrigger } from './chunk-KBXDU3G4.js';
3
+ import { button } from './chunk-UGQ756Z6.js';
4
+ import { cn } from './chunk-OMXWBB67.js';
5
+ import { jsx } from 'preact/jsx-runtime';
6
+
7
+ var AlertDialog = ({ children, ...rest }) => /* @__PURE__ */ jsx(Dialog, { "data-slot": "alert-dialog", lockBodyScroll: true, ...rest, children });
8
+ var AlertDialogAction = ({
9
+ variant = "default",
10
+ class: className,
11
+ children,
12
+ ...rest
13
+ }) => /* @__PURE__ */ jsx(
14
+ DialogClose,
15
+ {
16
+ class: button({ variant, class: cn("w-full sm:w-auto", className) }),
17
+ "data-slot": "alert-dialog-action",
18
+ ...rest,
19
+ children
20
+ }
21
+ );
22
+ var AlertDialogCancel = ({
23
+ variant = "outline",
24
+ class: className,
25
+ children,
26
+ ...rest
27
+ }) => /* @__PURE__ */ jsx(
28
+ DialogClose,
29
+ {
30
+ class: button({ variant, class: cn("w-full sm:w-auto", className) }),
31
+ "data-slot": "alert-dialog-cancel",
32
+ ...rest,
33
+ children
34
+ }
35
+ );
36
+ var AlertDialogContent = ({
37
+ size = "default",
38
+ class: className,
39
+ children,
40
+ ...rest
41
+ }) => (
42
+ // presentation="slot": we own the full-screen flex overlay + inner panel; default "modal" would add a second backdrop.
43
+ /* @__PURE__ */ jsx(
44
+ DialogContent,
45
+ {
46
+ presentation: "slot",
47
+ class: cn(
48
+ dialogViewportBleedClass,
49
+ "z-50 flex items-center justify-center bg-black/50 p-3 sm:p-6 pointer-events-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fill-mode-forwards fade-in fade-out"
50
+ ),
51
+ "data-slot": "alert-dialog-content",
52
+ ...rest,
53
+ children: /* @__PURE__ */ jsx(
54
+ "div",
55
+ {
56
+ class: cn(
57
+ "data-open:animate-in relative z-[1] grid min-h-0 min-w-0 w-full max-w-[calc(100svw-1.5rem)] max-h-[calc(100dvh-1.5rem)] overflow-y-auto overflow-x-hidden rounded-xl border bg-background shadow-lg pointer-events-auto",
58
+ size === "sm" ? "gap-3 p-4 sm:max-w-sm sm:max-h-[calc(100dvh-3rem)] sm:p-4" : "gap-4 p-4 sm:max-w-[32rem] sm:max-h-[calc(100dvh-3rem)] sm:p-6",
59
+ className
60
+ ),
61
+ "data-slot": "alert-dialog-panel",
62
+ "data-size": size,
63
+ "data-open": "true",
64
+ children
65
+ }
66
+ )
67
+ }
68
+ )
69
+ );
70
+ var AlertDialogDescription = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx(DialogDescription, { class: cn("text-muted-foreground text-sm leading-relaxed break-words", className), "data-slot": "alert-dialog-description", ...rest, children });
71
+ var AlertDialogFooter = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx(DialogFooter, { class: cn("flex flex-col-reverse gap-2 sm:flex-row sm:justify-end", className), "data-slot": "alert-dialog-footer", ...rest, children });
72
+ var AlertDialogHeader = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx(DialogHeader, { class: cn("grid gap-2 text-center sm:text-left", className), "data-slot": "alert-dialog-header", ...rest, children });
73
+ var AlertDialogMedia = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx(
74
+ "div",
75
+ {
76
+ "data-slot": "alert-dialog-media",
77
+ class: cn(
78
+ "mx-auto flex size-12 shrink-0 items-center justify-center rounded-full bg-muted text-foreground",
79
+ "[&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-6",
80
+ className
81
+ ),
82
+ ...rest,
83
+ children
84
+ }
85
+ );
86
+ var AlertDialogTitle = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx(DialogTitle, { class: cn("text-lg font-semibold break-words", className), "data-slot": "alert-dialog-title", ...rest, children });
87
+ var AlertDialogTrigger = ({ asChild, class: className, children, ...rest }) => /* @__PURE__ */ jsx(
88
+ DialogTrigger,
89
+ {
90
+ asChild,
91
+ class: asChild ? className : button({ variant: "outline", class: className }),
92
+ "data-slot": "alert-dialog-trigger",
93
+ ...rest,
94
+ children
95
+ }
96
+ );
97
+
98
+ // src/components/alert-dialog/index.ts
99
+ var alert_dialog_default = {
100
+ Root: AlertDialog,
101
+ Trigger: AlertDialogTrigger,
102
+ Content: AlertDialogContent,
103
+ Header: AlertDialogHeader,
104
+ Footer: AlertDialogFooter,
105
+ Title: AlertDialogTitle,
106
+ Description: AlertDialogDescription,
107
+ Media: AlertDialogMedia,
108
+ Cancel: AlertDialogCancel,
109
+ Action: AlertDialogAction
110
+ };
111
+
112
+ export { AlertDialog, AlertDialogAction, AlertDialogCancel, AlertDialogContent, AlertDialogDescription, AlertDialogFooter, AlertDialogHeader, AlertDialogMedia, AlertDialogTitle, AlertDialogTrigger, alert_dialog_default };
113
+ //# sourceMappingURL=chunk-G6PBJZYF.js.map
114
+ //# sourceMappingURL=chunk-G6PBJZYF.js.map