@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/alert-dialog/AlertDialog.tsx","../src/components/alert-dialog/AlertDialogAction.tsx","../src/components/alert-dialog/AlertDialogCancel.tsx","../src/components/alert-dialog/AlertDialogContent.tsx","../src/components/alert-dialog/AlertDialogDescription.tsx","../src/components/alert-dialog/AlertDialogFooter.tsx","../src/components/alert-dialog/AlertDialogHeader.tsx","../src/components/alert-dialog/AlertDialogMedia.tsx","../src/components/alert-dialog/AlertDialogTitle.tsx","../src/components/alert-dialog/AlertDialogTrigger.tsx","../src/components/alert-dialog/index.ts"],"names":["jsx"],"mappings":"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","file":"chunk-G6PBJZYF.js","sourcesContent":["import type { ComponentChildren } from \"preact\";\nimport { Dialog, type DialogProps } from \"../dialog/Dialog\";\n\nexport type AlertDialogProps = DialogProps & { children?: ComponentChildren };\n\nexport const AlertDialog = ({ children, ...rest }: AlertDialogProps) => (\n <Dialog data-slot=\"alert-dialog\" lockBodyScroll {...rest}>\n {children}\n </Dialog>\n);\n","import type { ComponentChildren } from \"preact\";\nimport type { VariantProps } from \"tailwind-variants\";\nimport { cn } from \"../../lib/utils\";\nimport { button } from \"../button/Button\";\nimport { DialogClose, type DialogCloseProps } from \"../dialog/DialogClose\";\n\nexport type AlertDialogActionProps = DialogCloseProps & {\n variant?: VariantProps<typeof button>[\"variant\"];\n children?: ComponentChildren;\n};\n\nexport const AlertDialogAction = ({\n variant = \"default\",\n class: className,\n children,\n ...rest\n}: AlertDialogActionProps) => (\n <DialogClose\n class={button({ variant, class: cn(\"w-full sm:w-auto\", className as string | undefined) })}\n data-slot=\"alert-dialog-action\"\n {...rest}\n >\n {children}\n </DialogClose>\n);\n","import type { ComponentChildren } from \"preact\";\nimport type { VariantProps } from \"tailwind-variants\";\nimport { cn } from \"../../lib/utils\";\nimport { button } from \"../button/Button\";\nimport { DialogClose, type DialogCloseProps } from \"../dialog/DialogClose\";\n\nexport type AlertDialogCancelProps = DialogCloseProps & {\n variant?: VariantProps<typeof button>[\"variant\"];\n children?: ComponentChildren;\n};\n\nexport const AlertDialogCancel = ({\n variant = \"outline\",\n class: className,\n children,\n ...rest\n}: AlertDialogCancelProps) => (\n <DialogClose\n class={button({ variant, class: cn(\"w-full sm:w-auto\", className as string | undefined) })}\n data-slot=\"alert-dialog-cancel\"\n {...rest}\n >\n {children}\n </DialogClose>\n);\n","import type { ComponentChildren } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { DialogContent, dialogViewportBleedClass, type DialogContentProps } from \"../dialog/DialogContent\";\n\nexport type AlertDialogContentSize = \"default\" | \"sm\";\n\nexport type AlertDialogContentProps = DialogContentProps & {\n /** `sm` — narrower panel (shadcn parity). */\n size?: AlertDialogContentSize;\n children?: ComponentChildren;\n};\n\nexport const AlertDialogContent = ({\n size = \"default\",\n class: className,\n children,\n ...rest\n}: AlertDialogContentProps) => (\n // presentation=\"slot\": we own the full-screen flex overlay + inner panel; default \"modal\" would add a second backdrop.\n <DialogContent\n presentation=\"slot\"\n class={cn(\n dialogViewportBleedClass,\n \"z-50 flex items-center justify-center bg-black/50 p-3 sm:p-6 pointer-events-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fill-mode-forwards fade-in fade-out\"\n )}\n data-slot=\"alert-dialog-content\"\n {...rest}\n >\n <div\n class={cn(\n \"data-open:animate-in relative z-[1] grid min-h-0 min-w-0 w-full max-w-[calc(100svw-1.5rem)] max-h-[calc(100dvh-1.5rem)] overflow-y-auto overflow-x-hidden rounded-xl border bg-background shadow-lg pointer-events-auto\",\n size === \"sm\" ? \"gap-3 p-4 sm:max-w-sm sm:max-h-[calc(100dvh-3rem)] sm:p-4\" : \"gap-4 p-4 sm:max-w-[32rem] sm:max-h-[calc(100dvh-3rem)] sm:p-6\",\n className\n )}\n data-slot=\"alert-dialog-panel\"\n data-size={size}\n data-open=\"true\"\n >\n {children}\n </div>\n </DialogContent>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { DialogDescription } from \"../dialog/DialogDescription\";\n\nexport type AlertDialogDescriptionProps = JSX.HTMLAttributes<HTMLParagraphElement> & {\n children?: ComponentChildren;\n};\n\nexport const AlertDialogDescription = ({ class: className, children, ...rest }: AlertDialogDescriptionProps) => (\n <DialogDescription class={cn(\"text-muted-foreground text-sm leading-relaxed break-words\", className)} data-slot=\"alert-dialog-description\" {...rest}>\n {children}\n </DialogDescription>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { DialogFooter } from \"../dialog/DialogFooter\";\n\nexport type AlertDialogFooterProps = JSX.HTMLAttributes<HTMLDivElement> & { children?: ComponentChildren };\n\nexport const AlertDialogFooter = ({ class: className, children, ...rest }: AlertDialogFooterProps) => (\n <DialogFooter class={cn(\"flex flex-col-reverse gap-2 sm:flex-row sm:justify-end\", className)} data-slot=\"alert-dialog-footer\" {...rest}>\n {children}\n </DialogFooter>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { DialogHeader } from \"../dialog/DialogHeader\";\n\nexport type AlertDialogHeaderProps = JSX.HTMLAttributes<HTMLDivElement> & { children?: ComponentChildren };\n\nexport const AlertDialogHeader = ({ class: className, children, ...rest }: AlertDialogHeaderProps) => (\n <DialogHeader class={cn(\"grid gap-2 text-center sm:text-left\", className)} data-slot=\"alert-dialog-header\" {...rest}>\n {children}\n </DialogHeader>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type AlertDialogMediaProps = JSX.HTMLAttributes<HTMLDivElement> & { children?: ComponentChildren };\n\n/** Optional icon or image slot above the title (shadcn AlertDialogMedia pattern). */\nexport const AlertDialogMedia = ({ class: className, children, ...rest }: AlertDialogMediaProps) => (\n <div\n data-slot=\"alert-dialog-media\"\n class={cn(\n \"mx-auto flex size-12 shrink-0 items-center justify-center rounded-full bg-muted text-foreground\",\n \"[&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-6\",\n className\n )}\n {...rest}\n >\n {children}\n </div>\n);\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { DialogTitle } from \"../dialog/DialogTitle\";\n\nexport type AlertDialogTitleProps = JSX.HTMLAttributes<HTMLHeadingElement> & { children?: ComponentChildren };\n\nexport const AlertDialogTitle = ({ class: className, children, ...rest }: AlertDialogTitleProps) => (\n <DialogTitle class={cn(\"text-lg font-semibold break-words\", className)} data-slot=\"alert-dialog-title\" {...rest}>\n {children}\n </DialogTitle>\n);\n","import type { ComponentChildren } from \"preact\";\nimport { button } from \"../button/Button\";\nimport { DialogTrigger, type DialogTriggerProps } from \"../dialog/DialogTrigger\";\n\nexport type AlertDialogTriggerProps = DialogTriggerProps & { children?: ComponentChildren };\n\nexport const AlertDialogTrigger = ({ asChild, class: className, children, ...rest }: AlertDialogTriggerProps) => (\n <DialogTrigger\n asChild={asChild}\n class={asChild ? className : button({ variant: \"outline\", class: className as string | undefined })}\n data-slot=\"alert-dialog-trigger\"\n {...rest}\n >\n {children}\n </DialogTrigger>\n);\n","import { AlertDialog } from \"./AlertDialog\";\nimport { AlertDialogAction } from \"./AlertDialogAction\";\nimport { AlertDialogCancel } from \"./AlertDialogCancel\";\nimport { AlertDialogContent } from \"./AlertDialogContent\";\nimport { AlertDialogDescription } from \"./AlertDialogDescription\";\nimport { AlertDialogFooter } from \"./AlertDialogFooter\";\nimport { AlertDialogHeader } from \"./AlertDialogHeader\";\nimport { AlertDialogMedia } from \"./AlertDialogMedia\";\nimport { AlertDialogTitle } from \"./AlertDialogTitle\";\nimport { AlertDialogTrigger } from \"./AlertDialogTrigger\";\n\nexport {\n AlertDialog,\n AlertDialogAction,\n AlertDialogCancel,\n AlertDialogContent,\n AlertDialogDescription,\n AlertDialogFooter,\n AlertDialogHeader,\n AlertDialogMedia,\n AlertDialogTitle,\n AlertDialogTrigger\n};\n\nexport default {\n Root: AlertDialog,\n Trigger: AlertDialogTrigger,\n Content: AlertDialogContent,\n Header: AlertDialogHeader,\n Footer: AlertDialogFooter,\n Title: AlertDialogTitle,\n Description: AlertDialogDescription,\n Media: AlertDialogMedia,\n Cancel: AlertDialogCancel,\n Action: AlertDialogAction\n};\n\n"]}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { Spinner } from './chunk-BMF5SGYP.js';
|
|
2
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
3
|
+
import { signal } from '@preact/signals';
|
|
4
|
+
import { jsxs, jsx } from 'preact/jsx-runtime';
|
|
5
|
+
|
|
6
|
+
var Dropzone = ({
|
|
7
|
+
accept,
|
|
8
|
+
multiple = true,
|
|
9
|
+
onFilesChange,
|
|
10
|
+
class: className,
|
|
11
|
+
children,
|
|
12
|
+
...rest
|
|
13
|
+
}) => {
|
|
14
|
+
const isDragging = signal(false);
|
|
15
|
+
const readFiles = (list) => {
|
|
16
|
+
const files = list ? Array.from(list) : [];
|
|
17
|
+
onFilesChange?.(files);
|
|
18
|
+
};
|
|
19
|
+
const onDragOver = (event) => {
|
|
20
|
+
event.preventDefault();
|
|
21
|
+
isDragging.value = true;
|
|
22
|
+
};
|
|
23
|
+
const onDragLeave = (event) => {
|
|
24
|
+
event.preventDefault();
|
|
25
|
+
isDragging.value = false;
|
|
26
|
+
};
|
|
27
|
+
const onDrop = (event) => {
|
|
28
|
+
event.preventDefault();
|
|
29
|
+
isDragging.value = false;
|
|
30
|
+
readFiles(event.dataTransfer?.files ?? null);
|
|
31
|
+
};
|
|
32
|
+
return /* @__PURE__ */ jsxs(
|
|
33
|
+
"div",
|
|
34
|
+
{
|
|
35
|
+
"data-slot": "dropzone",
|
|
36
|
+
"data-dragging": isDragging.value ? "true" : "false",
|
|
37
|
+
class: cn(
|
|
38
|
+
"border-input bg-background hover:bg-muted/50 relative rounded-lg border border-dashed p-5 transition-colors",
|
|
39
|
+
isDragging.value && "border-primary bg-primary/5",
|
|
40
|
+
className
|
|
41
|
+
),
|
|
42
|
+
onDragOver,
|
|
43
|
+
onDragLeave,
|
|
44
|
+
onDrop,
|
|
45
|
+
...rest,
|
|
46
|
+
children: [
|
|
47
|
+
/* @__PURE__ */ jsx(
|
|
48
|
+
"input",
|
|
49
|
+
{
|
|
50
|
+
"data-slot": "dropzone-input",
|
|
51
|
+
type: "file",
|
|
52
|
+
accept,
|
|
53
|
+
multiple,
|
|
54
|
+
class: "absolute inset-0 cursor-pointer opacity-0",
|
|
55
|
+
onChange: (event) => readFiles(event.currentTarget.files)
|
|
56
|
+
}
|
|
57
|
+
),
|
|
58
|
+
children
|
|
59
|
+
]
|
|
60
|
+
}
|
|
61
|
+
);
|
|
62
|
+
};
|
|
63
|
+
var DropzoneUploadIndicator = ({
|
|
64
|
+
class: className,
|
|
65
|
+
children = "Drop files here or click to upload",
|
|
66
|
+
...rest
|
|
67
|
+
}) => /* @__PURE__ */ jsx("div", { "data-slot": "dropzone-upload-indicator", class: cn("text-muted-foreground text-sm", className), ...rest, children });
|
|
68
|
+
var DropzoneLoadingIndicator = ({
|
|
69
|
+
class: className,
|
|
70
|
+
children = "Uploading...",
|
|
71
|
+
...rest
|
|
72
|
+
}) => /* @__PURE__ */ jsxs("div", { "data-slot": "dropzone-loading-indicator", class: cn("inline-flex items-center gap-2 text-sm", className), ...rest, children: [
|
|
73
|
+
/* @__PURE__ */ jsx(Spinner, { size: "sm" }),
|
|
74
|
+
/* @__PURE__ */ jsx("span", { children })
|
|
75
|
+
] });
|
|
76
|
+
var DropzoneFilesList = ({ files, class: className, ...rest }) => /* @__PURE__ */ jsx("ul", { "data-slot": "dropzone-files-list", class: cn("text-muted-foreground mt-2 grid gap-1 text-sm", className), ...rest, children: files.map((file) => /* @__PURE__ */ jsx("li", { children: file.name }, file.name)) });
|
|
77
|
+
|
|
78
|
+
export { Dropzone, DropzoneFilesList, DropzoneLoadingIndicator, DropzoneUploadIndicator };
|
|
79
|
+
//# sourceMappingURL=chunk-GFF5OT46.js.map
|
|
80
|
+
//# sourceMappingURL=chunk-GFF5OT46.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/dropzone/Dropzone.tsx","../src/components/dropzone/DropzoneUploadIndicator.tsx","../src/components/dropzone/DropzoneLoadingIndicator.tsx","../src/components/dropzone/DropzoneFilesList.tsx"],"names":["jsx","jsxs"],"mappings":"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","file":"chunk-GFF5OT46.js","sourcesContent":["import { signal } from \"@preact/signals\";\nimport type { ComponentChildren, JSX, TargetedDragEvent } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type DropzoneProps = JSX.HTMLAttributes<HTMLDivElement> & {\n accept?: string;\n multiple?: boolean;\n onFilesChange?: (files: File[]) => void;\n children?: ComponentChildren;\n};\n\nexport const Dropzone = ({\n accept,\n multiple = true,\n onFilesChange,\n class: className,\n children,\n ...rest\n}: DropzoneProps) => {\n const isDragging = signal(false);\n\n const readFiles = (list: FileList | null) => {\n const files = list ? Array.from(list) : [];\n onFilesChange?.(files);\n };\n\n const onDragOver = (event: TargetedDragEvent<HTMLDivElement>) => {\n event.preventDefault();\n isDragging.value = true;\n };\n\n const onDragLeave = (event: TargetedDragEvent<HTMLDivElement>) => {\n event.preventDefault();\n isDragging.value = false;\n };\n\n const onDrop = (event: TargetedDragEvent<HTMLDivElement>) => {\n event.preventDefault();\n isDragging.value = false;\n readFiles(event.dataTransfer?.files ?? null);\n };\n\n return (\n <div\n data-slot=\"dropzone\"\n data-dragging={isDragging.value ? \"true\" : \"false\"}\n class={cn(\n \"border-input bg-background hover:bg-muted/50 relative rounded-lg border border-dashed p-5 transition-colors\",\n isDragging.value && \"border-primary bg-primary/5\",\n className\n )}\n onDragOver={onDragOver}\n onDragLeave={onDragLeave}\n onDrop={onDrop}\n {...rest}\n >\n <input\n data-slot=\"dropzone-input\"\n type=\"file\"\n accept={accept}\n multiple={multiple}\n class=\"absolute inset-0 cursor-pointer opacity-0\"\n onChange={(event) => readFiles((event.currentTarget as HTMLInputElement).files)}\n />\n {children}\n </div>\n );\n};\n\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type DropzoneUploadIndicatorProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const DropzoneUploadIndicator = ({\n class: className,\n children = \"Drop files here or click to upload\",\n ...rest\n}: DropzoneUploadIndicatorProps) => (\n <div data-slot=\"dropzone-upload-indicator\" class={cn(\"text-muted-foreground text-sm\", className)} {...rest}>\n {children}\n </div>\n);\n\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { Spinner } from \"../spinner\";\n\nexport type DropzoneLoadingIndicatorProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const DropzoneLoadingIndicator = ({\n class: className,\n children = \"Uploading...\",\n ...rest\n}: DropzoneLoadingIndicatorProps) => (\n <div data-slot=\"dropzone-loading-indicator\" class={cn(\"inline-flex items-center gap-2 text-sm\", className)} {...rest}>\n <Spinner size=\"sm\" />\n <span>{children}</span>\n </div>\n);\n\n","import type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type DropzoneFilesListProps = JSX.HTMLAttributes<HTMLUListElement> & {\n files: File[];\n};\n\nexport const DropzoneFilesList = ({ files, class: className, ...rest }: DropzoneFilesListProps) => (\n <ul data-slot=\"dropzone-files-list\" class={cn(\"text-muted-foreground mt-2 grid gap-1 text-sm\", className)} {...rest}>\n {files.map((file) => (\n <li key={file.name}>{file.name}</li>\n ))}\n </ul>\n);\n\n"]}
|
|
@@ -0,0 +1,242 @@
|
|
|
1
|
+
import { createIdFactory, createDismissableLayer } from './chunk-HEQRODRF.js';
|
|
2
|
+
import { signal } from '@preact/signals';
|
|
3
|
+
import { createContext, isValidElement, cloneElement } from 'preact';
|
|
4
|
+
import { useContext, useMemo, useRef, useEffect } from 'preact/hooks';
|
|
5
|
+
import { tv } from 'tailwind-variants';
|
|
6
|
+
import { jsx } from 'preact/jsx-runtime';
|
|
7
|
+
|
|
8
|
+
var PopoverContext = createContext(null);
|
|
9
|
+
var nextPopoverId = createIdFactory("kamod-popover");
|
|
10
|
+
var usePopover = () => {
|
|
11
|
+
const context = useContext(PopoverContext);
|
|
12
|
+
if (!context) throw new Error("Popover subcomponents must be used within Popover");
|
|
13
|
+
return context;
|
|
14
|
+
};
|
|
15
|
+
var popover = tv({
|
|
16
|
+
base: "relative inline-flex"
|
|
17
|
+
});
|
|
18
|
+
var Popover = ({
|
|
19
|
+
open: openProp,
|
|
20
|
+
defaultOpen = false,
|
|
21
|
+
onOpenChange,
|
|
22
|
+
class: className,
|
|
23
|
+
children,
|
|
24
|
+
...rest
|
|
25
|
+
}) => {
|
|
26
|
+
const isControlled = openProp !== void 0;
|
|
27
|
+
const open = useMemo(() => signal(isControlled ? openProp : defaultOpen), []);
|
|
28
|
+
const rootRef = useRef(null);
|
|
29
|
+
const triggerRef = useRef(null);
|
|
30
|
+
const contentRef = useRef(null);
|
|
31
|
+
const instanceId = useMemo(() => nextPopoverId(), []);
|
|
32
|
+
useEffect(() => {
|
|
33
|
+
if (isControlled && openProp !== void 0) {
|
|
34
|
+
open.value = openProp;
|
|
35
|
+
}
|
|
36
|
+
}, [openProp, isControlled, open]);
|
|
37
|
+
const setOpen = (next) => {
|
|
38
|
+
onOpenChange?.(next);
|
|
39
|
+
if (!isControlled) {
|
|
40
|
+
open.value = next;
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
const setOpenRef = useRef(setOpen);
|
|
44
|
+
setOpenRef.current = setOpen;
|
|
45
|
+
useEffect(() => {
|
|
46
|
+
const layer = createDismissableLayer({
|
|
47
|
+
root: () => rootRef.current,
|
|
48
|
+
open: () => open.value,
|
|
49
|
+
onDismiss: () => {
|
|
50
|
+
setOpenRef.current(false);
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
return () => layer.dispose();
|
|
54
|
+
}, []);
|
|
55
|
+
return /* @__PURE__ */ jsx(
|
|
56
|
+
PopoverContext.Provider,
|
|
57
|
+
{
|
|
58
|
+
value: {
|
|
59
|
+
open,
|
|
60
|
+
setOpen,
|
|
61
|
+
triggerId: `${instanceId}-trigger`,
|
|
62
|
+
contentId: `${instanceId}-content`,
|
|
63
|
+
rootRef,
|
|
64
|
+
triggerRef,
|
|
65
|
+
contentRef
|
|
66
|
+
},
|
|
67
|
+
children: /* @__PURE__ */ jsx(
|
|
68
|
+
"div",
|
|
69
|
+
{
|
|
70
|
+
ref: rootRef,
|
|
71
|
+
class: popover({ class: className }),
|
|
72
|
+
"data-slot": "popover",
|
|
73
|
+
"data-state": open.value ? "open" : "closed",
|
|
74
|
+
...rest,
|
|
75
|
+
children
|
|
76
|
+
}
|
|
77
|
+
)
|
|
78
|
+
}
|
|
79
|
+
);
|
|
80
|
+
};
|
|
81
|
+
var positionBySide = {
|
|
82
|
+
top: "bottom-full",
|
|
83
|
+
bottom: "top-full",
|
|
84
|
+
left: "right-full",
|
|
85
|
+
right: "left-full"
|
|
86
|
+
};
|
|
87
|
+
var alignByAxis = {
|
|
88
|
+
vertical: {
|
|
89
|
+
start: "left-0",
|
|
90
|
+
center: "left-1/2 -translate-x-1/2",
|
|
91
|
+
end: "right-0"
|
|
92
|
+
},
|
|
93
|
+
horizontal: {
|
|
94
|
+
start: "top-0",
|
|
95
|
+
center: "top-1/2 -translate-y-1/2",
|
|
96
|
+
end: "bottom-0"
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
var popoverContent = tv({
|
|
100
|
+
base: [
|
|
101
|
+
"bg-popover text-popover-foreground z-50 flex min-w-0 w-80 max-w-[calc(100vw-1.5rem)] max-h-[calc(100dvh-2rem)] flex-col gap-3 overflow-x-hidden overflow-y-auto rounded-lg border p-4 shadow-md outline-none",
|
|
102
|
+
"data-[state=open]:animate-in fade-in zoom-in-95",
|
|
103
|
+
"data-[state=closed]:animate-out data-[state=closed]:fill-mode-forwards fade-out zoom-out-95",
|
|
104
|
+
"absolute isolate"
|
|
105
|
+
],
|
|
106
|
+
variants: {
|
|
107
|
+
side: {
|
|
108
|
+
bottom: "slide-in-from-top-2",
|
|
109
|
+
top: "slide-in-from-bottom-2",
|
|
110
|
+
right: "slide-in-from-left-2",
|
|
111
|
+
left: "slide-in-from-right-2"
|
|
112
|
+
}
|
|
113
|
+
},
|
|
114
|
+
defaultVariants: {
|
|
115
|
+
side: "bottom"
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
var PopoverContent = ({
|
|
119
|
+
forceMount = false,
|
|
120
|
+
side = "bottom",
|
|
121
|
+
align = "center",
|
|
122
|
+
sideOffset = 4,
|
|
123
|
+
class: className,
|
|
124
|
+
style,
|
|
125
|
+
children,
|
|
126
|
+
onKeyDown,
|
|
127
|
+
...rest
|
|
128
|
+
}) => {
|
|
129
|
+
const popover2 = usePopover();
|
|
130
|
+
if (!popover2.open.value && !forceMount) return null;
|
|
131
|
+
const isVertical = side === "top" || side === "bottom";
|
|
132
|
+
const alignClass = isVertical ? alignByAxis.vertical[align] : alignByAxis.horizontal[align];
|
|
133
|
+
const inlineStyle = typeof style === "object" && style !== null ? style : void 0;
|
|
134
|
+
const offsetStyle = side === "bottom" ? { marginTop: `${sideOffset}px` } : side === "top" ? { marginBottom: `${sideOffset}px` } : side === "right" ? { marginLeft: `${sideOffset}px` } : { marginRight: `${sideOffset}px` };
|
|
135
|
+
return /* @__PURE__ */ jsx(
|
|
136
|
+
"div",
|
|
137
|
+
{
|
|
138
|
+
ref: (node) => {
|
|
139
|
+
popover2.contentRef.current = node;
|
|
140
|
+
},
|
|
141
|
+
id: popover2.contentId,
|
|
142
|
+
role: "dialog",
|
|
143
|
+
tabIndex: -1,
|
|
144
|
+
"aria-labelledby": popover2.triggerId,
|
|
145
|
+
"data-slot": "popover-content",
|
|
146
|
+
"data-side": side,
|
|
147
|
+
"data-align": align,
|
|
148
|
+
"data-state": popover2.open.value ? "open" : "closed",
|
|
149
|
+
class: `${positionBySide[side]} ${alignClass} ${popoverContent({ side, class: className })}`,
|
|
150
|
+
style: inlineStyle ? { ...offsetStyle, ...inlineStyle } : offsetStyle,
|
|
151
|
+
onKeyDown: (event) => {
|
|
152
|
+
if (event.key === "Escape") {
|
|
153
|
+
event.preventDefault();
|
|
154
|
+
popover2.setOpen(false);
|
|
155
|
+
popover2.triggerRef.current?.focus();
|
|
156
|
+
return;
|
|
157
|
+
}
|
|
158
|
+
onKeyDown?.(event);
|
|
159
|
+
},
|
|
160
|
+
...rest,
|
|
161
|
+
children
|
|
162
|
+
}
|
|
163
|
+
);
|
|
164
|
+
};
|
|
165
|
+
var popoverTrigger = tv({
|
|
166
|
+
base: [
|
|
167
|
+
"inline-flex items-center justify-center",
|
|
168
|
+
"focus-visible:ring-outline/50 transition-[color,box-shadow] outline-none focus-visible:ring-3",
|
|
169
|
+
"disabled:pointer-events-none"
|
|
170
|
+
]
|
|
171
|
+
});
|
|
172
|
+
var callRef = (ref, node) => {
|
|
173
|
+
if (typeof ref === "function") {
|
|
174
|
+
ref(node);
|
|
175
|
+
} else if (ref && typeof ref === "object" && "current" in ref) {
|
|
176
|
+
ref.current = node;
|
|
177
|
+
}
|
|
178
|
+
};
|
|
179
|
+
var PopoverTrigger = ({
|
|
180
|
+
asChild = false,
|
|
181
|
+
class: className,
|
|
182
|
+
children,
|
|
183
|
+
onClick,
|
|
184
|
+
ref: outerRef,
|
|
185
|
+
...rest
|
|
186
|
+
}) => {
|
|
187
|
+
const popover2 = usePopover();
|
|
188
|
+
const handleClick = (event) => {
|
|
189
|
+
onClick?.(event);
|
|
190
|
+
if (event.defaultPrevented) return;
|
|
191
|
+
popover2.setOpen(!popover2.open.value);
|
|
192
|
+
};
|
|
193
|
+
if (asChild) {
|
|
194
|
+
if (!isValidElement(children)) {
|
|
195
|
+
return null;
|
|
196
|
+
}
|
|
197
|
+
const childProps = children.props ?? {};
|
|
198
|
+
return cloneElement(children, {
|
|
199
|
+
...childProps,
|
|
200
|
+
...rest,
|
|
201
|
+
id: popover2.triggerId,
|
|
202
|
+
"aria-controls": popover2.contentId,
|
|
203
|
+
"aria-haspopup": "dialog",
|
|
204
|
+
"aria-expanded": popover2.open.value,
|
|
205
|
+
"data-slot": "popover-trigger",
|
|
206
|
+
"data-state": popover2.open.value ? "open" : "closed",
|
|
207
|
+
onClick: (event) => {
|
|
208
|
+
childProps.onClick?.(event);
|
|
209
|
+
handleClick(event);
|
|
210
|
+
},
|
|
211
|
+
ref: (node) => {
|
|
212
|
+
popover2.triggerRef.current = node;
|
|
213
|
+
callRef(childProps.ref, node);
|
|
214
|
+
callRef(outerRef, node);
|
|
215
|
+
}
|
|
216
|
+
});
|
|
217
|
+
}
|
|
218
|
+
return /* @__PURE__ */ jsx(
|
|
219
|
+
"button",
|
|
220
|
+
{
|
|
221
|
+
ref: (node) => {
|
|
222
|
+
popover2.triggerRef.current = node;
|
|
223
|
+
callRef(outerRef, node);
|
|
224
|
+
},
|
|
225
|
+
id: popover2.triggerId,
|
|
226
|
+
type: "button",
|
|
227
|
+
class: popoverTrigger({ class: className }),
|
|
228
|
+
"data-slot": "popover-trigger",
|
|
229
|
+
"data-state": popover2.open.value ? "open" : "closed",
|
|
230
|
+
"aria-controls": popover2.contentId,
|
|
231
|
+
"aria-haspopup": "dialog",
|
|
232
|
+
"aria-expanded": popover2.open.value,
|
|
233
|
+
onClick: (event) => handleClick(event),
|
|
234
|
+
...rest,
|
|
235
|
+
children
|
|
236
|
+
}
|
|
237
|
+
);
|
|
238
|
+
};
|
|
239
|
+
|
|
240
|
+
export { Popover, PopoverContent, PopoverTrigger, popover, popoverContent, popoverTrigger, usePopover };
|
|
241
|
+
//# sourceMappingURL=chunk-GLWYIUE5.js.map
|
|
242
|
+
//# sourceMappingURL=chunk-GLWYIUE5.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/popover/Popover.tsx","../src/components/popover/PopoverContent.tsx","../src/components/popover/PopoverTrigger.tsx"],"names":["tv","popover","jsx"],"mappings":"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","file":"chunk-GLWYIUE5.js","sourcesContent":["import { signal } from \"@preact/signals\";\nimport { createContext } from \"preact\";\nimport { useContext, useEffect, useMemo, useRef } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { tv } from \"tailwind-variants\";\nimport { createDismissableLayer, createIdFactory } from \"../../lib/interactive\";\n\ntype PopoverContextValue = {\n open: ReturnType<typeof signal<boolean>>;\n setOpen: (next: boolean) => void;\n triggerId: string;\n contentId: string;\n rootRef: { current: HTMLDivElement | null };\n triggerRef: { current: HTMLElement | null };\n contentRef: { current: HTMLDivElement | null };\n};\n\nconst PopoverContext = createContext<PopoverContextValue | null>(null);\nconst nextPopoverId = createIdFactory(\"kamod-popover\");\n\nexport const usePopover = () => {\n const context = useContext(PopoverContext);\n if (!context) throw new Error(\"Popover subcomponents must be used within Popover\");\n return context;\n};\n\nexport const popover = tv({\n base: \"relative inline-flex\"\n});\n\nexport type PopoverProps = JSX.HTMLAttributes<HTMLDivElement> & {\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n children?: ComponentChildren;\n};\n\nexport const Popover = ({\n open: openProp,\n defaultOpen = false,\n onOpenChange,\n class: className,\n children,\n ...rest\n}: PopoverProps) => {\n const isControlled = openProp !== undefined;\n const open = useMemo(() => signal(isControlled ? openProp : defaultOpen), []);\n const rootRef = useRef<HTMLDivElement | null>(null);\n const triggerRef = useRef<HTMLElement | null>(null);\n const contentRef = useRef<HTMLDivElement | null>(null);\n const instanceId = useMemo(() => nextPopoverId(), []);\n\n useEffect(() => {\n if (isControlled && openProp !== undefined) {\n open.value = openProp;\n }\n }, [openProp, isControlled, open]);\n\n const setOpen = (next: boolean) => {\n onOpenChange?.(next);\n if (!isControlled) {\n open.value = next;\n }\n };\n\n const setOpenRef = useRef(setOpen);\n setOpenRef.current = setOpen;\n\n useEffect(() => {\n const layer = createDismissableLayer({\n root: () => rootRef.current,\n open: () => open.value,\n onDismiss: () => {\n setOpenRef.current(false);\n }\n });\n return () => layer.dispose();\n }, []);\n\n return (\n <PopoverContext.Provider\n value={{\n open,\n setOpen,\n triggerId: `${instanceId}-trigger`,\n contentId: `${instanceId}-content`,\n rootRef,\n triggerRef,\n contentRef\n }}\n >\n <div\n ref={rootRef}\n class={popover({ class: className as string | undefined })}\n data-slot=\"popover\"\n data-state={open.value ? \"open\" : \"closed\"}\n {...rest}\n >\n {children}\n </div>\n </PopoverContext.Provider>\n );\n};\n\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { tv, type VariantProps } from \"tailwind-variants\";\nimport { usePopover } from \"./Popover\";\n\nconst positionBySide = {\n top: \"bottom-full\",\n bottom: \"top-full\",\n left: \"right-full\",\n right: \"left-full\"\n} as const;\n\nconst alignByAxis = {\n vertical: {\n start: \"left-0\",\n center: \"left-1/2 -translate-x-1/2\",\n end: \"right-0\"\n },\n horizontal: {\n start: \"top-0\",\n center: \"top-1/2 -translate-y-1/2\",\n end: \"bottom-0\"\n }\n} as const;\n\nexport const popoverContent = tv({\n base: [\n \"bg-popover text-popover-foreground z-50 flex min-w-0 w-80 max-w-[calc(100vw-1.5rem)] max-h-[calc(100dvh-2rem)] flex-col gap-3 overflow-x-hidden overflow-y-auto rounded-lg border p-4 shadow-md outline-none\",\n \"data-[state=open]:animate-in fade-in zoom-in-95\",\n \"data-[state=closed]:animate-out data-[state=closed]:fill-mode-forwards fade-out zoom-out-95\",\n \"absolute isolate\"\n ],\n variants: {\n side: {\n bottom: \"slide-in-from-top-2\",\n top: \"slide-in-from-bottom-2\",\n right: \"slide-in-from-left-2\",\n left: \"slide-in-from-right-2\"\n }\n },\n defaultVariants: {\n side: \"bottom\"\n }\n});\n\nexport type PopoverContentProps = JSX.HTMLAttributes<HTMLDivElement> &\n VariantProps<typeof popoverContent> & {\n forceMount?: boolean;\n side?: \"top\" | \"bottom\" | \"left\" | \"right\";\n align?: \"start\" | \"center\" | \"end\";\n sideOffset?: number;\n children?: ComponentChildren;\n };\n\nexport const PopoverContent = ({\n forceMount = false,\n side = \"bottom\",\n align = \"center\",\n sideOffset = 4,\n class: className,\n style,\n children,\n onKeyDown,\n ...rest\n}: PopoverContentProps) => {\n const popover = usePopover();\n if (!popover.open.value && !forceMount) return null;\n\n const isVertical = side === \"top\" || side === \"bottom\";\n const alignClass = isVertical ? alignByAxis.vertical[align] : alignByAxis.horizontal[align];\n const inlineStyle = typeof style === \"object\" && style !== null ? style : undefined;\n const offsetStyle: JSX.CSSProperties =\n side === \"bottom\"\n ? { marginTop: `${sideOffset}px` }\n : side === \"top\"\n ? { marginBottom: `${sideOffset}px` }\n : side === \"right\"\n ? { marginLeft: `${sideOffset}px` }\n : { marginRight: `${sideOffset}px` };\n\n return (\n <div\n ref={(node) => {\n popover.contentRef.current = node;\n }}\n id={popover.contentId}\n role=\"dialog\"\n tabIndex={-1}\n aria-labelledby={popover.triggerId}\n data-slot=\"popover-content\"\n data-side={side}\n data-align={align}\n data-state={popover.open.value ? \"open\" : \"closed\"}\n class={`${positionBySide[side]} ${alignClass} ${popoverContent({ side, class: className as string | undefined })}`}\n style={inlineStyle ? { ...offsetStyle, ...inlineStyle } : offsetStyle}\n onKeyDown={(event) => {\n if (event.key === \"Escape\") {\n event.preventDefault();\n popover.setOpen(false);\n popover.triggerRef.current?.focus();\n return;\n }\n onKeyDown?.(event);\n }}\n {...rest}\n >\n {children}\n </div>\n );\n};\n\n","import { cloneElement, isValidElement, type ComponentChildren, type JSX } from \"preact\";\nimport { tv } from \"tailwind-variants\";\nimport { usePopover } from \"./Popover\";\n\nexport const popoverTrigger = tv({\n base: [\n \"inline-flex items-center justify-center\",\n \"focus-visible:ring-outline/50 transition-[color,box-shadow] outline-none focus-visible:ring-3\",\n \"disabled:pointer-events-none\"\n ]\n});\n\nexport type PopoverTriggerProps = JSX.ButtonHTMLAttributes<HTMLButtonElement> & {\n asChild?: boolean;\n children?: ComponentChildren;\n};\n\nconst callRef = <T extends HTMLElement>(ref: unknown, node: T | null) => {\n if (typeof ref === \"function\") {\n ref(node);\n } else if (ref && typeof ref === \"object\" && \"current\" in ref) {\n (ref as { current: T | null }).current = node;\n }\n};\n\nexport const PopoverTrigger = ({\n asChild = false,\n class: className,\n children,\n onClick,\n ref: outerRef,\n ...rest\n}: PopoverTriggerProps) => {\n const popover = usePopover();\n\n const handleClick = (event: JSX.TargetedMouseEvent<HTMLElement>) => {\n onClick?.(event as JSX.TargetedMouseEvent<HTMLButtonElement>);\n if (event.defaultPrevented) return;\n popover.setOpen(!popover.open.value);\n };\n\n if (asChild) {\n if (!isValidElement(children)) {\n return null;\n }\n\n const childProps = (children.props ?? {}) as JSX.HTMLAttributes<HTMLElement> & {\n ref?: unknown;\n onClick?: (event: JSX.TargetedMouseEvent<HTMLElement>) => void;\n };\n\n return cloneElement(children, {\n ...(childProps as Record<string, unknown>),\n ...(rest as Record<string, unknown>),\n id: popover.triggerId,\n \"aria-controls\": popover.contentId,\n \"aria-haspopup\": \"dialog\",\n \"aria-expanded\": popover.open.value,\n \"data-slot\": \"popover-trigger\",\n \"data-state\": popover.open.value ? \"open\" : \"closed\",\n onClick: (event: JSX.TargetedMouseEvent<HTMLElement>) => {\n childProps.onClick?.(event);\n handleClick(event);\n },\n ref: (node: HTMLElement | null) => {\n popover.triggerRef.current = node;\n callRef(childProps.ref, node);\n callRef(outerRef, node);\n }\n } as never);\n }\n\n return (\n <button\n ref={(node) => {\n popover.triggerRef.current = node;\n callRef(outerRef, node);\n }}\n id={popover.triggerId}\n type=\"button\"\n class={popoverTrigger({ class: className as string | undefined })}\n data-slot=\"popover-trigger\"\n data-state={popover.open.value ? \"open\" : \"closed\"}\n aria-controls={popover.contentId}\n aria-haspopup=\"dialog\"\n aria-expanded={popover.open.value}\n onClick={(event) => handleClick(event as unknown as JSX.TargetedMouseEvent<HTMLElement>)}\n {...rest}\n >\n {children}\n </button>\n );\n};\n"]}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { signal, effect } from '@preact/signals';
|
|
2
|
+
|
|
3
|
+
// src/lib/interactive/createDismissableLayer.ts
|
|
4
|
+
var MODAL_DIALOG_PANEL_OUTSIDE_SLOP_PX = 48;
|
|
5
|
+
var isPointerWithinModalDialogPanelSlop = (event) => {
|
|
6
|
+
const { clientX: x, clientY: y } = event;
|
|
7
|
+
const slop = MODAL_DIALOG_PANEL_OUTSIDE_SLOP_PX;
|
|
8
|
+
for (const panel of document.querySelectorAll(
|
|
9
|
+
'[data-slot="dialog-content"][data-state="open"]:not([data-kamod-root-dismissible])'
|
|
10
|
+
)) {
|
|
11
|
+
if (!(panel instanceof HTMLElement)) continue;
|
|
12
|
+
const r = panel.getBoundingClientRect();
|
|
13
|
+
if (r.width <= 0 || r.height <= 0) continue;
|
|
14
|
+
if (x >= r.left - slop && x <= r.right + slop && y >= r.top - slop && y <= r.bottom + slop) {
|
|
15
|
+
return true;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
return false;
|
|
19
|
+
};
|
|
20
|
+
var createDismissableLayer = ({
|
|
21
|
+
root,
|
|
22
|
+
open,
|
|
23
|
+
onDismiss
|
|
24
|
+
}) => {
|
|
25
|
+
const enabled = signal(true);
|
|
26
|
+
const portalLayerSelector = '[data-slot="dialog-content"], [data-slot="alert-dialog-content"], [data-slot="sheet-content"], [data-slot="popover-content"], [data-slot="select-content"], [data-slot="dropdown-content"]';
|
|
27
|
+
const overlayLayerSlots = /* @__PURE__ */ new Set(["dialog-content", "alert-dialog-content"]);
|
|
28
|
+
const stop = effect(() => {
|
|
29
|
+
if (!enabled.value || !open()) return;
|
|
30
|
+
const onPointerDown = (event) => {
|
|
31
|
+
const node = root();
|
|
32
|
+
if (!node) return;
|
|
33
|
+
const target = event.target;
|
|
34
|
+
if (!target) return;
|
|
35
|
+
if (node.contains(target)) return;
|
|
36
|
+
if (target instanceof Element) {
|
|
37
|
+
const closestLayer = target.closest(portalLayerSelector);
|
|
38
|
+
if (closestLayer) {
|
|
39
|
+
const layerSlot = closestLayer.getAttribute("data-slot");
|
|
40
|
+
const rootDismissible = closestLayer.hasAttribute("data-kamod-root-dismissible");
|
|
41
|
+
if (layerSlot === "dialog-content" && target === closestLayer && !rootDismissible) {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
const isOverlayLayer = layerSlot ? overlayLayerSlots.has(layerSlot) : false;
|
|
45
|
+
if (!isOverlayLayer || target !== closestLayer) return;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
if (target instanceof Element && target.closest('[data-slot="dialog-overlay"]') && isPointerWithinModalDialogPanelSlop(event)) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
onDismiss();
|
|
52
|
+
};
|
|
53
|
+
const onKeyDown = (event) => {
|
|
54
|
+
if (event.key === "Escape") {
|
|
55
|
+
onDismiss();
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
document.addEventListener("pointerdown", onPointerDown);
|
|
59
|
+
document.addEventListener("keydown", onKeyDown);
|
|
60
|
+
return () => {
|
|
61
|
+
document.removeEventListener("pointerdown", onPointerDown);
|
|
62
|
+
document.removeEventListener("keydown", onKeyDown);
|
|
63
|
+
};
|
|
64
|
+
});
|
|
65
|
+
return {
|
|
66
|
+
enabled,
|
|
67
|
+
dispose: () => stop()
|
|
68
|
+
};
|
|
69
|
+
};
|
|
70
|
+
|
|
71
|
+
// src/lib/interactive/createIdFactory.ts
|
|
72
|
+
var idCounter = 0;
|
|
73
|
+
var createIdFactory = (prefix) => {
|
|
74
|
+
return (explicitId) => {
|
|
75
|
+
if (explicitId) return explicitId;
|
|
76
|
+
idCounter += 1;
|
|
77
|
+
return `${prefix}-${idCounter}`;
|
|
78
|
+
};
|
|
79
|
+
};
|
|
80
|
+
var createRovingFocus = (count, initialIndex = -1) => {
|
|
81
|
+
const activeIndex = signal(initialIndex);
|
|
82
|
+
const clamp = (index) => {
|
|
83
|
+
if (count <= 0) return -1;
|
|
84
|
+
if (index < 0) return count - 1;
|
|
85
|
+
if (index >= count) return 0;
|
|
86
|
+
return index;
|
|
87
|
+
};
|
|
88
|
+
return {
|
|
89
|
+
activeIndex,
|
|
90
|
+
moveNext: () => {
|
|
91
|
+
activeIndex.value = clamp(activeIndex.value + 1);
|
|
92
|
+
},
|
|
93
|
+
movePrev: () => {
|
|
94
|
+
activeIndex.value = clamp(activeIndex.value - 1);
|
|
95
|
+
},
|
|
96
|
+
moveFirst: () => {
|
|
97
|
+
activeIndex.value = count > 0 ? 0 : -1;
|
|
98
|
+
},
|
|
99
|
+
moveLast: () => {
|
|
100
|
+
activeIndex.value = count > 0 ? count - 1 : -1;
|
|
101
|
+
},
|
|
102
|
+
set: (index) => {
|
|
103
|
+
activeIndex.value = clamp(index);
|
|
104
|
+
}
|
|
105
|
+
};
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
export { MODAL_DIALOG_PANEL_OUTSIDE_SLOP_PX, createDismissableLayer, createIdFactory, createRovingFocus, isPointerWithinModalDialogPanelSlop };
|
|
109
|
+
//# sourceMappingURL=chunk-HEQRODRF.js.map
|
|
110
|
+
//# sourceMappingURL=chunk-HEQRODRF.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/lib/interactive/createDismissableLayer.ts","../src/lib/interactive/createIdFactory.ts","../src/lib/interactive/createRovingFocus.ts"],"names":["signal"],"mappings":"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","file":"chunk-HEQRODRF.js","sourcesContent":["import { effect, signal } from \"@preact/signals\";\n\n/** Clicks on `box-shadow` fall through to the overlay (shadow is not hit-testable). */\nexport const MODAL_DIALOG_PANEL_OUTSIDE_SLOP_PX = 48;\n\n/**\n * True when the pointer lies in an expanded box around an open modal dialog panel\n * (`dialog-content` without `data-kamod-root-dismissible`). Used so overlay hits\n * in the shadow “halo” do not close the dialog.\n *\n * Skips panels with zero layout size (e.g. JSDOM) so tests keep dismissing on overlay.\n */\nexport const isPointerWithinModalDialogPanelSlop = (\n event: Pick<PointerEvent, \"clientX\" | \"clientY\">\n): boolean => {\n const { clientX: x, clientY: y } = event;\n const slop = MODAL_DIALOG_PANEL_OUTSIDE_SLOP_PX;\n\n for (const panel of document.querySelectorAll(\n '[data-slot=\"dialog-content\"][data-state=\"open\"]:not([data-kamod-root-dismissible])'\n )) {\n if (!(panel instanceof HTMLElement)) continue;\n const r = panel.getBoundingClientRect();\n if (r.width <= 0 || r.height <= 0) continue;\n if (x >= r.left - slop && x <= r.right + slop && y >= r.top - slop && y <= r.bottom + slop) {\n return true;\n }\n }\n return false;\n};\n\ntype CreateDismissableLayerOptions = {\n root: () => HTMLElement | null;\n open: () => boolean;\n onDismiss: () => void;\n};\n\nexport const createDismissableLayer = ({\n root,\n open,\n onDismiss\n}: CreateDismissableLayerOptions) => {\n const enabled = signal(true);\n const portalLayerSelector =\n '[data-slot=\"dialog-content\"], [data-slot=\"alert-dialog-content\"], [data-slot=\"sheet-content\"], [data-slot=\"popover-content\"], [data-slot=\"select-content\"], [data-slot=\"dropdown-content\"]';\n const overlayLayerSlots = new Set([\"dialog-content\", \"alert-dialog-content\"]);\n\n const stop = effect(() => {\n if (!enabled.value || !open()) return;\n\n const onPointerDown = (event: PointerEvent) => {\n const node = root();\n if (!node) return;\n const target = event.target as Node | null;\n if (!target) return;\n if (node.contains(target)) return;\n if (target instanceof Element) {\n const closestLayer = target.closest(portalLayerSelector);\n if (closestLayer) {\n const layerSlot = closestLayer.getAttribute(\"data-slot\");\n const rootDismissible = closestLayer.hasAttribute(\"data-kamod-root-dismissible\");\n\n // Modal `DialogContent` uses a separate `[data-slot=\"dialog-overlay\"]`; hits on the\n // panel root (grid gap, padding, border) still target this div — those must not dismiss.\n // `presentation=\"slot\"` fullscreen shells set `data-kamod-root-dismissible` so a direct\n // hit on that root (dim backdrop) still dismisses.\n if (layerSlot === \"dialog-content\" && target === closestLayer && !rootDismissible) {\n return;\n }\n\n const isOverlayLayer = layerSlot ? overlayLayerSlots.has(layerSlot) : false;\n\n // For overlay wrappers, clicking the backdrop (root element itself) should dismiss.\n if (!isOverlayLayer || target !== closestLayer) return;\n }\n }\n if (\n target instanceof Element &&\n target.closest('[data-slot=\"dialog-overlay\"]') &&\n isPointerWithinModalDialogPanelSlop(event)\n ) {\n return;\n }\n onDismiss();\n };\n\n const onKeyDown = (event: KeyboardEvent) => {\n if (event.key === \"Escape\") {\n onDismiss();\n }\n };\n\n document.addEventListener(\"pointerdown\", onPointerDown);\n document.addEventListener(\"keydown\", onKeyDown);\n\n return () => {\n document.removeEventListener(\"pointerdown\", onPointerDown);\n document.removeEventListener(\"keydown\", onKeyDown);\n };\n });\n\n return {\n enabled,\n dispose: () => stop()\n };\n};\n","let idCounter = 0;\n\nexport const createIdFactory = (prefix: string) => {\n return (explicitId?: string) => {\n if (explicitId) return explicitId;\n idCounter += 1;\n return `${prefix}-${idCounter}`;\n };\n};\n","import { signal } from \"@preact/signals\";\n\nexport const createRovingFocus = (count: number, initialIndex = -1) => {\n const activeIndex = signal(initialIndex);\n\n const clamp = (index: number) => {\n if (count <= 0) return -1;\n if (index < 0) return count - 1;\n if (index >= count) return 0;\n return index;\n };\n\n return {\n activeIndex,\n moveNext: () => {\n activeIndex.value = clamp(activeIndex.value + 1);\n },\n movePrev: () => {\n activeIndex.value = clamp(activeIndex.value - 1);\n },\n moveFirst: () => {\n activeIndex.value = count > 0 ? 0 : -1;\n },\n moveLast: () => {\n activeIndex.value = count > 0 ? count - 1 : -1;\n },\n set: (index: number) => {\n activeIndex.value = clamp(index);\n }\n };\n};\n"]}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
2
|
+
import { jsx } from 'preact/jsx-runtime';
|
|
3
|
+
import { isValidElement, cloneElement } from 'preact';
|
|
4
|
+
|
|
5
|
+
var ButtonGroup = ({ class: className, orientation = "horizontal", children, ...rest }) => {
|
|
6
|
+
const isVertical = orientation === "vertical";
|
|
7
|
+
return /* @__PURE__ */ jsx(
|
|
8
|
+
"div",
|
|
9
|
+
{
|
|
10
|
+
role: "group",
|
|
11
|
+
"data-slot": "button-group",
|
|
12
|
+
"data-orientation": orientation,
|
|
13
|
+
class: cn(
|
|
14
|
+
"flex w-fit items-stretch *:focus-visible:relative *:focus-visible:z-10 has-[>[data-slot=button-group]]:gap-2",
|
|
15
|
+
"[&>[data-slot=select-trigger]:not([class*='w-'])]:w-fit [&>input]:min-w-0 [&>input]:flex-1",
|
|
16
|
+
isVertical ? "flex-col [&>*:not(:first-child)]:rounded-t-none [&>*:not(:first-child)]:border-t-0 [&>*:not(:last-child)]:rounded-b-none" : "[&>*:not(:first-child)]:rounded-l-none [&>*:not(:first-child)]:border-l-0 [&>*:not(:last-child)]:rounded-r-none",
|
|
17
|
+
className
|
|
18
|
+
),
|
|
19
|
+
...rest,
|
|
20
|
+
children
|
|
21
|
+
}
|
|
22
|
+
);
|
|
23
|
+
};
|
|
24
|
+
var textClass = "text-muted-foreground flex items-center text-sm font-normal [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4";
|
|
25
|
+
var ButtonGroupText = ({
|
|
26
|
+
class: className,
|
|
27
|
+
children,
|
|
28
|
+
asChild = false,
|
|
29
|
+
...rest
|
|
30
|
+
}) => {
|
|
31
|
+
if (asChild) {
|
|
32
|
+
if (!isValidElement(children)) {
|
|
33
|
+
return null;
|
|
34
|
+
}
|
|
35
|
+
const childProps = children.props ?? {};
|
|
36
|
+
return cloneElement(children, {
|
|
37
|
+
...childProps ?? {},
|
|
38
|
+
...rest,
|
|
39
|
+
class: cn(childProps.class, childProps.className, textClass, className),
|
|
40
|
+
"data-slot": "button-group-text"
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
return /* @__PURE__ */ jsx("div", { "data-slot": "button-group-text", class: cn(textClass, className), ...rest, children });
|
|
44
|
+
};
|
|
45
|
+
var ButtonGroupSeparator = ({ class: className, orientation = "vertical", ...rest }) => /* @__PURE__ */ jsx(
|
|
46
|
+
"span",
|
|
47
|
+
{
|
|
48
|
+
"data-slot": "button-group-separator",
|
|
49
|
+
"data-orientation": orientation,
|
|
50
|
+
class: cn(
|
|
51
|
+
"bg-border relative inline-block shrink-0 self-stretch",
|
|
52
|
+
orientation === "horizontal" ? "mx-px h-px min-h-0 w-5 in-data-[slot=button-group]:w-auto" : "my-px h-5 min-w-0 w-px in-data-[slot=button-group]:h-auto",
|
|
53
|
+
className
|
|
54
|
+
),
|
|
55
|
+
...rest
|
|
56
|
+
}
|
|
57
|
+
);
|
|
58
|
+
|
|
59
|
+
export { ButtonGroup, ButtonGroupSeparator, ButtonGroupText };
|
|
60
|
+
//# sourceMappingURL=chunk-HGTFOOUL.js.map
|
|
61
|
+
//# sourceMappingURL=chunk-HGTFOOUL.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/button-group/ButtonGroup.tsx","../src/components/button-group/ButtonGroupText.tsx","../src/components/button-group/ButtonGroupSeparator.tsx"],"names":["jsx"],"mappings":";;;;AAQO,IAAM,WAAA,GAAc,CAAC,EAAE,KAAA,EAAO,SAAA,EAAW,cAAc,YAAA,EAAc,QAAA,EAAU,GAAG,IAAA,EAAK,KAAwB;AACpH,EAAA,MAAM,aAAa,WAAA,KAAgB,UAAA;AAEnC,EAAA,uBACE,GAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,IAAA,EAAK,OAAA;AAAA,MACL,WAAA,EAAU,cAAA;AAAA,MACV,kBAAA,EAAkB,WAAA;AAAA,MAClB,KAAA,EAAO,EAAA;AAAA,QACL,8GAAA;AAAA,QACA,4FAAA;AAAA,QACA,aACI,0HAAA,GACA,iHAAA;AAAA,QACJ;AAAA,OACF;AAAA,MACC,GAAG,IAAA;AAAA,MAEH;AAAA;AAAA,GACH;AAEJ;ACrBA,IAAM,SAAA,GACJ,+IAAA;AAEK,IAAM,kBAAkB,CAAC;AAAA,EAC9B,KAAA,EAAO,SAAA;AAAA,EACP,QAAA;AAAA,EACA,OAAA,GAAU,KAAA;AAAA,EACV,GAAG;AACL,CAAA,KAA4B;AAC1B,EAAA,IAAI,OAAA,EAAS;AACX,IAAA,IAAI,CAAC,cAAA,CAAe,QAAQ,CAAA,EAAG;AAC7B,MAAA,OAAO,IAAA;AAAA,IACT;AAEA,IAAA,MAAM,UAAA,GAAc,QAAA,CAAS,KAAA,IAAS,EAAC;AAKvC,IAAA,OAAO,aAAa,QAAA,EAAU;AAAA,MAC5B,GAAI,cAAc,EAAC;AAAA,MACnB,GAAI,IAAA;AAAA,MACJ,OAAO,EAAA,CAAG,UAAA,CAAW,OAAO,UAAA,CAAW,SAAA,EAAW,WAAW,SAAS,CAAA;AAAA,MACtE,WAAA,EAAa;AAAA,KACd,CAAA;AAAA,EACH;AAEA,EAAA,uBACEA,GAAAA,CAAC,KAAA,EAAA,EAAI,WAAA,EAAU,mBAAA,EAAoB,KAAA,EAAO,EAAA,CAAG,SAAA,EAAW,SAAS,CAAA,EAAI,GAAG,IAAA,EACrE,QAAA,EACH,CAAA;AAEJ;ACjCO,IAAM,oBAAA,GAAuB,CAAC,EAAE,KAAA,EAAO,SAAA,EAAW,cAAc,UAAA,EAAY,GAAG,IAAA,EAAK,qBACzFA,GAAAA;AAAA,EAAC,MAAA;AAAA,EAAA;AAAA,IACC,WAAA,EAAU,wBAAA;AAAA,IACV,kBAAA,EAAkB,WAAA;AAAA,IAClB,KAAA,EAAO,EAAA;AAAA,MACL,uDAAA;AAAA,MACA,WAAA,KAAgB,eACZ,2DAAA,GACA,2DAAA;AAAA,MACJ;AAAA,KACF;AAAA,IACC,GAAG;AAAA;AACN","file":"chunk-HGTFOOUL.js","sourcesContent":["import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type ButtonGroupProps = JSX.HTMLAttributes<HTMLDivElement> & {\n orientation?: \"horizontal\" | \"vertical\";\n children?: ComponentChildren;\n};\n\nexport const ButtonGroup = ({ class: className, orientation = \"horizontal\", children, ...rest }: ButtonGroupProps) => {\n const isVertical = orientation === \"vertical\";\n\n return (\n <div\n role=\"group\"\n data-slot=\"button-group\"\n data-orientation={orientation}\n class={cn(\n \"flex w-fit items-stretch *:focus-visible:relative *:focus-visible:z-10 has-[>[data-slot=button-group]]:gap-2\",\n \"[&>[data-slot=select-trigger]:not([class*='w-'])]:w-fit [&>input]:min-w-0 [&>input]:flex-1\",\n isVertical\n ? \"flex-col [&>*:not(:first-child)]:rounded-t-none [&>*:not(:first-child)]:border-t-0 [&>*:not(:last-child)]:rounded-b-none\"\n : \"[&>*:not(:first-child)]:rounded-l-none [&>*:not(:first-child)]:border-l-0 [&>*:not(:last-child)]:rounded-r-none\",\n className\n )}\n {...rest}\n >\n {children}\n </div>\n );\n};\n","import { cloneElement, isValidElement, type ComponentChildren, type JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type ButtonGroupTextProps = Omit<JSX.HTMLAttributes<HTMLDivElement>, \"size\"> & {\n children?: ComponentChildren;\n asChild?: boolean;\n};\n\nconst textClass =\n \"text-muted-foreground flex items-center text-sm font-normal [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\";\n\nexport const ButtonGroupText = ({\n class: className,\n children,\n asChild = false,\n ...rest\n}: ButtonGroupTextProps) => {\n if (asChild) {\n if (!isValidElement(children)) {\n return null;\n }\n\n const childProps = (children.props ?? {}) as JSX.HTMLAttributes<HTMLElement> & {\n class?: string;\n className?: string;\n };\n\n return cloneElement(children, {\n ...(childProps ?? {}),\n ...(rest as JSX.HTMLAttributes<HTMLElement>),\n class: cn(childProps.class, childProps.className, textClass, className),\n \"data-slot\": \"button-group-text\"\n });\n }\n\n return (\n <div data-slot=\"button-group-text\" class={cn(textClass, className)} {...rest}>\n {children}\n </div>\n );\n};\n","import type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type ButtonGroupSeparatorProps = JSX.HTMLAttributes<HTMLSpanElement> & {\n orientation?: \"horizontal\" | \"vertical\";\n};\n\nexport const ButtonGroupSeparator = ({ class: className, orientation = \"vertical\", ...rest }: ButtonGroupSeparatorProps) => (\n <span\n data-slot=\"button-group-separator\"\n data-orientation={orientation}\n class={cn(\n \"bg-border relative inline-block shrink-0 self-stretch\",\n orientation === \"horizontal\"\n ? \"mx-px h-px min-h-0 w-5 in-data-[slot=button-group]:w-auto\"\n : \"my-px h-5 min-w-0 w-px in-data-[slot=button-group]:h-auto\",\n className\n )}\n {...rest}\n />\n);\n"]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { SheetFooter, SheetHeader, SheetContent, Sheet } from './chunk-7HZUM5ZQ.js';
|
|
2
|
+
import { DialogClose, DialogDescription, DialogTitle, DialogTrigger } from './chunk-KBXDU3G4.js';
|
|
3
|
+
|
|
4
|
+
// src/components/sheet/index.ts
|
|
5
|
+
var sheet_default = {
|
|
6
|
+
Root: Sheet,
|
|
7
|
+
Trigger: DialogTrigger,
|
|
8
|
+
Content: SheetContent,
|
|
9
|
+
Header: SheetHeader,
|
|
10
|
+
Footer: SheetFooter,
|
|
11
|
+
Title: DialogTitle,
|
|
12
|
+
Description: DialogDescription,
|
|
13
|
+
Close: DialogClose
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
export { sheet_default };
|
|
17
|
+
//# sourceMappingURL=chunk-HNESOMVN.js.map
|
|
18
|
+
//# sourceMappingURL=chunk-HNESOMVN.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/sheet/index.ts"],"names":[],"mappings":";;;;AAoBA,IAAO,aAAA,GAAQ;AAAA,EACb,IAAA,EAAM,KAAA;AAAA,EACN,OAAA,EAAS,aAAA;AAAA,EACT,OAAA,EAAS,YAAA;AAAA,EACT,MAAA,EAAQ,WAAA;AAAA,EACR,MAAA,EAAQ,WAAA;AAAA,EACR,KAAA,EAAO,WAAA;AAAA,EACP,WAAA,EAAa,iBAAA;AAAA,EACb,KAAA,EAAO;AACT","file":"chunk-HNESOMVN.js","sourcesContent":["import { Sheet } from \"./Sheet\";\nimport { SheetClose } from \"./SheetClose\";\nimport { SheetContent } from \"./SheetContent\";\nimport { SheetDescription } from \"./SheetDescription\";\nimport { SheetFooter } from \"./SheetFooter\";\nimport { SheetHeader } from \"./SheetHeader\";\nimport { SheetTitle } from \"./SheetTitle\";\nimport { SheetTrigger } from \"./SheetTrigger\";\n\nexport {\n Sheet,\n SheetClose,\n SheetContent,\n SheetDescription,\n SheetFooter,\n SheetHeader,\n SheetTitle,\n SheetTrigger\n};\n\nexport default {\n Root: Sheet,\n Trigger: SheetTrigger,\n Content: SheetContent,\n Header: SheetHeader,\n Footer: SheetFooter,\n Title: SheetTitle,\n Description: SheetDescription,\n Close: SheetClose\n};\n"]}
|