@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,119 @@
|
|
|
1
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
2
|
+
import { useRef, useState, useLayoutEffect } from 'preact/hooks';
|
|
3
|
+
import { jsxs, jsx } from 'preact/jsx-runtime';
|
|
4
|
+
|
|
5
|
+
var CheckIcon = ({ class: className }) => /* @__PURE__ */ jsx(
|
|
6
|
+
"svg",
|
|
7
|
+
{
|
|
8
|
+
viewBox: "0 0 24 24",
|
|
9
|
+
fill: "none",
|
|
10
|
+
stroke: "currentColor",
|
|
11
|
+
"stroke-width": "2",
|
|
12
|
+
"stroke-linecap": "round",
|
|
13
|
+
"stroke-linejoin": "round",
|
|
14
|
+
class: cn("size-3.5", className),
|
|
15
|
+
"aria-hidden": "true",
|
|
16
|
+
children: /* @__PURE__ */ jsx("path", { d: "M20 6 9 17l-5-5" })
|
|
17
|
+
}
|
|
18
|
+
);
|
|
19
|
+
var MinusIcon = ({ class: className }) => /* @__PURE__ */ jsx("svg", { viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", "stroke-width": "2", class: cn("size-3.5", className), "aria-hidden": "true", children: /* @__PURE__ */ jsx("path", { d: "M5 12h14", "stroke-linecap": "round" }) });
|
|
20
|
+
var Checkbox = ({
|
|
21
|
+
checked: checkedProp,
|
|
22
|
+
defaultChecked = false,
|
|
23
|
+
onCheckedChange,
|
|
24
|
+
onChange,
|
|
25
|
+
class: className,
|
|
26
|
+
disabled,
|
|
27
|
+
ref: outerRef,
|
|
28
|
+
id,
|
|
29
|
+
...rest
|
|
30
|
+
}) => {
|
|
31
|
+
const inputRef = useRef(null);
|
|
32
|
+
const isControlled = checkedProp !== void 0;
|
|
33
|
+
const [inner, setInner] = useState(() => defaultChecked);
|
|
34
|
+
const state = isControlled ? checkedProp : inner;
|
|
35
|
+
useLayoutEffect(() => {
|
|
36
|
+
const el = inputRef.current;
|
|
37
|
+
if (!el) return;
|
|
38
|
+
el.indeterminate = state === "indeterminate";
|
|
39
|
+
}, [state]);
|
|
40
|
+
const dataState = state === true ? "checked" : state === "indeterminate" ? "indeterminate" : "unchecked";
|
|
41
|
+
return /* @__PURE__ */ jsxs(
|
|
42
|
+
"span",
|
|
43
|
+
{
|
|
44
|
+
"data-slot": "checkbox",
|
|
45
|
+
"data-state": dataState,
|
|
46
|
+
class: cn("group relative inline-grid size-4 shrink-0 place-content-center align-middle", className),
|
|
47
|
+
children: [
|
|
48
|
+
/* @__PURE__ */ jsx(
|
|
49
|
+
"input",
|
|
50
|
+
{
|
|
51
|
+
...rest,
|
|
52
|
+
id,
|
|
53
|
+
ref: (node) => {
|
|
54
|
+
inputRef.current = node;
|
|
55
|
+
if (typeof outerRef === "function") {
|
|
56
|
+
outerRef(node);
|
|
57
|
+
} else if (outerRef && typeof outerRef === "object" && "current" in outerRef) {
|
|
58
|
+
outerRef.current = node;
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
type: "checkbox",
|
|
62
|
+
disabled,
|
|
63
|
+
checked: state === true,
|
|
64
|
+
"aria-checked": state === "indeterminate" ? "mixed" : state,
|
|
65
|
+
class: peerInputClass,
|
|
66
|
+
onChange: (event) => {
|
|
67
|
+
const el = event.currentTarget;
|
|
68
|
+
const next = el.indeterminate ? "indeterminate" : el.checked;
|
|
69
|
+
if (!isControlled) {
|
|
70
|
+
setInner(next);
|
|
71
|
+
}
|
|
72
|
+
onCheckedChange?.(next);
|
|
73
|
+
onChange?.(event);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
),
|
|
77
|
+
/* @__PURE__ */ jsxs(
|
|
78
|
+
"span",
|
|
79
|
+
{
|
|
80
|
+
class: cn(
|
|
81
|
+
"pointer-events-none col-start-1 row-start-1 flex size-4 items-center justify-center rounded-[4px] border border-input bg-background shadow-xs transition-[color,box-shadow,background-color,border-color]",
|
|
82
|
+
"text-transparent dark:bg-input/30",
|
|
83
|
+
"group-data-[state=checked]:border-foreground group-data-[state=checked]:bg-foreground group-data-[state=checked]:text-background",
|
|
84
|
+
"group-data-[state=indeterminate]:border-foreground group-data-[state=indeterminate]:bg-foreground group-data-[state=indeterminate]:text-background",
|
|
85
|
+
"peer-focus-visible:outline-none peer-focus-visible:border-ring peer-focus-visible:ring-[3px] peer-focus-visible:ring-ring/50",
|
|
86
|
+
"peer-disabled:cursor-not-allowed peer-disabled:opacity-50",
|
|
87
|
+
"peer-aria-invalid:border-destructive peer-aria-invalid:ring-destructive/20 dark:peer-aria-invalid:ring-destructive/40"
|
|
88
|
+
),
|
|
89
|
+
"aria-hidden": "true",
|
|
90
|
+
children: [
|
|
91
|
+
/* @__PURE__ */ jsx(
|
|
92
|
+
CheckIcon,
|
|
93
|
+
{
|
|
94
|
+
class: cn(
|
|
95
|
+
"transition-opacity",
|
|
96
|
+
state === true ? "opacity-100" : "opacity-0",
|
|
97
|
+
state === "indeterminate" && "hidden"
|
|
98
|
+
)
|
|
99
|
+
}
|
|
100
|
+
),
|
|
101
|
+
/* @__PURE__ */ jsx(MinusIcon, { class: cn("absolute transition-opacity", state === "indeterminate" ? "opacity-100" : "opacity-0") })
|
|
102
|
+
]
|
|
103
|
+
}
|
|
104
|
+
)
|
|
105
|
+
]
|
|
106
|
+
}
|
|
107
|
+
);
|
|
108
|
+
};
|
|
109
|
+
var peerInputClass = cn(
|
|
110
|
+
"peer absolute inset-0 z-10 size-4 cursor-pointer appearance-none opacity-0",
|
|
111
|
+
"disabled:cursor-not-allowed"
|
|
112
|
+
);
|
|
113
|
+
|
|
114
|
+
// src/components/checkbox/index.ts
|
|
115
|
+
var checkbox_default = Checkbox;
|
|
116
|
+
|
|
117
|
+
export { Checkbox, checkbox_default };
|
|
118
|
+
//# sourceMappingURL=chunk-2UHCXHAX.js.map
|
|
119
|
+
//# sourceMappingURL=chunk-2UHCXHAX.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/checkbox/Checkbox.tsx","../src/components/checkbox/index.ts"],"names":[],"mappings":"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","file":"chunk-2UHCXHAX.js","sourcesContent":["import { useLayoutEffect, useRef, useState } from \"preact/hooks\";\nimport type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type CheckboxCheckedState = boolean | \"indeterminate\";\n\nexport type CheckboxProps = Omit<\n JSX.InputHTMLAttributes<HTMLInputElement>,\n \"type\" | \"checked\" | \"defaultChecked\" | \"onChange\"\n> & {\n checked?: CheckboxCheckedState;\n defaultChecked?: CheckboxCheckedState;\n onCheckedChange?: (checked: CheckboxCheckedState) => void;\n onChange?: (event: JSX.TargetedEvent<HTMLInputElement>) => void;\n};\n\nconst CheckIcon = ({ class: className }: { class?: string }) => (\n <svg\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class={cn(\"size-3.5\", className)}\n aria-hidden=\"true\"\n >\n <path d=\"M20 6 9 17l-5-5\" />\n </svg>\n);\n\nconst MinusIcon = ({ class: className }: { class?: string }) => (\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" class={cn(\"size-3.5\", className)} aria-hidden=\"true\">\n <path d=\"M5 12h14\" stroke-linecap=\"round\" />\n </svg>\n);\n\nexport const Checkbox = ({\n checked: checkedProp,\n defaultChecked = false,\n onCheckedChange,\n onChange,\n class: className,\n disabled,\n ref: outerRef,\n id,\n ...rest\n}: CheckboxProps) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const isControlled = checkedProp !== undefined;\n const [inner, setInner] = useState<CheckboxCheckedState>(() => defaultChecked);\n const state: CheckboxCheckedState = isControlled ? checkedProp! : inner;\n\n useLayoutEffect(() => {\n const el = inputRef.current;\n if (!el) return;\n el.indeterminate = state === \"indeterminate\";\n }, [state]);\n\n const dataState = state === true ? \"checked\" : state === \"indeterminate\" ? \"indeterminate\" : \"unchecked\";\n\n return (\n <span\n data-slot=\"checkbox\"\n data-state={dataState}\n class={cn(\"group relative inline-grid size-4 shrink-0 place-content-center align-middle\", className)}\n >\n <input\n {...rest}\n id={id}\n ref={(node) => {\n inputRef.current = node;\n if (typeof outerRef === \"function\") {\n outerRef(node);\n } else if (outerRef && typeof outerRef === \"object\" && \"current\" in outerRef) {\n (outerRef as { current: HTMLInputElement | null }).current = node;\n }\n }}\n type=\"checkbox\"\n disabled={disabled}\n checked={state === true}\n aria-checked={state === \"indeterminate\" ? \"mixed\" : state}\n class={peerInputClass}\n onChange={(event) => {\n const el = event.currentTarget as HTMLInputElement;\n const next: CheckboxCheckedState = el.indeterminate ? \"indeterminate\" : el.checked;\n if (!isControlled) {\n setInner(next);\n }\n onCheckedChange?.(next);\n onChange?.(event);\n }}\n />\n <span\n class={cn(\n \"pointer-events-none col-start-1 row-start-1 flex size-4 items-center justify-center rounded-[4px] border border-input bg-background shadow-xs transition-[color,box-shadow,background-color,border-color]\",\n \"text-transparent dark:bg-input/30\",\n \"group-data-[state=checked]:border-foreground group-data-[state=checked]:bg-foreground group-data-[state=checked]:text-background\",\n \"group-data-[state=indeterminate]:border-foreground group-data-[state=indeterminate]:bg-foreground group-data-[state=indeterminate]:text-background\",\n \"peer-focus-visible:outline-none peer-focus-visible:border-ring peer-focus-visible:ring-[3px] peer-focus-visible:ring-ring/50\",\n \"peer-disabled:cursor-not-allowed peer-disabled:opacity-50\",\n \"peer-aria-invalid:border-destructive peer-aria-invalid:ring-destructive/20 dark:peer-aria-invalid:ring-destructive/40\"\n )}\n aria-hidden=\"true\"\n >\n <CheckIcon\n class={cn(\n \"transition-opacity\",\n state === true ? \"opacity-100\" : \"opacity-0\",\n state === \"indeterminate\" && \"hidden\"\n )}\n />\n <MinusIcon class={cn(\"absolute transition-opacity\", state === \"indeterminate\" ? \"opacity-100\" : \"opacity-0\")} />\n </span>\n </span>\n );\n};\n\nconst peerInputClass = cn(\n \"peer absolute inset-0 z-10 size-4 cursor-pointer appearance-none opacity-0\",\n \"disabled:cursor-not-allowed\"\n);\n","import { Checkbox, type CheckboxCheckedState } from \"./Checkbox\";\n\nexport { Checkbox, type CheckboxCheckedState };\n\nexport default Checkbox;\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
2
|
+
import { jsx } from 'preact/jsx-runtime';
|
|
3
|
+
|
|
4
|
+
var Video = ({ class: className, controls = true, children, ...rest }) => (
|
|
5
|
+
// Captions are the consumer's responsibility (passed as <track> via children).
|
|
6
|
+
// eslint-disable-next-line jsx-a11y/media-has-caption
|
|
7
|
+
/* @__PURE__ */ jsx("video", { "data-slot": "video", class: cn("block w-full rounded-md border", className), controls, ...rest, children })
|
|
8
|
+
);
|
|
9
|
+
|
|
10
|
+
export { Video };
|
|
11
|
+
//# sourceMappingURL=chunk-2XNWLXG2.js.map
|
|
12
|
+
//# sourceMappingURL=chunk-2XNWLXG2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/video/Video.tsx"],"names":[],"mappings":";;;AAOO,IAAM,KAAA,GAAQ,CAAC,EAAE,KAAA,EAAO,WAAW,QAAA,GAAW,IAAA,EAAM,QAAA,EAAU,GAAG,IAAA,EAAK;AAAA;AAAA;AAAA,kBAG3E,GAAA,CAAC,OAAA,EAAA,EAAM,WAAA,EAAU,OAAA,EAAQ,KAAA,EAAO,EAAA,CAAG,gCAAA,EAAkC,SAAS,CAAA,EAAG,QAAA,EAAqB,GAAG,IAAA,EACtG,QAAA,EACH;AAAA","file":"chunk-2XNWLXG2.js","sourcesContent":["import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type VideoProps = JSX.VideoHTMLAttributes<HTMLVideoElement> & {\n children?: ComponentChildren;\n};\n\nexport const Video = ({ class: className, controls = true, children, ...rest }: VideoProps) => (\n // Captions are the consumer's responsibility (passed as <track> via children).\n // eslint-disable-next-line jsx-a11y/media-has-caption\n <video data-slot=\"video\" class={cn(\"block w-full rounded-md border\", className)} controls={controls} {...rest}>\n {children}\n </video>\n);\n\n"]}
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
import { signal } from '@preact/signals';
|
|
2
|
+
import { jsx, jsxs } from 'preact/jsx-runtime';
|
|
3
|
+
|
|
4
|
+
// src/components/toast/toast-store.ts
|
|
5
|
+
var toasts = signal([]);
|
|
6
|
+
var EXIT_ANIMATION_MS = 180;
|
|
7
|
+
var addToast = (toast) => {
|
|
8
|
+
const id = `toast-${Date.now()}-${Math.random().toString(16).slice(2)}`;
|
|
9
|
+
const nextToast = {
|
|
10
|
+
id,
|
|
11
|
+
variant: toast.variant ?? "default",
|
|
12
|
+
duration: toast.duration ?? 5e3,
|
|
13
|
+
...toast
|
|
14
|
+
};
|
|
15
|
+
toasts.value = [...toasts.value, nextToast];
|
|
16
|
+
if (typeof window !== "undefined" && (nextToast.duration ?? 0) > 0) {
|
|
17
|
+
window.setTimeout(() => {
|
|
18
|
+
removeToast(id);
|
|
19
|
+
}, nextToast.duration);
|
|
20
|
+
}
|
|
21
|
+
return id;
|
|
22
|
+
};
|
|
23
|
+
var removeToast = (id) => {
|
|
24
|
+
const item = toasts.value.find((toast) => toast.id === id);
|
|
25
|
+
if (!item) return;
|
|
26
|
+
if (item.closing) return;
|
|
27
|
+
toasts.value = toasts.value.map((toast) => toast.id === id ? { ...toast, closing: true } : toast);
|
|
28
|
+
if (typeof window !== "undefined") {
|
|
29
|
+
window.setTimeout(() => {
|
|
30
|
+
toasts.value = toasts.value.filter((toast) => toast.id !== id);
|
|
31
|
+
}, EXIT_ANIMATION_MS);
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
toasts.value = toasts.value.filter((toast) => toast.id !== id);
|
|
35
|
+
};
|
|
36
|
+
var POSITION_CLASS = {
|
|
37
|
+
"top-left": "top-4 left-4",
|
|
38
|
+
"top-center": "top-4 left-1/2 -translate-x-1/2",
|
|
39
|
+
"top-right": "top-4 right-4",
|
|
40
|
+
"bottom-left": "bottom-4 left-4",
|
|
41
|
+
"bottom-center": "bottom-4 left-1/2 -translate-x-1/2",
|
|
42
|
+
"bottom-right": "bottom-4 right-4"
|
|
43
|
+
};
|
|
44
|
+
var ENTER_CLASS = {
|
|
45
|
+
"top-left": "slide-in-from-top-2",
|
|
46
|
+
"top-center": "slide-in-from-top-2",
|
|
47
|
+
"top-right": "slide-in-from-top-2",
|
|
48
|
+
"bottom-left": "slide-in-from-bottom-2",
|
|
49
|
+
"bottom-center": "slide-in-from-bottom-2",
|
|
50
|
+
"bottom-right": "slide-in-from-bottom-2"
|
|
51
|
+
};
|
|
52
|
+
var EXIT_CLASS = {
|
|
53
|
+
"top-left": "slide-out-to-top-2",
|
|
54
|
+
"top-center": "slide-out-to-top-2",
|
|
55
|
+
"top-right": "slide-out-to-top-2",
|
|
56
|
+
"bottom-left": "slide-out-to-bottom-2",
|
|
57
|
+
"bottom-center": "slide-out-to-bottom-2",
|
|
58
|
+
"bottom-right": "slide-out-to-bottom-2"
|
|
59
|
+
};
|
|
60
|
+
var TONE_CLASS = {
|
|
61
|
+
default: "border-border",
|
|
62
|
+
success: "border-emerald-500/35",
|
|
63
|
+
info: "border-sky-500/35",
|
|
64
|
+
warning: "border-amber-500/35",
|
|
65
|
+
error: "border-destructive/40",
|
|
66
|
+
destructive: "border-destructive/40"
|
|
67
|
+
};
|
|
68
|
+
var BADGE_CLASS = {
|
|
69
|
+
default: "bg-muted text-muted-foreground",
|
|
70
|
+
success: "bg-emerald-500/15 text-emerald-500",
|
|
71
|
+
info: "bg-sky-500/15 text-sky-500",
|
|
72
|
+
warning: "bg-amber-500/15 text-amber-500",
|
|
73
|
+
error: "bg-destructive/15 text-destructive",
|
|
74
|
+
destructive: "bg-destructive/15 text-destructive"
|
|
75
|
+
};
|
|
76
|
+
var LABEL = {
|
|
77
|
+
default: "Info",
|
|
78
|
+
success: "Success",
|
|
79
|
+
info: "Info",
|
|
80
|
+
warning: "Warning",
|
|
81
|
+
error: "Error",
|
|
82
|
+
destructive: "Error"
|
|
83
|
+
};
|
|
84
|
+
var Toaster = ({ position = "bottom-right" }) => {
|
|
85
|
+
return /* @__PURE__ */ jsx(
|
|
86
|
+
"div",
|
|
87
|
+
{
|
|
88
|
+
"data-slot": "toaster",
|
|
89
|
+
role: "region",
|
|
90
|
+
"aria-live": "polite",
|
|
91
|
+
"aria-label": "Notifications",
|
|
92
|
+
class: ["pointer-events-none fixed z-[120] grid w-[calc(100%-2rem)] max-w-sm gap-2", POSITION_CLASS[position]].join(" "),
|
|
93
|
+
children: toasts.value.map((toast) => /* @__PURE__ */ jsx(
|
|
94
|
+
"div",
|
|
95
|
+
{
|
|
96
|
+
"data-slot": "toast-item",
|
|
97
|
+
class: [
|
|
98
|
+
"pointer-events-auto grid gap-3 rounded-xl border bg-popover/95 p-4 shadow-lg backdrop-blur-sm",
|
|
99
|
+
toast.closing ? "animate-out fade-out duration-150" : "animate-in fade-in duration-200",
|
|
100
|
+
toast.closing ? EXIT_CLASS[position] : ENTER_CLASS[position],
|
|
101
|
+
TONE_CLASS[toast.variant ?? "default"] ?? TONE_CLASS.default
|
|
102
|
+
].filter(Boolean).join(" "),
|
|
103
|
+
children: /* @__PURE__ */ jsxs("div", { class: "flex items-start gap-3", children: [
|
|
104
|
+
/* @__PURE__ */ jsx(
|
|
105
|
+
"div",
|
|
106
|
+
{
|
|
107
|
+
"aria-hidden": "true",
|
|
108
|
+
class: [
|
|
109
|
+
"inline-flex h-6 min-h-6 w-6 min-w-6 items-center justify-center rounded-md text-[11px] font-semibold uppercase",
|
|
110
|
+
BADGE_CLASS[toast.variant ?? "default"] ?? BADGE_CLASS.default
|
|
111
|
+
].join(" "),
|
|
112
|
+
children: (LABEL[toast.variant ?? "default"] ?? LABEL.default).slice(0, 1)
|
|
113
|
+
}
|
|
114
|
+
),
|
|
115
|
+
/* @__PURE__ */ jsxs("div", { class: "grid min-w-0 flex-1 gap-1", children: [
|
|
116
|
+
/* @__PURE__ */ jsxs("div", { class: "flex items-start justify-between gap-2", children: [
|
|
117
|
+
/* @__PURE__ */ jsx(
|
|
118
|
+
"div",
|
|
119
|
+
{
|
|
120
|
+
"data-slot": "toast-title",
|
|
121
|
+
class: [
|
|
122
|
+
"text-sm font-semibold",
|
|
123
|
+
toast.variant === "destructive" || toast.variant === "error" ? "text-destructive" : "text-foreground"
|
|
124
|
+
].filter(Boolean).join(" "),
|
|
125
|
+
children: toast.title
|
|
126
|
+
}
|
|
127
|
+
),
|
|
128
|
+
/* @__PURE__ */ jsx(
|
|
129
|
+
"button",
|
|
130
|
+
{
|
|
131
|
+
type: "button",
|
|
132
|
+
"data-slot": "toast-close",
|
|
133
|
+
"aria-label": "Dismiss notification",
|
|
134
|
+
class: "inline-flex h-6 min-h-6 items-center rounded-md px-1.5 text-xs font-medium text-muted-foreground transition-colors hover:bg-accent hover:text-foreground",
|
|
135
|
+
onClick: () => removeToast(toast.id),
|
|
136
|
+
children: "Close"
|
|
137
|
+
}
|
|
138
|
+
)
|
|
139
|
+
] }),
|
|
140
|
+
toast.description ? /* @__PURE__ */ jsx("div", { "data-slot": "toast-description", class: "text-xs leading-relaxed text-muted-foreground", children: toast.description }) : null,
|
|
141
|
+
toast.actionLabel ? /* @__PURE__ */ jsx("div", { class: "pt-0.5", children: /* @__PURE__ */ jsx(
|
|
142
|
+
"button",
|
|
143
|
+
{
|
|
144
|
+
type: "button",
|
|
145
|
+
"data-slot": "toast-action",
|
|
146
|
+
class: "inline-flex h-8 items-center rounded-md border border-border bg-background px-2.5 text-xs font-medium transition-colors hover:bg-accent",
|
|
147
|
+
onClick: () => {
|
|
148
|
+
toast.onAction?.();
|
|
149
|
+
removeToast(toast.id);
|
|
150
|
+
},
|
|
151
|
+
children: toast.actionLabel
|
|
152
|
+
}
|
|
153
|
+
) }) : null,
|
|
154
|
+
/* @__PURE__ */ jsx("div", { class: "text-[10px] uppercase tracking-wide text-muted-foreground/90", children: LABEL[toast.variant ?? "default"] ?? LABEL.default })
|
|
155
|
+
] })
|
|
156
|
+
] })
|
|
157
|
+
},
|
|
158
|
+
toast.id
|
|
159
|
+
))
|
|
160
|
+
}
|
|
161
|
+
);
|
|
162
|
+
};
|
|
163
|
+
|
|
164
|
+
// src/components/toast/useToast.ts
|
|
165
|
+
var useToast = () => {
|
|
166
|
+
return {
|
|
167
|
+
toasts,
|
|
168
|
+
toast: addToast,
|
|
169
|
+
dismiss: removeToast
|
|
170
|
+
};
|
|
171
|
+
};
|
|
172
|
+
|
|
173
|
+
export { Toaster, useToast };
|
|
174
|
+
//# sourceMappingURL=chunk-3EHH62ZA.js.map
|
|
175
|
+
//# sourceMappingURL=chunk-3EHH62ZA.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/toast/toast-store.ts","../src/components/toast/Toaster.tsx","../src/components/toast/useToast.ts"],"names":[],"mappings":"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","file":"chunk-3EHH62ZA.js","sourcesContent":["import { signal } from \"@preact/signals\";\n\nexport type ToastItemData = {\n id: string;\n title: string;\n description?: string;\n variant?: \"default\" | \"success\" | \"info\" | \"warning\" | \"error\" | \"destructive\";\n actionLabel?: string;\n onAction?: () => void;\n duration?: number;\n closing?: boolean;\n};\n\nexport const toasts = signal<ToastItemData[]>([]);\nconst EXIT_ANIMATION_MS = 180;\n\nexport const addToast = (toast: Omit<ToastItemData, \"id\">) => {\n const id = `toast-${Date.now()}-${Math.random().toString(16).slice(2)}`;\n const nextToast: ToastItemData = {\n id,\n variant: toast.variant ?? \"default\",\n duration: toast.duration ?? 5000,\n ...toast\n };\n toasts.value = [...toasts.value, nextToast];\n\n if (typeof window !== \"undefined\" && (nextToast.duration ?? 0) > 0) {\n window.setTimeout(() => {\n removeToast(id);\n }, nextToast.duration);\n }\n\n return id;\n};\n\nexport const removeToast = (id: string) => {\n const item = toasts.value.find((toast) => toast.id === id);\n if (!item) return;\n if (item.closing) return;\n\n toasts.value = toasts.value.map((toast) => (toast.id === id ? { ...toast, closing: true } : toast));\n\n if (typeof window !== \"undefined\") {\n window.setTimeout(() => {\n toasts.value = toasts.value.filter((toast) => toast.id !== id);\n }, EXIT_ANIMATION_MS);\n return;\n }\n\n toasts.value = toasts.value.filter((toast) => toast.id !== id);\n};\n","import { toasts, removeToast } from \"./toast-store\";\n\ntype ToasterPosition =\n | \"top-left\"\n | \"top-center\"\n | \"top-right\"\n | \"bottom-left\"\n | \"bottom-center\"\n | \"bottom-right\";\n\nconst POSITION_CLASS: Record<ToasterPosition, string> = {\n \"top-left\": \"top-4 left-4\",\n \"top-center\": \"top-4 left-1/2 -translate-x-1/2\",\n \"top-right\": \"top-4 right-4\",\n \"bottom-left\": \"bottom-4 left-4\",\n \"bottom-center\": \"bottom-4 left-1/2 -translate-x-1/2\",\n \"bottom-right\": \"bottom-4 right-4\"\n};\n\nconst ENTER_CLASS: Record<ToasterPosition, string> = {\n \"top-left\": \"slide-in-from-top-2\",\n \"top-center\": \"slide-in-from-top-2\",\n \"top-right\": \"slide-in-from-top-2\",\n \"bottom-left\": \"slide-in-from-bottom-2\",\n \"bottom-center\": \"slide-in-from-bottom-2\",\n \"bottom-right\": \"slide-in-from-bottom-2\"\n};\n\nconst EXIT_CLASS: Record<ToasterPosition, string> = {\n \"top-left\": \"slide-out-to-top-2\",\n \"top-center\": \"slide-out-to-top-2\",\n \"top-right\": \"slide-out-to-top-2\",\n \"bottom-left\": \"slide-out-to-bottom-2\",\n \"bottom-center\": \"slide-out-to-bottom-2\",\n \"bottom-right\": \"slide-out-to-bottom-2\"\n};\n\nconst TONE_CLASS: Record<string, string> = {\n default: \"border-border\",\n success: \"border-emerald-500/35\",\n info: \"border-sky-500/35\",\n warning: \"border-amber-500/35\",\n error: \"border-destructive/40\",\n destructive: \"border-destructive/40\"\n};\n\nconst BADGE_CLASS: Record<string, string> = {\n default: \"bg-muted text-muted-foreground\",\n success: \"bg-emerald-500/15 text-emerald-500\",\n info: \"bg-sky-500/15 text-sky-500\",\n warning: \"bg-amber-500/15 text-amber-500\",\n error: \"bg-destructive/15 text-destructive\",\n destructive: \"bg-destructive/15 text-destructive\"\n};\n\nconst LABEL: Record<string, string> = {\n default: \"Info\",\n success: \"Success\",\n info: \"Info\",\n warning: \"Warning\",\n error: \"Error\",\n destructive: \"Error\"\n};\n\ntype ToasterProps = {\n position?: ToasterPosition;\n};\n\nexport const Toaster = ({ position = \"bottom-right\" }: ToasterProps) => {\n return (\n <div\n data-slot=\"toaster\"\n role=\"region\"\n aria-live=\"polite\"\n aria-label=\"Notifications\"\n class={[\"pointer-events-none fixed z-[120] grid w-[calc(100%-2rem)] max-w-sm gap-2\", POSITION_CLASS[position]].join(\" \")}\n >\n {toasts.value.map((toast) => (\n <div\n key={toast.id}\n data-slot=\"toast-item\"\n class={[\n \"pointer-events-auto grid gap-3 rounded-xl border bg-popover/95 p-4 shadow-lg backdrop-blur-sm\",\n toast.closing ? \"animate-out fade-out duration-150\" : \"animate-in fade-in duration-200\",\n toast.closing ? EXIT_CLASS[position] : ENTER_CLASS[position],\n TONE_CLASS[toast.variant ?? \"default\"] ?? TONE_CLASS.default\n ]\n .filter(Boolean)\n .join(\" \")}\n >\n <div class=\"flex items-start gap-3\">\n <div\n aria-hidden=\"true\"\n class={[\n \"inline-flex h-6 min-h-6 w-6 min-w-6 items-center justify-center rounded-md text-[11px] font-semibold uppercase\",\n BADGE_CLASS[toast.variant ?? \"default\"] ?? BADGE_CLASS.default\n ].join(\" \")}\n >\n {(LABEL[toast.variant ?? \"default\"] ?? LABEL.default).slice(0, 1)}\n </div>\n <div class=\"grid min-w-0 flex-1 gap-1\">\n <div class=\"flex items-start justify-between gap-2\">\n <div\n data-slot=\"toast-title\"\n class={[\n \"text-sm font-semibold\",\n toast.variant === \"destructive\" || toast.variant === \"error\" ? \"text-destructive\" : \"text-foreground\"\n ]\n .filter(Boolean)\n .join(\" \")}\n >\n {toast.title}\n </div>\n <button\n type=\"button\"\n data-slot=\"toast-close\"\n aria-label=\"Dismiss notification\"\n class=\"inline-flex h-6 min-h-6 items-center rounded-md px-1.5 text-xs font-medium text-muted-foreground transition-colors hover:bg-accent hover:text-foreground\"\n onClick={() => removeToast(toast.id)}\n >\n Close\n </button>\n </div>\n {toast.description ? (\n <div data-slot=\"toast-description\" class=\"text-xs leading-relaxed text-muted-foreground\">\n {toast.description}\n </div>\n ) : null}\n {toast.actionLabel ? (\n <div class=\"pt-0.5\">\n <button\n type=\"button\"\n data-slot=\"toast-action\"\n class=\"inline-flex h-8 items-center rounded-md border border-border bg-background px-2.5 text-xs font-medium transition-colors hover:bg-accent\"\n onClick={() => {\n toast.onAction?.();\n removeToast(toast.id);\n }}\n >\n {toast.actionLabel}\n </button>\n </div>\n ) : null}\n <div class=\"text-[10px] uppercase tracking-wide text-muted-foreground/90\">{LABEL[toast.variant ?? \"default\"] ?? LABEL.default}</div>\n </div>\n </div>\n </div>\n ))}\n </div>\n );\n};\n","import { addToast, removeToast, toasts } from \"./toast-store\";\n\nexport const useToast = () => {\n return {\n toasts,\n toast: addToast,\n dismiss: removeToast\n };\n};\n\n"]}
|