@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.
- package/LICENSE.md +9 -0
- package/dist/Accordion-D1PiNspd.d.ts +39 -0
- package/dist/AlertDialog-CpnCfDdN.d.ts +64 -0
- package/dist/Button-tRKMr8-H.d.ts +84 -0
- package/dist/CalendarDateTimePanel-B3J8OlSc.d.ts +79 -0
- package/dist/Carousel-DvlcMPpB.d.ts +41 -0
- package/dist/Chart-Ax22S5_N.d.ts +10 -0
- package/dist/Checkbox-DBbLYq6Q.d.ts +12 -0
- package/dist/Collapsible-DSZCp0tm.d.ts +34 -0
- package/dist/ComboboxInlineInput-CB7CEXzy.d.ts +135 -0
- package/dist/CommandSeparator-pJQnB9Lu.d.ts +47 -0
- package/dist/DataTable-zNTTdYVU.d.ts +13 -0
- package/dist/DatePicker-AFAYh5Ca.d.ts +20 -0
- package/dist/Dialog-CqCI4s9U.d.ts +28 -0
- package/dist/DialogContent-9VJGDt5l.d.ts +24 -0
- package/dist/DialogHeader-CYT7iUDq.d.ts +13 -0
- package/dist/DialogTitle-CvcRlZ_Z.d.ts +13 -0
- package/dist/Direction-25ZOt0gW.d.ts +24 -0
- package/dist/Drawer-BOPihYBJ.d.ts +41 -0
- package/dist/Dropdown-uPFaMqkB.d.ts +143 -0
- package/dist/EmptyTitle-J8rVLcJ3.d.ts +59 -0
- package/dist/FieldTitle-aSgThW-B.d.ts +100 -0
- package/dist/HoverCard-OSnOE6pE.d.ts +52 -0
- package/dist/Input-Cem05el9.d.ts +27 -0
- package/dist/Menubar-DwYDW4w2.d.ts +88 -0
- package/dist/PopoverTrigger-B6kK73gh.d.ts +43 -0
- package/dist/Progress-BGij8Hob.d.ts +13 -0
- package/dist/RadioGroup-BaElzLwa.d.ts +40 -0
- package/dist/ScrollArea-B-vILe3g.d.ts +16 -0
- package/dist/Select-B_mNVh70.d.ts +51 -0
- package/dist/Separator-DCQYrnpB.d.ts +9 -0
- package/dist/Sheet-B41Emmis.d.ts +29 -0
- package/dist/SidebarProvider-IAihmyD7.d.ts +46 -0
- package/dist/Slider-BQLMBpYs.d.ts +16 -0
- package/dist/Switch-CTTkNdqF.d.ts +31 -0
- package/dist/Tabs-DFJR_P2D.d.ts +47 -0
- package/dist/Textarea-DbKkduOG.d.ts +27 -0
- package/dist/ThemeToggle-DfiEM1dZ.d.ts +9 -0
- package/dist/Toggle-CseZl7XN.d.ts +49 -0
- package/dist/ToggleGroup-UeYHzQe7.d.ts +137 -0
- package/dist/Tooltip-BtRWVyCA.d.ts +40 -0
- package/dist/Typography-ccTtE182.d.ts +64 -0
- package/dist/chunk-2UHCXHAX.js +119 -0
- package/dist/chunk-2UHCXHAX.js.map +1 -0
- package/dist/chunk-2XNWLXG2.js +12 -0
- package/dist/chunk-2XNWLXG2.js.map +1 -0
- package/dist/chunk-3EHH62ZA.js +175 -0
- package/dist/chunk-3EHH62ZA.js.map +1 -0
- package/dist/chunk-3GKUUTSA.js +586 -0
- package/dist/chunk-3GKUUTSA.js.map +1 -0
- package/dist/chunk-3IT2RVO6.js +151 -0
- package/dist/chunk-3IT2RVO6.js.map +1 -0
- package/dist/chunk-3WAPI4KR.js +36 -0
- package/dist/chunk-3WAPI4KR.js.map +1 -0
- package/dist/chunk-44YLIQIS.js +15 -0
- package/dist/chunk-44YLIQIS.js.map +1 -0
- package/dist/chunk-4AJM7IA4.js +9 -0
- package/dist/chunk-4AJM7IA4.js.map +1 -0
- package/dist/chunk-4HX6SEWP.js +24 -0
- package/dist/chunk-4HX6SEWP.js.map +1 -0
- package/dist/chunk-6FTWMOHU.js +478 -0
- package/dist/chunk-6FTWMOHU.js.map +1 -0
- package/dist/chunk-6ZXYDBPR.js +304 -0
- package/dist/chunk-6ZXYDBPR.js.map +1 -0
- package/dist/chunk-7E2ZPDVI.js +224 -0
- package/dist/chunk-7E2ZPDVI.js.map +1 -0
- package/dist/chunk-7HZUM5ZQ.js +85 -0
- package/dist/chunk-7HZUM5ZQ.js.map +1 -0
- package/dist/chunk-7MECYLKS.js +375 -0
- package/dist/chunk-7MECYLKS.js.map +1 -0
- package/dist/chunk-7TDS7TC6.js +49 -0
- package/dist/chunk-7TDS7TC6.js.map +1 -0
- package/dist/chunk-7ZXJRNJO.js +26 -0
- package/dist/chunk-7ZXJRNJO.js.map +1 -0
- package/dist/chunk-AVCG4W6D.js +122 -0
- package/dist/chunk-AVCG4W6D.js.map +1 -0
- package/dist/chunk-BF3F5SJX.js +89 -0
- package/dist/chunk-BF3F5SJX.js.map +1 -0
- package/dist/chunk-BHMKSFES.js +195 -0
- package/dist/chunk-BHMKSFES.js.map +1 -0
- package/dist/chunk-BMF5SGYP.js +45 -0
- package/dist/chunk-BMF5SGYP.js.map +1 -0
- package/dist/chunk-D25ZQ36E.js +273 -0
- package/dist/chunk-D25ZQ36E.js.map +1 -0
- package/dist/chunk-D5W5YHJZ.js +426 -0
- package/dist/chunk-D5W5YHJZ.js.map +1 -0
- package/dist/chunk-DHBILREV.js +70 -0
- package/dist/chunk-DHBILREV.js.map +1 -0
- package/dist/chunk-DJ4PFETN.js +17 -0
- package/dist/chunk-DJ4PFETN.js.map +1 -0
- package/dist/chunk-DKXUKLZT.js +342 -0
- package/dist/chunk-DKXUKLZT.js.map +1 -0
- package/dist/chunk-EL2HT25C.js +9 -0
- package/dist/chunk-EL2HT25C.js.map +1 -0
- package/dist/chunk-FDNPBI2Z.js +26 -0
- package/dist/chunk-FDNPBI2Z.js.map +1 -0
- package/dist/chunk-FWCN47RC.js +65 -0
- package/dist/chunk-FWCN47RC.js.map +1 -0
- package/dist/chunk-G6PBJZYF.js +114 -0
- package/dist/chunk-G6PBJZYF.js.map +1 -0
- package/dist/chunk-GFF5OT46.js +80 -0
- package/dist/chunk-GFF5OT46.js.map +1 -0
- package/dist/chunk-GLWYIUE5.js +242 -0
- package/dist/chunk-GLWYIUE5.js.map +1 -0
- package/dist/chunk-HEQRODRF.js +110 -0
- package/dist/chunk-HEQRODRF.js.map +1 -0
- package/dist/chunk-HGTFOOUL.js +61 -0
- package/dist/chunk-HGTFOOUL.js.map +1 -0
- package/dist/chunk-HNESOMVN.js +18 -0
- package/dist/chunk-HNESOMVN.js.map +1 -0
- package/dist/chunk-I2PR3HXC.js +51 -0
- package/dist/chunk-I2PR3HXC.js.map +1 -0
- package/dist/chunk-IGGEBO7K.js +8 -0
- package/dist/chunk-IGGEBO7K.js.map +1 -0
- package/dist/chunk-J2Z2LSXM.js +26 -0
- package/dist/chunk-J2Z2LSXM.js.map +1 -0
- package/dist/chunk-JC7JMWSH.js +109 -0
- package/dist/chunk-JC7JMWSH.js.map +1 -0
- package/dist/chunk-JZRMLE4X.js +77 -0
- package/dist/chunk-JZRMLE4X.js.map +1 -0
- package/dist/chunk-KBXDU3G4.js +382 -0
- package/dist/chunk-KBXDU3G4.js.map +1 -0
- package/dist/chunk-KF34SFFZ.js +18 -0
- package/dist/chunk-KF34SFFZ.js.map +1 -0
- package/dist/chunk-L42B6QZS.js +524 -0
- package/dist/chunk-L42B6QZS.js.map +1 -0
- package/dist/chunk-LGO5HXMG.js +592 -0
- package/dist/chunk-LGO5HXMG.js.map +1 -0
- package/dist/chunk-LVK44RMS.js +78 -0
- package/dist/chunk-LVK44RMS.js.map +1 -0
- package/dist/chunk-N2LRB6TA.js +8 -0
- package/dist/chunk-N2LRB6TA.js.map +1 -0
- package/dist/chunk-NHTY2HD2.js +8 -0
- package/dist/chunk-NHTY2HD2.js.map +1 -0
- package/dist/chunk-NJUXP5FM.js +392 -0
- package/dist/chunk-NJUXP5FM.js.map +1 -0
- package/dist/chunk-NPHECLV5.js +94 -0
- package/dist/chunk-NPHECLV5.js.map +1 -0
- package/dist/chunk-NXVAR6P2.js +79 -0
- package/dist/chunk-NXVAR6P2.js.map +1 -0
- package/dist/chunk-OMXWBB67.js +9 -0
- package/dist/chunk-OMXWBB67.js.map +1 -0
- package/dist/chunk-PE5QQIV5.js +69 -0
- package/dist/chunk-PE5QQIV5.js.map +1 -0
- package/dist/chunk-QAUGWXGJ.js +158 -0
- package/dist/chunk-QAUGWXGJ.js.map +1 -0
- package/dist/chunk-QCYFSBZ7.js +81 -0
- package/dist/chunk-QCYFSBZ7.js.map +1 -0
- package/dist/chunk-QJT5UAL2.js +714 -0
- package/dist/chunk-QJT5UAL2.js.map +1 -0
- package/dist/chunk-QRLVOM3E.js +83 -0
- package/dist/chunk-QRLVOM3E.js.map +1 -0
- package/dist/chunk-RBVGV7VO.js +26 -0
- package/dist/chunk-RBVGV7VO.js.map +1 -0
- package/dist/chunk-RD6VXGVY.js +340 -0
- package/dist/chunk-RD6VXGVY.js.map +1 -0
- package/dist/chunk-RSPI2A4W.js +106 -0
- package/dist/chunk-RSPI2A4W.js.map +1 -0
- package/dist/chunk-RT26RZ7W.js +79 -0
- package/dist/chunk-RT26RZ7W.js.map +1 -0
- package/dist/chunk-RXAIDZ33.js +522 -0
- package/dist/chunk-RXAIDZ33.js.map +1 -0
- package/dist/chunk-S6TO62GJ.js +53 -0
- package/dist/chunk-S6TO62GJ.js.map +1 -0
- package/dist/chunk-SJ5MYJ7L.js +283 -0
- package/dist/chunk-SJ5MYJ7L.js.map +1 -0
- package/dist/chunk-SZ2I2SRP.js +156 -0
- package/dist/chunk-SZ2I2SRP.js.map +1 -0
- package/dist/chunk-UGOQKTHL.js +23 -0
- package/dist/chunk-UGOQKTHL.js.map +1 -0
- package/dist/chunk-UGQ756Z6.js +92 -0
- package/dist/chunk-UGQ756Z6.js.map +1 -0
- package/dist/chunk-UNPCAFLS.js +22 -0
- package/dist/chunk-UNPCAFLS.js.map +1 -0
- package/dist/chunk-V27UIXBD.js +36 -0
- package/dist/chunk-V27UIXBD.js.map +1 -0
- package/dist/chunk-VB5LDR7C.js +97 -0
- package/dist/chunk-VB5LDR7C.js.map +1 -0
- package/dist/chunk-VJ26PA3U.js +9 -0
- package/dist/chunk-VJ26PA3U.js.map +1 -0
- package/dist/chunk-VKB4VUN7.js +164 -0
- package/dist/chunk-VKB4VUN7.js.map +1 -0
- package/dist/chunk-Y37OHTAO.js +208 -0
- package/dist/chunk-Y37OHTAO.js.map +1 -0
- package/dist/chunk-Y4OW24IS.js +18 -0
- package/dist/chunk-Y4OW24IS.js.map +1 -0
- package/dist/chunk-YDMMDO2W.js +141 -0
- package/dist/chunk-YDMMDO2W.js.map +1 -0
- package/dist/chunk-YENXORWK.js +9 -0
- package/dist/chunk-YENXORWK.js.map +1 -0
- package/dist/chunk-YLTIB224.js +76 -0
- package/dist/chunk-YLTIB224.js.map +1 -0
- package/dist/chunk-YVA6PAML.js +63 -0
- package/dist/chunk-YVA6PAML.js.map +1 -0
- package/dist/chunk-YWUMX4JR.js +9 -0
- package/dist/chunk-YWUMX4JR.js.map +1 -0
- package/dist/chunk-ZDXR2SWG.js +32 -0
- package/dist/chunk-ZDXR2SWG.js.map +1 -0
- package/dist/chunk-ZIFL6GXH.js +187 -0
- package/dist/chunk-ZIFL6GXH.js.map +1 -0
- package/dist/chunk-ZM4VJOGF.js +40 -0
- package/dist/chunk-ZM4VJOGF.js.map +1 -0
- package/dist/chunk-ZVKIJLNO.js +9 -0
- package/dist/chunk-ZVKIJLNO.js.map +1 -0
- package/dist/components/accordion/index.d.ts +12 -0
- package/dist/components/accordion/index.js +4 -0
- package/dist/components/accordion/index.js.map +1 -0
- package/dist/components/alert/index.d.ts +64 -0
- package/dist/components/alert/index.js +4 -0
- package/dist/components/alert/index.js.map +1 -0
- package/dist/components/alert-dialog/index.d.ts +22 -0
- package/dist/components/alert-dialog/index.js +9 -0
- package/dist/components/alert-dialog/index.js.map +1 -0
- package/dist/components/aspect-ratio/index.d.ts +11 -0
- package/dist/components/aspect-ratio/index.js +4 -0
- package/dist/components/aspect-ratio/index.js.map +1 -0
- package/dist/components/avatar/index.d.ts +53 -0
- package/dist/components/avatar/index.js +4 -0
- package/dist/components/avatar/index.js.map +1 -0
- package/dist/components/badge/index.d.ts +175 -0
- package/dist/components/badge/index.js +4 -0
- package/dist/components/badge/index.js.map +1 -0
- package/dist/components/breadcrumb/index.d.ts +38 -0
- package/dist/components/breadcrumb/index.js +4 -0
- package/dist/components/breadcrumb/index.js.map +1 -0
- package/dist/components/button/index.d.ts +72 -0
- package/dist/components/button/index.js +5 -0
- package/dist/components/button/index.js.map +1 -0
- package/dist/components/button-group/index.d.ts +21 -0
- package/dist/components/button-group/index.js +4 -0
- package/dist/components/button-group/index.js.map +1 -0
- package/dist/components/calendar/index.d.ts +7 -0
- package/dist/components/calendar/index.js +12 -0
- package/dist/components/calendar/index.js.map +1 -0
- package/dist/components/card/index.d.ts +80 -0
- package/dist/components/card/index.js +3 -0
- package/dist/components/card/index.js.map +1 -0
- package/dist/components/carousel/index.d.ts +14 -0
- package/dist/components/carousel/index.js +5 -0
- package/dist/components/carousel/index.js.map +1 -0
- package/dist/components/chart/index.d.ts +6 -0
- package/dist/components/chart/index.js +4 -0
- package/dist/components/chart/index.js.map +1 -0
- package/dist/components/checkbox/index.d.ts +7 -0
- package/dist/components/checkbox/index.js +4 -0
- package/dist/components/checkbox/index.js.map +1 -0
- package/dist/components/collapsible/index.d.ts +11 -0
- package/dist/components/collapsible/index.js +4 -0
- package/dist/components/collapsible/index.js.map +1 -0
- package/dist/components/combobox/index.d.ts +13 -0
- package/dist/components/combobox/index.js +7 -0
- package/dist/components/combobox/index.js.map +1 -0
- package/dist/components/command/index.d.ts +21 -0
- package/dist/components/command/index.js +10 -0
- package/dist/components/command/index.js.map +1 -0
- package/dist/components/context-menu/index.d.ts +114 -0
- package/dist/components/context-menu/index.js +5 -0
- package/dist/components/context-menu/index.js.map +1 -0
- package/dist/components/data-table/index.d.ts +6 -0
- package/dist/components/data-table/index.js +5 -0
- package/dist/components/data-table/index.js.map +1 -0
- package/dist/components/date-picker/index.d.ts +7 -0
- package/dist/components/date-picker/index.js +8 -0
- package/dist/components/date-picker/index.js.map +1 -0
- package/dist/components/dialog/index.d.ts +22 -0
- package/dist/components/dialog/index.js +8 -0
- package/dist/components/dialog/index.js.map +1 -0
- package/dist/components/direction/index.d.ts +7 -0
- package/dist/components/direction/index.js +4 -0
- package/dist/components/direction/index.js.map +1 -0
- package/dist/components/drawer/index.d.ts +19 -0
- package/dist/components/drawer/index.js +8 -0
- package/dist/components/drawer/index.js.map +1 -0
- package/dist/components/dropdown/index.d.ts +24 -0
- package/dist/components/dropdown/index.js +5 -0
- package/dist/components/dropdown/index.js.map +1 -0
- package/dist/components/dropzone/index.d.ts +26 -0
- package/dist/components/dropzone/index.js +5 -0
- package/dist/components/dropzone/index.js.map +1 -0
- package/dist/components/empty/index.d.ts +8 -0
- package/dist/components/empty/index.js +4 -0
- package/dist/components/empty/index.js.map +1 -0
- package/dist/components/field/index.d.ts +8 -0
- package/dist/components/field/index.js +6 -0
- package/dist/components/field/index.js.map +1 -0
- package/dist/components/hover-card/index.d.ts +12 -0
- package/dist/components/hover-card/index.js +3 -0
- package/dist/components/hover-card/index.js.map +1 -0
- package/dist/components/image/index.d.ts +6 -0
- package/dist/components/image/index.js +4 -0
- package/dist/components/image/index.js.map +1 -0
- package/dist/components/input/index.d.ts +27 -0
- package/dist/components/input/index.js +4 -0
- package/dist/components/input/index.js.map +1 -0
- package/dist/components/input-group/index.d.ts +132 -0
- package/dist/components/input-group/index.js +7 -0
- package/dist/components/input-group/index.js.map +1 -0
- package/dist/components/input-otp/index.d.ts +39 -0
- package/dist/components/input-otp/index.js +4 -0
- package/dist/components/input-otp/index.js.map +1 -0
- package/dist/components/item/index.d.ts +108 -0
- package/dist/components/item/index.js +5 -0
- package/dist/components/item/index.js.map +1 -0
- package/dist/components/kbd/index.d.ts +31 -0
- package/dist/components/kbd/index.js +4 -0
- package/dist/components/kbd/index.js.map +1 -0
- package/dist/components/label/index.d.ts +49 -0
- package/dist/components/label/index.js +4 -0
- package/dist/components/label/index.js.map +1 -0
- package/dist/components/locale-segment-group/index.d.ts +15 -0
- package/dist/components/locale-segment-group/index.js +4 -0
- package/dist/components/locale-segment-group/index.js.map +1 -0
- package/dist/components/menubar/index.d.ts +23 -0
- package/dist/components/menubar/index.js +5 -0
- package/dist/components/menubar/index.js.map +1 -0
- package/dist/components/native-select/index.d.ts +89 -0
- package/dist/components/native-select/index.js +3 -0
- package/dist/components/native-select/index.js.map +1 -0
- package/dist/components/navigation-menu/index.d.ts +15 -0
- package/dist/components/navigation-menu/index.js +5 -0
- package/dist/components/navigation-menu/index.js.map +1 -0
- package/dist/components/pagination/index.d.ts +44 -0
- package/dist/components/pagination/index.js +5 -0
- package/dist/components/pagination/index.js.map +1 -0
- package/dist/components/popover/index.d.ts +76 -0
- package/dist/components/popover/index.js +5 -0
- package/dist/components/popover/index.js.map +1 -0
- package/dist/components/progress/index.d.ts +6 -0
- package/dist/components/progress/index.js +4 -0
- package/dist/components/progress/index.js.map +1 -0
- package/dist/components/prose/index.d.ts +8 -0
- package/dist/components/prose/index.js +4 -0
- package/dist/components/prose/index.js.map +1 -0
- package/dist/components/radio-group/index.d.ts +11 -0
- package/dist/components/radio-group/index.js +5 -0
- package/dist/components/radio-group/index.js.map +1 -0
- package/dist/components/scroll-area/index.d.ts +11 -0
- package/dist/components/scroll-area/index.js +4 -0
- package/dist/components/scroll-area/index.js.map +1 -0
- package/dist/components/select/index.d.ts +17 -0
- package/dist/components/select/index.js +5 -0
- package/dist/components/select/index.js.map +1 -0
- package/dist/components/selectable-card/index.d.ts +11 -0
- package/dist/components/selectable-card/index.js +5 -0
- package/dist/components/selectable-card/index.js.map +1 -0
- package/dist/components/separator/index.d.ts +24 -0
- package/dist/components/separator/index.js +4 -0
- package/dist/components/separator/index.js.map +1 -0
- package/dist/components/sheet/index.d.ts +20 -0
- package/dist/components/sheet/index.js +8 -0
- package/dist/components/sheet/index.js.map +1 -0
- package/dist/components/sidebar/index.d.ts +16 -0
- package/dist/components/sidebar/index.js +3 -0
- package/dist/components/sidebar/index.js.map +1 -0
- package/dist/components/skeleton/index.d.ts +52 -0
- package/dist/components/skeleton/index.js +3 -0
- package/dist/components/skeleton/index.js.map +1 -0
- package/dist/components/slider/index.d.ts +7 -0
- package/dist/components/slider/index.js +4 -0
- package/dist/components/slider/index.js.map +1 -0
- package/dist/components/sonner/index.d.ts +7 -0
- package/dist/components/sonner/index.js +3 -0
- package/dist/components/sonner/index.js.map +1 -0
- package/dist/components/spinner/index.d.ts +10 -0
- package/dist/components/spinner/index.js +4 -0
- package/dist/components/spinner/index.js.map +1 -0
- package/dist/components/switch/index.d.ts +7 -0
- package/dist/components/switch/index.js +4 -0
- package/dist/components/switch/index.js.map +1 -0
- package/dist/components/table/index.d.ts +45 -0
- package/dist/components/table/index.js +5 -0
- package/dist/components/table/index.js.map +1 -0
- package/dist/components/tabs/index.d.ts +13 -0
- package/dist/components/tabs/index.js +4 -0
- package/dist/components/tabs/index.js.map +1 -0
- package/dist/components/textarea/index.d.ts +27 -0
- package/dist/components/textarea/index.js +4 -0
- package/dist/components/textarea/index.js.map +1 -0
- package/dist/components/theme-toggle/index.d.ts +6 -0
- package/dist/components/theme-toggle/index.js +6 -0
- package/dist/components/theme-toggle/index.js.map +1 -0
- package/dist/components/toast/index.d.ts +27 -0
- package/dist/components/toast/index.js +3 -0
- package/dist/components/toast/index.js.map +1 -0
- package/dist/components/toggle/index.d.ts +7 -0
- package/dist/components/toggle/index.js +4 -0
- package/dist/components/toggle/index.js.map +1 -0
- package/dist/components/toggle-group/index.d.ts +11 -0
- package/dist/components/toggle-group/index.js +4 -0
- package/dist/components/toggle-group/index.js.map +1 -0
- package/dist/components/tooltip/index.d.ts +12 -0
- package/dist/components/tooltip/index.js +3 -0
- package/dist/components/tooltip/index.js.map +1 -0
- package/dist/components/typography/index.d.ts +8 -0
- package/dist/components/typography/index.js +4 -0
- package/dist/components/typography/index.js.map +1 -0
- package/dist/components/video/index.d.ts +8 -0
- package/dist/components/video/index.js +4 -0
- package/dist/components/video/index.js.map +1 -0
- package/dist/index.d.ts +82 -0
- package/dist/index.js +83 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/interactive/index.d.ts +34 -0
- package/dist/lib/interactive/index.js +3 -0
- package/dist/lib/interactive/index.js.map +1 -0
- package/dist/lib/signals/index.d.ts +15 -0
- package/dist/lib/signals/index.js +3 -0
- package/dist/lib/signals/index.js.map +1 -0
- package/dist/lib/utils.d.ts +5 -0
- package/dist/lib/utils.js +3 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/navigationMenuTriggerStyle-MrMOOgmr.d.ts +48 -0
- package/dist/sonner-store-Dfdxy8ba.d.ts +11 -0
- package/dist/theme.css +81 -0
- package/package.json +360 -0
|
@@ -0,0 +1,283 @@
|
|
|
1
|
+
import { Button } from './chunk-UGQ756Z6.js';
|
|
2
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
3
|
+
import EmblaCarousel from 'embla-carousel';
|
|
4
|
+
import Autoplay from 'embla-carousel-autoplay';
|
|
5
|
+
import { signal } from '@preact/signals';
|
|
6
|
+
import { createContext } from 'preact';
|
|
7
|
+
import { useState, useRef, useCallback, useMemo, useLayoutEffect, useContext } from 'preact/hooks';
|
|
8
|
+
import { jsx, jsxs, Fragment } from 'preact/jsx-runtime';
|
|
9
|
+
|
|
10
|
+
var CarouselContext = createContext(null);
|
|
11
|
+
var useCarousel = (strict = true) => {
|
|
12
|
+
const context = useContext(CarouselContext);
|
|
13
|
+
if (!context && strict) throw new Error("Carousel subcomponents must be used within Carousel");
|
|
14
|
+
return context;
|
|
15
|
+
};
|
|
16
|
+
var Carousel = ({
|
|
17
|
+
opts,
|
|
18
|
+
orientation = "horizontal",
|
|
19
|
+
setApi,
|
|
20
|
+
plugins,
|
|
21
|
+
autoplay = false,
|
|
22
|
+
dir,
|
|
23
|
+
class: className,
|
|
24
|
+
children,
|
|
25
|
+
...rest
|
|
26
|
+
}) => {
|
|
27
|
+
const [viewport, setViewport] = useState(null);
|
|
28
|
+
const lastViewport = useRef(null);
|
|
29
|
+
const setCarouselViewport = useCallback((el) => {
|
|
30
|
+
if (lastViewport.current === el) return;
|
|
31
|
+
lastViewport.current = el;
|
|
32
|
+
setViewport(el);
|
|
33
|
+
}, []);
|
|
34
|
+
const signalsRef = useRef(null);
|
|
35
|
+
if (!signalsRef.current) {
|
|
36
|
+
signalsRef.current = {
|
|
37
|
+
embla: signal(null),
|
|
38
|
+
canScrollPrev: signal(false),
|
|
39
|
+
canScrollNext: signal(false)
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
const { embla, canScrollPrev, canScrollNext } = signalsRef.current;
|
|
43
|
+
const optsKey = JSON.stringify(opts ?? {});
|
|
44
|
+
const mergedOpts = useMemo(() => {
|
|
45
|
+
const base = opts ?? {};
|
|
46
|
+
return {
|
|
47
|
+
...base,
|
|
48
|
+
align: base.align ?? (orientation === "vertical" ? "start" : "center"),
|
|
49
|
+
axis: orientation === "vertical" ? "y" : "x",
|
|
50
|
+
...dir ? { direction: dir } : {}
|
|
51
|
+
};
|
|
52
|
+
}, [optsKey, orientation, dir]);
|
|
53
|
+
const effectivePlugins = useMemo(() => {
|
|
54
|
+
if (plugins !== void 0) return plugins;
|
|
55
|
+
if (!autoplay) return [];
|
|
56
|
+
return [Autoplay(typeof autoplay === "object" ? autoplay : {})];
|
|
57
|
+
}, [plugins, autoplay]);
|
|
58
|
+
const pluginsKey = useMemo(() => effectivePlugins.map((p) => p.name).join(","), [effectivePlugins]);
|
|
59
|
+
useLayoutEffect(() => {
|
|
60
|
+
if (!viewport) return;
|
|
61
|
+
const api = EmblaCarousel(viewport, mergedOpts, effectivePlugins);
|
|
62
|
+
embla.value = api;
|
|
63
|
+
const updateScroll = () => {
|
|
64
|
+
canScrollPrev.value = api.canScrollPrev();
|
|
65
|
+
canScrollNext.value = api.canScrollNext();
|
|
66
|
+
};
|
|
67
|
+
const onSelect = () => updateScroll();
|
|
68
|
+
const onReInit = () => updateScroll();
|
|
69
|
+
api.on("select", onSelect);
|
|
70
|
+
api.on("reInit", onReInit);
|
|
71
|
+
updateScroll();
|
|
72
|
+
setApi?.(api);
|
|
73
|
+
return () => {
|
|
74
|
+
api.off("select", onSelect);
|
|
75
|
+
api.off("reInit", onReInit);
|
|
76
|
+
setApi?.(null);
|
|
77
|
+
api.destroy();
|
|
78
|
+
embla.value = null;
|
|
79
|
+
canScrollPrev.value = false;
|
|
80
|
+
canScrollNext.value = false;
|
|
81
|
+
};
|
|
82
|
+
}, [viewport, mergedOpts, pluginsKey, optsKey, orientation, dir]);
|
|
83
|
+
return /* @__PURE__ */ jsx(
|
|
84
|
+
CarouselContext.Provider,
|
|
85
|
+
{
|
|
86
|
+
value: {
|
|
87
|
+
setCarouselViewport,
|
|
88
|
+
embla,
|
|
89
|
+
canScrollPrev,
|
|
90
|
+
canScrollNext,
|
|
91
|
+
scrollPrev: () => embla.value?.scrollPrev(),
|
|
92
|
+
scrollNext: () => embla.value?.scrollNext(),
|
|
93
|
+
orientation
|
|
94
|
+
},
|
|
95
|
+
children: /* @__PURE__ */ jsx(
|
|
96
|
+
"div",
|
|
97
|
+
{
|
|
98
|
+
role: "region",
|
|
99
|
+
"aria-roledescription": "carousel",
|
|
100
|
+
"data-slot": "carousel",
|
|
101
|
+
"data-carousel-orientation": orientation,
|
|
102
|
+
class: cn("relative", className),
|
|
103
|
+
dir,
|
|
104
|
+
...rest,
|
|
105
|
+
children
|
|
106
|
+
}
|
|
107
|
+
)
|
|
108
|
+
}
|
|
109
|
+
);
|
|
110
|
+
};
|
|
111
|
+
var CarouselContent = ({ class: className, children, ...rest }) => {
|
|
112
|
+
const ctx = useCarousel(true);
|
|
113
|
+
if (!ctx) throw new Error("CarouselContent requires Carousel");
|
|
114
|
+
const vertical = ctx.orientation === "vertical";
|
|
115
|
+
return /* @__PURE__ */ jsx(
|
|
116
|
+
"div",
|
|
117
|
+
{
|
|
118
|
+
ref: (el) => {
|
|
119
|
+
ctx.setCarouselViewport(el);
|
|
120
|
+
},
|
|
121
|
+
"data-slot": "carousel-viewport",
|
|
122
|
+
"data-carousel-axis": vertical ? "y" : "x",
|
|
123
|
+
class: cn(
|
|
124
|
+
"overflow-hidden",
|
|
125
|
+
vertical && "min-h-0 touch-pan-y",
|
|
126
|
+
className
|
|
127
|
+
),
|
|
128
|
+
...rest,
|
|
129
|
+
children: /* @__PURE__ */ jsx(
|
|
130
|
+
"div",
|
|
131
|
+
{
|
|
132
|
+
"data-slot": "carousel-container",
|
|
133
|
+
class: cn("flex", vertical ? "h-full min-h-0 flex-col" : "flex-row"),
|
|
134
|
+
children
|
|
135
|
+
}
|
|
136
|
+
)
|
|
137
|
+
}
|
|
138
|
+
);
|
|
139
|
+
};
|
|
140
|
+
var CarouselItem = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx(
|
|
141
|
+
"div",
|
|
142
|
+
{
|
|
143
|
+
role: "group",
|
|
144
|
+
"aria-roledescription": "slide",
|
|
145
|
+
"data-slot": "carousel-item",
|
|
146
|
+
class: cn("min-h-0 min-w-0 shrink-0 grow-0 basis-full", className),
|
|
147
|
+
...rest,
|
|
148
|
+
children
|
|
149
|
+
}
|
|
150
|
+
);
|
|
151
|
+
var ChevronRight = ({ class: className }) => /* @__PURE__ */ jsx(
|
|
152
|
+
"svg",
|
|
153
|
+
{
|
|
154
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
155
|
+
viewBox: "0 0 24 24",
|
|
156
|
+
fill: "none",
|
|
157
|
+
stroke: "currentColor",
|
|
158
|
+
"stroke-width": "2",
|
|
159
|
+
"stroke-linecap": "round",
|
|
160
|
+
"stroke-linejoin": "round",
|
|
161
|
+
class: cn("size-4", className),
|
|
162
|
+
"aria-hidden": true,
|
|
163
|
+
children: /* @__PURE__ */ jsx("path", { d: "m9 18 6-6-6-6" })
|
|
164
|
+
}
|
|
165
|
+
);
|
|
166
|
+
var ChevronDown = ({ class: className }) => /* @__PURE__ */ jsx(
|
|
167
|
+
"svg",
|
|
168
|
+
{
|
|
169
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
170
|
+
viewBox: "0 0 24 24",
|
|
171
|
+
fill: "none",
|
|
172
|
+
stroke: "currentColor",
|
|
173
|
+
"stroke-width": "2",
|
|
174
|
+
"stroke-linecap": "round",
|
|
175
|
+
"stroke-linejoin": "round",
|
|
176
|
+
class: cn("size-4", className),
|
|
177
|
+
"aria-hidden": true,
|
|
178
|
+
children: /* @__PURE__ */ jsx("path", { d: "m6 9 6 6 6-6" })
|
|
179
|
+
}
|
|
180
|
+
);
|
|
181
|
+
var CarouselNext = ({ children, class: className, onClick, disabled, ...rest }) => {
|
|
182
|
+
const ctx = useCarousel(false);
|
|
183
|
+
const vertical = ctx?.orientation === "vertical";
|
|
184
|
+
const canNext = ctx?.canScrollNext.value ?? false;
|
|
185
|
+
return /* @__PURE__ */ jsx(
|
|
186
|
+
Button,
|
|
187
|
+
{
|
|
188
|
+
...rest,
|
|
189
|
+
type: "button",
|
|
190
|
+
variant: "outline",
|
|
191
|
+
size: "icon",
|
|
192
|
+
"data-slot": "carousel-next",
|
|
193
|
+
"aria-label": "Next slide",
|
|
194
|
+
disabled: disabled ?? !canNext,
|
|
195
|
+
class: cn(
|
|
196
|
+
"absolute z-10 size-8 rounded-full shadow-xs",
|
|
197
|
+
vertical ? "-bottom-12 left-1/2 -translate-x-1/2" : "-end-12 top-1/2 -translate-y-1/2 rtl:-rotate-180",
|
|
198
|
+
className
|
|
199
|
+
),
|
|
200
|
+
onClick: (event) => {
|
|
201
|
+
ctx?.scrollNext();
|
|
202
|
+
onClick?.(event);
|
|
203
|
+
},
|
|
204
|
+
children: children ?? /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
205
|
+
/* @__PURE__ */ jsx("span", { class: "sr-only", children: "Next slide" }),
|
|
206
|
+
vertical ? /* @__PURE__ */ jsx(ChevronDown, {}) : /* @__PURE__ */ jsx(ChevronRight, {})
|
|
207
|
+
] })
|
|
208
|
+
}
|
|
209
|
+
);
|
|
210
|
+
};
|
|
211
|
+
var ChevronLeft = ({ class: className }) => /* @__PURE__ */ jsx(
|
|
212
|
+
"svg",
|
|
213
|
+
{
|
|
214
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
215
|
+
viewBox: "0 0 24 24",
|
|
216
|
+
fill: "none",
|
|
217
|
+
stroke: "currentColor",
|
|
218
|
+
"stroke-width": "2",
|
|
219
|
+
"stroke-linecap": "round",
|
|
220
|
+
"stroke-linejoin": "round",
|
|
221
|
+
class: cn("size-4", className),
|
|
222
|
+
"aria-hidden": true,
|
|
223
|
+
children: /* @__PURE__ */ jsx("path", { d: "m15 18-6-6 6-6" })
|
|
224
|
+
}
|
|
225
|
+
);
|
|
226
|
+
var ChevronUp = ({ class: className }) => /* @__PURE__ */ jsx(
|
|
227
|
+
"svg",
|
|
228
|
+
{
|
|
229
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
230
|
+
viewBox: "0 0 24 24",
|
|
231
|
+
fill: "none",
|
|
232
|
+
stroke: "currentColor",
|
|
233
|
+
"stroke-width": "2",
|
|
234
|
+
"stroke-linecap": "round",
|
|
235
|
+
"stroke-linejoin": "round",
|
|
236
|
+
class: cn("size-4", className),
|
|
237
|
+
"aria-hidden": true,
|
|
238
|
+
children: /* @__PURE__ */ jsx("path", { d: "m18 15-6-6-6 6" })
|
|
239
|
+
}
|
|
240
|
+
);
|
|
241
|
+
var CarouselPrevious = ({ children, class: className, onClick, disabled, ...rest }) => {
|
|
242
|
+
const ctx = useCarousel(false);
|
|
243
|
+
const vertical = ctx?.orientation === "vertical";
|
|
244
|
+
const canPrev = ctx?.canScrollPrev.value ?? false;
|
|
245
|
+
return /* @__PURE__ */ jsx(
|
|
246
|
+
Button,
|
|
247
|
+
{
|
|
248
|
+
...rest,
|
|
249
|
+
type: "button",
|
|
250
|
+
variant: "outline",
|
|
251
|
+
size: "icon",
|
|
252
|
+
"data-slot": "carousel-previous",
|
|
253
|
+
"aria-label": "Previous slide",
|
|
254
|
+
disabled: disabled ?? !canPrev,
|
|
255
|
+
class: cn(
|
|
256
|
+
"absolute z-10 size-8 rounded-full shadow-xs",
|
|
257
|
+
vertical ? "-top-12 left-1/2 -translate-x-1/2" : "-start-12 top-1/2 -translate-y-1/2 rtl:-rotate-180",
|
|
258
|
+
className
|
|
259
|
+
),
|
|
260
|
+
onClick: (event) => {
|
|
261
|
+
ctx?.scrollPrev();
|
|
262
|
+
onClick?.(event);
|
|
263
|
+
},
|
|
264
|
+
children: children ?? /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
265
|
+
/* @__PURE__ */ jsx("span", { class: "sr-only", children: "Previous slide" }),
|
|
266
|
+
vertical ? /* @__PURE__ */ jsx(ChevronUp, {}) : /* @__PURE__ */ jsx(ChevronLeft, {})
|
|
267
|
+
] })
|
|
268
|
+
}
|
|
269
|
+
);
|
|
270
|
+
};
|
|
271
|
+
|
|
272
|
+
// src/components/carousel/index.ts
|
|
273
|
+
var carousel_default = {
|
|
274
|
+
Root: Carousel,
|
|
275
|
+
Content: CarouselContent,
|
|
276
|
+
Item: CarouselItem,
|
|
277
|
+
Previous: CarouselPrevious,
|
|
278
|
+
Next: CarouselNext
|
|
279
|
+
};
|
|
280
|
+
|
|
281
|
+
export { Carousel, CarouselContent, CarouselItem, CarouselNext, CarouselPrevious, carousel_default };
|
|
282
|
+
//# sourceMappingURL=chunk-SJ5MYJ7L.js.map
|
|
283
|
+
//# sourceMappingURL=chunk-SJ5MYJ7L.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/carousel/Carousel.tsx","../src/components/carousel/CarouselContent.tsx","../src/components/carousel/CarouselItem.tsx","../src/components/carousel/CarouselNext.tsx","../src/components/carousel/CarouselPrevious.tsx","../src/components/carousel/index.ts"],"names":["jsx","jsxs","Fragment"],"mappings":"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","file":"chunk-SJ5MYJ7L.js","sourcesContent":["import EmblaCarousel, {\n type EmblaCarouselType,\n type EmblaOptionsType,\n type EmblaPluginType\n} from \"embla-carousel\";\nimport Autoplay from \"embla-carousel-autoplay\";\nimport { signal } from \"@preact/signals\";\nimport { createContext } from \"preact\";\nimport { useCallback, useContext, useLayoutEffect, useMemo, useRef, useState } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type CarouselApi = EmblaCarouselType;\n\nexport type CarouselOrientation = \"horizontal\" | \"vertical\";\n\ntype CarouselContextValue = {\n setCarouselViewport: (el: HTMLDivElement | null) => void;\n embla: ReturnType<typeof signal<EmblaCarouselType | null>>;\n canScrollPrev: ReturnType<typeof signal<boolean>>;\n canScrollNext: ReturnType<typeof signal<boolean>>;\n scrollPrev: () => void;\n scrollNext: () => void;\n orientation: CarouselOrientation;\n};\n\nconst CarouselContext = createContext<CarouselContextValue | null>(null);\n\nexport const useCarousel = (strict = true) => {\n const context = useContext(CarouselContext);\n if (!context && strict) throw new Error(\"Carousel subcomponents must be used within Carousel\");\n return context;\n};\n\nexport type CarouselProps = Omit<JSX.HTMLAttributes<HTMLDivElement>, \"dir\"> & {\n opts?: EmblaOptionsType;\n orientation?: CarouselOrientation;\n setApi?: (api: CarouselApi | null) => void;\n plugins?: EmblaPluginType[];\n /** When `plugins` is omitted, adds `embla-carousel-autoplay`. Ignored if `plugins` is set. */\n autoplay?: boolean | { delay?: number; stopOnInteraction?: boolean };\n dir?: \"ltr\" | \"rtl\";\n children?: ComponentChildren;\n};\n\nexport const Carousel = ({\n opts,\n orientation = \"horizontal\",\n setApi,\n plugins,\n autoplay = false,\n dir,\n class: className,\n children,\n ...rest\n}: CarouselProps) => {\n const [viewport, setViewport] = useState<HTMLDivElement | null>(null);\n const lastViewport = useRef<HTMLDivElement | null>(null);\n const setCarouselViewport = useCallback((el: HTMLDivElement | null) => {\n if (lastViewport.current === el) return;\n lastViewport.current = el;\n setViewport(el);\n }, []);\n const signalsRef = useRef<{\n embla: ReturnType<typeof signal<EmblaCarouselType | null>>;\n canScrollPrev: ReturnType<typeof signal<boolean>>;\n canScrollNext: ReturnType<typeof signal<boolean>>;\n } | null>(null);\n if (!signalsRef.current) {\n signalsRef.current = {\n embla: signal<EmblaCarouselType | null>(null),\n canScrollPrev: signal(false),\n canScrollNext: signal(false)\n };\n }\n const { embla, canScrollPrev, canScrollNext } = signalsRef.current;\n\n const optsKey = JSON.stringify(opts ?? {});\n\n const mergedOpts = useMemo<EmblaOptionsType>(() => {\n const base = opts ?? {};\n return {\n ...base,\n align: base.align ?? (orientation === \"vertical\" ? \"start\" : \"center\"),\n axis: orientation === \"vertical\" ? \"y\" : \"x\",\n ...(dir ? { direction: dir } : {})\n };\n }, [optsKey, orientation, dir]);\n\n const effectivePlugins = useMemo<EmblaPluginType[]>(() => {\n if (plugins !== undefined) return plugins;\n if (!autoplay) return [];\n return [Autoplay(typeof autoplay === \"object\" ? autoplay : {})];\n }, [plugins, autoplay]);\n\n const pluginsKey = useMemo(() => effectivePlugins.map((p) => p.name).join(\",\"), [effectivePlugins]);\n\n useLayoutEffect(() => {\n if (!viewport) return;\n\n const api = EmblaCarousel(viewport, mergedOpts, effectivePlugins);\n embla.value = api;\n\n const updateScroll = () => {\n canScrollPrev.value = api.canScrollPrev();\n canScrollNext.value = api.canScrollNext();\n };\n\n const onSelect = () => updateScroll();\n const onReInit = () => updateScroll();\n\n api.on(\"select\", onSelect);\n api.on(\"reInit\", onReInit);\n updateScroll();\n setApi?.(api);\n\n return () => {\n api.off(\"select\", onSelect);\n api.off(\"reInit\", onReInit);\n setApi?.(null);\n api.destroy();\n embla.value = null;\n canScrollPrev.value = false;\n canScrollNext.value = false;\n };\n }, [viewport, mergedOpts, pluginsKey, optsKey, orientation, dir]);\n\n return (\n <CarouselContext.Provider\n value={{\n setCarouselViewport,\n embla,\n canScrollPrev,\n canScrollNext,\n scrollPrev: () => embla.value?.scrollPrev(),\n scrollNext: () => embla.value?.scrollNext(),\n orientation\n }}\n >\n <div\n role=\"region\"\n aria-roledescription=\"carousel\"\n data-slot=\"carousel\"\n data-carousel-orientation={orientation}\n class={cn(\"relative\", className)}\n dir={dir}\n {...rest}\n >\n {children}\n </div>\n </CarouselContext.Provider>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useCarousel } from \"./Carousel\";\n\nexport type CarouselContentProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const CarouselContent = ({ class: className, children, ...rest }: CarouselContentProps) => {\n const ctx = useCarousel(true);\n if (!ctx) throw new Error(\"CarouselContent requires Carousel\");\n const vertical = ctx.orientation === \"vertical\";\n\n return (\n <div\n ref={(el) => {\n ctx.setCarouselViewport(el);\n }}\n data-slot=\"carousel-viewport\"\n data-carousel-axis={vertical ? \"y\" : \"x\"}\n class={cn(\n \"overflow-hidden\",\n vertical && \"min-h-0 touch-pan-y\",\n className\n )}\n {...rest}\n >\n <div\n data-slot=\"carousel-container\"\n class={cn(\"flex\", vertical ? \"h-full min-h-0 flex-col\" : \"flex-row\")}\n >\n {children}\n </div>\n </div>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type CarouselItemProps = JSX.HTMLAttributes<HTMLDivElement> & { children?: ComponentChildren };\n\nexport const CarouselItem = ({ class: className, children, ...rest }: CarouselItemProps) => (\n <div\n role=\"group\"\n aria-roledescription=\"slide\"\n data-slot=\"carousel-item\"\n class={cn(\"min-h-0 min-w-0 shrink-0 grow-0 basis-full\", className)}\n {...rest}\n >\n {children}\n </div>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { Button } from \"../button/Button\";\nimport { useCarousel } from \"./Carousel\";\n\nconst ChevronRight = ({ class: className }: { class?: string }) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class={cn(\"size-4\", className)}\n aria-hidden\n >\n <path d=\"m9 18 6-6-6-6\" />\n </svg>\n);\n\nconst ChevronDown = ({ class: className }: { class?: string }) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class={cn(\"size-4\", className)}\n aria-hidden\n >\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n);\n\nexport type CarouselNextProps = Omit<JSX.ButtonHTMLAttributes<HTMLButtonElement>, \"size\"> & {\n children?: ComponentChildren;\n};\n\nexport const CarouselNext = ({ children, class: className, onClick, disabled, ...rest }: CarouselNextProps) => {\n const ctx = useCarousel(false);\n const vertical = ctx?.orientation === \"vertical\";\n const canNext = ctx?.canScrollNext.value ?? false;\n\n return (\n <Button\n {...rest}\n type=\"button\"\n variant=\"outline\"\n size=\"icon\"\n data-slot=\"carousel-next\"\n aria-label=\"Next slide\"\n disabled={disabled ?? !canNext}\n class={cn(\n \"absolute z-10 size-8 rounded-full shadow-xs\",\n vertical\n ? \"-bottom-12 left-1/2 -translate-x-1/2\"\n : \"-end-12 top-1/2 -translate-y-1/2 rtl:-rotate-180\",\n className\n )}\n onClick={(event) => {\n ctx?.scrollNext();\n onClick?.(event);\n }}\n >\n {children ?? (\n <>\n <span class=\"sr-only\">Next slide</span>\n {vertical ? <ChevronDown /> : <ChevronRight />}\n </>\n )}\n </Button>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { Button } from \"../button/Button\";\nimport { useCarousel } from \"./Carousel\";\n\nconst ChevronLeft = ({ class: className }: { class?: string }) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class={cn(\"size-4\", className)}\n aria-hidden\n >\n <path d=\"m15 18-6-6 6-6\" />\n </svg>\n);\n\nconst ChevronUp = ({ class: className }: { class?: string }) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class={cn(\"size-4\", className)}\n aria-hidden\n >\n <path d=\"m18 15-6-6-6 6\" />\n </svg>\n);\n\nexport type CarouselPreviousProps = Omit<JSX.ButtonHTMLAttributes<HTMLButtonElement>, \"size\"> & {\n children?: ComponentChildren;\n};\n\nexport const CarouselPrevious = ({ children, class: className, onClick, disabled, ...rest }: CarouselPreviousProps) => {\n const ctx = useCarousel(false);\n const vertical = ctx?.orientation === \"vertical\";\n const canPrev = ctx?.canScrollPrev.value ?? false;\n\n return (\n <Button\n {...rest}\n type=\"button\"\n variant=\"outline\"\n size=\"icon\"\n data-slot=\"carousel-previous\"\n aria-label=\"Previous slide\"\n disabled={disabled ?? !canPrev}\n class={cn(\n \"absolute z-10 size-8 rounded-full shadow-xs\",\n vertical\n ? \"-top-12 left-1/2 -translate-x-1/2\"\n : \"-start-12 top-1/2 -translate-y-1/2 rtl:-rotate-180\",\n className\n )}\n onClick={(event) => {\n ctx?.scrollPrev();\n onClick?.(event);\n }}\n >\n {children ?? (\n <>\n <span class=\"sr-only\">Previous slide</span>\n {vertical ? <ChevronUp /> : <ChevronLeft />}\n </>\n )}\n </Button>\n );\n};\n","export {\n Carousel,\n type CarouselApi,\n type CarouselOrientation,\n type CarouselProps\n} from \"./Carousel\";\nexport { CarouselContent, type CarouselContentProps } from \"./CarouselContent\";\nexport { CarouselItem, type CarouselItemProps } from \"./CarouselItem\";\nexport { CarouselNext, type CarouselNextProps } from \"./CarouselNext\";\nexport { CarouselPrevious, type CarouselPreviousProps } from \"./CarouselPrevious\";\n\nimport { Carousel } from \"./Carousel\";\nimport { CarouselContent } from \"./CarouselContent\";\nimport { CarouselItem } from \"./CarouselItem\";\nimport { CarouselNext } from \"./CarouselNext\";\nimport { CarouselPrevious } from \"./CarouselPrevious\";\n\nexport default {\n Root: Carousel,\n Content: CarouselContent,\n Item: CarouselItem,\n Previous: CarouselPrevious,\n Next: CarouselNext\n};\n"]}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
import { Separator } from './chunk-3WAPI4KR.js';
|
|
2
|
+
import { label } from './chunk-Y4OW24IS.js';
|
|
3
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
4
|
+
import { tv } from 'tailwind-variants';
|
|
5
|
+
import { jsxs, jsx } from 'preact/jsx-runtime';
|
|
6
|
+
import { useMemo } from 'preact/hooks';
|
|
7
|
+
|
|
8
|
+
var fieldRoot = tv({
|
|
9
|
+
base: [
|
|
10
|
+
"group/field flex w-full gap-3",
|
|
11
|
+
"data-[invalid]:text-destructive"
|
|
12
|
+
],
|
|
13
|
+
variants: {
|
|
14
|
+
orientation: {
|
|
15
|
+
vertical: "flex-col *:w-full [.sr-only]:w-auto",
|
|
16
|
+
horizontal: [
|
|
17
|
+
"flex-row flex-wrap items-center",
|
|
18
|
+
"[&>[data-slot=field-label]]:flex-1",
|
|
19
|
+
"has-[>[data-slot=field-content]]:items-start",
|
|
20
|
+
"has-[>[data-slot=field-content]]:[&>[data-slot=checkbox],[role=checkbox],[role=radio]]:mt-px"
|
|
21
|
+
],
|
|
22
|
+
responsive: [
|
|
23
|
+
"flex-col *:w-full [.sr-only]:w-auto",
|
|
24
|
+
"@md/field-group:flex-row @md/field-group:flex-wrap @md/field-group:items-center",
|
|
25
|
+
"@md/field-group:[&>*]:w-auto @md/field-group:[&>[data-slot=field-label]]:flex-1",
|
|
26
|
+
"@md/field-group:has-[>[data-slot=field-content]]:items-start",
|
|
27
|
+
"@md/field-group:has-[>[data-slot=field-content]]:[&>[data-slot=checkbox],[role=checkbox],[role=radio]]:mt-px"
|
|
28
|
+
]
|
|
29
|
+
}
|
|
30
|
+
},
|
|
31
|
+
defaultVariants: {
|
|
32
|
+
orientation: "vertical"
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
var Field = ({
|
|
36
|
+
class: className,
|
|
37
|
+
label: label2,
|
|
38
|
+
description,
|
|
39
|
+
error,
|
|
40
|
+
required = false,
|
|
41
|
+
orientation = "vertical",
|
|
42
|
+
disabled = false,
|
|
43
|
+
invalid = false,
|
|
44
|
+
children,
|
|
45
|
+
...rest
|
|
46
|
+
}) => {
|
|
47
|
+
const legacy = label2 != null || description != null || error != null;
|
|
48
|
+
const resolvedRequired = required && label2 != null;
|
|
49
|
+
if (legacy) {
|
|
50
|
+
const isHorizontal = orientation === "horizontal";
|
|
51
|
+
return /* @__PURE__ */ jsxs(
|
|
52
|
+
"div",
|
|
53
|
+
{
|
|
54
|
+
...rest,
|
|
55
|
+
"data-slot": "field",
|
|
56
|
+
"data-orientation": orientation,
|
|
57
|
+
"data-disabled": disabled ? "" : void 0,
|
|
58
|
+
class: cn(
|
|
59
|
+
"group/field",
|
|
60
|
+
!isHorizontal && "grid gap-2",
|
|
61
|
+
isHorizontal && label2 != null && "flex flex-col gap-2",
|
|
62
|
+
isHorizontal && label2 == null && fieldRoot({ orientation: "horizontal" }),
|
|
63
|
+
disabled ? "opacity-80" : null,
|
|
64
|
+
className
|
|
65
|
+
),
|
|
66
|
+
...invalid ? { "data-invalid": "" } : {},
|
|
67
|
+
children: [
|
|
68
|
+
label2 != null ? /* @__PURE__ */ jsxs("label", { "data-slot": "field-label", class: "text-sm leading-none font-medium", children: [
|
|
69
|
+
label2,
|
|
70
|
+
resolvedRequired ? /* @__PURE__ */ jsx("span", { "aria-hidden": "true", class: "ms-1 text-destructive", children: "*" }) : null
|
|
71
|
+
] }) : null,
|
|
72
|
+
isHorizontal && label2 != null ? /* @__PURE__ */ jsx("div", { class: "flex min-w-0 flex-row flex-wrap items-center gap-3", children }) : children,
|
|
73
|
+
description != null ? /* @__PURE__ */ jsx("p", { "data-slot": "field-description", class: "text-muted-foreground text-sm leading-normal", children: description }) : null,
|
|
74
|
+
error != null ? /* @__PURE__ */ jsx("p", { "data-slot": "field-error", role: "alert", class: "text-destructive text-sm", children: error }) : null
|
|
75
|
+
]
|
|
76
|
+
}
|
|
77
|
+
);
|
|
78
|
+
}
|
|
79
|
+
const orient = orientation === "responsive" ? "responsive" : orientation;
|
|
80
|
+
return /* @__PURE__ */ jsx(
|
|
81
|
+
"div",
|
|
82
|
+
{
|
|
83
|
+
...rest,
|
|
84
|
+
"data-slot": "field",
|
|
85
|
+
"data-orientation": orientation,
|
|
86
|
+
"data-disabled": disabled ? "" : void 0,
|
|
87
|
+
class: cn(fieldRoot({ orientation: orient }), disabled ? "opacity-80" : null, className),
|
|
88
|
+
...invalid ? { "data-invalid": "" } : {},
|
|
89
|
+
children
|
|
90
|
+
}
|
|
91
|
+
);
|
|
92
|
+
};
|
|
93
|
+
var FieldContent = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("div", { class: cn("flex flex-1 flex-col gap-1", className), "data-slot": "field-content", ...rest, children });
|
|
94
|
+
var FieldDescription = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("p", { class: cn("text-muted-foreground text-sm leading-normal font-normal", className), "data-slot": "field-description", ...rest, children });
|
|
95
|
+
var FieldError = ({ class: className, children, errors, ...rest }) => {
|
|
96
|
+
const content = useMemo(() => {
|
|
97
|
+
if (children) return children;
|
|
98
|
+
if (!errors?.length) return null;
|
|
99
|
+
const uniqueErrors = [...new Map(errors.map((error) => [error?.message, error])).values()].filter(Boolean);
|
|
100
|
+
if (uniqueErrors.length === 0) return null;
|
|
101
|
+
if (uniqueErrors.length === 1) {
|
|
102
|
+
return uniqueErrors[0]?.message ?? null;
|
|
103
|
+
}
|
|
104
|
+
return /* @__PURE__ */ jsx("ul", { class: "ml-4 list-disc space-y-0.5", children: uniqueErrors.map(
|
|
105
|
+
(error, index) => error?.message ? /* @__PURE__ */ jsx("li", { children: error.message }, `${error.message}-${index}`) : null
|
|
106
|
+
) });
|
|
107
|
+
}, [children, errors]);
|
|
108
|
+
if (content == null) return null;
|
|
109
|
+
return /* @__PURE__ */ jsx(
|
|
110
|
+
"div",
|
|
111
|
+
{
|
|
112
|
+
role: "alert",
|
|
113
|
+
class: cn("text-destructive text-sm font-normal", className),
|
|
114
|
+
"data-slot": "field-error",
|
|
115
|
+
...rest,
|
|
116
|
+
children: content
|
|
117
|
+
}
|
|
118
|
+
);
|
|
119
|
+
};
|
|
120
|
+
var FieldGroup = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("div", { class: cn("flex flex-col gap-6 @container/field-group", className), "data-slot": "field-group", ...rest, children });
|
|
121
|
+
var FieldLabel = ({ class: className, ...rest }) => /* @__PURE__ */ jsx(
|
|
122
|
+
"label",
|
|
123
|
+
{
|
|
124
|
+
class: cn(
|
|
125
|
+
label({ size: "sm" }),
|
|
126
|
+
"group-data-[disabled]/field:pointer-events-none group-data-[disabled]/field:opacity-50",
|
|
127
|
+
className
|
|
128
|
+
),
|
|
129
|
+
"data-slot": "field-label",
|
|
130
|
+
...rest
|
|
131
|
+
}
|
|
132
|
+
);
|
|
133
|
+
var fieldLegend = tv({
|
|
134
|
+
base: "",
|
|
135
|
+
variants: {
|
|
136
|
+
variant: {
|
|
137
|
+
legend: "text-base font-semibold",
|
|
138
|
+
label: "text-sm font-medium"
|
|
139
|
+
}
|
|
140
|
+
},
|
|
141
|
+
defaultVariants: { variant: "legend" }
|
|
142
|
+
});
|
|
143
|
+
var FieldLegend = ({ class: className, variant, ...rest }) => /* @__PURE__ */ jsx("legend", { class: cn(fieldLegend({ variant }), className), "data-slot": "field-legend", ...rest });
|
|
144
|
+
var FieldSeparator = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsxs("div", { class: cn("flex items-center gap-3 py-2", className), "data-slot": "field-separator", ...rest, children: [
|
|
145
|
+
/* @__PURE__ */ jsx(Separator, { class: "min-w-0 flex-1 shrink", orientation: "horizontal" }),
|
|
146
|
+
children ? /* @__PURE__ */ jsx("span", { class: "text-muted-foreground shrink-0 text-xs font-medium whitespace-nowrap", children }) : null
|
|
147
|
+
] });
|
|
148
|
+
var FieldSet = ({ class: className, ...rest }) => /* @__PURE__ */ jsx("fieldset", { class: cn("m-0 min-w-0 space-y-6 border-0 p-0", className), "data-slot": "field-set", ...rest });
|
|
149
|
+
var FieldTitle = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx("div", { class: cn("text-sm leading-none font-medium", className), "data-slot": "field-title", ...rest, children });
|
|
150
|
+
|
|
151
|
+
// src/components/field/index.ts
|
|
152
|
+
var field_default = Field;
|
|
153
|
+
|
|
154
|
+
export { Field, FieldContent, FieldDescription, FieldError, FieldGroup, FieldLabel, FieldLegend, FieldSeparator, FieldSet, FieldTitle, fieldRoot, field_default };
|
|
155
|
+
//# sourceMappingURL=chunk-SZ2I2SRP.js.map
|
|
156
|
+
//# sourceMappingURL=chunk-SZ2I2SRP.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/field/field-variants.ts","../src/components/field/Field.tsx","../src/components/field/FieldContent.tsx","../src/components/field/FieldDescription.tsx","../src/components/field/FieldError.tsx","../src/components/field/FieldGroup.tsx","../src/components/field/FieldLabel.tsx","../src/components/field/FieldLegend.tsx","../src/components/field/FieldSeparator.tsx","../src/components/field/FieldSet.tsx","../src/components/field/FieldTitle.tsx","../src/components/field/index.ts"],"names":["label","jsx","tv","jsxs"],"mappings":"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","file":"chunk-SZ2I2SRP.js","sourcesContent":["import { tv, type VariantProps } from \"tailwind-variants\";\n\n/** Root layout for composable Field (shadcn fieldVariants). */\nexport const fieldRoot = tv({\n base: [\n \"group/field flex w-full gap-3\",\n \"data-[invalid]:text-destructive\"\n ],\n variants: {\n orientation: {\n vertical: \"flex-col *:w-full [.sr-only]:w-auto\",\n horizontal: [\n \"flex-row flex-wrap items-center\",\n \"[&>[data-slot=field-label]]:flex-1\",\n \"has-[>[data-slot=field-content]]:items-start\",\n \"has-[>[data-slot=field-content]]:[&>[data-slot=checkbox],[role=checkbox],[role=radio]]:mt-px\"\n ],\n responsive: [\n \"flex-col *:w-full [.sr-only]:w-auto\",\n \"@md/field-group:flex-row @md/field-group:flex-wrap @md/field-group:items-center\",\n \"@md/field-group:[&>*]:w-auto @md/field-group:[&>[data-slot=field-label]]:flex-1\",\n \"@md/field-group:has-[>[data-slot=field-content]]:items-start\",\n \"@md/field-group:has-[>[data-slot=field-content]]:[&>[data-slot=checkbox],[role=checkbox],[role=radio]]:mt-px\"\n ]\n }\n },\n defaultVariants: {\n orientation: \"vertical\"\n }\n});\n\nexport type FieldRootVariants = VariantProps<typeof fieldRoot>;\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { fieldRoot, type FieldRootVariants } from \"./field-variants\";\n\nexport type FieldProps = JSX.HTMLAttributes<HTMLDivElement> &\n FieldRootVariants & {\n /** Legacy: label text/node (composition: use FieldLabel instead). */\n label?: ComponentChildren;\n /** Legacy: helper below control. */\n description?: ComponentChildren;\n /** Legacy: error below control. */\n error?: ComponentChildren;\n required?: boolean;\n orientation?: \"vertical\" | \"horizontal\" | \"responsive\";\n disabled?: boolean;\n invalid?: boolean;\n children?: ComponentChildren;\n };\n\nexport const Field = ({\n class: className,\n label,\n description,\n error,\n required = false,\n orientation = \"vertical\",\n disabled = false,\n invalid = false,\n children,\n ...rest\n}: FieldProps) => {\n const legacy = label != null || description != null || error != null;\n const resolvedRequired = required && label != null;\n\n if (legacy) {\n const isHorizontal = orientation === \"horizontal\";\n\n return (\n <div\n {...rest}\n data-slot=\"field\"\n data-orientation={orientation}\n data-disabled={disabled ? \"\" : undefined}\n class={cn(\n \"group/field\",\n !isHorizontal && \"grid gap-2\",\n isHorizontal && label != null && \"flex flex-col gap-2\",\n isHorizontal && label == null && fieldRoot({ orientation: \"horizontal\" }),\n disabled ? \"opacity-80\" : null,\n className\n )}\n {...(invalid ? { \"data-invalid\": \"\" } : {})}\n >\n {label != null ? (\n <label data-slot=\"field-label\" class=\"text-sm leading-none font-medium\">\n {label}\n {resolvedRequired ? <span aria-hidden=\"true\" class=\"ms-1 text-destructive\">*</span> : null}\n </label>\n ) : null}\n {isHorizontal && label != null ? (\n <div class=\"flex min-w-0 flex-row flex-wrap items-center gap-3\">{children}</div>\n ) : (\n children\n )}\n {description != null ? (\n <p data-slot=\"field-description\" class=\"text-muted-foreground text-sm leading-normal\">\n {description}\n </p>\n ) : null}\n {error != null ? (\n <p data-slot=\"field-error\" role=\"alert\" class=\"text-destructive text-sm\">\n {error}\n </p>\n ) : null}\n </div>\n );\n }\n\n const orient = orientation === \"responsive\" ? \"responsive\" : orientation;\n\n return (\n <div\n {...rest}\n data-slot=\"field\"\n data-orientation={orientation}\n data-disabled={disabled ? \"\" : undefined}\n class={cn(fieldRoot({ orientation: orient }), disabled ? \"opacity-80\" : null, className)}\n {...(invalid ? { \"data-invalid\": \"\" } : {})}\n >\n {children}\n </div>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type FieldContentProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const FieldContent = ({ class: className, children, ...rest }: FieldContentProps) => (\n <div class={cn(\"flex flex-1 flex-col gap-1\", className)} data-slot=\"field-content\" {...rest}>\n {children}\n </div>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type FieldDescriptionProps = JSX.HTMLAttributes<HTMLParagraphElement> & {\n children?: ComponentChildren;\n};\n\nexport const FieldDescription = ({ class: className, children, ...rest }: FieldDescriptionProps) => (\n <p class={cn(\"text-muted-foreground text-sm leading-normal font-normal\", className)} data-slot=\"field-description\" {...rest}>\n {children}\n </p>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { useMemo } from \"preact/hooks\";\nimport { cn } from \"../../lib/utils\";\n\nexport type FieldErrorProps = JSX.HTMLAttributes<HTMLDivElement> & {\n errors?: Array<{ message?: string } | undefined>;\n children?: ComponentChildren;\n};\n\nexport const FieldError = ({ class: className, children, errors, ...rest }: FieldErrorProps) => {\n const content = useMemo(() => {\n if (children) return children;\n if (!errors?.length) return null;\n\n const uniqueErrors = [...new Map(errors.map((error) => [error?.message, error])).values()].filter(Boolean);\n\n if (uniqueErrors.length === 0) return null;\n if (uniqueErrors.length === 1) {\n return uniqueErrors[0]?.message ?? null;\n }\n\n return (\n <ul class=\"ml-4 list-disc space-y-0.5\">\n {uniqueErrors.map((error, index) =>\n error?.message ? (\n <li key={`${error.message}-${index}`}>{error.message}</li>\n ) : null\n )}\n </ul>\n );\n }, [children, errors]);\n\n if (content == null) return null;\n\n return (\n <div\n role=\"alert\"\n class={cn(\"text-destructive text-sm font-normal\", className)}\n data-slot=\"field-error\"\n {...rest}\n >\n {content}\n </div>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type FieldGroupProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const FieldGroup = ({ class: className, children, ...rest }: FieldGroupProps) => (\n <div class={cn(\"flex flex-col gap-6 @container/field-group\", className)} data-slot=\"field-group\" {...rest}>\n {children}\n </div>\n);\n","import type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { label as labelStyles } from \"../label/Label\";\n\nexport type FieldLabelProps = JSX.LabelHTMLAttributes<HTMLLabelElement>;\n\nexport const FieldLabel = ({ class: className, ...rest }: FieldLabelProps) => (\n <label\n class={cn(\n labelStyles({ size: \"sm\" }),\n \"group-data-[disabled]/field:pointer-events-none group-data-[disabled]/field:opacity-50\",\n className\n )}\n data-slot=\"field-label\"\n {...rest}\n />\n);\n","import type { JSX } from \"preact\";\nimport { tv, type VariantProps } from \"tailwind-variants\";\nimport { cn } from \"../../lib/utils\";\n\nexport const fieldLegend = tv({\n base: \"\",\n variants: {\n variant: {\n legend: \"text-base font-semibold\",\n label: \"text-sm font-medium\"\n }\n },\n defaultVariants: { variant: \"legend\" }\n});\n\nexport type FieldLegendProps = JSX.HTMLAttributes<HTMLLegendElement> & VariantProps<typeof fieldLegend>;\n\nexport const FieldLegend = ({ class: className, variant, ...rest }: FieldLegendProps) => (\n <legend class={cn(fieldLegend({ variant }), className)} data-slot=\"field-legend\" {...rest} />\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { Separator } from \"../separator/Separator\";\n\nexport type FieldSeparatorProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const FieldSeparator = ({ class: className, children, ...rest }: FieldSeparatorProps) => (\n <div class={cn(\"flex items-center gap-3 py-2\", className)} data-slot=\"field-separator\" {...rest}>\n <Separator class=\"min-w-0 flex-1 shrink\" orientation=\"horizontal\" />\n {children ? (\n <span class=\"text-muted-foreground shrink-0 text-xs font-medium whitespace-nowrap\">{children}</span>\n ) : null}\n </div>\n);\n","import type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type FieldSetProps = JSX.FieldsetHTMLAttributes<HTMLFieldSetElement>;\n\nexport const FieldSet = ({ class: className, ...rest }: FieldSetProps) => (\n <fieldset class={cn(\"m-0 min-w-0 space-y-6 border-0 p-0\", className)} data-slot=\"field-set\" {...rest} />\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type FieldTitleProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const FieldTitle = ({ class: className, children, ...rest }: FieldTitleProps) => (\n <div class={cn(\"text-sm leading-none font-medium\", className)} data-slot=\"field-title\" {...rest}>\n {children}\n </div>\n);\n","import { Field } from \"./Field\";\n\nexport { Field };\nexport { fieldRoot } from \"./field-variants\";\nexport type { FieldRootVariants } from \"./field-variants\";\nexport { FieldContent } from \"./FieldContent\";\nexport { FieldDescription } from \"./FieldDescription\";\nexport { FieldError } from \"./FieldError\";\nexport { FieldGroup } from \"./FieldGroup\";\nexport { FieldLabel } from \"./FieldLabel\";\nexport { FieldLegend } from \"./FieldLegend\";\nexport { FieldSeparator } from \"./FieldSeparator\";\nexport { FieldSet } from \"./FieldSet\";\nexport { FieldTitle } from \"./FieldTitle\";\n\nexport default Field;\n"]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
2
|
+
import { jsx } from 'preact/jsx-runtime';
|
|
3
|
+
|
|
4
|
+
var AspectRatio = ({ ratio, class: className, style, children, ...rest }) => {
|
|
5
|
+
const styleObject = typeof style === "object" && style !== null && !Array.isArray(style) ? style : void 0;
|
|
6
|
+
return /* @__PURE__ */ jsx(
|
|
7
|
+
"div",
|
|
8
|
+
{
|
|
9
|
+
"data-slot": "aspect-ratio",
|
|
10
|
+
class: cn("relative w-full min-h-0 overflow-hidden", className),
|
|
11
|
+
style: {
|
|
12
|
+
...styleObject,
|
|
13
|
+
aspectRatio: ratio
|
|
14
|
+
},
|
|
15
|
+
...rest,
|
|
16
|
+
children
|
|
17
|
+
}
|
|
18
|
+
);
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
export { AspectRatio };
|
|
22
|
+
//# sourceMappingURL=chunk-UGOQKTHL.js.map
|
|
23
|
+
//# sourceMappingURL=chunk-UGOQKTHL.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/aspect-ratio/AspectRatio.tsx"],"names":[],"mappings":";;;AAUO,IAAM,WAAA,GAAc,CAAC,EAAE,KAAA,EAAO,KAAA,EAAO,WAAW,KAAA,EAAO,QAAA,EAAU,GAAG,IAAA,EAAK,KAAwB;AACtG,EAAA,MAAM,WAAA,GAAc,OAAO,KAAA,KAAU,QAAA,IAAY,KAAA,KAAU,IAAA,IAAQ,CAAC,KAAA,CAAM,OAAA,CAAQ,KAAK,CAAA,GAAI,KAAA,GAAQ,MAAA;AAEnG,EAAA,uBACE,GAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,WAAA,EAAU,cAAA;AAAA,MACV,KAAA,EAAO,EAAA,CAAG,yCAAA,EAA2C,SAAS,CAAA;AAAA,MAC9D,KAAA,EAAO;AAAA,QACL,GAAG,WAAA;AAAA,QACH,WAAA,EAAa;AAAA,OACf;AAAA,MACC,GAAG,IAAA;AAAA,MAEH;AAAA;AAAA,GACH;AAEJ","file":"chunk-UGOQKTHL.js","sourcesContent":["import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type AspectRatioProps = JSX.HTMLAttributes<HTMLDivElement> & {\n /** Width ÷ height (e.g. `16 / 9`, `1`, `9 / 16`). Applied as CSS `aspect-ratio`. */\n ratio: number;\n children?: ComponentChildren;\n};\n\n/** Fixed-ratio box for media (CSS `aspect-ratio`; no Radix dependency). Children should use `h-full w-full object-cover` to fill. */\nexport const AspectRatio = ({ ratio, class: className, style, children, ...rest }: AspectRatioProps) => {\n const styleObject = typeof style === \"object\" && style !== null && !Array.isArray(style) ? style : undefined;\n\n return (\n <div\n data-slot=\"aspect-ratio\"\n class={cn(\"relative w-full min-h-0 overflow-hidden\", className)}\n style={{\n ...styleObject,\n aspectRatio: ratio\n }}\n {...rest}\n >\n {children}\n </div>\n );\n};\n\n"]}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
2
|
+
import { isValidElement, cloneElement } from 'preact';
|
|
3
|
+
import { tv } from 'tailwind-variants';
|
|
4
|
+
import { jsx } from 'preact/jsx-runtime';
|
|
5
|
+
|
|
6
|
+
var button = tv({
|
|
7
|
+
base: [
|
|
8
|
+
"group/button inline-flex shrink-0 cursor-pointer items-center justify-center rounded-lg bg-clip-padding text-sm font-medium whitespace-nowrap",
|
|
9
|
+
"select-none transition-all outline-none focus-visible:border-ring focus-visible:ring-3 focus-visible:ring-ring/50",
|
|
10
|
+
"active:translate-y-px disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50",
|
|
11
|
+
"aria-invalid:border-destructive aria-invalid:ring-3 aria-invalid:ring-destructive/20",
|
|
12
|
+
"dark:aria-invalid:border-destructive/50 dark:aria-invalid:ring-destructive/40",
|
|
13
|
+
"[&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
|
|
14
|
+
"has-data-[icon=inline-end]:pr-2 has-data-[icon=inline-start]:pl-2"
|
|
15
|
+
],
|
|
16
|
+
variants: {
|
|
17
|
+
variant: {
|
|
18
|
+
default: "bg-primary text-background hover:bg-foreground/90 focus-visible:ring-outline/50",
|
|
19
|
+
secondary: "bg-secondary text-secondary-foreground hover:bg-secondary/90 focus-visible:ring-secondary/50",
|
|
20
|
+
inverse: "bg-foreground text-background hover:opacity-[0.85] focus-visible:ring-outline/50",
|
|
21
|
+
outline: "border-border bg-background hover:bg-muted hover:text-foreground aria-expanded:bg-muted aria-expanded:text-foreground dark:border-input dark:bg-input/30 dark:hover:bg-input/50 border",
|
|
22
|
+
ghost: "hover:bg-muted hover:text-foreground focus-visible:ring-outline/50",
|
|
23
|
+
destructive: "bg-destructive text-destructive-foreground hover:bg-destructive/90 focus-visible:ring-outline/50",
|
|
24
|
+
link: "h-auto p-0 text-primary underline-offset-4 hover:underline active:translate-y-0 focus-visible:ring-0"
|
|
25
|
+
},
|
|
26
|
+
size: {
|
|
27
|
+
xxs: "h-5 gap-1 px-1.5 text-[10px]",
|
|
28
|
+
xs: "h-6 gap-1 px-2 text-xs",
|
|
29
|
+
sm: "h-7 gap-1.5 px-3",
|
|
30
|
+
default: "h-8 gap-1.5 px-2.5",
|
|
31
|
+
lg: "h-9 gap-2 px-5 text-base has-[>svg]:px-4 [&_svg:not([class*='size-'])]:size-4.5",
|
|
32
|
+
icon: "size-8",
|
|
33
|
+
"icon-xs": "size-6 [&_svg:not([class*='size-'])]:size-3.5",
|
|
34
|
+
"icon-sm": "size-7 [&_svg:not([class*='size-'])]:size-4",
|
|
35
|
+
"icon-lg": "size-9 [&_svg:not([class*='size-'])]:size-5"
|
|
36
|
+
}
|
|
37
|
+
},
|
|
38
|
+
defaultVariants: { variant: "default", size: "default" }
|
|
39
|
+
});
|
|
40
|
+
var Button = ({ variant, size, asChild = false, class: className, children, ...rest }) => {
|
|
41
|
+
const resolvedVariant = variant ?? "default";
|
|
42
|
+
const resolvedSize = size ?? "default";
|
|
43
|
+
const resolvedClassName = button({ variant: resolvedVariant, size: resolvedSize, class: className });
|
|
44
|
+
if (asChild) {
|
|
45
|
+
if (!isValidElement(children)) {
|
|
46
|
+
const env = globalThis.process?.env?.NODE_ENV;
|
|
47
|
+
if (env !== "production") {
|
|
48
|
+
console.warn(
|
|
49
|
+
"[kamod-ui] <Button asChild> expects a single valid element child. Received: " + typeof children + ". Falling back to rendering nothing."
|
|
50
|
+
);
|
|
51
|
+
}
|
|
52
|
+
return null;
|
|
53
|
+
}
|
|
54
|
+
const childProps = children.props ?? {};
|
|
55
|
+
return cloneElement(children, {
|
|
56
|
+
...childProps ?? {},
|
|
57
|
+
...rest,
|
|
58
|
+
class: cn(childProps.class, childProps.className, resolvedClassName),
|
|
59
|
+
"data-slot": "button",
|
|
60
|
+
"data-variant": resolvedVariant,
|
|
61
|
+
"data-size": resolvedSize
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
if ("href" in rest && typeof rest.href === "string") {
|
|
65
|
+
return /* @__PURE__ */ jsx(
|
|
66
|
+
"a",
|
|
67
|
+
{
|
|
68
|
+
class: resolvedClassName,
|
|
69
|
+
"data-slot": "button",
|
|
70
|
+
"data-variant": resolvedVariant,
|
|
71
|
+
"data-size": resolvedSize,
|
|
72
|
+
...rest,
|
|
73
|
+
children
|
|
74
|
+
}
|
|
75
|
+
);
|
|
76
|
+
}
|
|
77
|
+
return /* @__PURE__ */ jsx(
|
|
78
|
+
"button",
|
|
79
|
+
{
|
|
80
|
+
class: resolvedClassName,
|
|
81
|
+
"data-slot": "button",
|
|
82
|
+
"data-variant": resolvedVariant,
|
|
83
|
+
"data-size": resolvedSize,
|
|
84
|
+
...rest,
|
|
85
|
+
children
|
|
86
|
+
}
|
|
87
|
+
);
|
|
88
|
+
};
|
|
89
|
+
|
|
90
|
+
export { Button, button };
|
|
91
|
+
//# sourceMappingURL=chunk-UGQ756Z6.js.map
|
|
92
|
+
//# sourceMappingURL=chunk-UGQ756Z6.js.map
|