@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 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/calendar/Calendar.tsx"],"names":[],"mappings":"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","file":"chunk-3GKUUTSA.js","sourcesContent":["import { useMemo, useState } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { Button } from \"../button/Button\";\n\nexport type DateRange = { from?: Date; to?: Date };\n\nexport type CalendarMode = \"single\" | \"range\";\n\n/** `sm`: denser padding, smaller day cells, lighter caption controls (dropdown + nav). */\nexport type CalendarSize = \"default\" | \"sm\";\n\nexport type CalendarDisabledProp = ((date: Date) => boolean) | Date[];\n\nconst atNoon = (d: Date) => new Date(d.getFullYear(), d.getMonth(), d.getDate(), 12, 0, 0);\n\nconst isSameDay = (a: Date, b: Date) =>\n a.getFullYear() === b.getFullYear() && a.getMonth() === b.getMonth() && a.getDate() === b.getDate();\n\nconst isBetweenInclusive = (d: Date, a: Date, b: Date) => {\n const t = atNoon(d).getTime();\n return t >= atNoon(a).getTime() && t <= atNoon(b).getTime();\n};\n\nconst startOfMonth = (d: Date) => new Date(d.getFullYear(), d.getMonth(), 1);\n\nconst addMonths = (d: Date, delta: number) => new Date(d.getFullYear(), d.getMonth() + delta, 1);\n\n/** ISO week number (Mon–Sun weeks, week 1 contains Jan 4). */\nconst isoWeekNumber = (d: Date) => {\n const copy = new Date(d.getFullYear(), d.getMonth(), d.getDate(), 12, 0, 0);\n const day = (copy.getDay() + 6) % 7;\n copy.setDate(copy.getDate() - day + 3);\n const week1 = new Date(copy.getFullYear(), 0, 4);\n const w1d = (week1.getDay() + 6) % 7;\n week1.setDate(week1.getDate() - w1d + 3);\n return 1 + Math.round((copy.getTime() - week1.getTime()) / 604800000);\n};\n\nconst formatWeekIndex = (n: number) => String(n).padStart(2, \"0\");\n\ntype CalendarCell = { date: Date; outside: boolean } | null;\n\nconst buildCalendarRows = (\n year: number,\n month: number,\n showOutsideDays: boolean,\n fixedWeeks: boolean\n): CalendarCell[][] => {\n const first = new Date(year, month, 1);\n const daysInMonth = new Date(year, month + 1, 0).getDate();\n const startPad = first.getDay();\n\n const flat: CalendarCell[] = [];\n\n for (let i = 0; i < startPad; i += 1) {\n if (showOutsideDays) {\n const prevMonth = month === 0 ? 11 : month - 1;\n const prevYear = month === 0 ? year - 1 : year;\n const prevDays = new Date(prevYear, prevMonth + 1, 0).getDate();\n const day = prevDays - startPad + i + 1;\n flat.push({ date: new Date(prevYear, prevMonth, day), outside: true });\n } else {\n flat.push(null);\n }\n }\n\n for (let d = 1; d <= daysInMonth; d += 1) {\n flat.push({ date: new Date(year, month, d), outside: false });\n }\n\n const rem = flat.length % 7;\n if (rem !== 0) {\n const need = 7 - rem;\n for (let i = 0; i < need; i += 1) {\n if (showOutsideDays) {\n flat.push({ date: new Date(year, month + 1, i + 1), outside: true });\n } else {\n flat.push(null);\n }\n }\n }\n\n if (fixedWeeks) {\n while (flat.length < 42) {\n if (showOutsideDays) {\n const lastCell = flat[flat.length - 1];\n if (lastCell) {\n const next = new Date(lastCell.date);\n next.setDate(next.getDate() + 1);\n flat.push({ date: next, outside: true });\n } else {\n flat.push(null);\n }\n } else {\n flat.push(null);\n }\n }\n }\n\n const rows: CalendarCell[][] = [];\n for (let i = 0; i < flat.length; i += 7) {\n rows.push(flat.slice(i, i + 7));\n }\n return rows;\n};\n\nconst ChevronLeft = ({ class: className }: { class?: string }) => (\n <svg\n class={cn(\"size-4 shrink-0\", className)}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n aria-hidden=\"true\"\n >\n <path d=\"m15 18-6-6 6-6\" />\n </svg>\n);\n\nconst ChevronRight = ({ class: className }: { class?: string }) => (\n <svg\n class={cn(\"size-4 shrink-0\", className)}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n aria-hidden=\"true\"\n >\n <path d=\"m9 18 6-6-6-6\" />\n </svg>\n);\n\nexport type CalendarProps = Omit<JSX.HTMLAttributes<HTMLDivElement>, \"onSelect\"> & {\n mode?: CalendarMode;\n selected?: Date | DateRange;\n onSelect?: (value: Date | DateRange | undefined) => void;\n /** @deprecated Use `selected` in single mode. */\n value?: Date;\n /** @deprecated Use `onSelect` in single mode. */\n onValueChange?: (next: Date) => void;\n defaultMonth?: Date;\n month?: Date;\n onMonthChange?: (next: Date) => void;\n numberOfMonths?: 1 | 2;\n captionLayout?: \"buttons\" | \"dropdown\";\n dir?: \"ltr\" | \"rtl\";\n /** Show days from adjacent months. @default true */\n showOutsideDays?: boolean;\n /** Pad to six week rows. @default false */\n fixedWeeks?: boolean;\n disabled?: CalendarDisabledProp;\n /** Extra week-index column (ISO week of row start). @default false */\n showWeekNumber?: boolean;\n /** Named date sets for styling via `modifiersClassNames`. */\n modifiers?: Record<string, Date[]>;\n /** Tailwind / arbitrary classes keyed like `modifiers` (e.g. booked). */\n modifiersClassNames?: Record<string, string>;\n /** BCP 47 locale for captions and weekday labels. */\n locale?: string;\n /** Passed to `Intl` where supported; selection still uses local `Date` (use noon-normalized dates to avoid TZ drift). */\n timeZone?: string;\n /** Extra label under the day number (e.g. prices). Omit or return `undefined` for outside days if desired. */\n dayAddon?: (date: Date, outside: boolean) => ComponentChildren | undefined;\n /** Extra classes for the visible month/year caption text (single-month buttons layout and dual-month titles). */\n captionTitleClass?: string;\n /** If set (length 7, Sunday-first), overrides locale-derived weekday headers. */\n weekdayLabels?: string[];\n /** Decorative left border on the first weekday column (e.g. Su). @default false */\n showWeekdayLeadBorder?: boolean;\n /** Visual density; `sm` fits popovers and tight layouts. @default \"default\" */\n size?: CalendarSize;\n};\n\ntype MonthCaptionProps = {\n displayMonth: Date;\n captionLayout: \"buttons\" | \"dropdown\";\n dir: \"ltr\" | \"rtl\";\n locale?: string;\n timeZone?: string;\n captionTitleClass?: string;\n size: CalendarSize;\n onPrev: () => void;\n onNext: () => void;\n onPickMonthYear: (year: number, monthIndex: number) => void;\n};\n\nconst intlOpts = (locale?: string, timeZone?: string) =>\n timeZone ? ({ locale, timeZone } as const) : locale ? ({ locale } as const) : undefined;\n\nconst MonthCaption = ({\n displayMonth,\n captionLayout,\n dir,\n locale,\n timeZone,\n captionTitleClass,\n size,\n onPrev,\n onNext,\n onPickMonthYear\n}: MonthCaptionProps) => {\n const sm = size === \"sm\";\n const y = displayMonth.getFullYear();\n const m = displayMonth.getMonth();\n const yearStart = y - 100;\n const yearEnd = y + 20;\n const years = useMemo(() => {\n const list: number[] = [];\n for (let yy = yearStart; yy <= yearEnd; yy += 1) list.push(yy);\n return list;\n }, [yearStart, yearEnd]);\n\n const fmt = intlOpts(locale, timeZone);\n\n if (captionLayout === \"dropdown\") {\n /** Month/year selects centered, prev/next ghost icons — matches shadcn “Month and Year Selector” chrome. */\n /** Avoid `min-w-0` on selects: in a flex row it lets them shrink and clip month labels (e.g. de-DE “Mär”). */\n const selectBaseClass = sm\n ? \"border-input bg-background text-foreground focus-visible:ring-ring/50 box-border h-7 min-h-7 shrink-0 rounded-md border px-2 pe-7 text-xs leading-4 shadow-xs outline-none focus-visible:ring-2\"\n : \"border-input bg-background text-foreground focus-visible:ring-ring/50 box-border h-8 min-h-8 shrink-0 rounded-md border px-2.5 pe-8 text-xs leading-4 shadow-xs outline-none focus-visible:ring-2\";\n const monthSelectClass = cn(selectBaseClass, sm ? \"min-w-[5rem] max-w-full\" : \"min-w-[5.25rem] max-w-full\");\n const yearSelectClass = cn(selectBaseClass, sm ? \"min-w-[3.75rem] max-w-full\" : \"min-w-[4.25rem] max-w-full\");\n return (\n <div class={cn(\"flex w-full items-center justify-between\", sm ? \"mb-1 gap-0.5\" : \"mb-1.5 gap-1\")} dir={dir}>\n <Button\n type=\"button\"\n variant=\"ghost\"\n size={sm ? \"icon-xs\" : \"icon-sm\"}\n aria-label=\"Previous month\"\n onClick={onPrev}\n >\n <ChevronLeft class={dir === \"rtl\" ? \"rotate-180\" : undefined} />\n </Button>\n <div\n class={cn(\n \"text-foreground flex min-w-0 flex-1 items-center justify-center font-medium\",\n sm ? \"gap-1 text-xs\" : \"gap-1.5 text-xs\",\n captionTitleClass\n )}\n >\n <select\n class={monthSelectClass}\n value={String(m)}\n aria-label=\"Month\"\n onChange={(e) => {\n const nextM = Number((e.target as HTMLSelectElement).value);\n onPickMonthYear(y, nextM);\n }}\n >\n {Array.from({ length: 12 }, (_, i) => (\n <option key={i} value={String(i)}>\n {new Date(y, i, 1).toLocaleString(fmt?.locale ?? undefined, {\n month: \"short\",\n ...(fmt && \"timeZone\" in fmt && fmt.timeZone ? { timeZone: fmt.timeZone } : {})\n })}\n </option>\n ))}\n </select>\n <select\n class={yearSelectClass}\n value={String(y)}\n aria-label=\"Year\"\n onChange={(e) => {\n const nextY = Number((e.target as HTMLSelectElement).value);\n onPickMonthYear(nextY, m);\n }}\n >\n {years.map((yy) => (\n <option key={yy} value={String(yy)}>\n {yy}\n </option>\n ))}\n </select>\n </div>\n <Button\n type=\"button\"\n variant=\"ghost\"\n size={sm ? \"icon-xs\" : \"icon-sm\"}\n aria-label=\"Next month\"\n onClick={onNext}\n >\n <ChevronRight class={dir === \"rtl\" ? \"rotate-180\" : undefined} />\n </Button>\n </div>\n );\n }\n\n return (\n <div class={cn(\"flex items-center justify-between\", sm ? \"mb-1 gap-1\" : \"mb-1.5 gap-1.5\")} dir={dir}>\n <Button type=\"button\" variant=\"ghost\" size={sm ? \"icon-xs\" : \"icon-sm\"} aria-label=\"Previous month\" onClick={onPrev}>\n <ChevronLeft class={dir === \"rtl\" ? \"rotate-180\" : undefined} />\n </Button>\n <div class={cn(sm ? \"text-xs font-medium\" : \"text-sm font-medium\", captionTitleClass)}>\n {displayMonth.toLocaleString(fmt?.locale ?? undefined, {\n month: \"long\",\n year: \"numeric\",\n ...(fmt && \"timeZone\" in fmt && fmt.timeZone ? { timeZone: fmt.timeZone } : {})\n })}\n </div>\n <Button type=\"button\" variant=\"ghost\" size={sm ? \"icon-xs\" : \"icon-sm\"} aria-label=\"Next month\" onClick={onNext}>\n <ChevronRight class={dir === \"rtl\" ? \"rotate-180\" : undefined} />\n </Button>\n </div>\n );\n};\n\ntype DualMonthCaptionProps = {\n firstMonth: Date;\n secondMonth: Date;\n dir: \"ltr\" | \"rtl\";\n locale?: string;\n timeZone?: string;\n captionTitleClass?: string;\n size: CalendarSize;\n onPrev: () => void;\n onNext: () => void;\n};\n\nconst DualMonthCaption = ({\n firstMonth,\n secondMonth,\n dir,\n locale,\n timeZone,\n captionTitleClass,\n size,\n onPrev,\n onNext\n}: DualMonthCaptionProps) => {\n const fmt = intlOpts(locale, timeZone);\n const sm = size === \"sm\";\n return (\n <div class={cn(\"flex items-center justify-between\", sm ? \"mb-1 gap-1\" : \"mb-1.5 gap-1.5\")} dir={dir}>\n <Button\n type=\"button\"\n variant=\"ghost\"\n size={sm ? \"icon-xs\" : \"icon-sm\"}\n class=\"shrink-0\"\n aria-label=\"Previous month\"\n onClick={onPrev}\n >\n <ChevronLeft class={dir === \"rtl\" ? \"rotate-180\" : undefined} />\n </Button>\n <div\n class={cn(\n \"flex min-w-0 flex-1 justify-center text-center font-medium\",\n sm ? \"gap-2 text-xs sm:gap-4\" : \"gap-4 text-sm sm:gap-6\"\n )}\n >\n <span class={cn(\"truncate\", captionTitleClass)}>\n {firstMonth.toLocaleString(fmt?.locale ?? undefined, {\n month: \"long\",\n year: \"numeric\",\n ...(fmt && \"timeZone\" in fmt && fmt.timeZone ? { timeZone: fmt.timeZone } : {})\n })}\n </span>\n <span class={cn(\"truncate\", captionTitleClass)}>\n {secondMonth.toLocaleString(fmt?.locale ?? undefined, {\n month: \"long\",\n year: \"numeric\",\n ...(fmt && \"timeZone\" in fmt && fmt.timeZone ? { timeZone: fmt.timeZone } : {})\n })}\n </span>\n </div>\n <Button\n type=\"button\"\n variant=\"ghost\"\n size={sm ? \"icon-xs\" : \"icon-sm\"}\n class=\"shrink-0\"\n aria-label=\"Next month\"\n onClick={onNext}\n >\n <ChevronRight class={dir === \"rtl\" ? \"rotate-180\" : undefined} />\n </Button>\n </div>\n );\n};\n\ntype MonthGridProps = {\n year: number;\n month: number;\n mode: CalendarMode;\n singleSelected?: Date;\n range?: DateRange;\n locale?: string;\n weekdayLabels?: string[];\n showWeekdayLeadBorder?: boolean;\n showOutsideDays: boolean;\n fixedWeeks: boolean;\n showWeekNumber: boolean;\n isDisabled: (d: Date) => boolean;\n modifierClassesFor: (d: Date) => string;\n dayAddon?: (date: Date, outside: boolean) => ComponentChildren | undefined;\n hasDayAddon: boolean;\n size: CalendarSize;\n onDayClick: (d: Date, outside: boolean) => void;\n};\n\nconst MonthGrid = ({\n year,\n month,\n mode,\n singleSelected,\n range,\n locale,\n weekdayLabels: weekdayLabelsProp,\n showWeekdayLeadBorder,\n showOutsideDays,\n fixedWeeks,\n showWeekNumber,\n isDisabled,\n modifierClassesFor,\n dayAddon,\n hasDayAddon,\n size,\n onDayClick\n}: MonthGridProps) => {\n const sm = size === \"sm\";\n const gridGap = sm ? \"gap-0.5\" : \"gap-1\";\n const rows = useMemo(\n () => buildCalendarRows(year, month, showOutsideDays, fixedWeeks),\n [year, month, showOutsideDays, fixedWeeks]\n );\n\n const today = useMemo(() => atNoon(new Date()), []);\n\n /** Jan 7 2024 = Sunday; columns Su–Sa. */\n const weekdayLabels = useMemo(() => {\n if (weekdayLabelsProp?.length === 7) return weekdayLabelsProp;\n return Array.from({ length: 7 }, (_, i) =>\n new Date(2024, 0, 7 + i).toLocaleDateString(locale, { weekday: \"short\" })\n );\n }, [locale, weekdayLabelsProp]);\n\n const dayClass = (d: Date, outside: boolean) => {\n let cls = cn(\n \"inline-flex size-[length:var(--cell-size,2rem)] min-h-[length:var(--cell-size,2rem)] min-w-[length:var(--cell-size,2rem)] items-center justify-center rounded-md leading-none font-normal transition-colors focus-visible:ring-2 focus-visible:ring-ring/50 focus-visible:outline-none disabled:pointer-events-none disabled:opacity-50 dark:hover:text-accent-foreground\",\n sm ? \"text-xs\" : \"text-sm\",\n hasDayAddon && \"flex-col gap-0.5\"\n );\n\n if (outside) {\n cls += \" text-muted-foreground\";\n }\n\n const isToday = isSameDay(d, today);\n const singleSel = mode === \"single\" && singleSelected && isSameDay(d, singleSelected);\n const from = range?.from;\n const to = range?.to;\n const rangeFromOnly = mode === \"range\" && from && !to && isSameDay(d, from);\n const inFullRange =\n mode === \"range\" && from && to && isBetweenInclusive(d, from, to);\n\n if (singleSel || rangeFromOnly) {\n cls += \" bg-primary text-primary-foreground hover:bg-primary/90\";\n } else if (inFullRange && from && to) {\n if (isSameDay(from, to)) {\n cls += \" bg-primary text-primary-foreground hover:bg-primary/90 rounded-md\";\n } else if (isSameDay(d, from)) {\n cls += \" bg-primary text-primary-foreground hover:bg-primary/90 rounded-s-md rounded-e-none\";\n } else if (isSameDay(d, to)) {\n cls += \" bg-primary text-primary-foreground hover:bg-primary/90 rounded-e-md rounded-s-none\";\n } else {\n cls += \" bg-accent text-accent-foreground hover:bg-accent/80 rounded-none\";\n }\n } else if (isToday) {\n cls += \" bg-accent text-accent-foreground\";\n } else {\n cls += \" hover:bg-accent hover:text-accent-foreground\";\n }\n\n return cls;\n };\n\n return (\n <div class=\"min-w-0 flex-1\">\n <div\n class={cn(\n \"grid text-center text-muted-foreground\",\n gridGap,\n sm ? \"text-[0.65rem] leading-none\" : \"text-xs\",\n showWeekNumber ? \"grid-cols-8\" : \"grid-cols-7\"\n )}\n >\n {showWeekNumber ? <div class=\"flex size-[length:var(--cell-size,2rem)] items-center justify-center font-normal\" /> : null}\n {weekdayLabels.map((day, wi) => (\n <div\n key={`w-${wi}`}\n class={cn(\n \"flex size-[length:var(--cell-size,2rem)] items-center justify-center font-normal\",\n showWeekdayLeadBorder && wi === 0 && \"relative ms-0.5 border-s border-border ps-2\"\n )}\n >\n {day}\n </div>\n ))}\n </div>\n <div class={cn(\"flex flex-col\", gridGap, sm ? \"mt-1\" : \"mt-1.5\")}>\n {rows.map((row, ri) => (\n <div\n key={ri}\n class={cn(\"grid\", gridGap, showWeekNumber ? \"grid-cols-8\" : \"grid-cols-7\")}\n >\n {showWeekNumber ? (\n <div\n class=\"text-muted-foreground flex size-[length:var(--cell-size,2rem)] items-center justify-center text-[0.8rem] select-none\"\n aria-hidden=\"true\"\n >\n {(() => {\n const first = row.find((c): c is { date: Date; outside: boolean } => c !== null);\n return first ? formatWeekIndex(isoWeekNumber(first.date)) : \"\";\n })()}\n </div>\n ) : null}\n {row.map((cell, ci) =>\n cell ? (\n <button\n key={`${cell.date.getTime()}-${ci}`}\n type=\"button\"\n data-slot=\"calendar-day\"\n data-outside={cell.outside ? \"true\" : undefined}\n data-today={isSameDay(cell.date, today) ? \"true\" : undefined}\n disabled={isDisabled(cell.date)}\n class={cn(dayClass(cell.date, cell.outside), modifierClassesFor(cell.date))}\n onClick={() => onDayClick(cell.date, cell.outside)}\n >\n <span>{cell.date.getDate()}</span>\n {(() => {\n if (!dayAddon) return null;\n const extra = dayAddon(cell.date, cell.outside);\n if (extra == null || extra === false) return null;\n return (\n <span class=\"text-muted-foreground text-xs leading-none opacity-70\">{extra}</span>\n );\n })()}\n </button>\n ) : (\n <div key={`empty-${ri}-${ci}`} class=\"size-[length:var(--cell-size,2rem)]\" aria-hidden=\"true\" />\n )\n )}\n </div>\n ))}\n </div>\n </div>\n );\n};\n\nexport const Calendar = ({\n class: className,\n mode = \"single\",\n selected,\n onSelect,\n value,\n onValueChange,\n defaultMonth,\n month: monthProp,\n onMonthChange,\n numberOfMonths = 1,\n captionLayout = \"buttons\",\n dir = \"ltr\",\n showOutsideDays = true,\n fixedWeeks = false,\n disabled,\n showWeekNumber = false,\n modifiers,\n modifiersClassNames,\n locale,\n timeZone,\n dayAddon,\n captionTitleClass,\n weekdayLabels,\n showWeekdayLeadBorder,\n size = \"default\",\n ...rest\n}: CalendarProps) => {\n const calSize: CalendarSize = size;\n const singleSelected =\n mode === \"single\" ? ((selected as Date | undefined) ?? value) : undefined;\n const rangeSelected = mode === \"range\" ? (selected as DateRange | undefined) : undefined;\n\n const initialMonth = useMemo(() => {\n const fromSel = singleSelected ?? rangeSelected?.from;\n return startOfMonth(defaultMonth ?? fromSel ?? new Date());\n }, []);\n\n const [innerMonth, setInnerMonth] = useState<Date>(initialMonth);\n\n const displayMonth = monthProp !== undefined ? startOfMonth(monthProp) : innerMonth;\n\n const setMonth = (next: Date) => {\n const s = startOfMonth(next);\n onMonthChange?.(s);\n if (monthProp === undefined) {\n setInnerMonth(s);\n }\n };\n\n const shiftMonth = (delta: number) => {\n setMonth(addMonths(displayMonth, delta));\n };\n\n const isDisabled = (d: Date) => {\n if (!disabled) return false;\n if (Array.isArray(disabled)) {\n return disabled.some((x) => isSameDay(atNoon(x), atNoon(d)));\n }\n return disabled(d);\n };\n\n const modifierClassesFor = (d: Date) => {\n if (!modifiers || !modifiersClassNames) return \"\";\n const parts: string[] = [];\n for (const [name, dates] of Object.entries(modifiers)) {\n if (!dates?.length) continue;\n if (dates.some((x) => isSameDay(atNoon(x), atNoon(d)))) {\n const cnVal = modifiersClassNames[name];\n if (cnVal) parts.push(cnVal);\n }\n }\n return parts.join(\" \");\n };\n\n const handleDayClick = (d: Date, outside: boolean) => {\n if (outside) {\n setMonth(startOfMonth(d));\n }\n if (mode === \"single\") {\n onSelect?.(d);\n onValueChange?.(d);\n return;\n }\n const cur = rangeSelected;\n if (!cur?.from || (cur.from && cur.to)) {\n onSelect?.({ from: d, to: undefined });\n } else {\n let from = cur.from;\n let to = d;\n if (atNoon(to) < atNoon(from)) {\n const tmp = from;\n from = to;\n to = tmp;\n }\n onSelect?.({ from, to });\n }\n };\n\n const monthsToRender = numberOfMonths === 2 ? ([0, 1] as const) : ([0] as const);\n const effectiveCaption: \"buttons\" | \"dropdown\" = numberOfMonths === 2 ? \"buttons\" : captionLayout;\n\n const secondVisible = addMonths(displayMonth, 1);\n\n return (\n <div\n data-slot=\"calendar\"\n data-calendar-size={calSize}\n dir={dir}\n class={cn(\n \"bg-background group/calendar relative w-fit rounded-md border [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent\",\n calSize === \"sm\"\n ? \"min-w-[15rem] p-2 [--cell-size:1.5625rem]\"\n : \"min-w-[16.75rem] p-2.5 [--cell-size:1.75rem]\",\n numberOfMonths === 2 && \"max-w-full\",\n className\n )}\n {...rest}\n >\n {numberOfMonths === 2 ? (\n <DualMonthCaption\n firstMonth={displayMonth}\n secondMonth={secondVisible}\n dir={dir}\n locale={locale}\n timeZone={timeZone}\n captionTitleClass={captionTitleClass}\n size={calSize}\n onPrev={() => shiftMonth(-1)}\n onNext={() => shiftMonth(1)}\n />\n ) : (\n <MonthCaption\n displayMonth={displayMonth}\n captionLayout={effectiveCaption}\n dir={dir}\n locale={locale}\n timeZone={timeZone}\n captionTitleClass={captionTitleClass}\n size={calSize}\n onPrev={() => shiftMonth(-1)}\n onNext={() => shiftMonth(1)}\n onPickMonthYear={(yy, monthIndex) => {\n setMonth(new Date(yy, monthIndex, 1));\n }}\n />\n )}\n <div\n class={cn(\n \"relative flex flex-col\",\n calSize === \"sm\" ? \"gap-2.5\" : \"gap-3\",\n numberOfMonths === 2 && \"md:flex-row md:items-start md:justify-between\",\n numberOfMonths === 2 && (calSize === \"sm\" ? \"md:gap-4\" : \"md:gap-6\")\n )}\n >\n {monthsToRender.map((offset) => {\n const ym = addMonths(displayMonth, offset);\n const y = ym.getFullYear();\n const m = ym.getMonth();\n return (\n <MonthGrid\n key={`${y}-${m}`}\n year={y}\n month={m}\n mode={mode}\n singleSelected={singleSelected}\n range={rangeSelected}\n locale={locale}\n weekdayLabels={weekdayLabels}\n showWeekdayLeadBorder={showWeekdayLeadBorder}\n showOutsideDays={showOutsideDays}\n fixedWeeks={fixedWeeks}\n showWeekNumber={showWeekNumber}\n isDisabled={isDisabled}\n modifierClassesFor={modifierClassesFor}\n dayAddon={dayAddon}\n hasDayAddon={Boolean(dayAddon)}\n size={calSize}\n onDayClick={handleDayClick}\n />\n );\n })}\n </div>\n </div>\n );\n};\n"]}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { InputGroup, InputGroupAddon, InputGroupInput } from './chunk-YDMMDO2W.js';
|
|
2
|
+
import { FieldGroup, Field, FieldLabel } from './chunk-SZ2I2SRP.js';
|
|
3
|
+
import { Calendar } from './chunk-3GKUUTSA.js';
|
|
4
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
5
|
+
import { useId, useState } from 'preact/hooks';
|
|
6
|
+
import { jsxs, jsx } from 'preact/jsx-runtime';
|
|
7
|
+
|
|
8
|
+
var WEEKDAY_TWO_LETTER = ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"];
|
|
9
|
+
var ClockGlyph = ({ class: className }) => /* @__PURE__ */ jsxs(
|
|
10
|
+
"svg",
|
|
11
|
+
{
|
|
12
|
+
class: cn("size-3.5 shrink-0 opacity-70", className),
|
|
13
|
+
viewBox: "0 0 24 24",
|
|
14
|
+
fill: "none",
|
|
15
|
+
stroke: "currentColor",
|
|
16
|
+
"stroke-width": "2",
|
|
17
|
+
"aria-hidden": "true",
|
|
18
|
+
children: [
|
|
19
|
+
/* @__PURE__ */ jsx("circle", { cx: "12", cy: "12", r: "10" }),
|
|
20
|
+
/* @__PURE__ */ jsx("path", { d: "M12 6v6l4 2" })
|
|
21
|
+
]
|
|
22
|
+
}
|
|
23
|
+
);
|
|
24
|
+
var CalendarDateTimePanel = ({
|
|
25
|
+
class: className,
|
|
26
|
+
selected,
|
|
27
|
+
defaultSelected,
|
|
28
|
+
onSelect,
|
|
29
|
+
defaultMonth,
|
|
30
|
+
month,
|
|
31
|
+
onMonthChange,
|
|
32
|
+
locale = "en-US",
|
|
33
|
+
disabled,
|
|
34
|
+
dir,
|
|
35
|
+
showOutsideDays = true,
|
|
36
|
+
captionLayout = "buttons",
|
|
37
|
+
size = "sm",
|
|
38
|
+
startTime: startTimeProp,
|
|
39
|
+
defaultStartTime = "10:30:00",
|
|
40
|
+
onStartTimeChange,
|
|
41
|
+
endTime: endTimeProp,
|
|
42
|
+
defaultEndTime = "12:30:00",
|
|
43
|
+
onEndTimeChange,
|
|
44
|
+
startTimeLabel = "Start Time",
|
|
45
|
+
endTimeLabel = "End Time",
|
|
46
|
+
compactWeekdays = true,
|
|
47
|
+
showWeekdayLeadBorder = false,
|
|
48
|
+
...rest
|
|
49
|
+
}) => {
|
|
50
|
+
const uid = useId();
|
|
51
|
+
const startId = `kamod-cdtp-s-${uid}`;
|
|
52
|
+
const endId = `kamod-cdtp-e-${uid}`;
|
|
53
|
+
const [innerDate, setInnerDate] = useState(defaultSelected);
|
|
54
|
+
const selectedDate = selected !== void 0 ? selected : innerDate;
|
|
55
|
+
const [innerStart, setInnerStart] = useState(defaultStartTime);
|
|
56
|
+
const [innerEnd, setInnerEnd] = useState(defaultEndTime);
|
|
57
|
+
const startVal = startTimeProp !== void 0 ? startTimeProp : innerStart;
|
|
58
|
+
const endVal = endTimeProp !== void 0 ? endTimeProp : innerEnd;
|
|
59
|
+
const setDate = (d) => {
|
|
60
|
+
if (selected === void 0) setInnerDate(d);
|
|
61
|
+
onSelect?.(d);
|
|
62
|
+
};
|
|
63
|
+
const setStart = (v) => {
|
|
64
|
+
if (startTimeProp === void 0) setInnerStart(v);
|
|
65
|
+
onStartTimeChange?.(v);
|
|
66
|
+
};
|
|
67
|
+
const setEnd = (v) => {
|
|
68
|
+
if (endTimeProp === void 0) setInnerEnd(v);
|
|
69
|
+
onEndTimeChange?.(v);
|
|
70
|
+
};
|
|
71
|
+
const photoCalendarClass = "w-full min-w-0 max-w-full border-0 bg-transparent p-0 shadow-none [&_[data-slot=calendar-day][data-outside=true]]:!text-neutral-400 dark:[&_[data-slot=calendar-day][data-outside=true]]:!text-neutral-500 [&_[data-slot=calendar-day]]:!rounded-full [&_[data-slot=calendar-day]:not(:disabled):hover]:!bg-neutral-200/90 dark:[&_[data-slot=calendar-day]:not(:disabled):hover]:!bg-white/10 [&_[data-slot=calendar-day].bg-primary]:!rounded-xl [&_[data-slot=calendar-day].bg-primary]:!bg-[#1a1a1a] [&_[data-slot=calendar-day].bg-primary]:hover:!bg-[#1a1a1a] [&_[data-slot=calendar-day].bg-primary]:!text-white dark:[&_[data-slot=calendar-day].bg-primary]:!bg-primary dark:[&_[data-slot=calendar-day].bg-primary]:!text-primary-foreground dark:[&_[data-slot=calendar-day].bg-primary]:hover:!bg-primary/90 [&_[data-slot=calendar-day].bg-accent]:!rounded-full";
|
|
72
|
+
return /* @__PURE__ */ jsxs(
|
|
73
|
+
"div",
|
|
74
|
+
{
|
|
75
|
+
"data-slot": "calendar-datetime-panel",
|
|
76
|
+
class: cn(
|
|
77
|
+
"bg-background text-foreground w-full max-w-[min(100%,300px)] rounded-xl border border-[#e0e0e0] p-3.5 shadow-sm dark:border-border",
|
|
78
|
+
className
|
|
79
|
+
),
|
|
80
|
+
...rest,
|
|
81
|
+
children: [
|
|
82
|
+
/* @__PURE__ */ jsx(
|
|
83
|
+
Calendar,
|
|
84
|
+
{
|
|
85
|
+
mode: "single",
|
|
86
|
+
dir,
|
|
87
|
+
locale,
|
|
88
|
+
disabled,
|
|
89
|
+
showOutsideDays,
|
|
90
|
+
captionLayout,
|
|
91
|
+
size,
|
|
92
|
+
selected: selectedDate,
|
|
93
|
+
defaultMonth: defaultMonth ?? selectedDate ?? /* @__PURE__ */ new Date(),
|
|
94
|
+
month,
|
|
95
|
+
onMonthChange,
|
|
96
|
+
onSelect: (v) => {
|
|
97
|
+
if (v instanceof Date) setDate(v);
|
|
98
|
+
},
|
|
99
|
+
captionTitleClass: "text-sm font-semibold tracking-tight",
|
|
100
|
+
weekdayLabels: compactWeekdays ? [...WEEKDAY_TWO_LETTER] : void 0,
|
|
101
|
+
showWeekdayLeadBorder,
|
|
102
|
+
class: photoCalendarClass
|
|
103
|
+
}
|
|
104
|
+
),
|
|
105
|
+
/* @__PURE__ */ jsx("div", { class: "mt-0.5 border-t border-[#e0e0e0] pt-3 dark:border-border", children: /* @__PURE__ */ jsxs(FieldGroup, { class: "gap-2.5", children: [
|
|
106
|
+
/* @__PURE__ */ jsxs(Field, { children: [
|
|
107
|
+
/* @__PURE__ */ jsx(FieldLabel, { class: "text-foreground mb-1 text-xs font-semibold", htmlFor: startId, children: startTimeLabel }),
|
|
108
|
+
/* @__PURE__ */ jsxs(InputGroup, { class: "border-[#e0e0e0] dark:border-input h-9 min-h-9 rounded-full px-0.5 shadow-none", children: [
|
|
109
|
+
/* @__PURE__ */ jsx(InputGroupAddon, { class: "ps-2.5", children: /* @__PURE__ */ jsx(ClockGlyph, {}) }),
|
|
110
|
+
/* @__PURE__ */ jsx(
|
|
111
|
+
InputGroupInput,
|
|
112
|
+
{
|
|
113
|
+
id: startId,
|
|
114
|
+
type: "time",
|
|
115
|
+
step: 1,
|
|
116
|
+
value: startVal,
|
|
117
|
+
onInput: (e) => setStart(e.target.value),
|
|
118
|
+
class: "font-mono text-xs tabular-nums"
|
|
119
|
+
}
|
|
120
|
+
)
|
|
121
|
+
] })
|
|
122
|
+
] }),
|
|
123
|
+
/* @__PURE__ */ jsxs(Field, { children: [
|
|
124
|
+
/* @__PURE__ */ jsx(FieldLabel, { class: "text-foreground mb-1 text-xs font-semibold", htmlFor: endId, children: endTimeLabel }),
|
|
125
|
+
/* @__PURE__ */ jsxs(InputGroup, { class: "border-[#e0e0e0] dark:border-input h-9 min-h-9 rounded-full px-0.5 shadow-none", children: [
|
|
126
|
+
/* @__PURE__ */ jsx(InputGroupAddon, { class: "ps-2.5", children: /* @__PURE__ */ jsx(ClockGlyph, {}) }),
|
|
127
|
+
/* @__PURE__ */ jsx(
|
|
128
|
+
InputGroupInput,
|
|
129
|
+
{
|
|
130
|
+
id: endId,
|
|
131
|
+
type: "time",
|
|
132
|
+
step: 1,
|
|
133
|
+
value: endVal,
|
|
134
|
+
onInput: (e) => setEnd(e.target.value),
|
|
135
|
+
class: "font-mono text-xs tabular-nums"
|
|
136
|
+
}
|
|
137
|
+
)
|
|
138
|
+
] })
|
|
139
|
+
] })
|
|
140
|
+
] }) })
|
|
141
|
+
]
|
|
142
|
+
}
|
|
143
|
+
);
|
|
144
|
+
};
|
|
145
|
+
|
|
146
|
+
// src/components/calendar/index.ts
|
|
147
|
+
var calendar_default = Calendar;
|
|
148
|
+
|
|
149
|
+
export { CalendarDateTimePanel, calendar_default };
|
|
150
|
+
//# sourceMappingURL=chunk-3IT2RVO6.js.map
|
|
151
|
+
//# sourceMappingURL=chunk-3IT2RVO6.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/calendar/CalendarDateTimePanel.tsx","../src/components/calendar/index.ts"],"names":[],"mappings":"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","file":"chunk-3IT2RVO6.js","sourcesContent":["import type { JSX } from \"preact\";\nimport { useId, useState } from \"preact/hooks\";\nimport { cn } from \"../../lib/utils\";\nimport { Field, FieldGroup, FieldLabel } from \"../field\";\nimport { InputGroup, InputGroupAddon, InputGroupInput } from \"../input-group\";\nimport { Calendar } from \"./Calendar\";\nimport type { CalendarProps } from \"./Calendar\";\n\nconst WEEKDAY_TWO_LETTER = [\"Su\", \"Mo\", \"Tu\", \"We\", \"Th\", \"Fr\", \"Sa\"] as const;\n\nconst ClockGlyph = ({ class: className }: { class?: string }) => (\n <svg\n class={cn(\"size-3.5 shrink-0 opacity-70\", className)}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n aria-hidden=\"true\"\n >\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <path d=\"M12 6v6l4 2\" />\n </svg>\n);\n\nexport type CalendarDateTimePanelProps = Omit<JSX.HTMLAttributes<HTMLDivElement>, \"onSelect\"> &\n Pick<\n CalendarProps,\n | \"defaultMonth\"\n | \"month\"\n | \"onMonthChange\"\n | \"locale\"\n | \"disabled\"\n | \"dir\"\n | \"showOutsideDays\"\n | \"captionLayout\"\n | \"size\"\n > & {\n /** Selected calendar day (controlled). */\n selected?: Date;\n /** Initial day when uncontrolled. */\n defaultSelected?: Date;\n onSelect?: (date: Date) => void;\n /** `HH:mm` or `HH:mm:ss` for native `input[type=time]`. */\n startTime?: string;\n defaultStartTime?: string;\n onStartTimeChange?: (value: string) => void;\n endTime?: string;\n defaultEndTime?: string;\n onEndTimeChange?: (value: string) => void;\n startTimeLabel?: string;\n endTimeLabel?: string;\n /** Use two-letter weekday headers (Su–Sa). @default true */\n compactWeekdays?: boolean;\n /** Decorative line left of the first weekday; off by default. */\n showWeekdayLeadBorder?: boolean;\n };\n\n/**\n * Single-month calendar with start/end time fields, styled for a compact “schedule” card (date + time range).\n * Defaults to `size=\"sm\"` on the inner {@link Calendar} for a dense layout; pass `size=\"default\"` for roomier cells.\n */\nexport const CalendarDateTimePanel = ({\n class: className,\n selected,\n defaultSelected,\n onSelect,\n defaultMonth,\n month,\n onMonthChange,\n locale = \"en-US\",\n disabled,\n dir,\n showOutsideDays = true,\n captionLayout = \"buttons\",\n size = \"sm\",\n startTime: startTimeProp,\n defaultStartTime = \"10:30:00\",\n onStartTimeChange,\n endTime: endTimeProp,\n defaultEndTime = \"12:30:00\",\n onEndTimeChange,\n startTimeLabel = \"Start Time\",\n endTimeLabel = \"End Time\",\n compactWeekdays = true,\n showWeekdayLeadBorder = false,\n ...rest\n}: CalendarDateTimePanelProps) => {\n const uid = useId();\n const startId = `kamod-cdtp-s-${uid}`;\n const endId = `kamod-cdtp-e-${uid}`;\n\n const [innerDate, setInnerDate] = useState<Date | undefined>(defaultSelected);\n const selectedDate = selected !== undefined ? selected : innerDate;\n\n const [innerStart, setInnerStart] = useState(defaultStartTime);\n const [innerEnd, setInnerEnd] = useState(defaultEndTime);\n const startVal = startTimeProp !== undefined ? startTimeProp : innerStart;\n const endVal = endTimeProp !== undefined ? endTimeProp : innerEnd;\n\n const setDate = (d: Date) => {\n if (selected === undefined) setInnerDate(d);\n onSelect?.(d);\n };\n\n const setStart = (v: string) => {\n if (startTimeProp === undefined) setInnerStart(v);\n onStartTimeChange?.(v);\n };\n\n const setEnd = (v: string) => {\n if (endTimeProp === undefined) setInnerEnd(v);\n onEndTimeChange?.(v);\n };\n\n const photoCalendarClass =\n \"w-full min-w-0 max-w-full border-0 bg-transparent p-0 shadow-none \" +\n \"[&_[data-slot=calendar-day][data-outside=true]]:!text-neutral-400 dark:[&_[data-slot=calendar-day][data-outside=true]]:!text-neutral-500 \" +\n \"[&_[data-slot=calendar-day]]:!rounded-full [&_[data-slot=calendar-day]:not(:disabled):hover]:!bg-neutral-200/90 dark:[&_[data-slot=calendar-day]:not(:disabled):hover]:!bg-white/10 \" +\n \"[&_[data-slot=calendar-day].bg-primary]:!rounded-xl [&_[data-slot=calendar-day].bg-primary]:!bg-[#1a1a1a] [&_[data-slot=calendar-day].bg-primary]:hover:!bg-[#1a1a1a] [&_[data-slot=calendar-day].bg-primary]:!text-white \" +\n \"dark:[&_[data-slot=calendar-day].bg-primary]:!bg-primary dark:[&_[data-slot=calendar-day].bg-primary]:!text-primary-foreground dark:[&_[data-slot=calendar-day].bg-primary]:hover:!bg-primary/90 \" +\n \"[&_[data-slot=calendar-day].bg-accent]:!rounded-full\";\n\n return (\n <div\n data-slot=\"calendar-datetime-panel\"\n class={cn(\n \"bg-background text-foreground w-full max-w-[min(100%,300px)] rounded-xl border border-[#e0e0e0] p-3.5 shadow-sm dark:border-border\",\n className\n )}\n {...rest}\n >\n <Calendar\n mode=\"single\"\n dir={dir}\n locale={locale}\n disabled={disabled}\n showOutsideDays={showOutsideDays}\n captionLayout={captionLayout}\n size={size}\n selected={selectedDate}\n defaultMonth={defaultMonth ?? selectedDate ?? new Date()}\n month={month}\n onMonthChange={onMonthChange}\n onSelect={(v) => {\n if (v instanceof Date) setDate(v);\n }}\n captionTitleClass=\"text-sm font-semibold tracking-tight\"\n weekdayLabels={compactWeekdays ? [...WEEKDAY_TWO_LETTER] : undefined}\n showWeekdayLeadBorder={showWeekdayLeadBorder}\n class={photoCalendarClass}\n />\n <div class=\"mt-0.5 border-t border-[#e0e0e0] pt-3 dark:border-border\">\n <FieldGroup class=\"gap-2.5\">\n <Field>\n <FieldLabel class=\"text-foreground mb-1 text-xs font-semibold\" htmlFor={startId}>\n {startTimeLabel}\n </FieldLabel>\n <InputGroup class=\"border-[#e0e0e0] dark:border-input h-9 min-h-9 rounded-full px-0.5 shadow-none\">\n <InputGroupAddon class=\"ps-2.5\">\n <ClockGlyph />\n </InputGroupAddon>\n <InputGroupInput\n id={startId}\n type=\"time\"\n step={1}\n value={startVal}\n onInput={(e) => setStart((e.target as HTMLInputElement).value)}\n class=\"font-mono text-xs tabular-nums\"\n />\n </InputGroup>\n </Field>\n <Field>\n <FieldLabel class=\"text-foreground mb-1 text-xs font-semibold\" htmlFor={endId}>\n {endTimeLabel}\n </FieldLabel>\n <InputGroup class=\"border-[#e0e0e0] dark:border-input h-9 min-h-9 rounded-full px-0.5 shadow-none\">\n <InputGroupAddon class=\"ps-2.5\">\n <ClockGlyph />\n </InputGroupAddon>\n <InputGroupInput\n id={endId}\n type=\"time\"\n step={1}\n value={endVal}\n onInput={(e) => setEnd((e.target as HTMLInputElement).value)}\n class=\"font-mono text-xs tabular-nums\"\n />\n </InputGroup>\n </Field>\n </FieldGroup>\n </div>\n </div>\n );\n};\n","import { Calendar } from \"./Calendar\";\n\nexport type { CalendarDisabledProp, CalendarMode, CalendarProps, CalendarSize, DateRange } from \"./Calendar\";\nexport { Calendar };\nexport { CalendarDateTimePanel } from \"./CalendarDateTimePanel\";\nexport type { CalendarDateTimePanelProps } from \"./CalendarDateTimePanel\";\n\nexport default Calendar;\n\n"]}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { tv } from 'tailwind-variants';
|
|
2
|
+
import { jsx } from 'preact/jsx-runtime';
|
|
3
|
+
|
|
4
|
+
// src/components/separator/Separator.tsx
|
|
5
|
+
var separator = tv({
|
|
6
|
+
base: "bg-border shrink-0",
|
|
7
|
+
variants: {
|
|
8
|
+
orientation: {
|
|
9
|
+
horizontal: "h-[1px] w-full",
|
|
10
|
+
vertical: "h-full w-[1px]"
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
defaultVariants: {
|
|
14
|
+
orientation: "horizontal"
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
var Separator = ({
|
|
18
|
+
class: className,
|
|
19
|
+
orientation = "horizontal",
|
|
20
|
+
decorative = false,
|
|
21
|
+
...rest
|
|
22
|
+
}) => /* @__PURE__ */ jsx(
|
|
23
|
+
"div",
|
|
24
|
+
{
|
|
25
|
+
role: decorative ? void 0 : "separator",
|
|
26
|
+
"aria-orientation": decorative ? void 0 : orientation,
|
|
27
|
+
"data-orientation": orientation,
|
|
28
|
+
class: separator({ orientation, class: className }),
|
|
29
|
+
"data-slot": "separator",
|
|
30
|
+
...rest
|
|
31
|
+
}
|
|
32
|
+
);
|
|
33
|
+
|
|
34
|
+
export { Separator, separator };
|
|
35
|
+
//# sourceMappingURL=chunk-3WAPI4KR.js.map
|
|
36
|
+
//# sourceMappingURL=chunk-3WAPI4KR.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/separator/Separator.tsx"],"names":[],"mappings":";;;;AAGO,IAAM,YAAY,EAAA,CAAG;AAAA,EAC1B,IAAA,EAAM,oBAAA;AAAA,EACN,QAAA,EAAU;AAAA,IACR,WAAA,EAAa;AAAA,MACX,UAAA,EAAY,gBAAA;AAAA,MACZ,QAAA,EAAU;AAAA;AACZ,GACF;AAAA,EACA,eAAA,EAAiB;AAAA,IACf,WAAA,EAAa;AAAA;AAEjB,CAAC;AAOM,IAAM,YAAY,CAAC;AAAA,EACxB,KAAA,EAAO,SAAA;AAAA,EACP,WAAA,GAAc,YAAA;AAAA,EACd,UAAA,GAAa,KAAA;AAAA,EACb,GAAG;AACL,CAAA,qBACE,GAAA;AAAA,EAAC,KAAA;AAAA,EAAA;AAAA,IACC,IAAA,EAAM,aAAa,MAAA,GAAY,WAAA;AAAA,IAC/B,kBAAA,EAAkB,aAAa,MAAA,GAAY,WAAA;AAAA,IAC3C,kBAAA,EAAkB,WAAA;AAAA,IAClB,OAAO,SAAA,CAAU,EAAE,WAAA,EAAa,KAAA,EAAO,WAAiC,CAAA;AAAA,IACxE,WAAA,EAAU,WAAA;AAAA,IACT,GAAG;AAAA;AACN","file":"chunk-3WAPI4KR.js","sourcesContent":["import type { JSX } from \"preact\";\nimport { tv } from \"tailwind-variants\";\n\nexport const separator = tv({\n base: \"bg-border shrink-0\",\n variants: {\n orientation: {\n horizontal: \"h-[1px] w-full\",\n vertical: \"h-full w-[1px]\"\n }\n },\n defaultVariants: {\n orientation: \"horizontal\"\n }\n});\n\nexport type SeparatorProps = Omit<JSX.HTMLAttributes<HTMLDivElement>, \"role\" | \"aria-orientation\"> & {\n orientation?: \"horizontal\" | \"vertical\";\n decorative?: boolean;\n};\n\nexport const Separator = ({\n class: className,\n orientation = \"horizontal\",\n decorative = false,\n ...rest\n}: SeparatorProps) => (\n <div\n role={decorative ? undefined : \"separator\"}\n aria-orientation={decorative ? undefined : orientation}\n data-orientation={orientation}\n class={separator({ orientation, class: className as string | undefined })}\n data-slot=\"separator\"\n {...rest}\n />\n);\n\n"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
2
|
+
import { jsxs, jsx } from 'preact/jsx-runtime';
|
|
3
|
+
|
|
4
|
+
var Chart = ({ class: className, title, description, children, ...rest }) => /* @__PURE__ */ jsxs("div", { "data-slot": "chart", class: cn("rounded-md border p-4", className), ...rest, children: [
|
|
5
|
+
title ? /* @__PURE__ */ jsx("h3", { class: "text-sm font-medium", children: title }) : null,
|
|
6
|
+
description ? /* @__PURE__ */ jsx("p", { class: "mt-1 text-xs text-muted-foreground", children: description }) : null,
|
|
7
|
+
/* @__PURE__ */ jsx("div", { class: "mt-3", children })
|
|
8
|
+
] });
|
|
9
|
+
|
|
10
|
+
// src/components/chart/index.ts
|
|
11
|
+
var chart_default = Chart;
|
|
12
|
+
|
|
13
|
+
export { Chart, chart_default };
|
|
14
|
+
//# sourceMappingURL=chunk-44YLIQIS.js.map
|
|
15
|
+
//# sourceMappingURL=chunk-44YLIQIS.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/chart/Chart.tsx","../src/components/chart/index.ts"],"names":[],"mappings":";;;AASO,IAAM,KAAA,GAAQ,CAAC,EAAE,KAAA,EAAO,WAAW,KAAA,EAAO,WAAA,EAAa,UAAU,GAAG,IAAA,uBACzE,IAAA,CAAC,KAAA,EAAA,EAAI,aAAU,OAAA,EAAQ,KAAA,EAAO,GAAG,uBAAA,EAAyB,SAAS,CAAA,EAAI,GAAG,IAAA,EACvE,QAAA,EAAA;AAAA,EAAA,KAAA,mBAAQ,GAAA,CAAC,IAAA,EAAA,EAAG,KAAA,EAAM,qBAAA,EAAuB,iBAAM,CAAA,GAAQ,IAAA;AAAA,EACvD,8BAAc,GAAA,CAAC,GAAA,EAAA,EAAE,KAAA,EAAM,oCAAA,EAAsC,uBAAY,CAAA,GAAO,IAAA;AAAA,kBACjF,GAAA,CAAC,KAAA,EAAA,EAAI,KAAA,EAAM,MAAA,EAAQ,QAAA,EAAS;AAAA,CAAA,EAC9B;;;ACVF,IAAO,aAAA,GAAQ","file":"chunk-44YLIQIS.js","sourcesContent":["import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type ChartProps = JSX.HTMLAttributes<HTMLDivElement> & {\n title?: string;\n description?: string;\n children?: ComponentChildren;\n};\n\nexport const Chart = ({ class: className, title, description, children, ...rest }: ChartProps) => (\n <div data-slot=\"chart\" class={cn(\"rounded-md border p-4\", className)} {...rest}>\n {title ? <h3 class=\"text-sm font-medium\">{title}</h3> : null}\n {description ? <p class=\"mt-1 text-xs text-muted-foreground\">{description}</p> : null}\n <div class=\"mt-3\">{children}</div>\n </div>\n);\n\n","import { Chart } from \"./Chart\";\n\nexport { Chart };\n\nexport default Chart;\n\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { input, Input } from './chunk-4HX6SEWP.js';
|
|
2
|
+
|
|
3
|
+
// src/components/input/index.ts
|
|
4
|
+
var InputVariants = { input };
|
|
5
|
+
var input_default = Input;
|
|
6
|
+
|
|
7
|
+
export { InputVariants, input_default };
|
|
8
|
+
//# sourceMappingURL=chunk-4AJM7IA4.js.map
|
|
9
|
+
//# sourceMappingURL=chunk-4AJM7IA4.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/input/index.ts"],"names":[],"mappings":";;;AAEA,IAAM,aAAA,GAAgB,EAAE,KAAA;AAIxB,IAAO,aAAA,GAAQ","file":"chunk-4AJM7IA4.js","sourcesContent":["import { Input, input } from \"./Input\";\n\nconst InputVariants = { input };\n\nexport { Input, InputVariants };\n\nexport default Input;\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { tv } from 'tailwind-variants';
|
|
2
|
+
import { jsx } from 'preact/jsx-runtime';
|
|
3
|
+
|
|
4
|
+
// src/components/input/Input.tsx
|
|
5
|
+
var input = tv({
|
|
6
|
+
base: [
|
|
7
|
+
"border-input dark:bg-input/30 text-foreground min-w-0 w-full rounded-md border bg-transparent shadow-xs",
|
|
8
|
+
"outline-none focus-visible:border-outline focus-visible:ring-outline/50 transition-[color,box-shadow] focus-visible:ring-3",
|
|
9
|
+
"selection:bg-primary/20 selection:text-foreground",
|
|
10
|
+
"file:text-foreground file:my-auto file:me-4 file:h-full file:border-0 file:bg-transparent file:text-sm file:font-medium",
|
|
11
|
+
"disabled:cursor-not-allowed disabled:opacity-50",
|
|
12
|
+
"aria-invalid:border-error aria-invalid:focus-visible:ring-error/40",
|
|
13
|
+
"peer placeholder:text-muted-foreground"
|
|
14
|
+
],
|
|
15
|
+
variants: {
|
|
16
|
+
size: { sm: "h-7 px-2.5 text-sm", md: "h-8 px-3 text-sm", lg: "h-9 px-3.5 text-base" }
|
|
17
|
+
},
|
|
18
|
+
defaultVariants: { size: "md" }
|
|
19
|
+
});
|
|
20
|
+
var Input = ({ size, class: className, ...rest }) => /* @__PURE__ */ jsx("input", { class: input({ size, class: className }), "data-slot": "input", ...rest });
|
|
21
|
+
|
|
22
|
+
export { Input, input };
|
|
23
|
+
//# sourceMappingURL=chunk-4HX6SEWP.js.map
|
|
24
|
+
//# sourceMappingURL=chunk-4HX6SEWP.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/input/Input.tsx"],"names":[],"mappings":";;;;AAGO,IAAM,QAAQ,EAAA,CAAG;AAAA,EACtB,IAAA,EAAM;AAAA,IACJ,yGAAA;AAAA,IACA,4HAAA;AAAA,IACA,mDAAA;AAAA,IACA,yHAAA;AAAA,IACA,iDAAA;AAAA,IACA,oEAAA;AAAA,IACA;AAAA,GACF;AAAA,EACA,QAAA,EAAU;AAAA,IACR,MAAM,EAAE,EAAA,EAAI,sBAAsB,EAAA,EAAI,kBAAA,EAAoB,IAAI,sBAAA;AAAuB,GACvF;AAAA,EACA,eAAA,EAAiB,EAAE,IAAA,EAAM,IAAA;AAC3B,CAAC;AAKM,IAAM,KAAA,GAAQ,CAAC,EAAE,IAAA,EAAM,OAAO,SAAA,EAAW,GAAG,IAAA,EAAK,qBACtD,GAAA,CAAC,OAAA,EAAA,EAAM,OAAO,KAAA,CAAM,EAAE,MAAM,KAAA,EAAO,SAAA,EAAiC,CAAA,EAAG,WAAA,EAAU,OAAA,EAAS,GAAG,IAAA,EAAM","file":"chunk-4HX6SEWP.js","sourcesContent":["import type { JSX } from \"preact\";\nimport { tv, type VariantProps } from \"tailwind-variants\";\n\nexport const input = tv({\n base: [\n \"border-input dark:bg-input/30 text-foreground min-w-0 w-full rounded-md border bg-transparent shadow-xs\",\n \"outline-none focus-visible:border-outline focus-visible:ring-outline/50 transition-[color,box-shadow] focus-visible:ring-3\",\n \"selection:bg-primary/20 selection:text-foreground\",\n \"file:text-foreground file:my-auto file:me-4 file:h-full file:border-0 file:bg-transparent file:text-sm file:font-medium\",\n \"disabled:cursor-not-allowed disabled:opacity-50\",\n \"aria-invalid:border-error aria-invalid:focus-visible:ring-error/40\",\n \"peer placeholder:text-muted-foreground\"\n ],\n variants: {\n size: { sm: \"h-7 px-2.5 text-sm\", md: \"h-8 px-3 text-sm\", lg: \"h-9 px-3.5 text-base\" }\n },\n defaultVariants: { size: \"md\" }\n});\n\nexport type InputProps = Omit<JSX.InputHTMLAttributes<HTMLInputElement>, \"size\"> &\n VariantProps<typeof input>;\n\nexport const Input = ({ size, class: className, ...rest }: InputProps) => (\n <input class={input({ size, class: className as string | undefined })} data-slot=\"input\" {...rest} />\n);\n\n"]}
|