@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,122 @@
|
|
|
1
|
+
import { button } from './chunk-UGQ756Z6.js';
|
|
2
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
3
|
+
import { jsx, jsxs, Fragment } from 'preact/jsx-runtime';
|
|
4
|
+
|
|
5
|
+
var Pagination = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx(
|
|
6
|
+
"nav",
|
|
7
|
+
{
|
|
8
|
+
"aria-label": "pagination",
|
|
9
|
+
"data-slot": "pagination",
|
|
10
|
+
class: cn("mx-auto flex w-full justify-center", className),
|
|
11
|
+
...rest,
|
|
12
|
+
children
|
|
13
|
+
}
|
|
14
|
+
);
|
|
15
|
+
var PaginationContent = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx(
|
|
16
|
+
"ul",
|
|
17
|
+
{
|
|
18
|
+
"data-slot": "pagination-content",
|
|
19
|
+
class: cn("flex flex-row items-center gap-1 list-none", className),
|
|
20
|
+
...rest,
|
|
21
|
+
children
|
|
22
|
+
}
|
|
23
|
+
);
|
|
24
|
+
var PaginationItem = ({ children, ...rest }) => /* @__PURE__ */ jsx("li", { "data-slot": "pagination-item", ...rest, children });
|
|
25
|
+
var PaginationLink = ({
|
|
26
|
+
isActive = false,
|
|
27
|
+
size = "default",
|
|
28
|
+
class: className,
|
|
29
|
+
"data-slot": dataSlot = "pagination-link",
|
|
30
|
+
children,
|
|
31
|
+
...rest
|
|
32
|
+
}) => {
|
|
33
|
+
const r = rest;
|
|
34
|
+
const restStyleClass = r.class ?? r.className;
|
|
35
|
+
const { class: _c, className: _cn, ...anchorRest } = r;
|
|
36
|
+
return /* @__PURE__ */ jsx(
|
|
37
|
+
"a",
|
|
38
|
+
{
|
|
39
|
+
...anchorRest,
|
|
40
|
+
"data-slot": dataSlot,
|
|
41
|
+
"aria-current": isActive ? "page" : void 0,
|
|
42
|
+
class: cn(
|
|
43
|
+
button({ variant: isActive ? "outline" : "ghost", size }),
|
|
44
|
+
"h-9 min-w-9 justify-center px-2.5 [&_svg]:size-4 [&_svg]:shrink-0",
|
|
45
|
+
className,
|
|
46
|
+
restStyleClass
|
|
47
|
+
),
|
|
48
|
+
children
|
|
49
|
+
}
|
|
50
|
+
);
|
|
51
|
+
};
|
|
52
|
+
var svgBase = {
|
|
53
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
54
|
+
fill: "none",
|
|
55
|
+
stroke: "currentColor",
|
|
56
|
+
"stroke-width": 2,
|
|
57
|
+
"stroke-linecap": "round",
|
|
58
|
+
"stroke-linejoin": "round",
|
|
59
|
+
"aria-hidden": true
|
|
60
|
+
};
|
|
61
|
+
var PaginationChevronLeft = ({ class: className, ...props }) => /* @__PURE__ */ jsx("svg", { ...svgBase, viewBox: "0 0 24 24", class: cn("size-4", className), ...props, children: /* @__PURE__ */ jsx("path", { d: "m15 18-6-6 6-6" }) });
|
|
62
|
+
var PaginationChevronRight = ({ class: className, ...props }) => /* @__PURE__ */ jsx("svg", { ...svgBase, viewBox: "0 0 24 24", class: cn("size-4", className), ...props, children: /* @__PURE__ */ jsx("path", { d: "m9 18 6-6-6-6" }) });
|
|
63
|
+
var PaginationMoreHorizontal = ({ class: className, ...props }) => /* @__PURE__ */ jsxs("svg", { ...svgBase, viewBox: "0 0 24 24", class: cn("size-4", className), ...props, children: [
|
|
64
|
+
/* @__PURE__ */ jsx("circle", { cx: "12", cy: "12", r: "1" }),
|
|
65
|
+
/* @__PURE__ */ jsx("circle", { cx: "19", cy: "12", r: "1" }),
|
|
66
|
+
/* @__PURE__ */ jsx("circle", { cx: "5", cy: "12", r: "1" })
|
|
67
|
+
] });
|
|
68
|
+
var PaginationNext = ({
|
|
69
|
+
children,
|
|
70
|
+
text = "Next",
|
|
71
|
+
class: className,
|
|
72
|
+
...rest
|
|
73
|
+
}) => /* @__PURE__ */ jsx(
|
|
74
|
+
PaginationLink,
|
|
75
|
+
{
|
|
76
|
+
"data-slot": "pagination-next",
|
|
77
|
+
"aria-label": "Go to next page",
|
|
78
|
+
size: "default",
|
|
79
|
+
class: cn("gap-1 pr-2.5 sm:pl-2.5", className),
|
|
80
|
+
...rest,
|
|
81
|
+
children: children !== void 0 && children !== null ? children : /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
82
|
+
/* @__PURE__ */ jsx("span", { class: "hidden sm:inline", children: text }),
|
|
83
|
+
/* @__PURE__ */ jsx(PaginationChevronRight, {})
|
|
84
|
+
] })
|
|
85
|
+
}
|
|
86
|
+
);
|
|
87
|
+
var PaginationPrevious = ({
|
|
88
|
+
children,
|
|
89
|
+
text = "Previous",
|
|
90
|
+
class: className,
|
|
91
|
+
...rest
|
|
92
|
+
}) => /* @__PURE__ */ jsx(
|
|
93
|
+
PaginationLink,
|
|
94
|
+
{
|
|
95
|
+
"data-slot": "pagination-previous",
|
|
96
|
+
"aria-label": "Go to previous page",
|
|
97
|
+
size: "default",
|
|
98
|
+
class: cn("gap-1 pl-2.5 sm:pr-2.5", className),
|
|
99
|
+
...rest,
|
|
100
|
+
children: children !== void 0 && children !== null ? children : /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
101
|
+
/* @__PURE__ */ jsx(PaginationChevronLeft, {}),
|
|
102
|
+
/* @__PURE__ */ jsx("span", { class: "hidden sm:inline", children: text })
|
|
103
|
+
] })
|
|
104
|
+
}
|
|
105
|
+
);
|
|
106
|
+
var PaginationEllipsis = ({ class: className, ...rest }) => /* @__PURE__ */ jsxs(
|
|
107
|
+
"span",
|
|
108
|
+
{
|
|
109
|
+
"data-slot": "pagination-ellipsis",
|
|
110
|
+
"aria-hidden": true,
|
|
111
|
+
class: cn("text-muted-foreground flex size-9 items-center justify-center", className),
|
|
112
|
+
...rest,
|
|
113
|
+
children: [
|
|
114
|
+
/* @__PURE__ */ jsx(PaginationMoreHorizontal, {}),
|
|
115
|
+
/* @__PURE__ */ jsx("span", { class: "sr-only", children: "More pages" })
|
|
116
|
+
]
|
|
117
|
+
}
|
|
118
|
+
);
|
|
119
|
+
|
|
120
|
+
export { Pagination, PaginationContent, PaginationEllipsis, PaginationItem, PaginationLink, PaginationNext, PaginationPrevious };
|
|
121
|
+
//# sourceMappingURL=chunk-AVCG4W6D.js.map
|
|
122
|
+
//# sourceMappingURL=chunk-AVCG4W6D.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/pagination/Pagination.tsx","../src/components/pagination/PaginationContent.tsx","../src/components/pagination/PaginationItem.tsx","../src/components/pagination/PaginationLink.tsx","../src/components/pagination/pagination-icons.tsx","../src/components/pagination/PaginationNext.tsx","../src/components/pagination/PaginationPrevious.tsx","../src/components/pagination/PaginationEllipsis.tsx"],"names":["jsx","jsxs","Fragment"],"mappings":"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","file":"chunk-AVCG4W6D.js","sourcesContent":["import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type PaginationProps = JSX.HTMLAttributes<HTMLElement> & {\n children?: ComponentChildren;\n};\n\nexport const Pagination = ({ class: className, children, ...rest }: PaginationProps) => (\n <nav\n aria-label=\"pagination\"\n data-slot=\"pagination\"\n class={cn(\"mx-auto flex w-full justify-center\", className)}\n {...rest}\n >\n {children}\n </nav>\n);\n\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type PaginationContentProps = JSX.HTMLAttributes<HTMLUListElement> & {\n children?: ComponentChildren;\n};\n\nexport const PaginationContent = ({ class: className, children, ...rest }: PaginationContentProps) => (\n <ul\n data-slot=\"pagination-content\"\n class={cn(\"flex flex-row items-center gap-1 list-none\", className)}\n {...rest}\n >\n {children}\n </ul>\n);\n\n","import type { ComponentChildren, JSX } from \"preact\";\n\nexport type PaginationItemProps = JSX.HTMLAttributes<HTMLLIElement> & {\n children?: ComponentChildren;\n};\n\nexport const PaginationItem = ({ children, ...rest }: PaginationItemProps) => (\n <li data-slot=\"pagination-item\" {...rest}>\n {children}\n </li>\n);\n\n","import type { ComponentChildren, JSX } from \"preact\";\nimport type { VariantProps } from \"tailwind-variants\";\nimport { button } from \"../button/Button\";\nimport { cn } from \"../../lib/utils\";\n\nexport type PaginationLinkProps = Omit<JSX.AnchorHTMLAttributes<HTMLAnchorElement>, \"size\"> & {\n isActive?: boolean;\n size?: VariantProps<typeof button>[\"size\"];\n children?: ComponentChildren;\n \"data-slot\"?: string;\n};\n\nexport const PaginationLink = ({\n isActive = false,\n size = \"default\",\n class: className,\n \"data-slot\": dataSlot = \"pagination-link\",\n children,\n ...rest\n}: PaginationLinkProps) => {\n const r = rest as Record<string, unknown>;\n const restStyleClass = (r.class ?? r.className) as string | undefined;\n const { class: _c, className: _cn, ...anchorRest } = r;\n\n return (\n <a\n {...(anchorRest as JSX.AnchorHTMLAttributes<HTMLAnchorElement>)}\n data-slot={dataSlot}\n aria-current={isActive ? \"page\" : undefined}\n class={cn(\n button({ variant: isActive ? \"outline\" : \"ghost\", size }),\n \"h-9 min-w-9 justify-center px-2.5 [&_svg]:size-4 [&_svg]:shrink-0\",\n className,\n restStyleClass\n )}\n >\n {children}\n </a>\n );\n};\n","import type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nconst svgBase: JSX.SVGAttributes<SVGSVGElement> = {\n xmlns: \"http://www.w3.org/2000/svg\",\n fill: \"none\",\n stroke: \"currentColor\",\n \"stroke-width\": 2,\n \"stroke-linecap\": \"round\",\n \"stroke-linejoin\": \"round\",\n \"aria-hidden\": true\n};\n\nexport const PaginationChevronLeft = ({ class: className, ...props }: JSX.SVGAttributes<SVGSVGElement>) => (\n <svg {...svgBase} viewBox=\"0 0 24 24\" class={cn(\"size-4\", className)} {...props}>\n <path d=\"m15 18-6-6 6-6\" />\n </svg>\n);\n\nexport const PaginationChevronRight = ({ class: className, ...props }: JSX.SVGAttributes<SVGSVGElement>) => (\n <svg {...svgBase} viewBox=\"0 0 24 24\" class={cn(\"size-4\", className)} {...props}>\n <path d=\"m9 18 6-6-6-6\" />\n </svg>\n);\n\nexport const PaginationMoreHorizontal = ({ class: className, ...props }: JSX.SVGAttributes<SVGSVGElement>) => (\n <svg {...svgBase} viewBox=\"0 0 24 24\" class={cn(\"size-4\", className)} {...props}>\n <circle cx=\"12\" cy=\"12\" r=\"1\" />\n <circle cx=\"19\" cy=\"12\" r=\"1\" />\n <circle cx=\"5\" cy=\"12\" r=\"1\" />\n </svg>\n);\n","import type { ComponentChildren } from \"preact\";\nimport { PaginationChevronRight } from \"./pagination-icons\";\nimport { PaginationLink, type PaginationLinkProps } from \"./PaginationLink\";\nimport { cn } from \"../../lib/utils\";\n\nexport type PaginationNextProps = Omit<PaginationLinkProps, \"children\"> & {\n children?: ComponentChildren;\n text?: string;\n};\n\nexport const PaginationNext = ({\n children,\n text = \"Next\",\n class: className,\n ...rest\n}: PaginationNextProps) => (\n <PaginationLink\n data-slot=\"pagination-next\"\n aria-label=\"Go to next page\"\n size=\"default\"\n class={cn(\"gap-1 pr-2.5 sm:pl-2.5\", className)}\n {...rest}\n >\n {children !== undefined && children !== null ? (\n children\n ) : (\n <>\n <span class=\"hidden sm:inline\">{text}</span>\n <PaginationChevronRight />\n </>\n )}\n </PaginationLink>\n);\n","import type { ComponentChildren } from \"preact\";\nimport { PaginationChevronLeft } from \"./pagination-icons\";\nimport { PaginationLink, type PaginationLinkProps } from \"./PaginationLink\";\nimport { cn } from \"../../lib/utils\";\n\nexport type PaginationPreviousProps = Omit<PaginationLinkProps, \"children\"> & {\n children?: ComponentChildren;\n text?: string;\n};\n\nexport const PaginationPrevious = ({\n children,\n text = \"Previous\",\n class: className,\n ...rest\n}: PaginationPreviousProps) => (\n <PaginationLink\n data-slot=\"pagination-previous\"\n aria-label=\"Go to previous page\"\n size=\"default\"\n class={cn(\"gap-1 pl-2.5 sm:pr-2.5\", className)}\n {...rest}\n >\n {children !== undefined && children !== null ? (\n children\n ) : (\n <>\n <PaginationChevronLeft />\n <span class=\"hidden sm:inline\">{text}</span>\n </>\n )}\n </PaginationLink>\n);\n","import type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { PaginationMoreHorizontal } from \"./pagination-icons\";\n\nexport type PaginationEllipsisProps = JSX.HTMLAttributes<HTMLSpanElement>;\n\nexport const PaginationEllipsis = ({ class: className, ...rest }: PaginationEllipsisProps) => (\n <span\n data-slot=\"pagination-ellipsis\"\n aria-hidden\n class={cn(\"text-muted-foreground flex size-9 items-center justify-center\", className)}\n {...rest}\n >\n <PaginationMoreHorizontal />\n <span class=\"sr-only\">More pages</span>\n </span>\n);\n\n"]}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { tv } from 'tailwind-variants';
|
|
2
|
+
import { jsx } from 'preact/jsx-runtime';
|
|
3
|
+
|
|
4
|
+
// src/components/card/Card.tsx
|
|
5
|
+
var card = tv({
|
|
6
|
+
base: [
|
|
7
|
+
"bg-card text-card-foreground group/card ring-border flex min-w-0 flex-col rounded-xl ring-1",
|
|
8
|
+
"has-data-[slot=card-footer]:pb-0 has-[>img:first-child]:pt-0",
|
|
9
|
+
"*:[img:first-child]:rounded-t-xl *:[img:last-child]:rounded-b-xl"
|
|
10
|
+
],
|
|
11
|
+
variants: {
|
|
12
|
+
size: {
|
|
13
|
+
default: "gap-6 py-6",
|
|
14
|
+
sm: "gap-4 py-4 text-sm"
|
|
15
|
+
}
|
|
16
|
+
},
|
|
17
|
+
defaultVariants: {
|
|
18
|
+
size: "default"
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
var Card = ({ class: className, size, children, ...rest }) => /* @__PURE__ */ jsx(
|
|
22
|
+
"div",
|
|
23
|
+
{
|
|
24
|
+
class: card({ size, class: className }),
|
|
25
|
+
"data-slot": "card",
|
|
26
|
+
"data-size": size ?? "default",
|
|
27
|
+
...rest,
|
|
28
|
+
children
|
|
29
|
+
}
|
|
30
|
+
);
|
|
31
|
+
var cardAction = tv({
|
|
32
|
+
base: "col-start-2 row-span-2 row-start-1 shrink-0 self-start justify-self-end"
|
|
33
|
+
});
|
|
34
|
+
var CardAction = ({ class: className, ...rest }) => /* @__PURE__ */ jsx("div", { class: cardAction({ class: className }), "data-slot": "card-action", ...rest });
|
|
35
|
+
var cardContent = tv({
|
|
36
|
+
base: "px-6 group-data-[size=sm]/card:px-4"
|
|
37
|
+
});
|
|
38
|
+
var CardContent = ({ class: className, ...rest }) => /* @__PURE__ */ jsx("div", { class: cardContent({ class: className }), "data-slot": "card-content", ...rest });
|
|
39
|
+
var cardDescription = tv({
|
|
40
|
+
base: "min-w-0 break-words text-muted-foreground text-sm group-data-[size=sm]/card:text-xs"
|
|
41
|
+
});
|
|
42
|
+
var CardDescription = ({ class: className, ...rest }) => /* @__PURE__ */ jsx(
|
|
43
|
+
"div",
|
|
44
|
+
{
|
|
45
|
+
class: cardDescription({ class: className }),
|
|
46
|
+
"data-slot": "card-description",
|
|
47
|
+
...rest
|
|
48
|
+
}
|
|
49
|
+
);
|
|
50
|
+
var cardFooter = tv({
|
|
51
|
+
base: "bg-muted/50 flex items-center rounded-b-xl border-t p-6 group-data-[size=sm]/card:p-4"
|
|
52
|
+
});
|
|
53
|
+
var CardFooter = ({ class: className, ...rest }) => /* @__PURE__ */ jsx("div", { class: cardFooter({ class: className }), "data-slot": "card-footer", ...rest });
|
|
54
|
+
var cardHeader = tv({
|
|
55
|
+
base: [
|
|
56
|
+
"@container/card-header grid w-full min-w-0 auto-rows-min items-start gap-1.5 px-6 group-data-[size=sm]/card:px-4",
|
|
57
|
+
// minmax(0,1fr) + min-w-0 on title/description keeps CardAction in the second column inside the card (flex preview children)
|
|
58
|
+
"has-data-[slot=card-action]:grid-cols-[minmax(0,1fr)_auto] has-data-[slot=card-description]:grid-rows-[auto_auto]"
|
|
59
|
+
]
|
|
60
|
+
});
|
|
61
|
+
var CardHeader = ({ class: className, ...rest }) => /* @__PURE__ */ jsx("div", { class: cardHeader({ class: className }), "data-slot": "card-header", ...rest });
|
|
62
|
+
var cardTitle = tv({
|
|
63
|
+
base: "font-heading min-w-0 break-words text-xl leading-snug font-semibold group-data-[size=sm]/card:text-base"
|
|
64
|
+
});
|
|
65
|
+
var CardTitle = ({ class: className, ...rest }) => /* @__PURE__ */ jsx("div", { class: cardTitle({ class: className }), "data-slot": "card-title", ...rest });
|
|
66
|
+
|
|
67
|
+
// src/components/card/index.ts
|
|
68
|
+
var CardVariants = {
|
|
69
|
+
card,
|
|
70
|
+
cardAction,
|
|
71
|
+
cardContent,
|
|
72
|
+
cardDescription,
|
|
73
|
+
cardFooter,
|
|
74
|
+
cardHeader,
|
|
75
|
+
cardTitle
|
|
76
|
+
};
|
|
77
|
+
var card_default = {
|
|
78
|
+
Root: Card,
|
|
79
|
+
Header: CardHeader,
|
|
80
|
+
Footer: CardFooter,
|
|
81
|
+
Title: CardTitle,
|
|
82
|
+
Description: CardDescription,
|
|
83
|
+
Content: CardContent,
|
|
84
|
+
Action: CardAction
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
export { Card, CardAction, CardContent, CardDescription, CardFooter, CardHeader, CardTitle, CardVariants, card_default };
|
|
88
|
+
//# sourceMappingURL=chunk-BF3F5SJX.js.map
|
|
89
|
+
//# sourceMappingURL=chunk-BF3F5SJX.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/card/Card.tsx","../src/components/card/CardAction.tsx","../src/components/card/CardContent.tsx","../src/components/card/CardDescription.tsx","../src/components/card/CardFooter.tsx","../src/components/card/CardHeader.tsx","../src/components/card/CardTitle.tsx","../src/components/card/index.ts"],"names":["tv","jsx"],"mappings":"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","file":"chunk-BF3F5SJX.js","sourcesContent":["import type { ComponentChildren, JSX } from \"preact\";\nimport { tv, type VariantProps } from \"tailwind-variants\";\n\nexport const card = tv({\n base: [\n \"bg-card text-card-foreground group/card ring-border flex min-w-0 flex-col rounded-xl ring-1\",\n \"has-data-[slot=card-footer]:pb-0 has-[>img:first-child]:pt-0\",\n \"*:[img:first-child]:rounded-t-xl *:[img:last-child]:rounded-b-xl\"\n ],\n variants: {\n size: {\n default: \"gap-6 py-6\",\n sm: \"gap-4 py-4 text-sm\"\n }\n },\n defaultVariants: {\n size: \"default\"\n }\n});\n\nexport type CardProps = JSX.HTMLAttributes<HTMLDivElement> &\n VariantProps<typeof card> & {\n children?: ComponentChildren;\n };\n\nexport const Card = ({ class: className, size, children, ...rest }: CardProps) => (\n <div\n class={card({ size, class: className as string | undefined })}\n data-slot=\"card\"\n data-size={size ?? \"default\"}\n {...rest}\n >\n {children}\n </div>\n);\n\n","import type { JSX } from \"preact\";\nimport { tv } from \"tailwind-variants\";\n\nexport const cardAction = tv({\n base: \"col-start-2 row-span-2 row-start-1 shrink-0 self-start justify-self-end\"\n});\n\nexport type CardActionProps = JSX.HTMLAttributes<HTMLDivElement>;\n\nexport const CardAction = ({ class: className, ...rest }: CardActionProps) => (\n <div class={cardAction({ class: className as string | undefined })} data-slot=\"card-action\" {...rest} />\n);\n\n","import type { JSX } from \"preact\";\nimport { tv } from \"tailwind-variants\";\n\nexport const cardContent = tv({\n base: \"px-6 group-data-[size=sm]/card:px-4\"\n});\n\nexport type CardContentProps = JSX.HTMLAttributes<HTMLDivElement>;\n\nexport const CardContent = ({ class: className, ...rest }: CardContentProps) => (\n <div class={cardContent({ class: className as string | undefined })} data-slot=\"card-content\" {...rest} />\n);\n\n","import type { JSX } from \"preact\";\nimport { tv } from \"tailwind-variants\";\n\nexport const cardDescription = tv({\n base: \"min-w-0 break-words text-muted-foreground text-sm group-data-[size=sm]/card:text-xs\"\n});\n\nexport type CardDescriptionProps = JSX.HTMLAttributes<HTMLDivElement>;\n\nexport const CardDescription = ({ class: className, ...rest }: CardDescriptionProps) => (\n <div\n class={cardDescription({ class: className as string | undefined })}\n data-slot=\"card-description\"\n {...rest}\n />\n);\n\n","import type { JSX } from \"preact\";\nimport { tv } from \"tailwind-variants\";\n\nexport const cardFooter = tv({\n base: \"bg-muted/50 flex items-center rounded-b-xl border-t p-6 group-data-[size=sm]/card:p-4\"\n});\n\nexport type CardFooterProps = JSX.HTMLAttributes<HTMLDivElement>;\n\nexport const CardFooter = ({ class: className, ...rest }: CardFooterProps) => (\n <div class={cardFooter({ class: className as string | undefined })} data-slot=\"card-footer\" {...rest} />\n);\n\n","import type { JSX } from \"preact\";\nimport { tv } from \"tailwind-variants\";\n\nexport const cardHeader = tv({\n base: [\n \"@container/card-header grid w-full min-w-0 auto-rows-min items-start gap-1.5 px-6 group-data-[size=sm]/card:px-4\",\n // minmax(0,1fr) + min-w-0 on title/description keeps CardAction in the second column inside the card (flex preview children)\n \"has-data-[slot=card-action]:grid-cols-[minmax(0,1fr)_auto] has-data-[slot=card-description]:grid-rows-[auto_auto]\"\n ]\n});\n\nexport type CardHeaderProps = JSX.HTMLAttributes<HTMLDivElement>;\n\nexport const CardHeader = ({ class: className, ...rest }: CardHeaderProps) => (\n <div class={cardHeader({ class: className as string | undefined })} data-slot=\"card-header\" {...rest} />\n);\n\n","import type { JSX } from \"preact\";\nimport { tv } from \"tailwind-variants\";\n\nexport const cardTitle = tv({\n base:\n \"font-heading min-w-0 break-words text-xl leading-snug font-semibold group-data-[size=sm]/card:text-base\"\n});\n\nexport type CardTitleProps = JSX.HTMLAttributes<HTMLDivElement>;\n\nexport const CardTitle = ({ class: className, ...rest }: CardTitleProps) => (\n <div class={cardTitle({ class: className as string | undefined })} data-slot=\"card-title\" {...rest} />\n);\n\n","import { Card, card } from \"./Card\";\nimport { CardAction, cardAction } from \"./CardAction\";\nimport { CardContent, cardContent } from \"./CardContent\";\nimport { CardDescription, cardDescription } from \"./CardDescription\";\nimport { CardFooter, cardFooter } from \"./CardFooter\";\nimport { CardHeader, cardHeader } from \"./CardHeader\";\nimport { CardTitle, cardTitle } from \"./CardTitle\";\n\nconst CardVariants = {\n card,\n cardAction,\n cardContent,\n cardDescription,\n cardFooter,\n cardHeader,\n cardTitle\n};\n\nexport {\n Card,\n CardAction,\n CardContent,\n CardDescription,\n CardFooter,\n CardHeader,\n CardTitle,\n CardVariants\n};\n\nexport default {\n Root: Card,\n Header: CardHeader,\n Footer: CardFooter,\n Title: CardTitle,\n Description: CardDescription,\n Content: CardContent,\n Action: CardAction\n};\n"]}
|
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
2
|
+
import { useSignal } from '@preact/signals';
|
|
3
|
+
import { createContext } from 'preact';
|
|
4
|
+
import { useEffect, useContext } from 'preact/hooks';
|
|
5
|
+
import { jsx } from 'preact/jsx-runtime';
|
|
6
|
+
import { tv } from 'tailwind-variants';
|
|
7
|
+
|
|
8
|
+
var TabsContext = createContext(null);
|
|
9
|
+
var useTabs = () => {
|
|
10
|
+
const context = useContext(TabsContext);
|
|
11
|
+
if (!context) throw new Error("Tabs subcomponents must be used within Tabs");
|
|
12
|
+
return context;
|
|
13
|
+
};
|
|
14
|
+
var syncRegistry = /* @__PURE__ */ new Map();
|
|
15
|
+
var getOrCreateSyncEntry = (key, initialValue) => {
|
|
16
|
+
const existing = syncRegistry.get(key);
|
|
17
|
+
if (existing) return existing;
|
|
18
|
+
const created = {
|
|
19
|
+
value: initialValue,
|
|
20
|
+
subscribers: /* @__PURE__ */ new Set(),
|
|
21
|
+
instancesCount: 0
|
|
22
|
+
};
|
|
23
|
+
syncRegistry.set(key, created);
|
|
24
|
+
return created;
|
|
25
|
+
};
|
|
26
|
+
var Tabs = ({ defaultValue, syncKey, orientation = "horizontal", class: className, children, ...rest }) => {
|
|
27
|
+
const value = useSignal(defaultValue);
|
|
28
|
+
const setValue = (next) => {
|
|
29
|
+
if (!syncKey) {
|
|
30
|
+
value.value = next;
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
const syncEntry = getOrCreateSyncEntry(syncKey, value.value);
|
|
34
|
+
if (syncEntry.value === next) return;
|
|
35
|
+
syncEntry.value = next;
|
|
36
|
+
value.value = next;
|
|
37
|
+
syncEntry.subscribers.forEach((subscriber) => subscriber(next));
|
|
38
|
+
};
|
|
39
|
+
useEffect(() => {
|
|
40
|
+
if (!syncKey) return;
|
|
41
|
+
const syncEntry = getOrCreateSyncEntry(syncKey, defaultValue);
|
|
42
|
+
syncEntry.instancesCount += 1;
|
|
43
|
+
value.value = syncEntry.value;
|
|
44
|
+
const subscriber = (nextValue) => {
|
|
45
|
+
if (value.value === nextValue) return;
|
|
46
|
+
value.value = nextValue;
|
|
47
|
+
};
|
|
48
|
+
syncEntry.subscribers.add(subscriber);
|
|
49
|
+
return () => {
|
|
50
|
+
syncEntry.subscribers.delete(subscriber);
|
|
51
|
+
syncEntry.instancesCount -= 1;
|
|
52
|
+
if (syncEntry.instancesCount <= 0) {
|
|
53
|
+
syncRegistry.delete(syncKey);
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
}, [defaultValue, syncKey, value]);
|
|
57
|
+
return /* @__PURE__ */ jsx(TabsContext.Provider, { value: { value, setValue, orientation }, children: /* @__PURE__ */ jsx("div", { class: cn("group/tabs", className), "data-slot": "tabs", "data-orientation": orientation, ...rest, children }) });
|
|
58
|
+
};
|
|
59
|
+
var TabsContent = ({
|
|
60
|
+
value,
|
|
61
|
+
forceMount = false,
|
|
62
|
+
class: className,
|
|
63
|
+
children,
|
|
64
|
+
...rest
|
|
65
|
+
}) => {
|
|
66
|
+
const tabs = useTabs();
|
|
67
|
+
const active = tabs.value.value === value;
|
|
68
|
+
if (!active && !forceMount) return null;
|
|
69
|
+
return /* @__PURE__ */ jsx(
|
|
70
|
+
"div",
|
|
71
|
+
{
|
|
72
|
+
role: "tabpanel",
|
|
73
|
+
"data-slot": "tabs-content",
|
|
74
|
+
"data-state": active ? "active" : "inactive",
|
|
75
|
+
class: cn("mt-2 outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2", className),
|
|
76
|
+
tabIndex: 0,
|
|
77
|
+
...rest,
|
|
78
|
+
children
|
|
79
|
+
}
|
|
80
|
+
);
|
|
81
|
+
};
|
|
82
|
+
var tabsList = tv({
|
|
83
|
+
base: [
|
|
84
|
+
"group/tabs-list inline-flex w-fit items-stretch justify-center gap-0.5 rounded-md bg-muted/80 p-0.5 text-muted-foreground",
|
|
85
|
+
"ring-1 ring-inset ring-black/[0.04] dark:ring-white/[0.06]",
|
|
86
|
+
"group-data-[orientation=horizontal]/tabs:h-9 group-data-[orientation=horizontal]/tabs:rounded-full",
|
|
87
|
+
"group-data-[orientation=vertical]/tabs:h-fit group-data-[orientation=vertical]/tabs:flex-col group-data-[orientation=vertical]/tabs:rounded-xl group-data-[orientation=vertical]/tabs:gap-0.5 group-data-[orientation=vertical]/tabs:p-1"
|
|
88
|
+
],
|
|
89
|
+
variants: {
|
|
90
|
+
variant: {
|
|
91
|
+
default: "",
|
|
92
|
+
line: "rounded-none gap-1 bg-transparent p-0"
|
|
93
|
+
}
|
|
94
|
+
},
|
|
95
|
+
defaultVariants: {
|
|
96
|
+
variant: "default"
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
var TabsList = ({ variant, class: className, children, ...rest }) => {
|
|
100
|
+
const tabs = useTabs();
|
|
101
|
+
return /* @__PURE__ */ jsx(
|
|
102
|
+
"div",
|
|
103
|
+
{
|
|
104
|
+
role: "tablist",
|
|
105
|
+
"aria-orientation": tabs.orientation,
|
|
106
|
+
class: cn(tabsList({ variant }), className),
|
|
107
|
+
"data-slot": "tabs-list",
|
|
108
|
+
"data-variant": variant ?? "default",
|
|
109
|
+
"data-orientation": tabs.orientation,
|
|
110
|
+
...rest,
|
|
111
|
+
children
|
|
112
|
+
}
|
|
113
|
+
);
|
|
114
|
+
};
|
|
115
|
+
var TabsTrigger = ({ value, class: className, children, onClick, onKeyDown, ...rest }) => {
|
|
116
|
+
const tabs = useTabs();
|
|
117
|
+
const active = tabs.value.value === value;
|
|
118
|
+
return /* @__PURE__ */ jsx(
|
|
119
|
+
"button",
|
|
120
|
+
{
|
|
121
|
+
type: "button",
|
|
122
|
+
role: "tab",
|
|
123
|
+
class: cn(
|
|
124
|
+
"relative inline-flex h-full min-h-0 flex-1 items-center justify-center gap-1.5 border border-transparent px-3 py-1 text-sm whitespace-nowrap text-muted-foreground transition-[color,box-shadow,background-color,font-weight] duration-200 ease-out",
|
|
125
|
+
"group-data-[orientation=horizontal]/tabs:rounded-full group-data-[orientation=vertical]/tabs:rounded-md",
|
|
126
|
+
"group-data-[orientation=vertical]/tabs:w-full group-data-[orientation=vertical]/tabs:justify-start",
|
|
127
|
+
"hover:text-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 focus-visible:ring-offset-background",
|
|
128
|
+
"disabled:pointer-events-none disabled:opacity-50 dark:hover:text-foreground",
|
|
129
|
+
"group-data-[variant=default]/tabs-list:data-[state=inactive]:font-medium",
|
|
130
|
+
"group-data-[variant=default]/tabs-list:data-[state=active]:bg-background group-data-[variant=default]/tabs-list:data-[state=active]:font-semibold group-data-[variant=default]/tabs-list:data-[state=active]:text-foreground",
|
|
131
|
+
"group-data-[variant=default]/tabs-list:data-[state=active]:shadow-[0_1px_2px_-0.5px_rgb(0_0_0/0.06),0_1px_3px_-1px_rgb(0_0_0/0.08)]",
|
|
132
|
+
"dark:group-data-[variant=default]/tabs-list:data-[state=active]:shadow-[0_1px_2px_-0.5px_rgb(0_0_0/0.35)] dark:group-data-[variant=default]/tabs-list:data-[state=active]:ring-1 dark:group-data-[variant=default]/tabs-list:data-[state=active]:ring-white/[0.08]",
|
|
133
|
+
"group-data-[variant=line]/tabs-list:rounded-none group-data-[variant=line]/tabs-list:px-0 group-data-[variant=line]/tabs-list:data-[state=active]:shadow-none dark:group-data-[variant=line]/tabs-list:data-[state=active]:ring-0",
|
|
134
|
+
"[&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
|
|
135
|
+
"group-data-[variant=line]/tabs-list:bg-transparent group-data-[variant=line]/tabs-list:data-[state=active]:bg-transparent group-data-[variant=line]/tabs-list:data-[state=active]:text-foreground",
|
|
136
|
+
"dark:group-data-[variant=line]/tabs-list:data-[state=active]:border-transparent dark:group-data-[variant=line]/tabs-list:data-[state=active]:bg-transparent",
|
|
137
|
+
"dark:group-data-[variant=default]/tabs-list:data-[state=active]:bg-input/30 dark:group-data-[variant=default]/tabs-list:data-[state=active]:text-foreground",
|
|
138
|
+
"after:absolute after:bg-foreground after:opacity-0 after:transition-opacity",
|
|
139
|
+
"group-data-[orientation=horizontal]/tabs:after:inset-x-0 group-data-[orientation=horizontal]/tabs:after:bottom-[-5px] group-data-[orientation=horizontal]/tabs:after:h-0.5",
|
|
140
|
+
"group-data-[orientation=vertical]/tabs:after:inset-y-0 group-data-[orientation=vertical]/tabs:after:-right-1 group-data-[orientation=vertical]/tabs:after:w-0.5",
|
|
141
|
+
"group-data-[variant=line]/tabs-list:data-[state=active]:after:opacity-100",
|
|
142
|
+
className
|
|
143
|
+
),
|
|
144
|
+
"data-slot": "tabs-trigger",
|
|
145
|
+
"data-state": active ? "active" : "inactive",
|
|
146
|
+
"data-active": active ? "true" : void 0,
|
|
147
|
+
"data-value": value,
|
|
148
|
+
"data-orientation": tabs.orientation,
|
|
149
|
+
"aria-selected": active,
|
|
150
|
+
tabIndex: active ? 0 : -1,
|
|
151
|
+
onClick: (event) => {
|
|
152
|
+
tabs.setValue(value);
|
|
153
|
+
onClick?.(event);
|
|
154
|
+
},
|
|
155
|
+
onKeyDown: (event) => {
|
|
156
|
+
onKeyDown?.(event);
|
|
157
|
+
if (event.defaultPrevented) return;
|
|
158
|
+
if (!["ArrowLeft", "ArrowRight", "ArrowUp", "ArrowDown", "Home", "End"].includes(event.key)) return;
|
|
159
|
+
const tabList = event.currentTarget.closest('[role="tablist"]');
|
|
160
|
+
if (!tabList) return;
|
|
161
|
+
const triggers = Array.from(tabList.querySelectorAll('[role="tab"]:not([disabled])'));
|
|
162
|
+
const currentIndex = triggers.indexOf(event.currentTarget);
|
|
163
|
+
if (currentIndex === -1 || triggers.length === 0) return;
|
|
164
|
+
const horizontal = tabs.orientation === "horizontal";
|
|
165
|
+
let nextIndex = currentIndex;
|
|
166
|
+
if (event.key === "Home") nextIndex = 0;
|
|
167
|
+
if (event.key === "End") nextIndex = triggers.length - 1;
|
|
168
|
+
if (event.key === "ArrowRight" && horizontal) nextIndex = (currentIndex + 1) % triggers.length;
|
|
169
|
+
if (event.key === "ArrowLeft" && horizontal) nextIndex = (currentIndex - 1 + triggers.length) % triggers.length;
|
|
170
|
+
if (event.key === "ArrowDown" && !horizontal) nextIndex = (currentIndex + 1) % triggers.length;
|
|
171
|
+
if (event.key === "ArrowUp" && !horizontal) nextIndex = (currentIndex - 1 + triggers.length) % triggers.length;
|
|
172
|
+
if (nextIndex === currentIndex) return;
|
|
173
|
+
event.preventDefault();
|
|
174
|
+
const next = triggers[nextIndex];
|
|
175
|
+
next.focus();
|
|
176
|
+
const nextValue = next.getAttribute("data-value");
|
|
177
|
+
if (nextValue) tabs.setValue(nextValue);
|
|
178
|
+
},
|
|
179
|
+
...rest,
|
|
180
|
+
children
|
|
181
|
+
}
|
|
182
|
+
);
|
|
183
|
+
};
|
|
184
|
+
|
|
185
|
+
// src/components/tabs/index.ts
|
|
186
|
+
var tabs_default = {
|
|
187
|
+
Root: Tabs,
|
|
188
|
+
List: TabsList,
|
|
189
|
+
Trigger: TabsTrigger,
|
|
190
|
+
Content: TabsContent
|
|
191
|
+
};
|
|
192
|
+
|
|
193
|
+
export { Tabs, TabsContent, TabsList, TabsTrigger, tabs_default };
|
|
194
|
+
//# sourceMappingURL=chunk-BHMKSFES.js.map
|
|
195
|
+
//# sourceMappingURL=chunk-BHMKSFES.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/tabs/Tabs.tsx","../src/components/tabs/TabsContent.tsx","../src/components/tabs/TabsList.tsx","../src/components/tabs/TabsTrigger.tsx","../src/components/tabs/index.ts"],"names":["jsx"],"mappings":"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","file":"chunk-BHMKSFES.js","sourcesContent":["import { type Signal, useSignal } from \"@preact/signals\";\nimport { createContext } from \"preact\";\nimport { useEffect } from \"preact/hooks\";\nimport { useContext } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\ntype TabsContextValue = {\n value: Signal<string>;\n setValue: (next: string) => void;\n orientation: \"horizontal\" | \"vertical\";\n};\n\nconst TabsContext = createContext<TabsContextValue | null>(null);\n\nexport const useTabs = () => {\n const context = useContext(TabsContext);\n if (!context) throw new Error(\"Tabs subcomponents must be used within Tabs\");\n return context;\n};\n\nexport type TabsProps = JSX.HTMLAttributes<HTMLDivElement> & {\n defaultValue: string;\n syncKey?: string;\n orientation?: \"horizontal\" | \"vertical\";\n children?: ComponentChildren;\n};\n\ntype SyncSubscriber = (nextValue: string) => void;\n\ntype SyncRegistryEntry = {\n value: string;\n subscribers: Set<SyncSubscriber>;\n instancesCount: number;\n};\n\nconst syncRegistry = new Map<string, SyncRegistryEntry>();\n\nconst getOrCreateSyncEntry = (key: string, initialValue: string): SyncRegistryEntry => {\n const existing = syncRegistry.get(key);\n if (existing) return existing;\n\n const created: SyncRegistryEntry = {\n value: initialValue,\n subscribers: new Set<SyncSubscriber>(),\n instancesCount: 0\n };\n syncRegistry.set(key, created);\n return created;\n};\n\nexport const Tabs = ({ defaultValue, syncKey, orientation = \"horizontal\", class: className, children, ...rest }: TabsProps) => {\n const value = useSignal(defaultValue);\n const setValue = (next: string) => {\n if (!syncKey) {\n value.value = next;\n return;\n }\n\n const syncEntry = getOrCreateSyncEntry(syncKey, value.value);\n if (syncEntry.value === next) return;\n\n syncEntry.value = next;\n value.value = next;\n syncEntry.subscribers.forEach((subscriber) => subscriber(next));\n };\n\n useEffect(() => {\n if (!syncKey) return;\n\n const syncEntry = getOrCreateSyncEntry(syncKey, defaultValue);\n syncEntry.instancesCount += 1;\n value.value = syncEntry.value;\n\n const subscriber: SyncSubscriber = (nextValue) => {\n if (value.value === nextValue) return;\n value.value = nextValue;\n };\n syncEntry.subscribers.add(subscriber);\n\n return () => {\n syncEntry.subscribers.delete(subscriber);\n syncEntry.instancesCount -= 1;\n if (syncEntry.instancesCount <= 0) {\n syncRegistry.delete(syncKey);\n }\n };\n }, [defaultValue, syncKey, value]);\n\n return (\n <TabsContext.Provider value={{ value, setValue, orientation }}>\n <div class={cn(\"group/tabs\", className)} data-slot=\"tabs\" data-orientation={orientation} {...rest}>\n {children}\n </div>\n </TabsContext.Provider>\n );\n};\n\n","import { cn } from \"../../lib/utils\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { useTabs } from \"./Tabs\";\n\nexport type TabsContentProps = JSX.HTMLAttributes<HTMLDivElement> & {\n value: string;\n forceMount?: boolean;\n children?: ComponentChildren;\n};\n\nexport const TabsContent = ({\n value,\n forceMount = false,\n class: className,\n children,\n ...rest\n}: TabsContentProps) => {\n const tabs = useTabs();\n const active = tabs.value.value === value;\n if (!active && !forceMount) return null;\n\n return (\n <div\n role=\"tabpanel\"\n data-slot=\"tabs-content\"\n data-state={active ? \"active\" : \"inactive\"}\n class={cn(\"mt-2 outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\", className)}\n tabIndex={0}\n {...rest}\n >\n {children}\n </div>\n );\n};\n\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { tv, type VariantProps } from \"tailwind-variants\";\nimport { cn } from \"../../lib/utils\";\nimport { useTabs } from \"./Tabs\";\n\nconst tabsList = tv({\n base: [\n \"group/tabs-list inline-flex w-fit items-stretch justify-center gap-0.5 rounded-md bg-muted/80 p-0.5 text-muted-foreground\",\n \"ring-1 ring-inset ring-black/[0.04] dark:ring-white/[0.06]\",\n \"group-data-[orientation=horizontal]/tabs:h-9 group-data-[orientation=horizontal]/tabs:rounded-full\",\n \"group-data-[orientation=vertical]/tabs:h-fit group-data-[orientation=vertical]/tabs:flex-col group-data-[orientation=vertical]/tabs:rounded-xl group-data-[orientation=vertical]/tabs:gap-0.5 group-data-[orientation=vertical]/tabs:p-1\"\n ],\n variants: {\n variant: {\n default: \"\",\n line: \"rounded-none gap-1 bg-transparent p-0\"\n }\n },\n defaultVariants: {\n variant: \"default\"\n }\n});\n\nexport type TabsListProps = JSX.HTMLAttributes<HTMLDivElement> &\n VariantProps<typeof tabsList> & {\n children?: ComponentChildren;\n};\n\nexport const TabsList = ({ variant, class: className, children, ...rest }: TabsListProps) => {\n const tabs = useTabs();\n\n return (\n <div\n role=\"tablist\"\n aria-orientation={tabs.orientation}\n class={cn(tabsList({ variant }), className)}\n data-slot=\"tabs-list\"\n data-variant={variant ?? \"default\"}\n data-orientation={tabs.orientation}\n {...rest}\n >\n {children}\n </div>\n );\n};\n\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useTabs } from \"./Tabs\";\n\nexport type TabsTriggerProps = JSX.ButtonHTMLAttributes<HTMLButtonElement> & {\n value: string;\n children?: ComponentChildren;\n};\n\nexport const TabsTrigger = ({ value, class: className, children, onClick, onKeyDown, ...rest }: TabsTriggerProps) => {\n const tabs = useTabs();\n const active = tabs.value.value === value;\n\n return (\n <button\n type=\"button\"\n role=\"tab\"\n class={cn(\n \"relative inline-flex h-full min-h-0 flex-1 items-center justify-center gap-1.5 border border-transparent px-3 py-1 text-sm whitespace-nowrap text-muted-foreground transition-[color,box-shadow,background-color,font-weight] duration-200 ease-out\",\n \"group-data-[orientation=horizontal]/tabs:rounded-full group-data-[orientation=vertical]/tabs:rounded-md\",\n \"group-data-[orientation=vertical]/tabs:w-full group-data-[orientation=vertical]/tabs:justify-start\",\n \"hover:text-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 focus-visible:ring-offset-background\",\n \"disabled:pointer-events-none disabled:opacity-50 dark:hover:text-foreground\",\n \"group-data-[variant=default]/tabs-list:data-[state=inactive]:font-medium\",\n \"group-data-[variant=default]/tabs-list:data-[state=active]:bg-background group-data-[variant=default]/tabs-list:data-[state=active]:font-semibold group-data-[variant=default]/tabs-list:data-[state=active]:text-foreground\",\n \"group-data-[variant=default]/tabs-list:data-[state=active]:shadow-[0_1px_2px_-0.5px_rgb(0_0_0/0.06),0_1px_3px_-1px_rgb(0_0_0/0.08)]\",\n \"dark:group-data-[variant=default]/tabs-list:data-[state=active]:shadow-[0_1px_2px_-0.5px_rgb(0_0_0/0.35)] dark:group-data-[variant=default]/tabs-list:data-[state=active]:ring-1 dark:group-data-[variant=default]/tabs-list:data-[state=active]:ring-white/[0.08]\",\n \"group-data-[variant=line]/tabs-list:rounded-none group-data-[variant=line]/tabs-list:px-0 group-data-[variant=line]/tabs-list:data-[state=active]:shadow-none dark:group-data-[variant=line]/tabs-list:data-[state=active]:ring-0\",\n \"[&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n \"group-data-[variant=line]/tabs-list:bg-transparent group-data-[variant=line]/tabs-list:data-[state=active]:bg-transparent group-data-[variant=line]/tabs-list:data-[state=active]:text-foreground\",\n \"dark:group-data-[variant=line]/tabs-list:data-[state=active]:border-transparent dark:group-data-[variant=line]/tabs-list:data-[state=active]:bg-transparent\",\n \"dark:group-data-[variant=default]/tabs-list:data-[state=active]:bg-input/30 dark:group-data-[variant=default]/tabs-list:data-[state=active]:text-foreground\",\n \"after:absolute after:bg-foreground after:opacity-0 after:transition-opacity\",\n \"group-data-[orientation=horizontal]/tabs:after:inset-x-0 group-data-[orientation=horizontal]/tabs:after:bottom-[-5px] group-data-[orientation=horizontal]/tabs:after:h-0.5\",\n \"group-data-[orientation=vertical]/tabs:after:inset-y-0 group-data-[orientation=vertical]/tabs:after:-right-1 group-data-[orientation=vertical]/tabs:after:w-0.5\",\n \"group-data-[variant=line]/tabs-list:data-[state=active]:after:opacity-100\",\n className\n )}\n data-slot=\"tabs-trigger\"\n data-state={active ? \"active\" : \"inactive\"}\n data-active={active ? \"true\" : undefined}\n data-value={value}\n data-orientation={tabs.orientation}\n aria-selected={active}\n tabIndex={active ? 0 : -1}\n onClick={(event) => {\n tabs.setValue(value);\n onClick?.(event);\n }}\n onKeyDown={(event) => {\n onKeyDown?.(event);\n if (event.defaultPrevented) return;\n if (![\"ArrowLeft\", \"ArrowRight\", \"ArrowUp\", \"ArrowDown\", \"Home\", \"End\"].includes(event.key)) return;\n\n const tabList = event.currentTarget.closest('[role=\"tablist\"]');\n if (!tabList) return;\n\n const triggers = Array.from(tabList.querySelectorAll<HTMLButtonElement>('[role=\"tab\"]:not([disabled])'));\n const currentIndex = triggers.indexOf(event.currentTarget);\n if (currentIndex === -1 || triggers.length === 0) return;\n\n const horizontal = tabs.orientation === \"horizontal\";\n let nextIndex = currentIndex;\n\n if (event.key === \"Home\") nextIndex = 0;\n if (event.key === \"End\") nextIndex = triggers.length - 1;\n if (event.key === \"ArrowRight\" && horizontal) nextIndex = (currentIndex + 1) % triggers.length;\n if (event.key === \"ArrowLeft\" && horizontal) nextIndex = (currentIndex - 1 + triggers.length) % triggers.length;\n if (event.key === \"ArrowDown\" && !horizontal) nextIndex = (currentIndex + 1) % triggers.length;\n if (event.key === \"ArrowUp\" && !horizontal) nextIndex = (currentIndex - 1 + triggers.length) % triggers.length;\n\n if (nextIndex === currentIndex) return;\n event.preventDefault();\n const next = triggers[nextIndex];\n next.focus();\n const nextValue = next.getAttribute(\"data-value\");\n if (nextValue) tabs.setValue(nextValue);\n }}\n {...rest}\n >\n {children}\n </button>\n );\n};\n\n","import { Tabs } from \"./Tabs\";\nimport { TabsContent } from \"./TabsContent\";\nimport { TabsList } from \"./TabsList\";\nimport { TabsTrigger } from \"./TabsTrigger\";\n\nexport { Tabs, TabsContent, TabsList, TabsTrigger };\n\nexport default {\n Root: Tabs,\n List: TabsList,\n Trigger: TabsTrigger,\n Content: TabsContent\n};\n"]}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
2
|
+
import { jsx, jsxs } from 'preact/jsx-runtime';
|
|
3
|
+
|
|
4
|
+
var sizeClass = {
|
|
5
|
+
xs: "size-3",
|
|
6
|
+
sm: "size-4",
|
|
7
|
+
md: "size-6",
|
|
8
|
+
lg: "size-8",
|
|
9
|
+
xl: "size-10"
|
|
10
|
+
};
|
|
11
|
+
var toneClass = {
|
|
12
|
+
default: "text-current",
|
|
13
|
+
muted: "text-muted-foreground",
|
|
14
|
+
primary: "text-primary"
|
|
15
|
+
};
|
|
16
|
+
var Spinner = ({ size = "sm", tone = "default", strokeWidth = 2.5, class: className, ...rest }) => /* @__PURE__ */ jsx(
|
|
17
|
+
"span",
|
|
18
|
+
{
|
|
19
|
+
role: "status",
|
|
20
|
+
"aria-label": "Loading",
|
|
21
|
+
"data-slot": "spinner",
|
|
22
|
+
class: cn("inline-grid shrink-0 place-items-center align-middle", sizeClass[size], toneClass[tone], className),
|
|
23
|
+
...rest,
|
|
24
|
+
children: /* @__PURE__ */ jsxs(
|
|
25
|
+
"svg",
|
|
26
|
+
{
|
|
27
|
+
viewBox: "0 0 24 24",
|
|
28
|
+
fill: "none",
|
|
29
|
+
stroke: "currentColor",
|
|
30
|
+
"stroke-width": strokeWidth,
|
|
31
|
+
"stroke-linecap": "round",
|
|
32
|
+
class: "size-full motion-safe:animate-spin motion-reduce:animate-none [animation-duration:0.7s]",
|
|
33
|
+
"aria-hidden": "true",
|
|
34
|
+
children: [
|
|
35
|
+
/* @__PURE__ */ jsx("circle", { cx: "12", cy: "12", r: "9", class: "opacity-20" }),
|
|
36
|
+
/* @__PURE__ */ jsx("path", { d: "M12 3a9 9 0 1 1-9 9", class: "opacity-90", "stroke-dasharray": "42 16" })
|
|
37
|
+
]
|
|
38
|
+
}
|
|
39
|
+
)
|
|
40
|
+
}
|
|
41
|
+
);
|
|
42
|
+
|
|
43
|
+
export { Spinner };
|
|
44
|
+
//# sourceMappingURL=chunk-BMF5SGYP.js.map
|
|
45
|
+
//# sourceMappingURL=chunk-BMF5SGYP.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/spinner/Spinner.tsx"],"names":[],"mappings":";;;AASA,IAAM,SAAA,GAA+D;AAAA,EACnE,EAAA,EAAI,QAAA;AAAA,EACJ,EAAA,EAAI,QAAA;AAAA,EACJ,EAAA,EAAI,QAAA;AAAA,EACJ,EAAA,EAAI,QAAA;AAAA,EACJ,EAAA,EAAI;AACN,CAAA;AAEA,IAAM,SAAA,GAA+D;AAAA,EACnE,OAAA,EAAS,cAAA;AAAA,EACT,KAAA,EAAO,uBAAA;AAAA,EACP,OAAA,EAAS;AACX,CAAA;AAEO,IAAM,OAAA,GAAU,CAAC,EAAE,IAAA,GAAO,IAAA,EAAM,IAAA,GAAO,SAAA,EAAW,WAAA,GAAc,GAAA,EAAK,KAAA,EAAO,SAAA,EAAW,GAAG,MAAK,qBACpG,GAAA;AAAA,EAAC,MAAA;AAAA,EAAA;AAAA,IACC,IAAA,EAAK,QAAA;AAAA,IACL,YAAA,EAAW,SAAA;AAAA,IACX,WAAA,EAAU,SAAA;AAAA,IACV,KAAA,EAAO,GAAG,sDAAA,EAAwD,SAAA,CAAU,IAAI,CAAA,EAAG,SAAA,CAAU,IAAI,CAAA,EAAG,SAAS,CAAA;AAAA,IAC5G,GAAG,IAAA;AAAA,IAEJ,QAAA,kBAAA,IAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,OAAA,EAAQ,WAAA;AAAA,QACR,IAAA,EAAK,MAAA;AAAA,QACL,MAAA,EAAO,cAAA;AAAA,QACP,cAAA,EAAc,WAAA;AAAA,QACd,gBAAA,EAAe,OAAA;AAAA,QACf,KAAA,EAAM,yFAAA;AAAA,QACN,aAAA,EAAY,MAAA;AAAA,QAEZ,QAAA,EAAA;AAAA,0BAAA,GAAA,CAAC,QAAA,EAAA,EAAO,IAAG,IAAA,EAAK,EAAA,EAAG,MAAK,CAAA,EAAE,GAAA,EAAI,OAAM,YAAA,EAAa,CAAA;AAAA,8BAChD,MAAA,EAAA,EAAK,CAAA,EAAE,uBAAsB,KAAA,EAAM,YAAA,EAAa,oBAAiB,OAAA,EAAQ;AAAA;AAAA;AAAA;AAC5E;AACF","file":"chunk-BMF5SGYP.js","sourcesContent":["import type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type SpinnerProps = JSX.HTMLAttributes<HTMLSpanElement> & {\n size?: \"xs\" | \"sm\" | \"md\" | \"lg\" | \"xl\";\n tone?: \"default\" | \"muted\" | \"primary\";\n strokeWidth?: number;\n};\n\nconst sizeClass: Record<NonNullable<SpinnerProps[\"size\"]>, string> = {\n xs: \"size-3\",\n sm: \"size-4\",\n md: \"size-6\",\n lg: \"size-8\",\n xl: \"size-10\"\n};\n\nconst toneClass: Record<NonNullable<SpinnerProps[\"tone\"]>, string> = {\n default: \"text-current\",\n muted: \"text-muted-foreground\",\n primary: \"text-primary\"\n};\n\nexport const Spinner = ({ size = \"sm\", tone = \"default\", strokeWidth = 2.5, class: className, ...rest }: SpinnerProps) => (\n <span\n role=\"status\"\n aria-label=\"Loading\"\n data-slot=\"spinner\"\n class={cn(\"inline-grid shrink-0 place-items-center align-middle\", sizeClass[size], toneClass[tone], className)}\n {...rest}\n >\n <svg\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width={strokeWidth}\n stroke-linecap=\"round\"\n class=\"size-full motion-safe:animate-spin motion-reduce:animate-none [animation-duration:0.7s]\"\n aria-hidden=\"true\"\n >\n <circle cx=\"12\" cy=\"12\" r=\"9\" class=\"opacity-20\" />\n <path d=\"M12 3a9 9 0 1 1-9 9\" class=\"opacity-90\" stroke-dasharray=\"42 16\" />\n </svg>\n </span>\n);\n\n"]}
|