@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,426 @@
1
+ import { createIdFactory, createDismissableLayer } from './chunk-HEQRODRF.js';
2
+ import { cn } from './chunk-OMXWBB67.js';
3
+ import { signal } from '@preact/signals';
4
+ import { useMemo, useRef, useEffect, useContext } from 'preact/hooks';
5
+ import { createContext } from 'preact';
6
+ import { jsx, jsxs } from 'preact/jsx-runtime';
7
+
8
+ var MenubarRootContext = createContext(null);
9
+ var useMenubarRoot = () => {
10
+ const ctx = useContext(MenubarRootContext);
11
+ if (!ctx) throw new Error("Menubar components must be used within Menubar");
12
+ return ctx;
13
+ };
14
+ var MenubarMenuContext = createContext(null);
15
+ var useMenubarMenu = () => {
16
+ const ctx = useContext(MenubarMenuContext);
17
+ if (!ctx) throw new Error("MenubarTrigger and MenubarContent must be inside MenubarMenu");
18
+ return ctx;
19
+ };
20
+ var MenubarRadioContext = createContext(null);
21
+ var useMenubarRadio = () => {
22
+ const ctx = useContext(MenubarRadioContext);
23
+ if (!ctx) throw new Error("MenubarRadioItem must be inside MenubarRadioGroup");
24
+ return ctx;
25
+ };
26
+ var MenubarSubContext = createContext(null);
27
+ var useMenubarSub = () => {
28
+ const ctx = useContext(MenubarSubContext);
29
+ if (!ctx) throw new Error("MenubarSub parts must be inside MenubarSub");
30
+ return ctx;
31
+ };
32
+ var Menubar = ({ class: className, children, dir, ...rest }) => {
33
+ const openMenuId = useMemo(() => signal(null), []);
34
+ const rootRef = useRef(null);
35
+ const ctx = useMemo(
36
+ () => ({
37
+ openMenuId,
38
+ setOpenMenuId: (id) => {
39
+ openMenuId.value = id;
40
+ },
41
+ rootRef
42
+ }),
43
+ [openMenuId]
44
+ );
45
+ useEffect(() => {
46
+ const layer = createDismissableLayer({
47
+ root: () => rootRef.current,
48
+ open: () => openMenuId.value != null,
49
+ onDismiss: () => {
50
+ openMenuId.value = null;
51
+ }
52
+ });
53
+ return () => layer.dispose();
54
+ }, [openMenuId]);
55
+ return /* @__PURE__ */ jsx(MenubarRootContext.Provider, { value: ctx, children: /* @__PURE__ */ jsx(
56
+ "div",
57
+ {
58
+ ref: rootRef,
59
+ "data-slot": "menubar",
60
+ role: "menubar",
61
+ dir,
62
+ class: cn(
63
+ "flex h-9 items-center gap-0 rounded-md border border-border bg-background p-1 shadow-xs",
64
+ className
65
+ ),
66
+ ...rest,
67
+ children
68
+ }
69
+ ) });
70
+ };
71
+ var CheckIcon = () => /* @__PURE__ */ jsx(
72
+ "svg",
73
+ {
74
+ xmlns: "http://www.w3.org/2000/svg",
75
+ width: "16",
76
+ height: "16",
77
+ viewBox: "0 0 24 24",
78
+ fill: "none",
79
+ stroke: "currentColor",
80
+ "stroke-width": "2",
81
+ "stroke-linecap": "round",
82
+ "stroke-linejoin": "round",
83
+ class: "size-4",
84
+ "aria-hidden": true,
85
+ children: /* @__PURE__ */ jsx("path", { d: "M20 6 9 17l-5-5" })
86
+ }
87
+ );
88
+ var MenubarCheckboxItem = ({
89
+ class: className,
90
+ children,
91
+ checked: controlledChecked,
92
+ defaultChecked = false,
93
+ onCheckedChange,
94
+ disabled,
95
+ onClick,
96
+ ...rest
97
+ }) => {
98
+ const internal = useMemo(() => signal(defaultChecked), []);
99
+ const checked = controlledChecked !== void 0 ? controlledChecked : internal.value;
100
+ const setChecked = (next) => {
101
+ if (controlledChecked === void 0) internal.value = next;
102
+ onCheckedChange?.(next);
103
+ };
104
+ return /* @__PURE__ */ jsxs(
105
+ "button",
106
+ {
107
+ type: "button",
108
+ role: "menuitemcheckbox",
109
+ "data-slot": "menubar-checkbox-item",
110
+ "aria-checked": checked,
111
+ disabled,
112
+ class: cn(
113
+ "relative flex w-full cursor-default select-none items-center gap-2 rounded-sm py-1.5 ps-8 pe-2 text-start text-sm outline-none",
114
+ "focus:bg-accent focus:text-accent-foreground",
115
+ "disabled:pointer-events-none disabled:opacity-50",
116
+ className
117
+ ),
118
+ onClick: (e) => {
119
+ onClick?.(e);
120
+ if (e.defaultPrevented) return;
121
+ setChecked(!checked);
122
+ },
123
+ ...rest,
124
+ children: [
125
+ /* @__PURE__ */ jsx("span", { class: "absolute start-2 flex size-3.5 items-center justify-center", children: checked ? /* @__PURE__ */ jsx(CheckIcon, {}) : null }),
126
+ children
127
+ ]
128
+ }
129
+ );
130
+ };
131
+ var MenubarContent = ({ class: className, children, ...rest }) => {
132
+ const root = useMenubarRoot();
133
+ const { menuId } = useMenubarMenu();
134
+ const open = root.openMenuId.value === menuId;
135
+ if (!open) return null;
136
+ return /* @__PURE__ */ jsx(
137
+ "div",
138
+ {
139
+ role: "menu",
140
+ "data-slot": "menubar-content",
141
+ "data-state": "open",
142
+ class: cn(
143
+ "absolute start-0 top-full z-50 mt-1 min-w-48 rounded-md border border-border bg-popover p-0 text-popover-foreground shadow-md outline-none",
144
+ className
145
+ ),
146
+ ...rest,
147
+ children
148
+ }
149
+ );
150
+ };
151
+ var MenubarGroup = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("div", { role: "group", "data-slot": "menubar-group", class: cn("p-1", className), ...rest, children });
152
+ var MenubarItem = ({
153
+ class: className,
154
+ inset = false,
155
+ variant = "default",
156
+ children,
157
+ disabled,
158
+ onClick,
159
+ ...rest
160
+ }) => {
161
+ const root = useMenubarRoot();
162
+ return /* @__PURE__ */ jsx(
163
+ "button",
164
+ {
165
+ type: "button",
166
+ role: "menuitem",
167
+ "data-slot": "menubar-item",
168
+ "data-inset": inset ? "true" : void 0,
169
+ "data-variant": variant,
170
+ disabled,
171
+ class: cn(
172
+ "relative flex w-full cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-start text-sm outline-none",
173
+ "focus:bg-accent focus:text-accent-foreground",
174
+ "disabled:pointer-events-none disabled:opacity-50",
175
+ inset && "ps-8",
176
+ variant === "destructive" && "text-destructive focus:bg-destructive/10 focus:text-destructive",
177
+ className
178
+ ),
179
+ onClick: (e) => {
180
+ onClick?.(e);
181
+ if (e.defaultPrevented) return;
182
+ root.setOpenMenuId(null);
183
+ },
184
+ ...rest,
185
+ children
186
+ }
187
+ );
188
+ };
189
+ var MenubarLabel = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("div", { "data-slot": "menubar-label", class: cn("px-2 py-1.5 text-sm font-medium text-muted-foreground", className), ...rest, children });
190
+ var nextMenuId = createIdFactory("menubar-menu");
191
+ var MenubarMenu = ({ class: className, children, value: valueProp, ...rest }) => {
192
+ const menuId = useMemo(() => nextMenuId(valueProp), [valueProp]);
193
+ return /* @__PURE__ */ jsx(MenubarMenuContext.Provider, { value: { menuId }, children: /* @__PURE__ */ jsx("div", { "data-slot": "menubar-menu", class: cn("relative flex", className), ...rest, children }) });
194
+ };
195
+ var MenubarRadioGroup = ({
196
+ class: className,
197
+ children,
198
+ value: controlledValue,
199
+ defaultValue = "",
200
+ onValueChange,
201
+ ...rest
202
+ }) => {
203
+ const selected = useMemo(() => signal(controlledValue ?? defaultValue), []);
204
+ useEffect(() => {
205
+ if (controlledValue !== void 0) selected.value = controlledValue;
206
+ }, [controlledValue, selected]);
207
+ const ctx = useMemo(
208
+ () => ({
209
+ selected,
210
+ controlledValue,
211
+ setValue: (next) => {
212
+ if (controlledValue === void 0) selected.value = next;
213
+ onValueChange?.(next);
214
+ }
215
+ }),
216
+ [controlledValue, onValueChange, selected]
217
+ );
218
+ return /* @__PURE__ */ jsx(MenubarRadioContext.Provider, { value: ctx, children: /* @__PURE__ */ jsx("div", { role: "group", "data-slot": "menubar-radio-group", class: cn("p-1", className), ...rest, children }) });
219
+ };
220
+ var CircleIcon = ({ filled }) => /* @__PURE__ */ jsx("span", { class: "flex size-3.5 items-center justify-center", "aria-hidden": true, children: filled ? /* @__PURE__ */ jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", class: "size-2 fill-current", children: /* @__PURE__ */ jsx("circle", { cx: "12", cy: "12", r: "6" }) }) : /* @__PURE__ */ jsx("span", { class: "size-2 rounded-full border border-current opacity-60" }) });
221
+ var MenubarRadioItem = ({
222
+ class: className,
223
+ value,
224
+ children,
225
+ disabled,
226
+ onClick,
227
+ ...rest
228
+ }) => {
229
+ const radio = useMenubarRadio();
230
+ const current = radio.controlledValue !== void 0 ? radio.controlledValue : radio.selected.value;
231
+ const checked = current === value;
232
+ return /* @__PURE__ */ jsxs(
233
+ "button",
234
+ {
235
+ type: "button",
236
+ role: "menuitemradio",
237
+ "data-slot": "menubar-radio-item",
238
+ "aria-checked": checked,
239
+ disabled,
240
+ class: cn(
241
+ "relative flex w-full cursor-default select-none items-center gap-2 rounded-sm py-1.5 ps-8 pe-2 text-start text-sm outline-none",
242
+ "focus:bg-accent focus:text-accent-foreground",
243
+ "disabled:pointer-events-none disabled:opacity-50",
244
+ className
245
+ ),
246
+ onClick: (e) => {
247
+ onClick?.(e);
248
+ if (e.defaultPrevented) return;
249
+ radio.setValue(value);
250
+ },
251
+ ...rest,
252
+ children: [
253
+ /* @__PURE__ */ jsx("span", { class: "absolute start-2 flex size-3.5 items-center justify-center text-foreground", children: /* @__PURE__ */ jsx(CircleIcon, { filled: checked }) }),
254
+ children
255
+ ]
256
+ }
257
+ );
258
+ };
259
+ var MenubarSeparator = ({ class: className, ...rest }) => /* @__PURE__ */ jsx(
260
+ "div",
261
+ {
262
+ role: "separator",
263
+ "data-slot": "menubar-separator",
264
+ class: cn("mx-1 my-1 h-px bg-border", className),
265
+ ...rest
266
+ }
267
+ );
268
+ var MenubarShortcut = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx(
269
+ "span",
270
+ {
271
+ "data-slot": "menubar-shortcut",
272
+ class: cn("ms-auto text-xs tracking-widest text-muted-foreground", className),
273
+ ...rest,
274
+ children
275
+ }
276
+ );
277
+ var MenubarSub = ({ class: className, children, ...rest }) => {
278
+ const open = useMemo(() => signal(false), []);
279
+ const ctx = useMemo(
280
+ () => ({
281
+ open,
282
+ setOpen: (next) => {
283
+ open.value = next;
284
+ }
285
+ }),
286
+ [open]
287
+ );
288
+ return /* @__PURE__ */ jsx(MenubarSubContext.Provider, { value: ctx, children: /* @__PURE__ */ jsx(
289
+ "div",
290
+ {
291
+ "data-slot": "menubar-sub",
292
+ class: cn("relative", className),
293
+ onPointerLeave: () => {
294
+ open.value = false;
295
+ },
296
+ ...rest,
297
+ children
298
+ }
299
+ ) });
300
+ };
301
+ var MenubarSubContent = ({ class: className, children, onPointerEnter, ...rest }) => {
302
+ const sub = useMenubarSub();
303
+ if (!sub.open.value) return null;
304
+ return /* @__PURE__ */ jsx(
305
+ "div",
306
+ {
307
+ role: "menu",
308
+ "data-slot": "menubar-sub-content",
309
+ "data-state": "open",
310
+ class: cn(
311
+ "absolute start-full top-0 z-50 min-w-40 rounded-md border border-border bg-popover p-0 text-popover-foreground shadow-md outline-none ms-1 rtl:me-1 rtl:ms-0",
312
+ className
313
+ ),
314
+ onPointerEnter: (e) => {
315
+ onPointerEnter?.(e);
316
+ sub.setOpen(true);
317
+ },
318
+ ...rest,
319
+ children
320
+ }
321
+ );
322
+ };
323
+ var ChevronRight = ({ class: className }) => /* @__PURE__ */ jsx(
324
+ "svg",
325
+ {
326
+ xmlns: "http://www.w3.org/2000/svg",
327
+ width: "16",
328
+ height: "16",
329
+ viewBox: "0 0 24 24",
330
+ fill: "none",
331
+ stroke: "currentColor",
332
+ "stroke-width": "2",
333
+ "stroke-linecap": "round",
334
+ "stroke-linejoin": "round",
335
+ class: cn("size-4 shrink-0 rtl:rotate-180", className),
336
+ "aria-hidden": true,
337
+ children: /* @__PURE__ */ jsx("path", { d: "m9 18 6-6-6-6" })
338
+ }
339
+ );
340
+ var MenubarSubTrigger = ({ class: className, children, onClick, onPointerEnter, ...rest }) => {
341
+ const sub = useMenubarSub();
342
+ const open = sub.open.value;
343
+ return /* @__PURE__ */ jsxs(
344
+ "button",
345
+ {
346
+ type: "button",
347
+ role: "menuitem",
348
+ "data-slot": "menubar-sub-trigger",
349
+ "data-state": open ? "open" : "closed",
350
+ "aria-expanded": open,
351
+ "aria-haspopup": "menu",
352
+ class: cn(
353
+ "flex w-full cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-start text-sm outline-none",
354
+ "focus:bg-accent focus:text-accent-foreground",
355
+ "data-[state=open]:bg-accent data-[state=open]:text-accent-foreground",
356
+ className
357
+ ),
358
+ onPointerEnter: (e) => {
359
+ onPointerEnter?.(e);
360
+ if (e.defaultPrevented) return;
361
+ sub.setOpen(true);
362
+ },
363
+ onClick: (e) => {
364
+ onClick?.(e);
365
+ if (e.defaultPrevented) return;
366
+ sub.setOpen(!open);
367
+ },
368
+ ...rest,
369
+ children: [
370
+ children,
371
+ /* @__PURE__ */ jsx(ChevronRight, { class: "ms-auto" })
372
+ ]
373
+ }
374
+ );
375
+ };
376
+ var MenubarTrigger = ({ class: className, children, onClick, ...rest }) => {
377
+ const root = useMenubarRoot();
378
+ const { menuId } = useMenubarMenu();
379
+ const open = root.openMenuId.value === menuId;
380
+ return /* @__PURE__ */ jsx(
381
+ "button",
382
+ {
383
+ type: "button",
384
+ "data-slot": "menubar-trigger",
385
+ "data-state": open ? "open" : "closed",
386
+ "aria-expanded": open,
387
+ "aria-haspopup": "menu",
388
+ class: cn(
389
+ "flex cursor-default select-none items-center rounded-sm px-2 py-1 text-sm font-medium outline-none",
390
+ "focus:bg-accent focus:text-accent-foreground",
391
+ "data-[state=open]:bg-accent data-[state=open]:text-accent-foreground",
392
+ className
393
+ ),
394
+ onClick: (e) => {
395
+ onClick?.(e);
396
+ if (e.defaultPrevented) return;
397
+ root.setOpenMenuId(open ? null : menuId);
398
+ },
399
+ ...rest,
400
+ children
401
+ }
402
+ );
403
+ };
404
+
405
+ // src/components/menubar/index.ts
406
+ var menubar_default = {
407
+ Root: Menubar,
408
+ Menu: MenubarMenu,
409
+ Trigger: MenubarTrigger,
410
+ Content: MenubarContent,
411
+ Group: MenubarGroup,
412
+ Item: MenubarItem,
413
+ Label: MenubarLabel,
414
+ Separator: MenubarSeparator,
415
+ Shortcut: MenubarShortcut,
416
+ CheckboxItem: MenubarCheckboxItem,
417
+ RadioGroup: MenubarRadioGroup,
418
+ RadioItem: MenubarRadioItem,
419
+ Sub: MenubarSub,
420
+ SubTrigger: MenubarSubTrigger,
421
+ SubContent: MenubarSubContent
422
+ };
423
+
424
+ export { Menubar, MenubarCheckboxItem, MenubarContent, MenubarGroup, MenubarItem, MenubarLabel, MenubarMenu, MenubarRadioGroup, MenubarRadioItem, MenubarSeparator, MenubarShortcut, MenubarSub, MenubarSubContent, MenubarSubTrigger, MenubarTrigger, menubar_default };
425
+ //# sourceMappingURL=chunk-D5W5YHJZ.js.map
426
+ //# sourceMappingURL=chunk-D5W5YHJZ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/menubar/menubar-context.tsx","../src/components/menubar/Menubar.tsx","../src/components/menubar/MenubarCheckboxItem.tsx","../src/components/menubar/MenubarContent.tsx","../src/components/menubar/MenubarGroup.tsx","../src/components/menubar/MenubarItem.tsx","../src/components/menubar/MenubarLabel.tsx","../src/components/menubar/MenubarMenu.tsx","../src/components/menubar/MenubarRadioGroup.tsx","../src/components/menubar/MenubarRadioItem.tsx","../src/components/menubar/MenubarSeparator.tsx","../src/components/menubar/MenubarShortcut.tsx","../src/components/menubar/MenubarSub.tsx","../src/components/menubar/MenubarSubContent.tsx","../src/components/menubar/MenubarSubTrigger.tsx","../src/components/menubar/MenubarTrigger.tsx","../src/components/menubar/index.ts"],"names":["jsx","useMemo","signal","useEffect","jsxs"],"mappings":"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","file":"chunk-D5W5YHJZ.js","sourcesContent":["import { type signal } from \"@preact/signals\";\nimport { createContext } from \"preact\";\nimport { useContext } from \"preact/hooks\";\n\nexport type MenubarRootContextValue = {\n openMenuId: ReturnType<typeof signal<string | null>>;\n setOpenMenuId: (id: string | null) => void;\n rootRef: { current: HTMLDivElement | null };\n};\n\nexport const MenubarRootContext = createContext<MenubarRootContextValue | null>(null);\n\nexport const useMenubarRoot = () => {\n const ctx = useContext(MenubarRootContext);\n if (!ctx) throw new Error(\"Menubar components must be used within Menubar\");\n return ctx;\n};\n\nexport type MenubarMenuContextValue = {\n menuId: string;\n};\n\nexport const MenubarMenuContext = createContext<MenubarMenuContextValue | null>(null);\n\nexport const useMenubarMenu = () => {\n const ctx = useContext(MenubarMenuContext);\n if (!ctx) throw new Error(\"MenubarTrigger and MenubarContent must be inside MenubarMenu\");\n return ctx;\n};\n\nexport type MenubarRadioContextValue = {\n selected: ReturnType<typeof signal<string>>;\n controlledValue: string | undefined;\n setValue: (next: string) => void;\n};\n\nexport const MenubarRadioContext = createContext<MenubarRadioContextValue | null>(null);\n\nexport const useMenubarRadio = () => {\n const ctx = useContext(MenubarRadioContext);\n if (!ctx) throw new Error(\"MenubarRadioItem must be inside MenubarRadioGroup\");\n return ctx;\n};\n\nexport type MenubarSubContextValue = {\n open: ReturnType<typeof signal<boolean>>;\n setOpen: (next: boolean) => void;\n};\n\nexport const MenubarSubContext = createContext<MenubarSubContextValue | null>(null);\n\nexport const useMenubarSub = () => {\n const ctx = useContext(MenubarSubContext);\n if (!ctx) throw new Error(\"MenubarSub parts must be inside MenubarSub\");\n return ctx;\n};\n","import { signal } from \"@preact/signals\";\nimport { useEffect, useMemo, useRef } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { createDismissableLayer } from \"../../lib/interactive\";\nimport { MenubarRootContext } from \"./menubar-context\";\n\nexport type MenubarProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n dir?: \"ltr\" | \"rtl\";\n};\n\nexport const Menubar = ({ class: className, children, dir, ...rest }: MenubarProps) => {\n const openMenuId = useMemo(() => signal<string | null>(null), []);\n const rootRef = useRef<HTMLDivElement | null>(null);\n\n const ctx = useMemo(\n () => ({\n openMenuId,\n setOpenMenuId: (id: string | null) => {\n openMenuId.value = id;\n },\n rootRef\n }),\n [openMenuId]\n );\n\n useEffect(() => {\n const layer = createDismissableLayer({\n root: () => rootRef.current,\n open: () => openMenuId.value != null,\n onDismiss: () => {\n openMenuId.value = null;\n }\n });\n return () => layer.dispose();\n }, [openMenuId]);\n\n return (\n <MenubarRootContext.Provider value={ctx}>\n <div\n ref={rootRef}\n data-slot=\"menubar\"\n role=\"menubar\"\n dir={dir}\n class={cn(\n \"flex h-9 items-center gap-0 rounded-md border border-border bg-background p-1 shadow-xs\",\n className\n )}\n {...rest}\n >\n {children}\n </div>\n </MenubarRootContext.Provider>\n );\n};\n","import { useMemo } from \"preact/hooks\";\nimport { signal } from \"@preact/signals\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type MenubarCheckboxItemProps = JSX.ButtonHTMLAttributes<HTMLButtonElement> & {\n children?: ComponentChildren;\n checked?: boolean;\n defaultChecked?: boolean;\n onCheckedChange?: (checked: boolean) => void;\n};\n\nconst CheckIcon = () => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class=\"size-4\"\n aria-hidden\n >\n <path d=\"M20 6 9 17l-5-5\" />\n </svg>\n);\n\nexport const MenubarCheckboxItem = ({\n class: className,\n children,\n checked: controlledChecked,\n defaultChecked = false,\n onCheckedChange,\n disabled,\n onClick,\n ...rest\n}: MenubarCheckboxItemProps) => {\n const internal = useMemo(() => signal(defaultChecked), []);\n const checked = controlledChecked !== undefined ? controlledChecked : internal.value;\n\n const setChecked = (next: boolean) => {\n if (controlledChecked === undefined) internal.value = next;\n onCheckedChange?.(next);\n };\n\n return (\n <button\n type=\"button\"\n role=\"menuitemcheckbox\"\n data-slot=\"menubar-checkbox-item\"\n aria-checked={checked}\n disabled={disabled}\n class={cn(\n \"relative flex w-full cursor-default select-none items-center gap-2 rounded-sm py-1.5 ps-8 pe-2 text-start text-sm outline-none\",\n \"focus:bg-accent focus:text-accent-foreground\",\n \"disabled:pointer-events-none disabled:opacity-50\",\n className\n )}\n onClick={(e) => {\n onClick?.(e);\n if (e.defaultPrevented) return;\n setChecked(!checked);\n }}\n {...rest}\n >\n <span class=\"absolute start-2 flex size-3.5 items-center justify-center\">\n {checked ? <CheckIcon /> : null}\n </span>\n {children}\n </button>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useMenubarMenu, useMenubarRoot } from \"./menubar-context\";\n\nexport type MenubarContentProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const MenubarContent = ({ class: className, children, ...rest }: MenubarContentProps) => {\n const root = useMenubarRoot();\n const { menuId } = useMenubarMenu();\n const open = root.openMenuId.value === menuId;\n\n if (!open) return null;\n\n return (\n <div\n role=\"menu\"\n data-slot=\"menubar-content\"\n data-state=\"open\"\n class={cn(\n \"absolute start-0 top-full z-50 mt-1 min-w-48 rounded-md border border-border bg-popover p-0 text-popover-foreground shadow-md outline-none\",\n className\n )}\n {...rest}\n >\n {children}\n </div>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type MenubarGroupProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const MenubarGroup = ({ class: className, children, ...rest }: MenubarGroupProps) => (\n <div role=\"group\" data-slot=\"menubar-group\" class={cn(\"p-1\", className)} {...rest}>\n {children}\n </div>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useMenubarRoot } from \"./menubar-context\";\n\nexport type MenubarItemProps = JSX.ButtonHTMLAttributes<HTMLButtonElement> & {\n children?: ComponentChildren;\n inset?: boolean;\n variant?: \"default\" | \"destructive\";\n};\n\nexport const MenubarItem = ({\n class: className,\n inset = false,\n variant = \"default\",\n children,\n disabled,\n onClick,\n ...rest\n}: MenubarItemProps) => {\n const root = useMenubarRoot();\n\n return (\n <button\n type=\"button\"\n role=\"menuitem\"\n data-slot=\"menubar-item\"\n data-inset={inset ? \"true\" : undefined}\n data-variant={variant}\n disabled={disabled}\n class={cn(\n \"relative flex w-full cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-start text-sm outline-none\",\n \"focus:bg-accent focus:text-accent-foreground\",\n \"disabled:pointer-events-none disabled:opacity-50\",\n inset && \"ps-8\",\n variant === \"destructive\" && \"text-destructive focus:bg-destructive/10 focus:text-destructive\",\n className\n )}\n onClick={(e) => {\n onClick?.(e);\n if (e.defaultPrevented) return;\n root.setOpenMenuId(null);\n }}\n {...rest}\n >\n {children}\n </button>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type MenubarLabelProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const MenubarLabel = ({ class: className, children, ...rest }: MenubarLabelProps) => (\n <div data-slot=\"menubar-label\" class={cn(\"px-2 py-1.5 text-sm font-medium text-muted-foreground\", className)} {...rest}>\n {children}\n </div>\n);\n","import { useMemo } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { createIdFactory } from \"../../lib/interactive\";\nimport { MenubarMenuContext } from \"./menubar-context\";\n\nconst nextMenuId = createIdFactory(\"menubar-menu\");\n\nexport type MenubarMenuProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n /** Optional stable id; auto-generated when omitted. */\n value?: string;\n};\n\nexport const MenubarMenu = ({ class: className, children, value: valueProp, ...rest }: MenubarMenuProps) => {\n const menuId = useMemo(() => nextMenuId(valueProp), [valueProp]);\n\n return (\n <MenubarMenuContext.Provider value={{ menuId }}>\n <div data-slot=\"menubar-menu\" class={cn(\"relative flex\", className)} {...rest}>\n {children}\n </div>\n </MenubarMenuContext.Provider>\n );\n};\n","import { useEffect, useMemo } from \"preact/hooks\";\nimport { signal } from \"@preact/signals\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { MenubarRadioContext } from \"./menubar-context\";\n\nexport type MenubarRadioGroupProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n value?: string;\n defaultValue?: string;\n onValueChange?: (value: string) => void;\n};\n\nexport const MenubarRadioGroup = ({\n class: className,\n children,\n value: controlledValue,\n defaultValue = \"\",\n onValueChange,\n ...rest\n}: MenubarRadioGroupProps) => {\n const selected = useMemo(() => signal(controlledValue ?? defaultValue), []);\n\n useEffect(() => {\n if (controlledValue !== undefined) selected.value = controlledValue;\n }, [controlledValue, selected]);\n\n const ctx = useMemo(\n () => ({\n selected,\n controlledValue,\n setValue: (next: string) => {\n if (controlledValue === undefined) selected.value = next;\n onValueChange?.(next);\n }\n }),\n [controlledValue, onValueChange, selected]\n );\n\n return (\n <MenubarRadioContext.Provider value={ctx}>\n <div role=\"group\" data-slot=\"menubar-radio-group\" class={cn(\"p-1\", className)} {...rest}>\n {children}\n </div>\n </MenubarRadioContext.Provider>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useMenubarRadio } from \"./menubar-context\";\n\nexport type MenubarRadioItemProps = JSX.ButtonHTMLAttributes<HTMLButtonElement> & {\n children?: ComponentChildren;\n value: string;\n};\n\nconst CircleIcon = ({ filled }: { filled: boolean }) => (\n <span class=\"flex size-3.5 items-center justify-center\" aria-hidden>\n {filled ? (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" class=\"size-2 fill-current\">\n <circle cx=\"12\" cy=\"12\" r=\"6\" />\n </svg>\n ) : (\n <span class=\"size-2 rounded-full border border-current opacity-60\" />\n )}\n </span>\n);\n\nexport const MenubarRadioItem = ({\n class: className,\n value,\n children,\n disabled,\n onClick,\n ...rest\n}: MenubarRadioItemProps) => {\n const radio = useMenubarRadio();\n const current = radio.controlledValue !== undefined ? radio.controlledValue : radio.selected.value;\n const checked = current === value;\n\n return (\n <button\n type=\"button\"\n role=\"menuitemradio\"\n data-slot=\"menubar-radio-item\"\n aria-checked={checked}\n disabled={disabled}\n class={cn(\n \"relative flex w-full cursor-default select-none items-center gap-2 rounded-sm py-1.5 ps-8 pe-2 text-start text-sm outline-none\",\n \"focus:bg-accent focus:text-accent-foreground\",\n \"disabled:pointer-events-none disabled:opacity-50\",\n className\n )}\n onClick={(e) => {\n onClick?.(e);\n if (e.defaultPrevented) return;\n radio.setValue(value);\n }}\n {...rest}\n >\n <span class=\"absolute start-2 flex size-3.5 items-center justify-center text-foreground\">\n <CircleIcon filled={checked} />\n </span>\n {children}\n </button>\n );\n};\n","import type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type MenubarSeparatorProps = JSX.HTMLAttributes<HTMLDivElement>;\n\nexport const MenubarSeparator = ({ class: className, ...rest }: MenubarSeparatorProps) => (\n <div\n role=\"separator\"\n data-slot=\"menubar-separator\"\n class={cn(\"mx-1 my-1 h-px bg-border\", className)}\n {...rest}\n />\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type MenubarShortcutProps = JSX.HTMLAttributes<HTMLSpanElement> & {\n children?: ComponentChildren;\n};\n\nexport const MenubarShortcut = ({ class: className, children, ...rest }: MenubarShortcutProps) => (\n <span\n data-slot=\"menubar-shortcut\"\n class={cn(\"ms-auto text-xs tracking-widest text-muted-foreground\", className)}\n {...rest}\n >\n {children}\n </span>\n);\n","import { signal } from \"@preact/signals\";\nimport { useMemo } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { MenubarSubContext } from \"./menubar-context\";\n\nexport type MenubarSubProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const MenubarSub = ({ class: className, children, ...rest }: MenubarSubProps) => {\n const open = useMemo(() => signal(false), []);\n\n const ctx = useMemo(\n () => ({\n open,\n setOpen: (next: boolean) => {\n open.value = next;\n }\n }),\n [open]\n );\n\n return (\n <MenubarSubContext.Provider value={ctx}>\n <div\n data-slot=\"menubar-sub\"\n class={cn(\"relative\", className)}\n onPointerLeave={() => {\n open.value = false;\n }}\n {...rest}\n >\n {children}\n </div>\n </MenubarSubContext.Provider>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useMenubarSub } from \"./menubar-context\";\n\nexport type MenubarSubContentProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const MenubarSubContent = ({ class: className, children, onPointerEnter, ...rest }: MenubarSubContentProps) => {\n const sub = useMenubarSub();\n\n if (!sub.open.value) return null;\n\n return (\n <div\n role=\"menu\"\n data-slot=\"menubar-sub-content\"\n data-state=\"open\"\n class={cn(\n \"absolute start-full top-0 z-50 min-w-40 rounded-md border border-border bg-popover p-0 text-popover-foreground shadow-md outline-none ms-1 rtl:me-1 rtl:ms-0\",\n className\n )}\n onPointerEnter={(e) => {\n onPointerEnter?.(e);\n sub.setOpen(true);\n }}\n {...rest}\n >\n {children}\n </div>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useMenubarSub } from \"./menubar-context\";\n\nconst ChevronRight = ({ class: className }: { class?: string }) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class={cn(\"size-4 shrink-0 rtl:rotate-180\", className)}\n aria-hidden\n >\n <path d=\"m9 18 6-6-6-6\" />\n </svg>\n);\n\nexport type MenubarSubTriggerProps = JSX.ButtonHTMLAttributes<HTMLButtonElement> & {\n children?: ComponentChildren;\n};\n\nexport const MenubarSubTrigger = ({ class: className, children, onClick, onPointerEnter, ...rest }: MenubarSubTriggerProps) => {\n const sub = useMenubarSub();\n const open = sub.open.value;\n\n return (\n <button\n type=\"button\"\n role=\"menuitem\"\n data-slot=\"menubar-sub-trigger\"\n data-state={open ? \"open\" : \"closed\"}\n aria-expanded={open}\n aria-haspopup=\"menu\"\n class={cn(\n \"flex w-full cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-start text-sm outline-none\",\n \"focus:bg-accent focus:text-accent-foreground\",\n \"data-[state=open]:bg-accent data-[state=open]:text-accent-foreground\",\n className\n )}\n onPointerEnter={(e) => {\n onPointerEnter?.(e);\n if (e.defaultPrevented) return;\n sub.setOpen(true);\n }}\n onClick={(e) => {\n onClick?.(e);\n if (e.defaultPrevented) return;\n sub.setOpen(!open);\n }}\n {...rest}\n >\n {children}\n <ChevronRight class=\"ms-auto\" />\n </button>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useMenubarMenu, useMenubarRoot } from \"./menubar-context\";\n\nexport type MenubarTriggerProps = JSX.ButtonHTMLAttributes<HTMLButtonElement> & {\n children?: ComponentChildren;\n};\n\nexport const MenubarTrigger = ({ class: className, children, onClick, ...rest }: MenubarTriggerProps) => {\n const root = useMenubarRoot();\n const { menuId } = useMenubarMenu();\n const open = root.openMenuId.value === menuId;\n\n return (\n <button\n type=\"button\"\n data-slot=\"menubar-trigger\"\n data-state={open ? \"open\" : \"closed\"}\n aria-expanded={open}\n aria-haspopup=\"menu\"\n class={cn(\n \"flex cursor-default select-none items-center rounded-sm px-2 py-1 text-sm font-medium outline-none\",\n \"focus:bg-accent focus:text-accent-foreground\",\n \"data-[state=open]:bg-accent data-[state=open]:text-accent-foreground\",\n className\n )}\n onClick={(e) => {\n onClick?.(e);\n if (e.defaultPrevented) return;\n root.setOpenMenuId(open ? null : menuId);\n }}\n {...rest}\n >\n {children}\n </button>\n );\n};\n","import { Menubar } from \"./Menubar\";\nimport { MenubarCheckboxItem } from \"./MenubarCheckboxItem\";\nimport { MenubarContent } from \"./MenubarContent\";\nimport { MenubarGroup } from \"./MenubarGroup\";\nimport { MenubarItem } from \"./MenubarItem\";\nimport { MenubarLabel } from \"./MenubarLabel\";\nimport { MenubarMenu } from \"./MenubarMenu\";\nimport { MenubarRadioGroup } from \"./MenubarRadioGroup\";\nimport { MenubarRadioItem } from \"./MenubarRadioItem\";\nimport { MenubarSeparator } from \"./MenubarSeparator\";\nimport { MenubarShortcut } from \"./MenubarShortcut\";\nimport { MenubarSub } from \"./MenubarSub\";\nimport { MenubarSubContent } from \"./MenubarSubContent\";\nimport { MenubarSubTrigger } from \"./MenubarSubTrigger\";\nimport { MenubarTrigger } from \"./MenubarTrigger\";\n\nexport {\n Menubar,\n MenubarCheckboxItem,\n MenubarContent,\n MenubarGroup,\n MenubarItem,\n MenubarLabel,\n MenubarMenu,\n MenubarRadioGroup,\n MenubarRadioItem,\n MenubarSeparator,\n MenubarShortcut,\n MenubarSub,\n MenubarSubContent,\n MenubarSubTrigger,\n MenubarTrigger\n};\n\nexport type { MenubarProps } from \"./Menubar\";\nexport type { MenubarCheckboxItemProps } from \"./MenubarCheckboxItem\";\nexport type { MenubarContentProps } from \"./MenubarContent\";\nexport type { MenubarGroupProps } from \"./MenubarGroup\";\nexport type { MenubarItemProps } from \"./MenubarItem\";\nexport type { MenubarLabelProps } from \"./MenubarLabel\";\nexport type { MenubarMenuProps } from \"./MenubarMenu\";\nexport type { MenubarRadioGroupProps } from \"./MenubarRadioGroup\";\nexport type { MenubarRadioItemProps } from \"./MenubarRadioItem\";\nexport type { MenubarSeparatorProps } from \"./MenubarSeparator\";\nexport type { MenubarShortcutProps } from \"./MenubarShortcut\";\nexport type { MenubarSubProps } from \"./MenubarSub\";\nexport type { MenubarSubContentProps } from \"./MenubarSubContent\";\nexport type { MenubarSubTriggerProps } from \"./MenubarSubTrigger\";\nexport type { MenubarTriggerProps } from \"./MenubarTrigger\";\n\nexport default {\n Root: Menubar,\n Menu: MenubarMenu,\n Trigger: MenubarTrigger,\n Content: MenubarContent,\n Group: MenubarGroup,\n Item: MenubarItem,\n Label: MenubarLabel,\n Separator: MenubarSeparator,\n Shortcut: MenubarShortcut,\n CheckboxItem: MenubarCheckboxItem,\n RadioGroup: MenubarRadioGroup,\n RadioItem: MenubarRadioItem,\n Sub: MenubarSub,\n SubTrigger: MenubarSubTrigger,\n SubContent: MenubarSubContent\n};\n"]}
@@ -0,0 +1,70 @@
1
+ import { cn } from './chunk-OMXWBB67.js';
2
+ import { jsx, jsxs } from 'preact/jsx-runtime';
3
+ import { isValidElement, cloneElement } from 'preact';
4
+
5
+ var Breadcrumb = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("nav", { "aria-label": "breadcrumb", "data-slot": "breadcrumb", class: cn(className), ...rest, children });
6
+ var BreadcrumbList = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx(
7
+ "ol",
8
+ {
9
+ "data-slot": "breadcrumb-list",
10
+ class: cn("text-muted-foreground flex flex-wrap items-center gap-1.5 break-words text-sm", className),
11
+ ...rest,
12
+ children
13
+ }
14
+ );
15
+ var BreadcrumbItem = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("li", { "data-slot": "breadcrumb-item", class: cn("inline-flex items-center gap-1.5", className), ...rest, children });
16
+ var linkClass = "hover:text-foreground transition-colors";
17
+ var BreadcrumbLink = ({ asChild = false, class: className, children, ...rest }) => {
18
+ const mergedClass = cn(linkClass, className);
19
+ if (asChild) {
20
+ if (!isValidElement(children)) {
21
+ return null;
22
+ }
23
+ const childProps = children.props ?? {};
24
+ return cloneElement(children, {
25
+ ...rest,
26
+ ...childProps ?? {},
27
+ class: cn(mergedClass, childProps.class, childProps.className),
28
+ "data-slot": "breadcrumb-link"
29
+ });
30
+ }
31
+ return /* @__PURE__ */ jsx("a", { "data-slot": "breadcrumb-link", class: mergedClass, ...rest, children });
32
+ };
33
+ var BreadcrumbPage = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx(
34
+ "span",
35
+ {
36
+ role: "link",
37
+ "aria-disabled": "true",
38
+ "aria-current": "page",
39
+ "data-slot": "breadcrumb-page",
40
+ class: cn("text-foreground font-medium", className),
41
+ ...rest,
42
+ children
43
+ }
44
+ );
45
+ var BreadcrumbSeparator = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("li", { "data-slot": "breadcrumb-separator", role: "presentation", "aria-hidden": "true", class: cn("[&>svg]:size-3.5", className), ...rest, children: children ?? /* @__PURE__ */ jsx(
46
+ "svg",
47
+ {
48
+ viewBox: "0 0 24 24",
49
+ fill: "none",
50
+ stroke: "currentColor",
51
+ "stroke-width": "2",
52
+ "stroke-linecap": "round",
53
+ "stroke-linejoin": "round",
54
+ class: "shrink-0 rtl:rotate-180",
55
+ "aria-hidden": "true",
56
+ children: /* @__PURE__ */ jsx("path", { d: "m9 18 6-6-6-6" })
57
+ }
58
+ ) });
59
+ var BreadcrumbEllipsis = ({ class: className, ...rest }) => /* @__PURE__ */ jsxs("span", { "data-slot": "breadcrumb-ellipsis", class: cn("flex size-9 items-center justify-center", className), ...rest, children: [
60
+ /* @__PURE__ */ jsxs("svg", { viewBox: "0 0 24 24", fill: "currentColor", class: "size-4", "aria-hidden": "true", children: [
61
+ /* @__PURE__ */ jsx("circle", { cx: "5", cy: "12", r: "2" }),
62
+ /* @__PURE__ */ jsx("circle", { cx: "12", cy: "12", r: "2" }),
63
+ /* @__PURE__ */ jsx("circle", { cx: "19", cy: "12", r: "2" })
64
+ ] }),
65
+ /* @__PURE__ */ jsx("span", { class: "sr-only", children: "More" })
66
+ ] });
67
+
68
+ export { Breadcrumb, BreadcrumbEllipsis, BreadcrumbItem, BreadcrumbLink, BreadcrumbList, BreadcrumbPage, BreadcrumbSeparator };
69
+ //# sourceMappingURL=chunk-DHBILREV.js.map
70
+ //# sourceMappingURL=chunk-DHBILREV.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/breadcrumb/Breadcrumb.tsx","../src/components/breadcrumb/BreadcrumbList.tsx","../src/components/breadcrumb/BreadcrumbItem.tsx","../src/components/breadcrumb/BreadcrumbLink.tsx","../src/components/breadcrumb/BreadcrumbPage.tsx","../src/components/breadcrumb/BreadcrumbSeparator.tsx","../src/components/breadcrumb/BreadcrumbEllipsis.tsx"],"names":["jsx"],"mappings":"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","file":"chunk-DHBILREV.js","sourcesContent":["import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type BreadcrumbProps = JSX.HTMLAttributes<HTMLElement> & {\n children?: ComponentChildren;\n};\n\nexport const Breadcrumb = ({ class: className, children, ...rest }: BreadcrumbProps) => (\n <nav aria-label=\"breadcrumb\" data-slot=\"breadcrumb\" class={cn(className)} {...rest}>\n {children}\n </nav>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type BreadcrumbListProps = JSX.HTMLAttributes<HTMLOListElement> & {\n children?: ComponentChildren;\n};\n\nexport const BreadcrumbList = ({ class: className, children, ...rest }: BreadcrumbListProps) => (\n <ol\n data-slot=\"breadcrumb-list\"\n class={cn(\"text-muted-foreground flex flex-wrap items-center gap-1.5 break-words text-sm\", className)}\n {...rest}\n >\n {children}\n </ol>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type BreadcrumbItemProps = JSX.HTMLAttributes<HTMLLIElement> & {\n children?: ComponentChildren;\n};\n\nexport const BreadcrumbItem = ({ class: className, children, ...rest }: BreadcrumbItemProps) => (\n <li data-slot=\"breadcrumb-item\" class={cn(\"inline-flex items-center gap-1.5\", className)} {...rest}>\n {children}\n </li>\n);\n","import { cloneElement, isValidElement, type ComponentChildren, type JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type BreadcrumbLinkProps = JSX.AnchorHTMLAttributes<HTMLAnchorElement> & {\n children?: ComponentChildren;\n asChild?: boolean;\n};\n\nconst linkClass = \"hover:text-foreground transition-colors\";\n\nexport const BreadcrumbLink = ({ asChild = false, class: className, children, ...rest }: BreadcrumbLinkProps) => {\n const mergedClass = cn(linkClass, className);\n\n if (asChild) {\n if (!isValidElement(children)) {\n return null;\n }\n\n const childProps = (children.props ?? {}) as JSX.HTMLAttributes<HTMLElement> & {\n class?: string;\n className?: string;\n };\n\n return cloneElement(children, {\n ...(rest as JSX.HTMLAttributes<HTMLElement>),\n ...(childProps ?? {}),\n class: cn(mergedClass, childProps.class, childProps.className),\n \"data-slot\": \"breadcrumb-link\"\n });\n }\n\n return (\n <a data-slot=\"breadcrumb-link\" class={mergedClass} {...rest}>\n {children}\n </a>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type BreadcrumbPageProps = JSX.HTMLAttributes<HTMLSpanElement> & {\n children?: ComponentChildren;\n};\n\nexport const BreadcrumbPage = ({ class: className, children, ...rest }: BreadcrumbPageProps) => (\n <span\n role=\"link\"\n aria-disabled=\"true\"\n aria-current=\"page\"\n data-slot=\"breadcrumb-page\"\n class={cn(\"text-foreground font-medium\", className)}\n {...rest}\n >\n {children}\n </span>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type BreadcrumbSeparatorProps = JSX.HTMLAttributes<HTMLLIElement> & {\n children?: ComponentChildren;\n};\n\nexport const BreadcrumbSeparator = ({ class: className, children, ...rest }: BreadcrumbSeparatorProps) => (\n <li data-slot=\"breadcrumb-separator\" role=\"presentation\" aria-hidden=\"true\" class={cn(\"[&>svg]:size-3.5\", className)} {...rest}>\n {children ?? (\n <svg\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class=\"shrink-0 rtl:rotate-180\"\n aria-hidden=\"true\"\n >\n <path d=\"m9 18 6-6-6-6\" />\n </svg>\n )}\n </li>\n);\n","import type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type BreadcrumbEllipsisProps = JSX.HTMLAttributes<HTMLSpanElement>;\n\nexport const BreadcrumbEllipsis = ({ class: className, ...rest }: BreadcrumbEllipsisProps) => (\n <span data-slot=\"breadcrumb-ellipsis\" class={cn(\"flex size-9 items-center justify-center\", className)} {...rest}>\n <svg viewBox=\"0 0 24 24\" fill=\"currentColor\" class=\"size-4\" aria-hidden=\"true\">\n <circle cx=\"5\" cy=\"12\" r=\"2\" />\n <circle cx=\"12\" cy=\"12\" r=\"2\" />\n <circle cx=\"19\" cy=\"12\" r=\"2\" />\n </svg>\n <span class=\"sr-only\">More</span>\n </span>\n);\n"]}
@@ -0,0 +1,17 @@
1
+ import { Table } from './chunk-IGGEBO7K.js';
2
+ import { cn } from './chunk-OMXWBB67.js';
3
+ import { jsx } from 'preact/jsx-runtime';
4
+
5
+ var DataTable = ({
6
+ chrome = true,
7
+ class: className,
8
+ children,
9
+ ...rest
10
+ }) => /* @__PURE__ */ jsx("div", { "data-slot": "data-table", class: cn("w-full", className), ...rest, children: chrome ? /* @__PURE__ */ jsx("div", { class: "overflow-hidden rounded-md border bg-card text-card-foreground", children: /* @__PURE__ */ jsx(Table, { class: "rounded-none border-0 shadow-none", children }) }) : /* @__PURE__ */ jsx(Table, { children }) });
11
+
12
+ // src/components/data-table/index.ts
13
+ var data_table_default = DataTable;
14
+
15
+ export { DataTable, data_table_default };
16
+ //# sourceMappingURL=chunk-DJ4PFETN.js.map
17
+ //# sourceMappingURL=chunk-DJ4PFETN.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/data-table/DataTable.tsx","../src/components/data-table/index.ts"],"names":[],"mappings":";;;;AAaO,IAAM,YAAY,CAAC;AAAA,EACxB,MAAA,GAAS,IAAA;AAAA,EACT,KAAA,EAAO,SAAA;AAAA,EACP,QAAA;AAAA,EACA,GAAG;AACL,CAAA,qBACE,GAAA,CAAC,KAAA,EAAA,EAAI,WAAA,EAAU,YAAA,EAAa,KAAA,EAAO,EAAA,CAAG,QAAA,EAAU,SAAS,CAAA,EAAI,GAAG,IAAA,EAC7D,QAAA,EAAA,MAAA,mBACC,GAAA,CAAC,SAAI,KAAA,EAAM,gEAAA,EACT,QAAA,kBAAA,GAAA,CAAC,KAAA,EAAA,EAAM,KAAA,EAAM,mCAAA,EAAqC,QAAA,EAAS,CAAA,EAC7D,CAAA,mBAEA,GAAA,CAAC,KAAA,EAAA,EAAO,QAAA,EAAS,CAAA,EAErB;;;ACvBF,IAAO,kBAAA,GAAQ","file":"chunk-DJ4PFETN.js","sourcesContent":["import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { Table } from \"../table/Table\";\n\nexport type DataTableProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n /**\n * When true (default), wraps the table in `overflow-hidden rounded-md border` like shadcn data tables.\n * Set false if you already provide an outer chrome or use a bare `<Table>`.\n */\n chrome?: boolean;\n};\n\nexport const DataTable = ({\n chrome = true,\n class: className,\n children,\n ...rest\n}: DataTableProps) => (\n <div data-slot=\"data-table\" class={cn(\"w-full\", className)} {...rest}>\n {chrome ? (\n <div class=\"overflow-hidden rounded-md border bg-card text-card-foreground\">\n <Table class=\"rounded-none border-0 shadow-none\">{children}</Table>\n </div>\n ) : (\n <Table>{children}</Table>\n )}\n </div>\n);\n","import { DataTable } from \"./DataTable\";\n\nexport { DataTable };\n\nexport default DataTable;\n\n"]}