@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,304 @@
|
|
|
1
|
+
import { createIdFactory, createDismissableLayer } from './chunk-HEQRODRF.js';
|
|
2
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
3
|
+
import { signal } from '@preact/signals';
|
|
4
|
+
import { useMemo, useRef, useEffect, useContext } from 'preact/hooks';
|
|
5
|
+
import { createContext, isValidElement, cloneElement } from 'preact';
|
|
6
|
+
import { jsx, jsxs } from 'preact/jsx-runtime';
|
|
7
|
+
import { tv } from 'tailwind-variants';
|
|
8
|
+
|
|
9
|
+
var NavigationMenuRootContext = createContext(null);
|
|
10
|
+
var useNavigationMenuRoot = () => {
|
|
11
|
+
const ctx = useContext(NavigationMenuRootContext);
|
|
12
|
+
if (!ctx) throw new Error("NavigationMenu subcomponents must be used within NavigationMenu");
|
|
13
|
+
return ctx;
|
|
14
|
+
};
|
|
15
|
+
var NavigationMenuItemContext = createContext(null);
|
|
16
|
+
var useNavigationMenuItemCtx = () => {
|
|
17
|
+
const ctx = useContext(NavigationMenuItemContext);
|
|
18
|
+
if (!ctx) throw new Error("NavigationMenuTrigger and NavigationMenuContent must be inside NavigationMenuItem");
|
|
19
|
+
return ctx;
|
|
20
|
+
};
|
|
21
|
+
var NavigationMenu = ({
|
|
22
|
+
class: className,
|
|
23
|
+
children,
|
|
24
|
+
delayDuration = 200,
|
|
25
|
+
skipDelayDuration = 300,
|
|
26
|
+
dir,
|
|
27
|
+
...rest
|
|
28
|
+
}) => {
|
|
29
|
+
const openValue = useMemo(() => signal(null), []);
|
|
30
|
+
const rootRef = useRef(null);
|
|
31
|
+
const openTimerRef = useRef(null);
|
|
32
|
+
const closeTimerRef = useRef(null);
|
|
33
|
+
const lastOpenAtRef = useRef(0);
|
|
34
|
+
const ctx = useMemo(() => {
|
|
35
|
+
const clearTimers = () => {
|
|
36
|
+
if (openTimerRef.current) {
|
|
37
|
+
clearTimeout(openTimerRef.current);
|
|
38
|
+
openTimerRef.current = null;
|
|
39
|
+
}
|
|
40
|
+
if (closeTimerRef.current) {
|
|
41
|
+
clearTimeout(closeTimerRef.current);
|
|
42
|
+
closeTimerRef.current = null;
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
return {
|
|
46
|
+
openValue,
|
|
47
|
+
delayDuration,
|
|
48
|
+
skipDelayDuration,
|
|
49
|
+
rootRef,
|
|
50
|
+
openTimerRef,
|
|
51
|
+
closeTimerRef,
|
|
52
|
+
lastOpenAtRef,
|
|
53
|
+
clearTimers,
|
|
54
|
+
requestOpen: (itemValue) => {
|
|
55
|
+
clearTimers();
|
|
56
|
+
const now = Date.now();
|
|
57
|
+
const skip = now - lastOpenAtRef.current < skipDelayDuration && lastOpenAtRef.current > 0;
|
|
58
|
+
const run = () => {
|
|
59
|
+
openValue.value = itemValue;
|
|
60
|
+
lastOpenAtRef.current = Date.now();
|
|
61
|
+
};
|
|
62
|
+
if (skip || delayDuration <= 0) {
|
|
63
|
+
run();
|
|
64
|
+
} else {
|
|
65
|
+
openTimerRef.current = setTimeout(run, delayDuration);
|
|
66
|
+
}
|
|
67
|
+
},
|
|
68
|
+
requestClose: (delayMs = 120) => {
|
|
69
|
+
clearTimers();
|
|
70
|
+
closeTimerRef.current = setTimeout(() => {
|
|
71
|
+
openValue.value = null;
|
|
72
|
+
closeTimerRef.current = null;
|
|
73
|
+
}, delayMs);
|
|
74
|
+
},
|
|
75
|
+
toggleItem: (itemValue) => {
|
|
76
|
+
clearTimers();
|
|
77
|
+
openValue.value = openValue.value === itemValue ? null : itemValue;
|
|
78
|
+
if (openValue.value) lastOpenAtRef.current = Date.now();
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
}, [openValue, delayDuration, skipDelayDuration]);
|
|
82
|
+
useEffect(() => {
|
|
83
|
+
ctx.delayDuration = delayDuration;
|
|
84
|
+
ctx.skipDelayDuration = skipDelayDuration;
|
|
85
|
+
}, [ctx, delayDuration, skipDelayDuration]);
|
|
86
|
+
useEffect(() => {
|
|
87
|
+
const layer = createDismissableLayer({
|
|
88
|
+
root: () => rootRef.current,
|
|
89
|
+
open: () => openValue.value != null,
|
|
90
|
+
onDismiss: () => {
|
|
91
|
+
openValue.value = null;
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
return () => layer.dispose();
|
|
95
|
+
}, [openValue]);
|
|
96
|
+
return /* @__PURE__ */ jsx(NavigationMenuRootContext.Provider, { value: ctx, children: /* @__PURE__ */ jsx(
|
|
97
|
+
"nav",
|
|
98
|
+
{
|
|
99
|
+
ref: rootRef,
|
|
100
|
+
"data-slot": "navigation-menu",
|
|
101
|
+
"aria-label": "Main",
|
|
102
|
+
dir,
|
|
103
|
+
class: cn("relative z-10 flex max-w-max flex-1 items-center justify-center", className),
|
|
104
|
+
...rest,
|
|
105
|
+
children
|
|
106
|
+
}
|
|
107
|
+
) });
|
|
108
|
+
};
|
|
109
|
+
var NavigationMenuContent = ({
|
|
110
|
+
class: className,
|
|
111
|
+
children,
|
|
112
|
+
onPointerEnter,
|
|
113
|
+
onPointerLeave,
|
|
114
|
+
...rest
|
|
115
|
+
}) => {
|
|
116
|
+
const root = useNavigationMenuRoot();
|
|
117
|
+
const { value } = useNavigationMenuItemCtx();
|
|
118
|
+
const open = root.openValue.value === value;
|
|
119
|
+
const handlePointerEnter = (e) => {
|
|
120
|
+
onPointerEnter?.(e);
|
|
121
|
+
root.clearTimers();
|
|
122
|
+
};
|
|
123
|
+
const handlePointerLeave = (e) => {
|
|
124
|
+
onPointerLeave?.(e);
|
|
125
|
+
if (e.defaultPrevented) return;
|
|
126
|
+
root.requestClose();
|
|
127
|
+
};
|
|
128
|
+
return /* @__PURE__ */ jsx(
|
|
129
|
+
"div",
|
|
130
|
+
{
|
|
131
|
+
"data-slot": "navigation-menu-content",
|
|
132
|
+
"data-state": open ? "open" : "closed",
|
|
133
|
+
class: cn(
|
|
134
|
+
"absolute start-0 top-full z-50 mt-1.5 w-max origin-top-start overflow-hidden rounded-md border border-border bg-popover p-2 text-popover-foreground shadow-md outline-none",
|
|
135
|
+
"transition-[opacity,transform] duration-200",
|
|
136
|
+
open ? "pointer-events-auto visible opacity-100" : "pointer-events-none invisible opacity-0",
|
|
137
|
+
className
|
|
138
|
+
),
|
|
139
|
+
onPointerEnter: handlePointerEnter,
|
|
140
|
+
onPointerLeave: handlePointerLeave,
|
|
141
|
+
...rest,
|
|
142
|
+
children
|
|
143
|
+
}
|
|
144
|
+
);
|
|
145
|
+
};
|
|
146
|
+
var nextItemValue = createIdFactory("nm-item");
|
|
147
|
+
var NavigationMenuItem = ({ class: className, children, value: valueProp, ...rest }) => {
|
|
148
|
+
const value = useMemo(() => nextItemValue(valueProp), [valueProp]);
|
|
149
|
+
return /* @__PURE__ */ jsx(NavigationMenuItemContext.Provider, { value: { value }, children: /* @__PURE__ */ jsx("li", { "data-slot": "navigation-menu-item", class: cn("relative", className), ...rest, children }) });
|
|
150
|
+
};
|
|
151
|
+
var callRef = (ref, node) => {
|
|
152
|
+
if (typeof ref === "function") {
|
|
153
|
+
ref(node);
|
|
154
|
+
} else if (ref && typeof ref === "object" && "current" in ref) {
|
|
155
|
+
ref.current = node;
|
|
156
|
+
}
|
|
157
|
+
};
|
|
158
|
+
var NavigationMenuLink = ({
|
|
159
|
+
class: className,
|
|
160
|
+
active = false,
|
|
161
|
+
asChild = false,
|
|
162
|
+
children,
|
|
163
|
+
onClick,
|
|
164
|
+
ref: outerRef,
|
|
165
|
+
...rest
|
|
166
|
+
}) => {
|
|
167
|
+
const root = useNavigationMenuRoot();
|
|
168
|
+
const { value } = useNavigationMenuItemCtx();
|
|
169
|
+
const open = root.openValue.value === value;
|
|
170
|
+
const linkClass = cn(
|
|
171
|
+
"block select-none rounded-sm px-3 py-2 text-sm no-underline outline-none transition-colors",
|
|
172
|
+
"hover:bg-accent hover:text-accent-foreground focus:bg-accent focus:text-accent-foreground",
|
|
173
|
+
active ? "bg-accent text-accent-foreground" : "",
|
|
174
|
+
className
|
|
175
|
+
);
|
|
176
|
+
const handleClick = (event) => {
|
|
177
|
+
onClick?.(event);
|
|
178
|
+
if (event.defaultPrevented) return;
|
|
179
|
+
root.clearTimers();
|
|
180
|
+
root.openValue.value = null;
|
|
181
|
+
};
|
|
182
|
+
if (asChild) {
|
|
183
|
+
if (!isValidElement(children)) return null;
|
|
184
|
+
const childProps = children.props ?? {};
|
|
185
|
+
const mergedClass = cn(linkClass, childProps.class, childProps.className);
|
|
186
|
+
return cloneElement(children, {
|
|
187
|
+
...childProps,
|
|
188
|
+
...rest,
|
|
189
|
+
"data-slot": "navigation-menu-link",
|
|
190
|
+
"data-active": active ? "" : void 0,
|
|
191
|
+
"data-state": open ? "open" : "closed",
|
|
192
|
+
class: mergedClass,
|
|
193
|
+
onClick: (event) => {
|
|
194
|
+
childProps.onClick?.(event);
|
|
195
|
+
handleClick(event);
|
|
196
|
+
},
|
|
197
|
+
ref: (node) => {
|
|
198
|
+
callRef(childProps.ref, node);
|
|
199
|
+
callRef(outerRef, node);
|
|
200
|
+
}
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
return /* @__PURE__ */ jsx(
|
|
204
|
+
"a",
|
|
205
|
+
{
|
|
206
|
+
ref: (node) => callRef(outerRef, node),
|
|
207
|
+
"data-slot": "navigation-menu-link",
|
|
208
|
+
"data-active": active ? "" : void 0,
|
|
209
|
+
"data-state": open ? "open" : "closed",
|
|
210
|
+
"aria-current": active ? "page" : void 0,
|
|
211
|
+
class: linkClass,
|
|
212
|
+
onClick: (e) => handleClick(e),
|
|
213
|
+
...rest,
|
|
214
|
+
children
|
|
215
|
+
}
|
|
216
|
+
);
|
|
217
|
+
};
|
|
218
|
+
var NavigationMenuList = ({ class: className, children, ...rest }) => /* @__PURE__ */ jsx(
|
|
219
|
+
"ul",
|
|
220
|
+
{
|
|
221
|
+
"data-slot": "navigation-menu-list",
|
|
222
|
+
class: cn("group flex flex-1 list-none items-center justify-center gap-1", className),
|
|
223
|
+
...rest,
|
|
224
|
+
children
|
|
225
|
+
}
|
|
226
|
+
);
|
|
227
|
+
var navigationMenuTriggerStyle = tv({
|
|
228
|
+
base: [
|
|
229
|
+
"group inline-flex h-9 w-max items-center justify-center gap-1 rounded-md bg-background px-4 py-2 text-sm font-medium outline-none",
|
|
230
|
+
"transition-[color,box-shadow] hover:bg-accent hover:text-accent-foreground",
|
|
231
|
+
"focus:bg-accent focus:text-accent-foreground focus-visible:ring-[3px] focus-visible:ring-outline/50 focus-visible:outline-1",
|
|
232
|
+
"disabled:pointer-events-none disabled:opacity-50",
|
|
233
|
+
"data-[state=open]:bg-accent/50 data-[state=open]:text-accent-foreground data-[state=open]:hover:bg-accent data-[state=open]:focus:bg-accent"
|
|
234
|
+
]
|
|
235
|
+
});
|
|
236
|
+
var ChevronDownIcon = ({ class: className }) => /* @__PURE__ */ jsx(
|
|
237
|
+
"svg",
|
|
238
|
+
{
|
|
239
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
240
|
+
width: "16",
|
|
241
|
+
height: "16",
|
|
242
|
+
viewBox: "0 0 24 24",
|
|
243
|
+
fill: "none",
|
|
244
|
+
stroke: "currentColor",
|
|
245
|
+
"stroke-width": "2",
|
|
246
|
+
"stroke-linecap": "round",
|
|
247
|
+
"stroke-linejoin": "round",
|
|
248
|
+
"aria-hidden": true,
|
|
249
|
+
class: cn("size-4 shrink-0 transition duration-200 group-data-[state=open]:rotate-180 rtl:-rotate-180 group-data-[state=open]:rtl:rotate-0", className),
|
|
250
|
+
children: /* @__PURE__ */ jsx("path", { d: "m6 9 6 6 6-6" })
|
|
251
|
+
}
|
|
252
|
+
);
|
|
253
|
+
var NavigationMenuTrigger = ({ class: className, children, onClick, onPointerEnter, onPointerLeave, ...rest }) => {
|
|
254
|
+
const root = useNavigationMenuRoot();
|
|
255
|
+
const { value } = useNavigationMenuItemCtx();
|
|
256
|
+
const open = root.openValue.value === value;
|
|
257
|
+
const handlePointerEnter = (e) => {
|
|
258
|
+
onPointerEnter?.(e);
|
|
259
|
+
if (e.defaultPrevented) return;
|
|
260
|
+
root.requestOpen(value);
|
|
261
|
+
};
|
|
262
|
+
const handlePointerLeave = (e) => {
|
|
263
|
+
onPointerLeave?.(e);
|
|
264
|
+
if (e.defaultPrevented) return;
|
|
265
|
+
root.requestClose();
|
|
266
|
+
};
|
|
267
|
+
const handleClick = (e) => {
|
|
268
|
+
onClick?.(e);
|
|
269
|
+
if (e.defaultPrevented) return;
|
|
270
|
+
root.toggleItem(value);
|
|
271
|
+
};
|
|
272
|
+
return /* @__PURE__ */ jsxs(
|
|
273
|
+
"button",
|
|
274
|
+
{
|
|
275
|
+
type: "button",
|
|
276
|
+
"data-slot": "navigation-menu-trigger",
|
|
277
|
+
"data-state": open ? "open" : "closed",
|
|
278
|
+
"aria-expanded": open,
|
|
279
|
+
class: cn(navigationMenuTriggerStyle(), "group", className),
|
|
280
|
+
onPointerEnter: handlePointerEnter,
|
|
281
|
+
onPointerLeave: handlePointerLeave,
|
|
282
|
+
onClick: handleClick,
|
|
283
|
+
...rest,
|
|
284
|
+
children: [
|
|
285
|
+
children,
|
|
286
|
+
/* @__PURE__ */ jsx(ChevronDownIcon, {})
|
|
287
|
+
]
|
|
288
|
+
}
|
|
289
|
+
);
|
|
290
|
+
};
|
|
291
|
+
|
|
292
|
+
// src/components/navigation-menu/index.ts
|
|
293
|
+
var navigation_menu_default = {
|
|
294
|
+
Root: NavigationMenu,
|
|
295
|
+
List: NavigationMenuList,
|
|
296
|
+
Item: NavigationMenuItem,
|
|
297
|
+
Link: NavigationMenuLink,
|
|
298
|
+
Trigger: NavigationMenuTrigger,
|
|
299
|
+
Content: NavigationMenuContent
|
|
300
|
+
};
|
|
301
|
+
|
|
302
|
+
export { NavigationMenu, NavigationMenuContent, NavigationMenuItem, NavigationMenuLink, NavigationMenuList, NavigationMenuTrigger, navigationMenuTriggerStyle, navigation_menu_default };
|
|
303
|
+
//# sourceMappingURL=chunk-6ZXYDBPR.js.map
|
|
304
|
+
//# sourceMappingURL=chunk-6ZXYDBPR.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/navigation-menu/navigation-menu-context.tsx","../src/components/navigation-menu/NavigationMenu.tsx","../src/components/navigation-menu/NavigationMenuContent.tsx","../src/components/navigation-menu/NavigationMenuItem.tsx","../src/components/navigation-menu/NavigationMenuLink.tsx","../src/components/navigation-menu/NavigationMenuList.tsx","../src/components/navigation-menu/navigationMenuTriggerStyle.ts","../src/components/navigation-menu/NavigationMenuTrigger.tsx","../src/components/navigation-menu/index.ts"],"names":["jsx","useMemo"],"mappings":"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","file":"chunk-6ZXYDBPR.js","sourcesContent":["import { type signal } from \"@preact/signals\";\nimport { createContext } from \"preact\";\nimport { useContext } from \"preact/hooks\";\n\nexport type NavigationMenuRootContextValue = {\n openValue: ReturnType<typeof signal<string | null>>;\n delayDuration: number;\n skipDelayDuration: number;\n rootRef: { current: HTMLElement | null };\n openTimerRef: { current: ReturnType<typeof setTimeout> | null };\n closeTimerRef: { current: ReturnType<typeof setTimeout> | null };\n lastOpenAtRef: { current: number };\n requestOpen: (itemValue: string) => void;\n requestClose: (delayMs?: number) => void;\n clearTimers: () => void;\n toggleItem: (itemValue: string) => void;\n};\n\nexport const NavigationMenuRootContext = createContext<NavigationMenuRootContextValue | null>(null);\n\nexport const useNavigationMenuRoot = () => {\n const ctx = useContext(NavigationMenuRootContext);\n if (!ctx) throw new Error(\"NavigationMenu subcomponents must be used within NavigationMenu\");\n return ctx;\n};\n\nexport type NavigationMenuItemContextValue = {\n value: string;\n};\n\nexport const NavigationMenuItemContext = createContext<NavigationMenuItemContextValue | null>(null);\n\nexport const useNavigationMenuItemCtx = () => {\n const ctx = useContext(NavigationMenuItemContext);\n if (!ctx) throw new Error(\"NavigationMenuTrigger and NavigationMenuContent must be inside NavigationMenuItem\");\n return ctx;\n};\n","import { signal } from \"@preact/signals\";\nimport { useEffect, useMemo, useRef } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { createDismissableLayer } from \"../../lib/interactive\";\nimport { NavigationMenuRootContext, type NavigationMenuRootContextValue } from \"./navigation-menu-context\";\n\nexport type NavigationMenuProps = JSX.HTMLAttributes<HTMLElement> & {\n children?: ComponentChildren;\n /** Delay before opening a submenu on hover (ms). */\n delayDuration?: number;\n /** After opening, subsequent opens skip the delay for this many ms. */\n skipDelayDuration?: number;\n /** Passed to the root `nav` for RTL. */\n dir?: \"ltr\" | \"rtl\";\n};\n\nexport const NavigationMenu = ({\n class: className,\n children,\n delayDuration = 200,\n skipDelayDuration = 300,\n dir,\n ...rest\n}: NavigationMenuProps) => {\n const openValue = useMemo(() => signal<string | null>(null), []);\n const rootRef = useRef<HTMLElement | null>(null);\n const openTimerRef = useRef<ReturnType<typeof setTimeout> | null>(null);\n const closeTimerRef = useRef<ReturnType<typeof setTimeout> | null>(null);\n const lastOpenAtRef = useRef(0);\n\n const ctx = useMemo<NavigationMenuRootContextValue>(() => {\n const clearTimers = () => {\n if (openTimerRef.current) {\n clearTimeout(openTimerRef.current);\n openTimerRef.current = null;\n }\n if (closeTimerRef.current) {\n clearTimeout(closeTimerRef.current);\n closeTimerRef.current = null;\n }\n };\n\n return {\n openValue,\n delayDuration,\n skipDelayDuration,\n rootRef,\n openTimerRef,\n closeTimerRef,\n lastOpenAtRef,\n clearTimers,\n requestOpen: (itemValue: string) => {\n clearTimers();\n const now = Date.now();\n const skip = now - lastOpenAtRef.current < skipDelayDuration && lastOpenAtRef.current > 0;\n const run = () => {\n openValue.value = itemValue;\n lastOpenAtRef.current = Date.now();\n };\n if (skip || delayDuration <= 0) {\n run();\n } else {\n openTimerRef.current = setTimeout(run, delayDuration);\n }\n },\n requestClose: (delayMs = 120) => {\n clearTimers();\n closeTimerRef.current = setTimeout(() => {\n openValue.value = null;\n closeTimerRef.current = null;\n }, delayMs);\n },\n toggleItem: (itemValue: string) => {\n clearTimers();\n openValue.value = openValue.value === itemValue ? null : itemValue;\n if (openValue.value) lastOpenAtRef.current = Date.now();\n }\n };\n }, [openValue, delayDuration, skipDelayDuration]);\n\n useEffect(() => {\n ctx.delayDuration = delayDuration;\n ctx.skipDelayDuration = skipDelayDuration;\n }, [ctx, delayDuration, skipDelayDuration]);\n\n useEffect(() => {\n const layer = createDismissableLayer({\n root: () => rootRef.current,\n open: () => openValue.value != null,\n onDismiss: () => {\n openValue.value = null;\n }\n });\n return () => layer.dispose();\n }, [openValue]);\n\n return (\n <NavigationMenuRootContext.Provider value={ctx}>\n <nav\n ref={rootRef}\n data-slot=\"navigation-menu\"\n aria-label=\"Main\"\n dir={dir}\n class={cn(\"relative z-10 flex max-w-max flex-1 items-center justify-center\", className)}\n {...rest}\n >\n {children}\n </nav>\n </NavigationMenuRootContext.Provider>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useNavigationMenuItemCtx, useNavigationMenuRoot } from \"./navigation-menu-context\";\n\nexport type NavigationMenuContentProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const NavigationMenuContent = ({\n class: className,\n children,\n onPointerEnter,\n onPointerLeave,\n ...rest\n}: NavigationMenuContentProps) => {\n const root = useNavigationMenuRoot();\n const { value } = useNavigationMenuItemCtx();\n const open = root.openValue.value === value;\n\n const handlePointerEnter = (e: JSX.TargetedPointerEvent<HTMLDivElement>) => {\n onPointerEnter?.(e);\n root.clearTimers();\n };\n\n const handlePointerLeave = (e: JSX.TargetedPointerEvent<HTMLDivElement>) => {\n onPointerLeave?.(e);\n if (e.defaultPrevented) return;\n root.requestClose();\n };\n\n return (\n <div\n data-slot=\"navigation-menu-content\"\n data-state={open ? \"open\" : \"closed\"}\n class={cn(\n \"absolute start-0 top-full z-50 mt-1.5 w-max origin-top-start overflow-hidden rounded-md border border-border bg-popover p-2 text-popover-foreground shadow-md outline-none\",\n \"transition-[opacity,transform] duration-200\",\n open ? \"pointer-events-auto visible opacity-100\" : \"pointer-events-none invisible opacity-0\",\n className\n )}\n onPointerEnter={handlePointerEnter}\n onPointerLeave={handlePointerLeave}\n {...rest}\n >\n {children}\n </div>\n );\n};\n","import { useMemo } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { createIdFactory } from \"../../lib/interactive\";\nimport { NavigationMenuItemContext } from \"./navigation-menu-context\";\n\nconst nextItemValue = createIdFactory(\"nm-item\");\n\nexport type NavigationMenuItemProps = JSX.HTMLAttributes<HTMLLIElement> & {\n children?: ComponentChildren;\n /** Stable id for this branch; auto-generated when omitted. */\n value?: string;\n};\n\nexport const NavigationMenuItem = ({ class: className, children, value: valueProp, ...rest }: NavigationMenuItemProps) => {\n const value = useMemo(() => nextItemValue(valueProp), [valueProp]);\n\n return (\n <NavigationMenuItemContext.Provider value={{ value }}>\n <li data-slot=\"navigation-menu-item\" class={cn(\"relative\", className)} {...rest}>\n {children}\n </li>\n </NavigationMenuItemContext.Provider>\n );\n};\n","import { cloneElement, isValidElement, type ComponentChildren, type JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useNavigationMenuItemCtx, useNavigationMenuRoot } from \"./navigation-menu-context\";\n\nexport type NavigationMenuLinkProps = JSX.AnchorHTMLAttributes<HTMLAnchorElement> & {\n active?: boolean;\n children?: ComponentChildren;\n asChild?: boolean;\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 NavigationMenuLink = ({\n class: className,\n active = false,\n asChild = false,\n children,\n onClick,\n ref: outerRef,\n ...rest\n}: NavigationMenuLinkProps) => {\n const root = useNavigationMenuRoot();\n const { value } = useNavigationMenuItemCtx();\n const open = root.openValue.value === value;\n\n const linkClass = cn(\n \"block select-none rounded-sm px-3 py-2 text-sm no-underline outline-none transition-colors\",\n \"hover:bg-accent hover:text-accent-foreground focus:bg-accent focus:text-accent-foreground\",\n active ? \"bg-accent text-accent-foreground\" : \"\",\n className\n );\n\n const handleClick = (event: JSX.TargetedMouseEvent<HTMLElement>) => {\n onClick?.(event as JSX.TargetedMouseEvent<HTMLAnchorElement>);\n if (event.defaultPrevented) return;\n root.clearTimers();\n root.openValue.value = null;\n };\n\n if (asChild) {\n if (!isValidElement(children)) return null;\n const childProps = (children.props ?? {}) as JSX.HTMLAttributes<HTMLElement> & {\n ref?: unknown;\n onClick?: (event: JSX.TargetedMouseEvent<HTMLElement>) => void;\n class?: string;\n className?: string;\n };\n const mergedClass = cn(linkClass, childProps.class, childProps.className);\n return cloneElement(children, {\n ...(childProps as Record<string, unknown>),\n ...(rest as Record<string, unknown>),\n \"data-slot\": \"navigation-menu-link\",\n \"data-active\": active ? \"\" : undefined,\n \"data-state\": open ? \"open\" : \"closed\",\n class: mergedClass,\n onClick: (event: JSX.TargetedMouseEvent<HTMLElement>) => {\n childProps.onClick?.(event);\n handleClick(event);\n },\n ref: (node: HTMLElement | null) => {\n callRef(childProps.ref, node);\n callRef(outerRef, node);\n }\n } as never);\n }\n\n return (\n <a\n ref={(node) => callRef(outerRef, node)}\n data-slot=\"navigation-menu-link\"\n data-active={active ? \"\" : undefined}\n data-state={open ? \"open\" : \"closed\"}\n aria-current={active ? \"page\" : undefined}\n class={linkClass}\n onClick={(e) => handleClick(e as unknown as JSX.TargetedMouseEvent<HTMLElement>)}\n {...rest}\n >\n {children}\n </a>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type NavigationMenuListProps = JSX.HTMLAttributes<HTMLUListElement> & {\n children?: ComponentChildren;\n};\n\nexport const NavigationMenuList = ({ class: className, children, ...rest }: NavigationMenuListProps) => (\n <ul\n data-slot=\"navigation-menu-list\"\n class={cn(\"group flex flex-1 list-none items-center justify-center gap-1\", className)}\n {...rest}\n >\n {children}\n </ul>\n);\n","import { tv } from \"tailwind-variants\";\n\n/** Matches shadcn `navigationMenuTriggerStyle()` for use on `NavigationMenuLink` with `asChild`. */\nexport const navigationMenuTriggerStyle = tv({\n base: [\n \"group inline-flex h-9 w-max items-center justify-center gap-1 rounded-md bg-background px-4 py-2 text-sm font-medium outline-none\",\n \"transition-[color,box-shadow] hover:bg-accent hover:text-accent-foreground\",\n \"focus:bg-accent focus:text-accent-foreground focus-visible:ring-[3px] focus-visible:ring-outline/50 focus-visible:outline-1\",\n \"disabled:pointer-events-none disabled:opacity-50\",\n \"data-[state=open]:bg-accent/50 data-[state=open]:text-accent-foreground data-[state=open]:hover:bg-accent data-[state=open]:focus:bg-accent\"\n ]\n});\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useNavigationMenuItemCtx, useNavigationMenuRoot } from \"./navigation-menu-context\";\nimport { navigationMenuTriggerStyle } from \"./navigationMenuTriggerStyle\";\n\nconst ChevronDownIcon = ({ class: className }: { class?: string }) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\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 aria-hidden\n class={cn(\"size-4 shrink-0 transition duration-200 group-data-[state=open]:rotate-180 rtl:-rotate-180 group-data-[state=open]:rtl:rotate-0\", className)}\n >\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n);\n\nexport type NavigationMenuTriggerProps = JSX.ButtonHTMLAttributes<HTMLButtonElement> & {\n children?: ComponentChildren;\n};\n\nexport const NavigationMenuTrigger = ({ class: className, children, onClick, onPointerEnter, onPointerLeave, ...rest }: NavigationMenuTriggerProps) => {\n const root = useNavigationMenuRoot();\n const { value } = useNavigationMenuItemCtx();\n const open = root.openValue.value === value;\n\n const handlePointerEnter = (e: JSX.TargetedPointerEvent<HTMLButtonElement>) => {\n onPointerEnter?.(e);\n if (e.defaultPrevented) return;\n root.requestOpen(value);\n };\n\n const handlePointerLeave = (e: JSX.TargetedPointerEvent<HTMLButtonElement>) => {\n onPointerLeave?.(e);\n if (e.defaultPrevented) return;\n root.requestClose();\n };\n\n const handleClick = (e: JSX.TargetedMouseEvent<HTMLButtonElement>) => {\n onClick?.(e);\n if (e.defaultPrevented) return;\n root.toggleItem(value);\n };\n\n return (\n <button\n type=\"button\"\n data-slot=\"navigation-menu-trigger\"\n data-state={open ? \"open\" : \"closed\"}\n aria-expanded={open}\n class={cn(navigationMenuTriggerStyle(), \"group\", className)}\n onPointerEnter={handlePointerEnter}\n onPointerLeave={handlePointerLeave}\n onClick={handleClick}\n {...rest}\n >\n {children}\n <ChevronDownIcon />\n </button>\n );\n};\n","import { NavigationMenu } from \"./NavigationMenu\";\nimport { NavigationMenuContent } from \"./NavigationMenuContent\";\nimport { NavigationMenuItem } from \"./NavigationMenuItem\";\nimport { NavigationMenuLink } from \"./NavigationMenuLink\";\nimport { NavigationMenuList } from \"./NavigationMenuList\";\nimport { NavigationMenuTrigger } from \"./NavigationMenuTrigger\";\nimport { navigationMenuTriggerStyle } from \"./navigationMenuTriggerStyle\";\n\nexport {\n NavigationMenu,\n NavigationMenuContent,\n NavigationMenuItem,\n NavigationMenuLink,\n NavigationMenuList,\n NavigationMenuTrigger,\n navigationMenuTriggerStyle\n};\n\nexport type { NavigationMenuProps } from \"./NavigationMenu\";\nexport type { NavigationMenuContentProps } from \"./NavigationMenuContent\";\nexport type { NavigationMenuItemProps } from \"./NavigationMenuItem\";\nexport type { NavigationMenuLinkProps } from \"./NavigationMenuLink\";\nexport type { NavigationMenuListProps } from \"./NavigationMenuList\";\nexport type { NavigationMenuTriggerProps } from \"./NavigationMenuTrigger\";\n\nexport default {\n Root: NavigationMenu,\n List: NavigationMenuList,\n Item: NavigationMenuItem,\n Link: NavigationMenuLink,\n Trigger: NavigationMenuTrigger,\n Content: NavigationMenuContent\n};\n"]}
|
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
import { cn } from './chunk-OMXWBB67.js';
|
|
2
|
+
import { signal } from '@preact/signals';
|
|
3
|
+
import { createContext } from 'preact';
|
|
4
|
+
import { useContext, useMemo, useCallback, useRef, useLayoutEffect } from 'preact/hooks';
|
|
5
|
+
import { jsx, jsxs } from 'preact/jsx-runtime';
|
|
6
|
+
|
|
7
|
+
var CommandContext = createContext(null);
|
|
8
|
+
var useCommand = () => {
|
|
9
|
+
const context = useContext(CommandContext);
|
|
10
|
+
if (!context) throw new Error("Command subcomponents must be used within Command");
|
|
11
|
+
return context;
|
|
12
|
+
};
|
|
13
|
+
var Command = ({
|
|
14
|
+
class: className,
|
|
15
|
+
children,
|
|
16
|
+
autoHighlight = false,
|
|
17
|
+
query: queryProp,
|
|
18
|
+
hasVisibleItems: hasVisibleProp,
|
|
19
|
+
...rest
|
|
20
|
+
}) => {
|
|
21
|
+
const internalQuery = useMemo(() => signal(""), []);
|
|
22
|
+
const query = queryProp ?? internalQuery;
|
|
23
|
+
const internalHas = useMemo(() => signal(true), []);
|
|
24
|
+
const hasVisibleItems = hasVisibleProp ?? internalHas;
|
|
25
|
+
const highlightedIndex = useMemo(() => signal(-1), []);
|
|
26
|
+
const listRef = useMemo(() => ({ current: null }), []);
|
|
27
|
+
const moveHighlight = useCallback(
|
|
28
|
+
(delta) => {
|
|
29
|
+
const root = listRef.current;
|
|
30
|
+
if (!root || !autoHighlight) return;
|
|
31
|
+
const nodes = [...root.querySelectorAll('[data-slot="command-item"][data-match="true"]')];
|
|
32
|
+
if (nodes.length === 0) return;
|
|
33
|
+
let idx = highlightedIndex.value;
|
|
34
|
+
if (idx < 0) idx = delta > 0 ? 0 : nodes.length - 1;
|
|
35
|
+
else idx = (idx + delta + nodes.length) % nodes.length;
|
|
36
|
+
highlightedIndex.value = idx;
|
|
37
|
+
},
|
|
38
|
+
[autoHighlight, highlightedIndex, listRef]
|
|
39
|
+
);
|
|
40
|
+
const activateHighlighted = useCallback(() => {
|
|
41
|
+
if (!autoHighlight) return;
|
|
42
|
+
const root = listRef.current;
|
|
43
|
+
if (!root) return;
|
|
44
|
+
const nodes = [...root.querySelectorAll('[data-slot="command-item"][data-match="true"]')];
|
|
45
|
+
if (nodes.length === 0) return;
|
|
46
|
+
let idx = highlightedIndex.value;
|
|
47
|
+
if (idx < 0 || idx >= nodes.length) idx = 0;
|
|
48
|
+
nodes[idx]?.click();
|
|
49
|
+
}, [autoHighlight, highlightedIndex, listRef]);
|
|
50
|
+
const contextValue = useMemo(
|
|
51
|
+
() => ({
|
|
52
|
+
query,
|
|
53
|
+
hasVisibleItems,
|
|
54
|
+
autoHighlight,
|
|
55
|
+
highlightedIndex,
|
|
56
|
+
listRef,
|
|
57
|
+
moveHighlight,
|
|
58
|
+
activateHighlighted
|
|
59
|
+
}),
|
|
60
|
+
[query, hasVisibleItems, autoHighlight, highlightedIndex, listRef, moveHighlight, activateHighlighted]
|
|
61
|
+
);
|
|
62
|
+
return /* @__PURE__ */ jsx(CommandContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsx("div", { "data-slot": "command", class: cn("w-full rounded-md border bg-popover text-popover-foreground", className), ...rest, children }) });
|
|
63
|
+
};
|
|
64
|
+
var CommandEmpty = ({ children, class: className, ...rest }) => {
|
|
65
|
+
const { query, hasVisibleItems } = useCommand();
|
|
66
|
+
void hasVisibleItems.value;
|
|
67
|
+
if (!(query.value ?? "").trim()) return null;
|
|
68
|
+
if (hasVisibleItems.value) return null;
|
|
69
|
+
return /* @__PURE__ */ jsx("div", { "data-slot": "command-empty", class: cn("p-2 text-sm text-muted-foreground", className), ...rest, children });
|
|
70
|
+
};
|
|
71
|
+
var CommandGroup = ({ heading, class: className, children, ...rest }) => /* @__PURE__ */ jsxs(
|
|
72
|
+
"div",
|
|
73
|
+
{
|
|
74
|
+
"data-slot": "command-group",
|
|
75
|
+
role: "presentation",
|
|
76
|
+
class: cn("text-foreground overflow-hidden p-1", className),
|
|
77
|
+
...rest,
|
|
78
|
+
children: [
|
|
79
|
+
heading ? /* @__PURE__ */ jsx("div", { class: "text-muted-foreground px-2 py-1.5 text-xs font-medium", "data-slot": "command-group-heading", children: heading }) : null,
|
|
80
|
+
/* @__PURE__ */ jsx("div", { class: "space-y-0.5", role: "group", children })
|
|
81
|
+
]
|
|
82
|
+
}
|
|
83
|
+
);
|
|
84
|
+
var CommandInput = ({ class: className, onInput, onKeyDown, ...rest }) => {
|
|
85
|
+
const { query, autoHighlight, moveHighlight, activateHighlighted } = useCommand();
|
|
86
|
+
void query.value;
|
|
87
|
+
return /* @__PURE__ */ jsx(
|
|
88
|
+
"input",
|
|
89
|
+
{
|
|
90
|
+
"data-slot": "command-input",
|
|
91
|
+
class: cn("h-10 w-full border-b bg-transparent px-3 text-sm outline-none", className),
|
|
92
|
+
value: query.value,
|
|
93
|
+
onInput: (event) => {
|
|
94
|
+
query.value = event.currentTarget.value;
|
|
95
|
+
onInput?.(event);
|
|
96
|
+
},
|
|
97
|
+
onKeyDown: (event) => {
|
|
98
|
+
if (autoHighlight) {
|
|
99
|
+
if (event.key === "ArrowDown") {
|
|
100
|
+
event.preventDefault();
|
|
101
|
+
moveHighlight(1);
|
|
102
|
+
return;
|
|
103
|
+
}
|
|
104
|
+
if (event.key === "ArrowUp") {
|
|
105
|
+
event.preventDefault();
|
|
106
|
+
moveHighlight(-1);
|
|
107
|
+
return;
|
|
108
|
+
}
|
|
109
|
+
if (event.key === "Enter") {
|
|
110
|
+
event.preventDefault();
|
|
111
|
+
activateHighlighted();
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
onKeyDown?.(event);
|
|
116
|
+
},
|
|
117
|
+
...rest
|
|
118
|
+
}
|
|
119
|
+
);
|
|
120
|
+
};
|
|
121
|
+
var CommandItem = ({
|
|
122
|
+
class: className,
|
|
123
|
+
value,
|
|
124
|
+
children,
|
|
125
|
+
disabled,
|
|
126
|
+
onClick,
|
|
127
|
+
onSelect,
|
|
128
|
+
...rest
|
|
129
|
+
}) => {
|
|
130
|
+
const { query } = useCommand();
|
|
131
|
+
const q = (query.value ?? "").trim().toLowerCase();
|
|
132
|
+
const textMatch = !q || value.toLowerCase().includes(q);
|
|
133
|
+
return /* @__PURE__ */ jsx(
|
|
134
|
+
"button",
|
|
135
|
+
{
|
|
136
|
+
type: "button",
|
|
137
|
+
"data-slot": "command-item",
|
|
138
|
+
"data-match": textMatch ? "true" : "false",
|
|
139
|
+
disabled,
|
|
140
|
+
class: cn(
|
|
141
|
+
"flex w-full cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-start text-sm outline-none",
|
|
142
|
+
"hover:bg-accent hover:text-accent-foreground",
|
|
143
|
+
"focus:bg-accent focus:text-accent-foreground",
|
|
144
|
+
"data-[highlighted=true]:bg-accent data-[highlighted=true]:text-accent-foreground",
|
|
145
|
+
"data-[disabled]:pointer-events-none data-[disabled]:opacity-50",
|
|
146
|
+
"[&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
|
|
147
|
+
!textMatch && "hidden",
|
|
148
|
+
className
|
|
149
|
+
),
|
|
150
|
+
onClick: (event) => {
|
|
151
|
+
onClick?.(event);
|
|
152
|
+
if (event.defaultPrevented) return;
|
|
153
|
+
onSelect?.(value);
|
|
154
|
+
},
|
|
155
|
+
...rest,
|
|
156
|
+
children
|
|
157
|
+
}
|
|
158
|
+
);
|
|
159
|
+
};
|
|
160
|
+
var CommandList = ({ class: className, children, onMount, ...rest }) => {
|
|
161
|
+
const { query, hasVisibleItems, autoHighlight, highlightedIndex, listRef } = useCommand();
|
|
162
|
+
const prevQueryRef = useRef(null);
|
|
163
|
+
void query.value;
|
|
164
|
+
void highlightedIndex.value;
|
|
165
|
+
useLayoutEffect(() => {
|
|
166
|
+
const root = listRef.current;
|
|
167
|
+
if (!root) return;
|
|
168
|
+
const nodes = [...root.querySelectorAll('[data-slot="command-item"][data-match="true"]')];
|
|
169
|
+
hasVisibleItems.value = nodes.length > 0;
|
|
170
|
+
if (!autoHighlight) {
|
|
171
|
+
root.querySelectorAll('[data-slot="command-item"]').forEach((el) => el.removeAttribute("data-highlighted"));
|
|
172
|
+
prevQueryRef.current = query.value;
|
|
173
|
+
return;
|
|
174
|
+
}
|
|
175
|
+
const queryBumped = prevQueryRef.current !== query.value;
|
|
176
|
+
prevQueryRef.current = query.value;
|
|
177
|
+
let idx = highlightedIndex.value;
|
|
178
|
+
if (queryBumped) {
|
|
179
|
+
idx = nodes.length > 0 ? 0 : -1;
|
|
180
|
+
highlightedIndex.value = idx;
|
|
181
|
+
} else {
|
|
182
|
+
if (nodes.length === 0) {
|
|
183
|
+
highlightedIndex.value = -1;
|
|
184
|
+
idx = -1;
|
|
185
|
+
} else if (idx >= nodes.length) {
|
|
186
|
+
idx = nodes.length - 1;
|
|
187
|
+
highlightedIndex.value = idx;
|
|
188
|
+
} else if (idx < 0) {
|
|
189
|
+
idx = 0;
|
|
190
|
+
highlightedIndex.value = idx;
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
root.querySelectorAll('[data-slot="command-item"]').forEach((el) => el.removeAttribute("data-highlighted"));
|
|
194
|
+
if (idx >= 0 && nodes[idx]) {
|
|
195
|
+
nodes[idx].setAttribute("data-highlighted", "true");
|
|
196
|
+
nodes[idx].scrollIntoView({ block: "nearest" });
|
|
197
|
+
}
|
|
198
|
+
}, [query.value, highlightedIndex.value, autoHighlight]);
|
|
199
|
+
return /* @__PURE__ */ jsx(
|
|
200
|
+
"div",
|
|
201
|
+
{
|
|
202
|
+
ref: (node) => {
|
|
203
|
+
listRef.current = node;
|
|
204
|
+
onMount?.(node);
|
|
205
|
+
},
|
|
206
|
+
"data-slot": "command-list",
|
|
207
|
+
class: cn("max-h-72 overflow-y-auto overflow-x-hidden p-1", className),
|
|
208
|
+
...rest,
|
|
209
|
+
children
|
|
210
|
+
}
|
|
211
|
+
);
|
|
212
|
+
};
|
|
213
|
+
var CommandSeparator = ({ class: className, ...rest }) => /* @__PURE__ */ jsx(
|
|
214
|
+
"hr",
|
|
215
|
+
{
|
|
216
|
+
"data-slot": "command-separator",
|
|
217
|
+
class: cn("bg-border -mx-1 my-1 h-px border-0", className),
|
|
218
|
+
...rest
|
|
219
|
+
}
|
|
220
|
+
);
|
|
221
|
+
|
|
222
|
+
export { Command, CommandEmpty, CommandGroup, CommandInput, CommandItem, CommandList, CommandSeparator, useCommand };
|
|
223
|
+
//# sourceMappingURL=chunk-7E2ZPDVI.js.map
|
|
224
|
+
//# sourceMappingURL=chunk-7E2ZPDVI.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/command/Command.tsx","../src/components/command/CommandEmpty.tsx","../src/components/command/CommandGroup.tsx","../src/components/command/CommandInput.tsx","../src/components/command/CommandItem.tsx","../src/components/command/CommandList.tsx","../src/components/command/CommandSeparator.tsx"],"names":["jsx"],"mappings":"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","file":"chunk-7E2ZPDVI.js","sourcesContent":["import { signal, type Signal } from \"@preact/signals\";\nimport { createContext } from \"preact\";\nimport { useCallback, useContext, useMemo } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type CommandContextValue = {\n query: Signal<string>;\n hasVisibleItems: Signal<boolean>;\n autoHighlight: boolean;\n highlightedIndex: Signal<number>;\n listRef: { current: HTMLDivElement | null };\n moveHighlight: (delta: number) => void;\n activateHighlighted: () => void;\n};\n\nconst CommandContext = createContext<CommandContextValue | null>(null);\n\nexport const useCommand = () => {\n const context = useContext(CommandContext);\n if (!context) throw new Error(\"Command subcomponents must be used within Command\");\n return context;\n};\n\nexport type CommandProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n /** First visible item gets `data-highlighted`; enables ArrowUp/Down + Enter in `CommandInput`. */\n autoHighlight?: boolean;\n /** External filter signal (e.g. combobox inline input shares query with the list). */\n query?: Signal<string>;\n /** External visibility signal; updated by `CommandList` when provided. */\n hasVisibleItems?: Signal<boolean>;\n};\n\nexport const Command = ({\n class: className,\n children,\n autoHighlight = false,\n query: queryProp,\n hasVisibleItems: hasVisibleProp,\n ...rest\n}: CommandProps) => {\n const internalQuery = useMemo(() => signal(\"\"), []);\n const query = queryProp ?? internalQuery;\n const internalHas = useMemo(() => signal(true), []);\n const hasVisibleItems = hasVisibleProp ?? internalHas;\n const highlightedIndex = useMemo(() => signal(-1), []);\n const listRef = useMemo(() => ({ current: null as HTMLDivElement | null }), []);\n\n const moveHighlight = useCallback(\n (delta: number) => {\n const root = listRef.current;\n if (!root || !autoHighlight) return;\n const nodes = [...root.querySelectorAll<HTMLElement>('[data-slot=\"command-item\"][data-match=\"true\"]')];\n if (nodes.length === 0) return;\n let idx = highlightedIndex.value;\n if (idx < 0) idx = delta > 0 ? 0 : nodes.length - 1;\n else idx = (idx + delta + nodes.length) % nodes.length;\n highlightedIndex.value = idx;\n },\n [autoHighlight, highlightedIndex, listRef]\n );\n\n const activateHighlighted = useCallback(() => {\n if (!autoHighlight) return;\n const root = listRef.current;\n if (!root) return;\n const nodes = [...root.querySelectorAll<HTMLElement>('[data-slot=\"command-item\"][data-match=\"true\"]')];\n if (nodes.length === 0) return;\n let idx = highlightedIndex.value;\n if (idx < 0 || idx >= nodes.length) idx = 0;\n nodes[idx]?.click();\n }, [autoHighlight, highlightedIndex, listRef]);\n\n const contextValue = useMemo<CommandContextValue>(\n () => ({\n query,\n hasVisibleItems,\n autoHighlight,\n highlightedIndex,\n listRef,\n moveHighlight,\n activateHighlighted\n }),\n [query, hasVisibleItems, autoHighlight, highlightedIndex, listRef, moveHighlight, activateHighlighted]\n );\n\n return (\n <CommandContext.Provider value={contextValue}>\n <div data-slot=\"command\" class={cn(\"w-full rounded-md border bg-popover text-popover-foreground\", className)} {...rest}>\n {children}\n </div>\n </CommandContext.Provider>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useCommand } from \"./Command\";\n\nexport type CommandEmptyProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n};\n\nexport const CommandEmpty = ({ children, class: className, ...rest }: CommandEmptyProps) => {\n const { query, hasVisibleItems } = useCommand();\n void hasVisibleItems.value;\n\n if (!(query.value ?? \"\").trim()) return null;\n if (hasVisibleItems.value) return null;\n\n return (\n <div data-slot=\"command-empty\" class={cn(\"p-2 text-sm text-muted-foreground\", className)} {...rest}>\n {children}\n </div>\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type CommandGroupProps = JSX.HTMLAttributes<HTMLDivElement> & {\n heading?: string;\n children?: ComponentChildren;\n};\n\nexport const CommandGroup = ({ heading, class: className, children, ...rest }: CommandGroupProps) => (\n <div\n data-slot=\"command-group\"\n role=\"presentation\"\n class={cn(\"text-foreground overflow-hidden p-1\", className)}\n {...rest}\n >\n {heading ? (\n <div class=\"text-muted-foreground px-2 py-1.5 text-xs font-medium\" data-slot=\"command-group-heading\">\n {heading}\n </div>\n ) : null}\n <div class=\"space-y-0.5\" role=\"group\">\n {children}\n </div>\n </div>\n);\n","import type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useCommand } from \"./Command\";\n\nexport type CommandInputProps = JSX.InputHTMLAttributes<HTMLInputElement>;\n\nexport const CommandInput = ({ class: className, onInput, onKeyDown, ...rest }: CommandInputProps) => {\n const { query, autoHighlight, moveHighlight, activateHighlighted } = useCommand();\n void query.value;\n return (\n <input\n data-slot=\"command-input\"\n class={cn(\"h-10 w-full border-b bg-transparent px-3 text-sm outline-none\", className)}\n value={query.value}\n onInput={(event) => {\n query.value = event.currentTarget.value;\n onInput?.(event);\n }}\n onKeyDown={(event) => {\n if (autoHighlight) {\n if (event.key === \"ArrowDown\") {\n event.preventDefault();\n moveHighlight(1);\n return;\n }\n if (event.key === \"ArrowUp\") {\n event.preventDefault();\n moveHighlight(-1);\n return;\n }\n if (event.key === \"Enter\") {\n event.preventDefault();\n activateHighlighted();\n return;\n }\n }\n onKeyDown?.(event);\n }}\n {...rest}\n />\n );\n};\n","import type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useCommand } from \"./Command\";\n\nexport type CommandItemProps = JSX.ButtonHTMLAttributes<HTMLButtonElement> & {\n /** Used for case-insensitive filtering against the query. */\n value: string;\n children?: ComponentChildren;\n onSelect?: (value: string) => void;\n};\n\nexport const CommandItem = ({\n class: className,\n value,\n children,\n disabled,\n onClick,\n onSelect,\n ...rest\n}: CommandItemProps) => {\n const { query } = useCommand();\n const q = (query.value ?? \"\").trim().toLowerCase();\n const textMatch = !q || value.toLowerCase().includes(q);\n\n return (\n <button\n type=\"button\"\n data-slot=\"command-item\"\n data-match={textMatch ? \"true\" : \"false\"}\n disabled={disabled}\n class={cn(\n \"flex w-full cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-start text-sm outline-none\",\n \"hover:bg-accent hover:text-accent-foreground\",\n \"focus:bg-accent focus:text-accent-foreground\",\n \"data-[highlighted=true]:bg-accent data-[highlighted=true]:text-accent-foreground\",\n \"data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n \"[&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n !textMatch && \"hidden\",\n className\n )}\n onClick={(event) => {\n onClick?.(event);\n if (event.defaultPrevented) return;\n onSelect?.(value);\n }}\n {...rest}\n >\n {children}\n </button>\n );\n};\n","import { useLayoutEffect, useRef } from \"preact/hooks\";\nimport type { ComponentChildren, JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\nimport { useCommand } from \"./Command\";\n\nexport type CommandListProps = JSX.HTMLAttributes<HTMLDivElement> & {\n children?: ComponentChildren;\n /** Notified when the list root mounts (e.g. combobox inline input forwards keyboard to the list). */\n onMount?: (el: HTMLDivElement | null) => void;\n};\n\nexport const CommandList = ({ class: className, children, onMount, ...rest }: CommandListProps) => {\n const { query, hasVisibleItems, autoHighlight, highlightedIndex, listRef } = useCommand();\n const prevQueryRef = useRef<string | null>(null);\n\n void query.value;\n void highlightedIndex.value;\n\n useLayoutEffect(() => {\n const root = listRef.current;\n if (!root) return;\n\n const nodes = [...root.querySelectorAll<HTMLElement>('[data-slot=\"command-item\"][data-match=\"true\"]')];\n hasVisibleItems.value = nodes.length > 0;\n\n if (!autoHighlight) {\n root.querySelectorAll('[data-slot=\"command-item\"]').forEach((el) => el.removeAttribute(\"data-highlighted\"));\n prevQueryRef.current = query.value;\n return;\n }\n\n const queryBumped = prevQueryRef.current !== query.value;\n prevQueryRef.current = query.value;\n\n let idx = highlightedIndex.value;\n if (queryBumped) {\n idx = nodes.length > 0 ? 0 : -1;\n highlightedIndex.value = idx;\n } else {\n if (nodes.length === 0) {\n highlightedIndex.value = -1;\n idx = -1;\n } else if (idx >= nodes.length) {\n idx = nodes.length - 1;\n highlightedIndex.value = idx;\n } else if (idx < 0) {\n idx = 0;\n highlightedIndex.value = idx;\n }\n }\n\n root.querySelectorAll('[data-slot=\"command-item\"]').forEach((el) => el.removeAttribute(\"data-highlighted\"));\n if (idx >= 0 && nodes[idx]) {\n nodes[idx].setAttribute(\"data-highlighted\", \"true\");\n nodes[idx].scrollIntoView({ block: \"nearest\" });\n }\n }, [query.value, highlightedIndex.value, autoHighlight]);\n\n return (\n <div\n ref={(node) => {\n listRef.current = node;\n onMount?.(node);\n }}\n data-slot=\"command-list\"\n class={cn(\"max-h-72 overflow-y-auto overflow-x-hidden p-1\", className)}\n {...rest}\n >\n {children}\n </div>\n );\n};\n","import type { JSX } from \"preact\";\nimport { cn } from \"../../lib/utils\";\n\nexport type CommandSeparatorProps = JSX.HTMLAttributes<HTMLHRElement>;\n\nexport const CommandSeparator = ({ class: className, ...rest }: CommandSeparatorProps) => (\n <hr\n data-slot=\"command-separator\"\n class={cn(\"bg-border -mx-1 my-1 h-px border-0\", className)}\n {...rest}\n />\n);\n"]}
|