@rupe/v-datepicker 1.0.0-alpha.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 +21 -0
- package/dist/components/Calendar/CalendarCell.d.ts +17 -0
- package/dist/components/Calendar/CalendarCell.vue.js +34 -0
- package/dist/components/Calendar/CalendarCell.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarCell.vue2.js +5 -0
- package/dist/components/Calendar/CalendarCell.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarCellTrigger.d.ts +72 -0
- package/dist/components/Calendar/CalendarCellTrigger.vue.js +159 -0
- package/dist/components/Calendar/CalendarCellTrigger.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarCellTrigger.vue2.js +5 -0
- package/dist/components/Calendar/CalendarCellTrigger.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarGrid.d.ts +13 -0
- package/dist/components/Calendar/CalendarGrid.vue.js +40 -0
- package/dist/components/Calendar/CalendarGrid.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarGrid.vue2.js +5 -0
- package/dist/components/Calendar/CalendarGrid.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarGridBody.d.ts +13 -0
- package/dist/components/Calendar/CalendarGridBody.vue.js +25 -0
- package/dist/components/Calendar/CalendarGridBody.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarGridBody.vue2.js +5 -0
- package/dist/components/Calendar/CalendarGridBody.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarGridHead.d.ts +13 -0
- package/dist/components/Calendar/CalendarGridHead.vue.js +25 -0
- package/dist/components/Calendar/CalendarGridHead.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarGridHead.vue2.js +5 -0
- package/dist/components/Calendar/CalendarGridHead.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarGridRow.d.ts +13 -0
- package/dist/components/Calendar/CalendarGridRow.vue.js +25 -0
- package/dist/components/Calendar/CalendarGridRow.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarGridRow.vue2.js +5 -0
- package/dist/components/Calendar/CalendarGridRow.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarHeadCell.d.ts +13 -0
- package/dist/components/Calendar/CalendarHeadCell.vue.js +25 -0
- package/dist/components/Calendar/CalendarHeadCell.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarHeadCell.vue2.js +5 -0
- package/dist/components/Calendar/CalendarHeadCell.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarHeader.d.ts +13 -0
- package/dist/components/Calendar/CalendarHeader.vue.js +25 -0
- package/dist/components/Calendar/CalendarHeader.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarHeader.vue2.js +5 -0
- package/dist/components/Calendar/CalendarHeader.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarHeading.d.ts +21 -0
- package/dist/components/Calendar/CalendarHeading.vue.js +33 -0
- package/dist/components/Calendar/CalendarHeading.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarHeading.vue2.js +5 -0
- package/dist/components/Calendar/CalendarHeading.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarMonthHeading.d.ts +22 -0
- package/dist/components/Calendar/CalendarMonthHeading.vue.js +49 -0
- package/dist/components/Calendar/CalendarMonthHeading.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarMonthHeading.vue2.js +5 -0
- package/dist/components/Calendar/CalendarMonthHeading.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarMonthYearOverlay.d.ts +27 -0
- package/dist/components/Calendar/CalendarMonthYearOverlay.vue.js +61 -0
- package/dist/components/Calendar/CalendarMonthYearOverlay.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarMonthYearOverlay.vue2.js +5 -0
- package/dist/components/Calendar/CalendarMonthYearOverlay.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarNext.d.ts +21 -0
- package/dist/components/Calendar/CalendarNext.vue.js +42 -0
- package/dist/components/Calendar/CalendarNext.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarNext.vue2.js +5 -0
- package/dist/components/Calendar/CalendarNext.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarOverlayItem.d.ts +24 -0
- package/dist/components/Calendar/CalendarOverlayItem.vue.js +34 -0
- package/dist/components/Calendar/CalendarOverlayItem.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarOverlayItem.vue2.js +5 -0
- package/dist/components/Calendar/CalendarOverlayItem.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarPrev.d.ts +21 -0
- package/dist/components/Calendar/CalendarPrev.vue.js +42 -0
- package/dist/components/Calendar/CalendarPrev.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarPrev.vue2.js +5 -0
- package/dist/components/Calendar/CalendarPrev.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarRoot.d.ts +210 -0
- package/dist/components/Calendar/CalendarRoot.vue.js +253 -0
- package/dist/components/Calendar/CalendarRoot.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarRoot.vue2.js +8 -0
- package/dist/components/Calendar/CalendarRoot.vue2.js.map +1 -0
- package/dist/components/Calendar/CalendarYearHeading.d.ts +22 -0
- package/dist/components/Calendar/CalendarYearHeading.vue.js +49 -0
- package/dist/components/Calendar/CalendarYearHeading.vue.js.map +1 -0
- package/dist/components/Calendar/CalendarYearHeading.vue2.js +5 -0
- package/dist/components/Calendar/CalendarYearHeading.vue2.js.map +1 -0
- package/dist/components/Calendar/index.d.ts +15 -0
- package/dist/components/Calendar/useCalendar.d.ts +50 -0
- package/dist/components/Calendar/useCalendar.js +317 -0
- package/dist/components/Calendar/useCalendar.js.map +1 -0
- package/dist/components/ConfigProvider/ConfigProvider.d.ts +51 -0
- package/dist/components/ConfigProvider/ConfigProvider.vue.js +7 -0
- package/dist/components/ConfigProvider/ConfigProvider.vue.js.map +1 -0
- package/dist/components/ConfigProvider/index.d.ts +1 -0
- package/dist/components/DateField/DateFieldInput.d.ts +15 -0
- package/dist/components/DateField/DateFieldInput.vue.js +70 -0
- package/dist/components/DateField/DateFieldInput.vue.js.map +1 -0
- package/dist/components/DateField/DateFieldInput.vue2.js +5 -0
- package/dist/components/DateField/DateFieldInput.vue2.js.map +1 -0
- package/dist/components/DateField/DateFieldRoot.d.ts +151 -0
- package/dist/components/DateField/DateFieldRoot.vue.js +237 -0
- package/dist/components/DateField/DateFieldRoot.vue.js.map +1 -0
- package/dist/components/DateField/DateFieldRoot.vue2.js +8 -0
- package/dist/components/DateField/DateFieldRoot.vue2.js.map +1 -0
- package/dist/components/DateField/index.d.ts +2 -0
- package/dist/components/DatePicker/DatePickerAnchor.d.ts +11 -0
- package/dist/components/DatePicker/DatePickerAnchor.vue.js +29 -0
- package/dist/components/DatePicker/DatePickerAnchor.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerAnchor.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerAnchor.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerArrow.d.ts +11 -0
- package/dist/components/DatePicker/DatePickerArrow.vue.js +31 -0
- package/dist/components/DatePicker/DatePickerArrow.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerArrow.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerArrow.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerCalendar.d.ts +17 -0
- package/dist/components/DatePicker/DatePickerCalendar.vue.js +60 -0
- package/dist/components/DatePicker/DatePickerCalendar.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerCalendar.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerCalendar.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerCell.d.ts +11 -0
- package/dist/components/DatePicker/DatePickerCell.vue.js +28 -0
- package/dist/components/DatePicker/DatePickerCell.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerCell.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerCell.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerCellTrigger.d.ts +10 -0
- package/dist/components/DatePicker/DatePickerCellTrigger.vue.js +29 -0
- package/dist/components/DatePicker/DatePickerCellTrigger.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerCellTrigger.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerCellTrigger.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerClose.d.ts +11 -0
- package/dist/components/DatePicker/DatePickerClose.vue.js +28 -0
- package/dist/components/DatePicker/DatePickerClose.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerClose.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerClose.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerContent.d.ts +31 -0
- package/dist/components/DatePicker/DatePickerContent.vue.js +69 -0
- package/dist/components/DatePicker/DatePickerContent.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerContent.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerContent.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerField.d.ts +16 -0
- package/dist/components/DatePicker/DatePickerField.vue.js +55 -0
- package/dist/components/DatePicker/DatePickerField.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerField.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerField.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerGrid.d.ts +11 -0
- package/dist/components/DatePicker/DatePickerGrid.vue.js +27 -0
- package/dist/components/DatePicker/DatePickerGrid.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerGrid.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerGrid.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerGridBody.d.ts +11 -0
- package/dist/components/DatePicker/DatePickerGridBody.vue.js +27 -0
- package/dist/components/DatePicker/DatePickerGridBody.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerGridBody.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerGridBody.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerGridHead.d.ts +11 -0
- package/dist/components/DatePicker/DatePickerGridHead.vue.js +27 -0
- package/dist/components/DatePicker/DatePickerGridHead.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerGridHead.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerGridHead.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerGridRow.d.ts +11 -0
- package/dist/components/DatePicker/DatePickerGridRow.vue.js +27 -0
- package/dist/components/DatePicker/DatePickerGridRow.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerGridRow.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerGridRow.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerHeadCell.d.ts +11 -0
- package/dist/components/DatePicker/DatePickerHeadCell.vue.js +27 -0
- package/dist/components/DatePicker/DatePickerHeadCell.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerHeadCell.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerHeadCell.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerHeader.d.ts +11 -0
- package/dist/components/DatePicker/DatePickerHeader.vue.js +27 -0
- package/dist/components/DatePicker/DatePickerHeader.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerHeader.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerHeader.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerHeading.d.ts +19 -0
- package/dist/components/DatePicker/DatePickerHeading.vue.js +29 -0
- package/dist/components/DatePicker/DatePickerHeading.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerHeading.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerHeading.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerInput.d.ts +11 -0
- package/dist/components/DatePicker/DatePickerInput.vue.js +27 -0
- package/dist/components/DatePicker/DatePickerInput.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerInput.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerInput.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerMonthHeading.d.ts +13 -0
- package/dist/components/DatePicker/DatePickerMonthHeading.vue.js +27 -0
- package/dist/components/DatePicker/DatePickerMonthHeading.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerMonthHeading.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerMonthHeading.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerMonthYearOverlay.d.ts +24 -0
- package/dist/components/DatePicker/DatePickerMonthYearOverlay.vue.js +30 -0
- package/dist/components/DatePicker/DatePickerMonthYearOverlay.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerMonthYearOverlay.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerMonthYearOverlay.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerNext.d.ts +10 -0
- package/dist/components/DatePicker/DatePickerNext.vue.js +28 -0
- package/dist/components/DatePicker/DatePickerNext.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerNext.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerNext.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerOverlayItem.d.ts +19 -0
- package/dist/components/DatePicker/DatePickerOverlayItem.vue.js +25 -0
- package/dist/components/DatePicker/DatePickerOverlayItem.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerOverlayItem.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerOverlayItem.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerPrev.d.ts +10 -0
- package/dist/components/DatePicker/DatePickerPrev.vue.js +28 -0
- package/dist/components/DatePicker/DatePickerPrev.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerPrev.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerPrev.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerRoot.d.ts +84 -0
- package/dist/components/DatePicker/DatePickerRoot.vue.js +169 -0
- package/dist/components/DatePicker/DatePickerRoot.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerRoot.vue2.js +8 -0
- package/dist/components/DatePicker/DatePickerRoot.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerTrigger.d.ts +11 -0
- package/dist/components/DatePicker/DatePickerTrigger.vue.js +37 -0
- package/dist/components/DatePicker/DatePickerTrigger.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerTrigger.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerTrigger.vue2.js.map +1 -0
- package/dist/components/DatePicker/DatePickerYearHeading.d.ts +13 -0
- package/dist/components/DatePicker/DatePickerYearHeading.vue.js +27 -0
- package/dist/components/DatePicker/DatePickerYearHeading.vue.js.map +1 -0
- package/dist/components/DatePicker/DatePickerYearHeading.vue2.js +5 -0
- package/dist/components/DatePicker/DatePickerYearHeading.vue2.js.map +1 -0
- package/dist/components/DatePicker/index.d.ts +24 -0
- package/dist/components/DismissableLayer/DismissableLayer.d.ts +67 -0
- package/dist/components/DismissableLayer/DismissableLayer.vue.js +118 -0
- package/dist/components/DismissableLayer/DismissableLayer.vue.js.map +1 -0
- package/dist/components/DismissableLayer/DismissableLayer.vue2.js +7 -0
- package/dist/components/DismissableLayer/DismissableLayer.vue2.js.map +1 -0
- package/dist/components/DismissableLayer/DismissableLayerBranch.d.ts +11 -0
- package/dist/components/DismissableLayer/index.d.ts +3 -0
- package/dist/components/DismissableLayer/utils.d.ts +28 -0
- package/dist/components/DismissableLayer/utils.js +112 -0
- package/dist/components/DismissableLayer/utils.js.map +1 -0
- package/dist/components/FocusScope/FocusScope.d.ts +82 -0
- package/dist/components/FocusScope/FocusScope.test.d.ts +1 -0
- package/dist/components/FocusScope/FocusScope.vue.js +149 -0
- package/dist/components/FocusScope/FocusScope.vue.js.map +1 -0
- package/dist/components/FocusScope/FocusScope.vue2.js +5 -0
- package/dist/components/FocusScope/FocusScope.vue2.js.map +1 -0
- package/dist/components/FocusScope/index.d.ts +1 -0
- package/dist/components/FocusScope/stack.d.ts +12 -0
- package/dist/components/FocusScope/stack.js +38 -0
- package/dist/components/FocusScope/stack.js.map +1 -0
- package/dist/components/FocusScope/utils.d.ts +46 -0
- package/dist/components/FocusScope/utils.js +70 -0
- package/dist/components/FocusScope/utils.js.map +1 -0
- package/dist/components/Popover/PopoverAnchor.d.ts +11 -0
- package/dist/components/Popover/PopoverAnchor.vue.js +37 -0
- package/dist/components/Popover/PopoverAnchor.vue.js.map +1 -0
- package/dist/components/Popover/PopoverAnchor.vue2.js +5 -0
- package/dist/components/Popover/PopoverAnchor.vue2.js.map +1 -0
- package/dist/components/Popover/PopoverArrow.d.ts +15 -0
- package/dist/components/Popover/PopoverArrow.vue.js +31 -0
- package/dist/components/Popover/PopoverArrow.vue.js.map +1 -0
- package/dist/components/Popover/PopoverArrow.vue2.js +5 -0
- package/dist/components/Popover/PopoverArrow.vue2.js.map +1 -0
- package/dist/components/Popover/PopoverClose.d.ts +13 -0
- package/dist/components/Popover/PopoverClose.vue.js +34 -0
- package/dist/components/Popover/PopoverClose.vue.js.map +1 -0
- package/dist/components/Popover/PopoverClose.vue2.js +5 -0
- package/dist/components/Popover/PopoverClose.vue2.js.map +1 -0
- package/dist/components/Popover/PopoverContent.d.ts +32 -0
- package/dist/components/Popover/PopoverContent.vue.js +61 -0
- package/dist/components/Popover/PopoverContent.vue.js.map +1 -0
- package/dist/components/Popover/PopoverContent.vue2.js +5 -0
- package/dist/components/Popover/PopoverContent.vue2.js.map +1 -0
- package/dist/components/Popover/PopoverContentImpl.d.ts +47 -0
- package/dist/components/Popover/PopoverContentImpl.vue.js +97 -0
- package/dist/components/Popover/PopoverContentImpl.vue.js.map +1 -0
- package/dist/components/Popover/PopoverContentImpl.vue2.js +5 -0
- package/dist/components/Popover/PopoverContentImpl.vue2.js.map +1 -0
- package/dist/components/Popover/PopoverContentNonModal.d.ts +32 -0
- package/dist/components/Popover/PopoverContentNonModal.vue.js +78 -0
- package/dist/components/Popover/PopoverContentNonModal.vue.js.map +1 -0
- package/dist/components/Popover/PopoverContentNonModal.vue2.js +5 -0
- package/dist/components/Popover/PopoverContentNonModal.vue2.js.map +1 -0
- package/dist/components/Popover/PopoverPortal.d.ts +11 -0
- package/dist/components/Popover/PopoverPortal.vue.js +26 -0
- package/dist/components/Popover/PopoverPortal.vue.js.map +1 -0
- package/dist/components/Popover/PopoverPortal.vue2.js +5 -0
- package/dist/components/Popover/PopoverPortal.vue2.js.map +1 -0
- package/dist/components/Popover/PopoverRoot.d.ts +55 -0
- package/dist/components/Popover/PopoverRoot.vue.js +55 -0
- package/dist/components/Popover/PopoverRoot.vue.js.map +1 -0
- package/dist/components/Popover/PopoverRoot.vue2.js +8 -0
- package/dist/components/Popover/PopoverRoot.vue2.js.map +1 -0
- package/dist/components/Popover/PopoverTrigger.d.ts +13 -0
- package/dist/components/Popover/PopoverTrigger.vue.js +51 -0
- package/dist/components/Popover/PopoverTrigger.vue.js.map +1 -0
- package/dist/components/Popover/PopoverTrigger.vue2.js +5 -0
- package/dist/components/Popover/PopoverTrigger.vue2.js.map +1 -0
- package/dist/components/Popover/index.d.ts +7 -0
- package/dist/components/Popper/PopperAnchor.d.ts +19 -0
- package/dist/components/Popper/PopperAnchor.vue.js +37 -0
- package/dist/components/Popper/PopperAnchor.vue.js.map +1 -0
- package/dist/components/Popper/PopperAnchor.vue2.js +5 -0
- package/dist/components/Popper/PopperAnchor.vue2.js.map +1 -0
- package/dist/components/Popper/PopperArrow.d.ts +15 -0
- package/dist/components/Popper/PopperArrow.vue.js +76 -0
- package/dist/components/Popper/PopperArrow.vue.js.map +1 -0
- package/dist/components/Popper/PopperArrow.vue2.js +5 -0
- package/dist/components/Popper/PopperArrow.vue2.js.map +1 -0
- package/dist/components/Popper/PopperContent.d.ts +179 -0
- package/dist/components/Popper/PopperContent.vue.js +9 -0
- package/dist/components/Popper/PopperContent.vue.js.map +1 -0
- package/dist/components/Popper/PopperContent.vue2.js +230 -0
- package/dist/components/Popper/PopperContent.vue2.js.map +1 -0
- package/dist/components/Popper/PopperRoot.d.ts +19 -0
- package/dist/components/Popper/PopperRoot.vue.js +25 -0
- package/dist/components/Popper/PopperRoot.vue.js.map +1 -0
- package/dist/components/Popper/PopperRoot.vue2.js +8 -0
- package/dist/components/Popper/PopperRoot.vue2.js.map +1 -0
- package/dist/components/Popper/index.d.ts +5 -0
- package/dist/components/Popper/utils.d.ts +12 -0
- package/dist/components/Popper/utils.js +46 -0
- package/dist/components/Popper/utils.js.map +1 -0
- package/dist/components/Presence/Presence.d.ts +43 -0
- package/dist/components/Presence/Presence.js +61 -0
- package/dist/components/Presence/Presence.js.map +1 -0
- package/dist/components/Presence/index.d.ts +1 -0
- package/dist/components/Presence/usePresence.d.ts +4 -0
- package/dist/components/Presence/usePresence.js +131 -0
- package/dist/components/Presence/usePresence.js.map +1 -0
- package/dist/components/Primitive/Primitive.d.ts +39 -0
- package/dist/components/Primitive/Primitive.js +29 -0
- package/dist/components/Primitive/Primitive.js.map +1 -0
- package/dist/components/Primitive/Slot.d.ts +5 -0
- package/dist/components/Primitive/Slot.js +30 -0
- package/dist/components/Primitive/Slot.js.map +1 -0
- package/dist/components/Primitive/index.d.ts +3 -0
- package/dist/components/Primitive/usePrimitiveElement.d.ts +5 -0
- package/dist/components/Primitive/usePrimitiveElement.js +14 -0
- package/dist/components/Primitive/usePrimitiveElement.js.map +1 -0
- package/dist/components/Teleport/Teleport.d.ts +37 -0
- package/dist/components/Teleport/Teleport.vue.js +28 -0
- package/dist/components/Teleport/Teleport.vue.js.map +1 -0
- package/dist/components/Teleport/Teleport.vue2.js +5 -0
- package/dist/components/Teleport/Teleport.vue2.js.map +1 -0
- package/dist/components/Teleport/index.d.ts +1 -0
- package/dist/components/VisuallyHidden/VisuallyHidden.d.ts +16 -0
- package/dist/components/VisuallyHidden/VisuallyHidden.vue.js +49 -0
- package/dist/components/VisuallyHidden/VisuallyHidden.vue.js.map +1 -0
- package/dist/components/VisuallyHidden/VisuallyHidden.vue2.js +5 -0
- package/dist/components/VisuallyHidden/VisuallyHidden.vue2.js.map +1 -0
- package/dist/components/VisuallyHidden/VisuallyHiddenInput.d.ts +14 -0
- package/dist/components/VisuallyHidden/VisuallyHiddenInputBubble.d.ts +22 -0
- package/dist/components/VisuallyHidden/index.d.ts +2 -0
- package/dist/date/calendar.d.ts +59 -0
- package/dist/date/calendar.js +90 -0
- package/dist/date/calendar.js.map +1 -0
- package/dist/date/comparators.d.ts +80 -0
- package/dist/date/comparators.js +61 -0
- package/dist/date/comparators.js.map +1 -0
- package/dist/date/index.d.ts +3 -0
- package/dist/date/types.d.ts +28 -0
- package/dist/date/utils.d.ts +12 -0
- package/dist/date/utils.js +10 -0
- package/dist/date/utils.js.map +1 -0
- package/dist/index.cjs +9097 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +27 -0
- package/dist/index.js +54 -0
- package/dist/index.js.map +1 -0
- package/dist/node_modules/.pnpm/@floating-ui_core@1.7.3/node_modules/@floating-ui/core/dist/floating-ui.core.js +722 -0
- package/dist/node_modules/.pnpm/@floating-ui_core@1.7.3/node_modules/@floating-ui/core/dist/floating-ui.core.js.map +1 -0
- package/dist/node_modules/.pnpm/@floating-ui_dom@1.7.4/node_modules/@floating-ui/dom/dist/floating-ui.dom.js +626 -0
- package/dist/node_modules/.pnpm/@floating-ui_dom@1.7.4/node_modules/@floating-ui/dom/dist/floating-ui.dom.js.map +1 -0
- package/dist/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.js +174 -0
- package/dist/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.js.map +1 -0
- package/dist/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.js +155 -0
- package/dist/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.js.map +1 -0
- package/dist/node_modules/.pnpm/@floating-ui_vue@1.1.9_vue@3.5.26_typescript@5.9.3_/node_modules/@floating-ui/vue/dist/floating-ui.vue.js +180 -0
- package/dist/node_modules/.pnpm/@floating-ui_vue@1.1.9_vue@3.5.26_typescript@5.9.3_/node_modules/@floating-ui/vue/dist/floating-ui.vue.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/BuddhistCalendar.js +34 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/BuddhistCalendar.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/CalendarDate.js +213 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/CalendarDate.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/DateFormatter.js +116 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/DateFormatter.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/EthiopicCalendar.js +129 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/EthiopicCalendar.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/GregorianCalendar.js +123 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/GregorianCalendar.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/HebrewCalendar.js +114 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/HebrewCalendar.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/IndianCalendar.js +77 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/IndianCalendar.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/IslamicCalendar.js +141 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/IslamicCalendar.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/JapaneseCalendar.js +155 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/JapaneseCalendar.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/PersianCalendar.js +59 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/PersianCalendar.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/TaiwanCalendar.js +59 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/TaiwanCalendar.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/conversion.js +170 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/conversion.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/createCalendar.js +44 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/createCalendar.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/manipulation.js +301 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/manipulation.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/queries.js +141 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/queries.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/string.js +35 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/string.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/utils.js +7 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/utils.js.map +1 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/weekStartData.js +101 -0
- package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/weekStartData.js.map +1 -0
- package/dist/node_modules/.pnpm/@swc_helpers@0.5.18/node_modules/@swc/helpers/esm/_check_private_redeclaration.js +9 -0
- package/dist/node_modules/.pnpm/@swc_helpers@0.5.18/node_modules/@swc/helpers/esm/_check_private_redeclaration.js.map +1 -0
- package/dist/node_modules/.pnpm/@swc_helpers@0.5.18/node_modules/@swc/helpers/esm/_class_private_field_init.js +9 -0
- package/dist/node_modules/.pnpm/@swc_helpers@0.5.18/node_modules/@swc/helpers/esm/_class_private_field_init.js.map +1 -0
- package/dist/node_modules/.pnpm/@vueuse_core@14.1.0_vue@3.5.26_typescript@5.9.3_/node_modules/@vueuse/core/dist/index.js +140 -0
- package/dist/node_modules/.pnpm/@vueuse_core@14.1.0_vue@3.5.26_typescript@5.9.3_/node_modules/@vueuse/core/dist/index.js.map +1 -0
- package/dist/node_modules/.pnpm/@vueuse_shared@14.1.0_vue@3.5.26_typescript@5.9.3_/node_modules/@vueuse/shared/dist/index.js +88 -0
- package/dist/node_modules/.pnpm/@vueuse_shared@14.1.0_vue@3.5.26_typescript@5.9.3_/node_modules/@vueuse/shared/dist/index.js.map +1 -0
- package/dist/node_modules/.pnpm/defu@6.1.4/node_modules/defu/dist/defu.js +60 -0
- package/dist/node_modules/.pnpm/defu@6.1.4/node_modules/defu/dist/defu.js.map +1 -0
- package/dist/shared/arrays.d.ts +37 -0
- package/dist/shared/component/Arrow.d.ts +34 -0
- package/dist/shared/component/Arrow.vue.js +45 -0
- package/dist/shared/component/Arrow.vue.js.map +1 -0
- package/dist/shared/component/Arrow.vue2.js +5 -0
- package/dist/shared/component/Arrow.vue2.js.map +1 -0
- package/dist/shared/component/BaseSeparator.d.ts +26 -0
- package/dist/shared/component/index.d.ts +2 -0
- package/dist/shared/constant/countryList.d.ts +1 -0
- package/dist/shared/constant/index.d.ts +1 -0
- package/dist/shared/createContext.d.ts +8 -0
- package/dist/shared/createContext.js +26 -0
- package/dist/shared/createContext.js.map +1 -0
- package/dist/shared/date/comparators.d.ts +27 -0
- package/dist/shared/date/comparators.js +27 -0
- package/dist/shared/date/comparators.js.map +1 -0
- package/dist/shared/date/index.d.ts +8 -0
- package/dist/shared/date/parser.d.ts +37 -0
- package/dist/shared/date/parser.js +161 -0
- package/dist/shared/date/parser.js.map +1 -0
- package/dist/shared/date/parts.d.ts +12 -0
- package/dist/shared/date/parts.js +17 -0
- package/dist/shared/date/parts.js.map +1 -0
- package/dist/shared/date/placeholders.d.ts +8 -0
- package/dist/shared/date/placeholders.js +196 -0
- package/dist/shared/date/placeholders.js.map +1 -0
- package/dist/shared/date/segment.d.ts +5 -0
- package/dist/shared/date/segment.js +44 -0
- package/dist/shared/date/segment.js.map +1 -0
- package/dist/shared/date/types.d.ts +37 -0
- package/dist/shared/date/useDateField.d.ts +142 -0
- package/dist/shared/date/useDateField.js +618 -0
- package/dist/shared/date/useDateField.js.map +1 -0
- package/dist/shared/date/utils.d.ts +11 -0
- package/dist/shared/date/utils.js +76 -0
- package/dist/shared/date/utils.js.map +1 -0
- package/dist/shared/getActiveElement.d.ts +1 -0
- package/dist/shared/getActiveElement.js +14 -0
- package/dist/shared/getActiveElement.js.map +1 -0
- package/dist/shared/handleAndDispatchCustomEvent.d.ts +3 -0
- package/dist/shared/handleAndDispatchCustomEvent.js +15 -0
- package/dist/shared/handleAndDispatchCustomEvent.js.map +1 -0
- package/dist/shared/index.d.ts +22 -0
- package/dist/shared/nullish.d.ts +1 -0
- package/dist/shared/nullish.js +7 -0
- package/dist/shared/nullish.js.map +1 -0
- package/dist/shared/onFocusOutside.d.ts +2 -0
- package/dist/shared/renderSlotFragments.d.ts +2 -0
- package/dist/shared/renderSlotFragments.js +14 -0
- package/dist/shared/renderSlotFragments.js.map +1 -0
- package/dist/shared/trap-focus.d.ts +1 -0
- package/dist/shared/types.d.ts +48 -0
- package/dist/shared/useDateFormatter.d.ts +30 -0
- package/dist/shared/useDateFormatter.js +121 -0
- package/dist/shared/useDateFormatter.js.map +1 -0
- package/dist/shared/useDirection.d.ts +8 -0
- package/dist/shared/useDirection.js +12 -0
- package/dist/shared/useDirection.js.map +1 -0
- package/dist/shared/useEmitAsProps.d.ts +10 -0
- package/dist/shared/useEmitAsProps.js +19 -0
- package/dist/shared/useEmitAsProps.js.map +1 -0
- package/dist/shared/useFocusGuards.d.ts +5 -0
- package/dist/shared/useFocusGuards.js +39 -0
- package/dist/shared/useFocusGuards.js.map +1 -0
- package/dist/shared/useForwardExpose.d.ts +6 -0
- package/dist/shared/useForwardExpose.js +49 -0
- package/dist/shared/useForwardExpose.js.map +1 -0
- package/dist/shared/useForwardProps.d.ts +9 -0
- package/dist/shared/useForwardProps.js +27 -0
- package/dist/shared/useForwardProps.js.map +1 -0
- package/dist/shared/useForwardPropsEmits.d.ts +14 -0
- package/dist/shared/useForwardPropsEmits.js +15 -0
- package/dist/shared/useForwardPropsEmits.js.map +1 -0
- package/dist/shared/useId.d.ts +9 -0
- package/dist/shared/useId.js +19 -0
- package/dist/shared/useId.js.map +1 -0
- package/dist/shared/useIsUsingKeyboard.d.ts +3 -0
- package/dist/shared/useKbd.d.ts +78 -0
- package/dist/shared/useKbd.js +42 -0
- package/dist/shared/useKbd.js.map +1 -0
- package/dist/shared/useLocale.d.ts +7 -0
- package/dist/shared/useLocale.js +12 -0
- package/dist/shared/useLocale.js.map +1 -0
- package/dist/shared/useNonce.d.ts +2 -0
- package/dist/shared/useSize.d.ts +5 -0
- package/dist/shared/useSize.js +44 -0
- package/dist/shared/useSize.js.map +1 -0
- package/dist/shared/useStateMachine.d.ts +25 -0
- package/dist/shared/useStateMachine.js +19 -0
- package/dist/shared/useStateMachine.js.map +1 -0
- package/dist/shared/withDefault.d.ts +22 -0
- package/package.json +72 -0
- package/src/components/Calendar/CalendarCell.vue +39 -0
- package/src/components/Calendar/CalendarCellTrigger.vue +206 -0
- package/src/components/Calendar/CalendarGrid.vue +35 -0
- package/src/components/Calendar/CalendarGridBody.vue +19 -0
- package/src/components/Calendar/CalendarGridHead.vue +19 -0
- package/src/components/Calendar/CalendarGridRow.vue +17 -0
- package/src/components/Calendar/CalendarHeadCell.vue +17 -0
- package/src/components/Calendar/CalendarHeader.vue +17 -0
- package/src/components/Calendar/CalendarHeading.vue +32 -0
- package/src/components/Calendar/CalendarMonthHeading.vue +65 -0
- package/src/components/Calendar/CalendarMonthYearOverlay.vue +48 -0
- package/src/components/Calendar/CalendarNext.vue +51 -0
- package/src/components/Calendar/CalendarOverlayItem.vue +30 -0
- package/src/components/Calendar/CalendarPrev.vue +51 -0
- package/src/components/Calendar/CalendarRoot.vue +394 -0
- package/src/components/Calendar/CalendarYearHeading.vue +63 -0
- package/src/components/Calendar/index.ts +63 -0
- package/src/components/Calendar/useCalendar.ts +453 -0
- package/src/components/ConfigProvider/ConfigProvider.vue +73 -0
- package/src/components/ConfigProvider/index.ts +5 -0
- package/src/components/DateField/DateFieldInput.vue +72 -0
- package/src/components/DateField/DateFieldRoot.vue +359 -0
- package/src/components/DateField/index.ts +10 -0
- package/src/components/DatePicker/DatePickerAnchor.vue +16 -0
- package/src/components/DatePicker/DatePickerArrow.vue +16 -0
- package/src/components/DatePicker/DatePickerCalendar.vue +62 -0
- package/src/components/DatePicker/DatePickerCell.vue +16 -0
- package/src/components/DatePicker/DatePickerCellTrigger.vue +18 -0
- package/src/components/DatePicker/DatePickerClose.vue +16 -0
- package/src/components/DatePicker/DatePickerContent.vue +50 -0
- package/src/components/DatePicker/DatePickerField.vue +53 -0
- package/src/components/DatePicker/DatePickerGrid.vue +16 -0
- package/src/components/DatePicker/DatePickerGridBody.vue +16 -0
- package/src/components/DatePicker/DatePickerGridHead.vue +16 -0
- package/src/components/DatePicker/DatePickerGridRow.vue +16 -0
- package/src/components/DatePicker/DatePickerHeadCell.vue +16 -0
- package/src/components/DatePicker/DatePickerHeader.vue +16 -0
- package/src/components/DatePicker/DatePickerHeading.vue +24 -0
- package/src/components/DatePicker/DatePickerInput.vue +16 -0
- package/src/components/DatePicker/DatePickerMonthHeading.vue +19 -0
- package/src/components/DatePicker/DatePickerMonthYearOverlay.vue +13 -0
- package/src/components/DatePicker/DatePickerNext.vue +19 -0
- package/src/components/DatePicker/DatePickerOverlayItem.vue +16 -0
- package/src/components/DatePicker/DatePickerPrev.vue +18 -0
- package/src/components/DatePicker/DatePickerRoot.vue +216 -0
- package/src/components/DatePicker/DatePickerTrigger.vue +29 -0
- package/src/components/DatePicker/DatePickerYearHeading.vue +19 -0
- package/src/components/DatePicker/index.ts +92 -0
- package/src/components/DismissableLayer/DismissableLayer.vue +175 -0
- package/src/components/DismissableLayer/DismissableLayerBranch.vue +28 -0
- package/src/components/DismissableLayer/index.ts +7 -0
- package/src/components/DismissableLayer/utils.ts +194 -0
- package/src/components/FocusScope/FocusScope.vue +220 -0
- package/src/components/FocusScope/index.ts +5 -0
- package/src/components/FocusScope/stack.ts +49 -0
- package/src/components/FocusScope/utils.ts +108 -0
- package/src/components/Popover/PopoverAnchor.vue +30 -0
- package/src/components/Popover/PopoverArrow.vue +23 -0
- package/src/components/Popover/PopoverClose.vue +29 -0
- package/src/components/Popover/PopoverContent.vue +41 -0
- package/src/components/Popover/PopoverContentImpl.vue +97 -0
- package/src/components/Popover/PopoverContentNonModal.vue +74 -0
- package/src/components/Popover/PopoverPortal.vue +17 -0
- package/src/components/Popover/PopoverRoot.vue +83 -0
- package/src/components/Popover/PopoverTrigger.vue +48 -0
- package/src/components/Popover/index.ts +31 -0
- package/src/components/Popper/PopperAnchor.vue +36 -0
- package/src/components/Popper/PopperArrow.vue +81 -0
- package/src/components/Popper/PopperContent.vue +399 -0
- package/src/components/Popper/PopperRoot.vue +36 -0
- package/src/components/Popper/index.ts +15 -0
- package/src/components/Popper/utils.ts +63 -0
- package/src/components/Presence/Presence.ts +91 -0
- package/src/components/Presence/index.ts +1 -0
- package/src/components/Presence/usePresence.ts +175 -0
- package/src/components/Primitive/Primitive.ts +66 -0
- package/src/components/Primitive/Slot.ts +40 -0
- package/src/components/Primitive/index.ts +3 -0
- package/src/components/Primitive/usePrimitiveElement.ts +13 -0
- package/src/components/Teleport/Teleport.vue +49 -0
- package/src/components/Teleport/index.ts +1 -0
- package/src/components/VisuallyHidden/VisuallyHidden.vue +47 -0
- package/src/components/VisuallyHidden/VisuallyHiddenInput.vue +67 -0
- package/src/components/VisuallyHidden/VisuallyHiddenInputBubble.vue +56 -0
- package/src/components/VisuallyHidden/index.ts +2 -0
- package/src/date/calendar.ts +242 -0
- package/src/date/comparators.ts +199 -0
- package/src/date/index.ts +3 -0
- package/src/date/types.ts +37 -0
- package/src/date/utils.ts +18 -0
- package/src/index.ts +78 -0
- package/src/shared/arrays.ts +66 -0
- package/src/shared/component/Arrow.vue +55 -0
- package/src/shared/component/BaseSeparator.vue +57 -0
- package/src/shared/component/index.ts +2 -0
- package/src/shared/constant/countryList.ts +251 -0
- package/src/shared/constant/index.ts +1 -0
- package/src/shared/createContext.ts +57 -0
- package/src/shared/date/comparators.ts +74 -0
- package/src/shared/date/index.ts +42 -0
- package/src/shared/date/parser.ts +252 -0
- package/src/shared/date/parts.ts +32 -0
- package/src/shared/date/placeholders.ts +221 -0
- package/src/shared/date/segment.ts +50 -0
- package/src/shared/date/types.ts +50 -0
- package/src/shared/date/useDateField.ts +998 -0
- package/src/shared/date/utils.ts +84 -0
- package/src/shared/getActiveElement.ts +12 -0
- package/src/shared/handleAndDispatchCustomEvent.ts +21 -0
- package/src/shared/index.ts +27 -0
- package/src/shared/nullish.ts +3 -0
- package/src/shared/onFocusOutside.ts +29 -0
- package/src/shared/renderSlotFragments.ts +13 -0
- package/src/shared/trap-focus.ts +45 -0
- package/src/shared/types.ts +64 -0
- package/src/shared/useDateFormatter.ts +186 -0
- package/src/shared/useDirection.ts +16 -0
- package/src/shared/useEmitAsProps.ts +32 -0
- package/src/shared/useFocusGuards.ts +46 -0
- package/src/shared/useForwardExpose.ts +66 -0
- package/src/shared/useForwardProps.ts +43 -0
- package/src/shared/useForwardPropsEmits.ts +26 -0
- package/src/shared/useId.ts +34 -0
- package/src/shared/useIsUsingKeyboard.ts +22 -0
- package/src/shared/useKbd.ts +58 -0
- package/src/shared/useLocale.ts +15 -0
- package/src/shared/useNonce.ts +10 -0
- package/src/shared/useSize.ts +64 -0
- package/src/shared/useStateMachine.ts +48 -0
- package/src/shared/withDefault.ts +61 -0
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
import { defineComponent, mergeDefaults, ref, computed, watchPostEffect, watchEffect, createElementBlock, openBlock, normalizeStyle, unref, createVNode, mergeProps, withCtx, renderSlot } from "vue";
|
|
2
|
+
import { useFloating, arrow } from "../../node_modules/.pnpm/@floating-ui_vue@1.1.9_vue@3.5.26_typescript@5.9.3_/node_modules/@floating-ui/vue/dist/floating-ui.vue.js";
|
|
3
|
+
import { Primitive } from "../Primitive/Primitive.js";
|
|
4
|
+
import "../Primitive/Slot.js";
|
|
5
|
+
import { injectPopperRootContext } from "./PopperRoot.vue.js";
|
|
6
|
+
import { isNotNull, getSideAndAlignFromPlacement, transformOrigin } from "./utils.js";
|
|
7
|
+
import { createContext } from "../../shared/createContext.js";
|
|
8
|
+
import { computedEager } from "../../node_modules/.pnpm/@vueuse_shared@14.1.0_vue@3.5.26_typescript@5.9.3_/node_modules/@vueuse/shared/dist/index.js";
|
|
9
|
+
import { useForwardExpose } from "../../shared/useForwardExpose.js";
|
|
10
|
+
import { useSize } from "../../shared/useSize.js";
|
|
11
|
+
import { autoUpdate, offset, flip, shift, size, hide, limitShift } from "../../node_modules/.pnpm/@floating-ui_dom@1.7.4/node_modules/@floating-ui/dom/dist/floating-ui.dom.js";
|
|
12
|
+
const PopperContentPropsDefaultValue = {
|
|
13
|
+
side: "bottom",
|
|
14
|
+
sideOffset: 0,
|
|
15
|
+
sideFlip: true,
|
|
16
|
+
align: "center",
|
|
17
|
+
alignOffset: 0,
|
|
18
|
+
alignFlip: true,
|
|
19
|
+
arrowPadding: 0,
|
|
20
|
+
avoidCollisions: true,
|
|
21
|
+
collisionBoundary: () => [],
|
|
22
|
+
collisionPadding: 0,
|
|
23
|
+
sticky: "partial",
|
|
24
|
+
hideWhenDetached: false,
|
|
25
|
+
positionStrategy: "fixed",
|
|
26
|
+
updatePositionStrategy: "optimized",
|
|
27
|
+
prioritizePosition: false
|
|
28
|
+
};
|
|
29
|
+
const [injectPopperContentContext, providePopperContentContext] = createContext("PopperContent");
|
|
30
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
31
|
+
...{
|
|
32
|
+
inheritAttrs: false
|
|
33
|
+
},
|
|
34
|
+
__name: "PopperContent",
|
|
35
|
+
props: /* @__PURE__ */ mergeDefaults({
|
|
36
|
+
side: {},
|
|
37
|
+
sideOffset: {},
|
|
38
|
+
sideFlip: { type: Boolean },
|
|
39
|
+
align: {},
|
|
40
|
+
alignOffset: {},
|
|
41
|
+
alignFlip: { type: Boolean },
|
|
42
|
+
avoidCollisions: { type: Boolean },
|
|
43
|
+
collisionBoundary: {},
|
|
44
|
+
collisionPadding: {},
|
|
45
|
+
arrowPadding: {},
|
|
46
|
+
sticky: {},
|
|
47
|
+
hideWhenDetached: { type: Boolean },
|
|
48
|
+
positionStrategy: {},
|
|
49
|
+
updatePositionStrategy: {},
|
|
50
|
+
disableUpdateOnLayoutShift: { type: Boolean },
|
|
51
|
+
prioritizePosition: { type: Boolean },
|
|
52
|
+
reference: {},
|
|
53
|
+
asChild: { type: Boolean },
|
|
54
|
+
as: {}
|
|
55
|
+
}, {
|
|
56
|
+
...PopperContentPropsDefaultValue
|
|
57
|
+
}),
|
|
58
|
+
emits: ["placed"],
|
|
59
|
+
setup(__props, { emit: __emit }) {
|
|
60
|
+
const props = __props;
|
|
61
|
+
const emits = __emit;
|
|
62
|
+
const rootContext = injectPopperRootContext();
|
|
63
|
+
const { forwardRef, currentElement: contentElement } = useForwardExpose();
|
|
64
|
+
const floatingRef = ref();
|
|
65
|
+
const arrow$1 = ref();
|
|
66
|
+
const { width: arrowWidth, height: arrowHeight } = useSize(arrow$1);
|
|
67
|
+
const desiredPlacement = computed(
|
|
68
|
+
() => props.side + (props.align !== "center" ? `-${props.align}` : "")
|
|
69
|
+
);
|
|
70
|
+
const collisionPadding = computed(() => {
|
|
71
|
+
return typeof props.collisionPadding === "number" ? props.collisionPadding : { top: 0, right: 0, bottom: 0, left: 0, ...props.collisionPadding };
|
|
72
|
+
});
|
|
73
|
+
const boundary = computed(() => {
|
|
74
|
+
return Array.isArray(props.collisionBoundary) ? props.collisionBoundary : [props.collisionBoundary];
|
|
75
|
+
});
|
|
76
|
+
const detectOverflowOptions = computed(() => {
|
|
77
|
+
return {
|
|
78
|
+
padding: collisionPadding.value,
|
|
79
|
+
boundary: boundary.value.filter(isNotNull),
|
|
80
|
+
// with `strategy: 'fixed'`, this is the only way to get it to respect boundaries
|
|
81
|
+
altBoundary: boundary.value.length > 0
|
|
82
|
+
};
|
|
83
|
+
});
|
|
84
|
+
const flipOptions = computed(() => {
|
|
85
|
+
return {
|
|
86
|
+
mainAxis: props.sideFlip,
|
|
87
|
+
crossAxis: props.alignFlip
|
|
88
|
+
};
|
|
89
|
+
});
|
|
90
|
+
const computedMiddleware = computedEager(() => {
|
|
91
|
+
return [
|
|
92
|
+
offset({
|
|
93
|
+
mainAxis: props.sideOffset + arrowHeight.value,
|
|
94
|
+
alignmentAxis: props.alignOffset
|
|
95
|
+
}),
|
|
96
|
+
props.prioritizePosition && props.avoidCollisions && flip({
|
|
97
|
+
...detectOverflowOptions.value,
|
|
98
|
+
...flipOptions.value
|
|
99
|
+
}),
|
|
100
|
+
props.avoidCollisions && shift({
|
|
101
|
+
mainAxis: true,
|
|
102
|
+
crossAxis: !!props.prioritizePosition,
|
|
103
|
+
limiter: props.sticky === "partial" ? limitShift() : void 0,
|
|
104
|
+
...detectOverflowOptions.value
|
|
105
|
+
}),
|
|
106
|
+
!props.prioritizePosition && props.avoidCollisions && flip({
|
|
107
|
+
...detectOverflowOptions.value,
|
|
108
|
+
...flipOptions.value
|
|
109
|
+
}),
|
|
110
|
+
size({
|
|
111
|
+
...detectOverflowOptions.value,
|
|
112
|
+
apply: ({ elements, rects, availableWidth, availableHeight }) => {
|
|
113
|
+
const { width: anchorWidth, height: anchorHeight } = rects.reference;
|
|
114
|
+
const contentStyle = elements.floating.style;
|
|
115
|
+
contentStyle.setProperty(
|
|
116
|
+
"--reka-popper-available-width",
|
|
117
|
+
`${availableWidth}px`
|
|
118
|
+
);
|
|
119
|
+
contentStyle.setProperty(
|
|
120
|
+
"--reka-popper-available-height",
|
|
121
|
+
`${availableHeight}px`
|
|
122
|
+
);
|
|
123
|
+
contentStyle.setProperty(
|
|
124
|
+
"--reka-popper-anchor-width",
|
|
125
|
+
`${anchorWidth}px`
|
|
126
|
+
);
|
|
127
|
+
contentStyle.setProperty(
|
|
128
|
+
"--reka-popper-anchor-height",
|
|
129
|
+
`${anchorHeight}px`
|
|
130
|
+
);
|
|
131
|
+
}
|
|
132
|
+
}),
|
|
133
|
+
arrow$1.value && arrow({ element: arrow$1.value, padding: props.arrowPadding }),
|
|
134
|
+
transformOrigin({
|
|
135
|
+
arrowWidth: arrowWidth.value,
|
|
136
|
+
arrowHeight: arrowHeight.value
|
|
137
|
+
}),
|
|
138
|
+
props.hideWhenDetached && hide({ strategy: "referenceHidden", ...detectOverflowOptions.value })
|
|
139
|
+
];
|
|
140
|
+
});
|
|
141
|
+
const reference = computed(() => props.reference ?? rootContext.anchor.value);
|
|
142
|
+
const { floatingStyles, placement, isPositioned, middlewareData } = useFloating(reference, floatingRef, {
|
|
143
|
+
strategy: props.positionStrategy,
|
|
144
|
+
placement: desiredPlacement,
|
|
145
|
+
whileElementsMounted: (...args) => {
|
|
146
|
+
const cleanup = autoUpdate(...args, {
|
|
147
|
+
layoutShift: !props.disableUpdateOnLayoutShift,
|
|
148
|
+
animationFrame: props.updatePositionStrategy === "always"
|
|
149
|
+
});
|
|
150
|
+
return cleanup;
|
|
151
|
+
},
|
|
152
|
+
middleware: computedMiddleware
|
|
153
|
+
});
|
|
154
|
+
const placedSide = computed(
|
|
155
|
+
() => getSideAndAlignFromPlacement(placement.value)[0]
|
|
156
|
+
);
|
|
157
|
+
const placedAlign = computed(
|
|
158
|
+
() => getSideAndAlignFromPlacement(placement.value)[1]
|
|
159
|
+
);
|
|
160
|
+
watchPostEffect(() => {
|
|
161
|
+
if (isPositioned.value) emits("placed");
|
|
162
|
+
});
|
|
163
|
+
const cannotCenterArrow = computed(
|
|
164
|
+
() => middlewareData.value.arrow?.centerOffset !== 0
|
|
165
|
+
);
|
|
166
|
+
const contentZIndex = ref("");
|
|
167
|
+
watchEffect(() => {
|
|
168
|
+
if (contentElement.value)
|
|
169
|
+
contentZIndex.value = window.getComputedStyle(contentElement.value).zIndex;
|
|
170
|
+
});
|
|
171
|
+
const arrowX = computed(() => middlewareData.value.arrow?.x ?? 0);
|
|
172
|
+
const arrowY = computed(() => middlewareData.value.arrow?.y ?? 0);
|
|
173
|
+
providePopperContentContext({
|
|
174
|
+
placedSide,
|
|
175
|
+
onArrowChange: (element) => arrow$1.value = element,
|
|
176
|
+
arrowX,
|
|
177
|
+
arrowY,
|
|
178
|
+
shouldHideArrow: cannotCenterArrow
|
|
179
|
+
});
|
|
180
|
+
return (_ctx, _cache) => {
|
|
181
|
+
return openBlock(), createElementBlock("div", {
|
|
182
|
+
ref_key: "floatingRef",
|
|
183
|
+
ref: floatingRef,
|
|
184
|
+
"data-reka-popper-content-wrapper": "",
|
|
185
|
+
style: normalizeStyle({
|
|
186
|
+
...unref(floatingStyles),
|
|
187
|
+
transform: unref(isPositioned) ? unref(floatingStyles).transform : "translate(0, -200%)",
|
|
188
|
+
// keep off the page when measuring
|
|
189
|
+
minWidth: "max-content",
|
|
190
|
+
zIndex: contentZIndex.value,
|
|
191
|
+
["--reka-popper-transform-origin"]: [
|
|
192
|
+
unref(middlewareData).transformOrigin?.x,
|
|
193
|
+
unref(middlewareData).transformOrigin?.y
|
|
194
|
+
].join(" "),
|
|
195
|
+
// hide the content if using the hide middleware and should be hidden
|
|
196
|
+
// set visibility to hidden and disable pointer events so the UI behaves
|
|
197
|
+
// as if the PopperContent isn't there at all
|
|
198
|
+
...unref(middlewareData).hide?.referenceHidden && {
|
|
199
|
+
visibility: "hidden",
|
|
200
|
+
pointerEvents: "none"
|
|
201
|
+
}
|
|
202
|
+
})
|
|
203
|
+
}, [
|
|
204
|
+
createVNode(unref(Primitive), mergeProps({ ref: unref(forwardRef) }, _ctx.$attrs, {
|
|
205
|
+
"as-child": props.asChild,
|
|
206
|
+
as: __props.as,
|
|
207
|
+
"data-side": placedSide.value,
|
|
208
|
+
"data-align": placedAlign.value,
|
|
209
|
+
style: {
|
|
210
|
+
// if the PopperContent hasn't been placed yet (not all measurements done)
|
|
211
|
+
// we prevent animations so that users's animation don't kick in too early referring wrong sides
|
|
212
|
+
animation: !unref(isPositioned) ? "none" : void 0
|
|
213
|
+
}
|
|
214
|
+
}), {
|
|
215
|
+
default: withCtx(() => [
|
|
216
|
+
renderSlot(_ctx.$slots, "default")
|
|
217
|
+
]),
|
|
218
|
+
_: 3
|
|
219
|
+
}, 16, ["as-child", "as", "data-side", "data-align", "style"])
|
|
220
|
+
], 4);
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
});
|
|
224
|
+
export {
|
|
225
|
+
PopperContentPropsDefaultValue,
|
|
226
|
+
_sfc_main as default,
|
|
227
|
+
injectPopperContentContext,
|
|
228
|
+
providePopperContentContext
|
|
229
|
+
};
|
|
230
|
+
//# sourceMappingURL=PopperContent.vue2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PopperContent.vue2.js","sources":["../../../src/components/Popper/PopperContent.vue"],"sourcesContent":["<script lang=\"ts\">\nimport type { Middleware, Placement, ReferenceElement } from \"@floating-ui/vue\";\nimport type { Ref } from \"vue\";\nimport type { Align, Side } from \"./utils\";\nimport type { PrimitiveProps } from \"../Primitive\";\nimport { createContext, useForwardExpose, useSize } from \"../../shared\";\n\nexport const PopperContentPropsDefaultValue = {\n side: \"bottom\" as Side,\n sideOffset: 0,\n sideFlip: true,\n align: \"center\" as Align,\n alignOffset: 0,\n alignFlip: true,\n arrowPadding: 0,\n avoidCollisions: true,\n collisionBoundary: () => [],\n collisionPadding: 0,\n sticky: \"partial\" as \"partial\" | \"always\",\n hideWhenDetached: false,\n positionStrategy: \"fixed\" as \"absolute\" | \"fixed\",\n updatePositionStrategy: \"optimized\" as \"optimized\" | \"always\",\n prioritizePosition: false,\n};\n\nexport interface PopperContentProps extends PrimitiveProps {\n /**\n * The preferred side of the trigger to render against when open.\n * Will be reversed when collisions occur and avoidCollisions\n * is enabled.\n *\n * @defaultValue \"top\"\n */\n side?: Side;\n\n /**\n * The distance in pixels from the trigger.\n *\n * @defaultValue 0\n */\n sideOffset?: number;\n\n /**\n * Flip to the opposite side when colliding with boundary.\n *\n * @defaultValue true\n */\n sideFlip?: boolean;\n\n /**\n * The preferred alignment against the trigger.\n * May change when collisions occur.\n *\n * @defaultValue \"center\"\n */\n align?: Align;\n\n /**\n * An offset in pixels from the `start` or `end` alignment options.\n *\n * @defaultValue 0\n */\n alignOffset?: number;\n\n /**\n * Flip alignment when colliding with boundary.\n * May only occur when `prioritizePosition` is true.\n *\n * @defaultValue true\n */\n alignFlip?: boolean;\n\n /**\n * When `true`, overrides the side and align preferences\n * to prevent collisions with boundary edges.\n *\n * @defaultValue true\n */\n avoidCollisions?: boolean;\n\n /**\n * The element used as the collision boundary. By default\n * this is the viewport, though you can provide additional\n * element(s) to be included in this check.\n *\n * @defaultValue []\n */\n collisionBoundary?: Element | null | Array<Element | null>;\n\n /**\n * The distance in pixels from the boundary edges where collision\n * detection should occur. Accepts a number (same for all sides),\n * or a partial padding object, for example: { top: 20, left: 20 }.\n *\n * @defaultValue 0\n */\n collisionPadding?: number | Partial<Record<Side, number>>;\n\n /**\n * The padding between the arrow and the edges of the content.\n * If your content has border-radius, this will prevent it from\n * overflowing the corners.\n *\n * @defaultValue 0\n */\n arrowPadding?: number;\n\n /**\n * The sticky behavior on the align axis. `partial` will keep the\n * content in the boundary as long as the trigger is at least partially\n * in the boundary whilst \"always\" will keep the content in the boundary\n * regardless.\n *\n * @defaultValue \"partial\"\n */\n sticky?: \"partial\" | \"always\";\n\n /**\n * Whether to hide the content when the trigger becomes fully occluded.\n *\n * @defaultValue false\n */\n hideWhenDetached?: boolean;\n\n /**\n * The type of CSS position property to use.\n */\n positionStrategy?: \"absolute\" | \"fixed\";\n\n /**\n * Strategy to update the position of the floating element on every animation frame.\n *\n * @defaultValue 'optimized'\n */\n updatePositionStrategy?: \"optimized\" | \"always\";\n\n /**\n * Whether to disable the update position for the content when the layout shifted.\n *\n * @defaultValue false\n */\n disableUpdateOnLayoutShift?: boolean;\n\n /**\n * Force content to be position within the viewport.\n *\n * Might overlap the reference element, which may not be desired.\n *\n * @defaultValue false\n */\n prioritizePosition?: boolean;\n\n /**\n * The custom element or virtual element that will be set as the reference\n * to position the floating element.\n *\n * If provided, it will replace the default anchor element.\n */\n reference?: ReferenceElement;\n}\n\nexport interface PopperContentContext {\n placedSide: Ref<Side>;\n onArrowChange: (arrow: HTMLElement | undefined) => void;\n arrowX?: Ref<number>;\n arrowY?: Ref<number>;\n shouldHideArrow: Ref<boolean>;\n}\n\nexport const [injectPopperContentContext, providePopperContentContext] =\n createContext<PopperContentContext>(\"PopperContent\");\n</script>\n\n<script setup lang=\"ts\">\nimport {\n autoUpdate,\n flip,\n arrow as floatingUIarrow,\n hide,\n limitShift,\n offset,\n shift,\n size,\n useFloating,\n} from \"@floating-ui/vue\";\nimport { computedEager } from \"@vueuse/core\";\nimport { computed, ref, watchEffect, watchPostEffect } from \"vue\";\nimport { Primitive } from \"../Primitive\";\nimport { injectPopperRootContext } from \"./PopperRoot.vue\";\nimport {\n getSideAndAlignFromPlacement,\n isNotNull,\n transformOrigin,\n} from \"./utils\";\n\ndefineOptions({\n inheritAttrs: false,\n});\n\nconst props = withDefaults(defineProps<PopperContentProps>(), {\n ...PopperContentPropsDefaultValue,\n});\nconst emits = defineEmits<{\n placed: [void];\n}>();\n\nconst rootContext = injectPopperRootContext();\nconst { forwardRef, currentElement: contentElement } = useForwardExpose();\n\nconst floatingRef = ref<HTMLElement>();\n\nconst arrow = ref<HTMLElement>();\nconst { width: arrowWidth, height: arrowHeight } = useSize(arrow);\n\nconst desiredPlacement = computed(\n () =>\n (props.side +\n (props.align !== \"center\" ? `-${props.align}` : \"\")) as Placement,\n);\n\nconst collisionPadding = computed(() => {\n return typeof props.collisionPadding === \"number\"\n ? props.collisionPadding\n : { top: 0, right: 0, bottom: 0, left: 0, ...props.collisionPadding };\n});\n\nconst boundary = computed(() => {\n return Array.isArray(props.collisionBoundary)\n ? props.collisionBoundary\n : [props.collisionBoundary];\n});\n\nconst detectOverflowOptions = computed(() => {\n return {\n padding: collisionPadding.value,\n boundary: boundary.value.filter(isNotNull),\n // with `strategy: 'fixed'`, this is the only way to get it to respect boundaries\n altBoundary: boundary.value.length > 0,\n };\n});\n\nconst flipOptions = computed(() => {\n return {\n mainAxis: props.sideFlip,\n crossAxis: props.alignFlip,\n };\n});\n\nconst computedMiddleware = computedEager(() => {\n return [\n offset({\n mainAxis: props.sideOffset + arrowHeight.value,\n alignmentAxis: props.alignOffset,\n }),\n props.prioritizePosition &&\n props.avoidCollisions &&\n flip({\n ...detectOverflowOptions.value,\n ...flipOptions.value,\n }),\n props.avoidCollisions &&\n shift({\n mainAxis: true,\n crossAxis: !!props.prioritizePosition,\n limiter: props.sticky === \"partial\" ? limitShift() : undefined,\n ...detectOverflowOptions.value,\n }),\n !props.prioritizePosition &&\n props.avoidCollisions &&\n flip({\n ...detectOverflowOptions.value,\n ...flipOptions.value,\n }),\n size({\n ...detectOverflowOptions.value,\n apply: ({ elements, rects, availableWidth, availableHeight }) => {\n const { width: anchorWidth, height: anchorHeight } = rects.reference;\n const contentStyle = elements.floating.style;\n contentStyle.setProperty(\n \"--reka-popper-available-width\",\n `${availableWidth}px`,\n );\n contentStyle.setProperty(\n \"--reka-popper-available-height\",\n `${availableHeight}px`,\n );\n contentStyle.setProperty(\n \"--reka-popper-anchor-width\",\n `${anchorWidth}px`,\n );\n contentStyle.setProperty(\n \"--reka-popper-anchor-height\",\n `${anchorHeight}px`,\n );\n },\n }),\n arrow.value &&\n floatingUIarrow({ element: arrow.value, padding: props.arrowPadding }),\n transformOrigin({\n arrowWidth: arrowWidth.value,\n arrowHeight: arrowHeight.value,\n }),\n props.hideWhenDetached &&\n hide({ strategy: \"referenceHidden\", ...detectOverflowOptions.value }),\n ] as Middleware[];\n});\n\n// If provided custom reference, it will overwrite the default anchor element\nconst reference = computed(() => props.reference ?? rootContext.anchor.value);\n\nconst { floatingStyles, placement, isPositioned, middlewareData, update } =\n useFloating(reference, floatingRef, {\n strategy: props.positionStrategy,\n placement: desiredPlacement,\n whileElementsMounted: (...args) => {\n const cleanup = autoUpdate(...args, {\n layoutShift: !props.disableUpdateOnLayoutShift,\n animationFrame: props.updatePositionStrategy === \"always\",\n });\n return cleanup;\n },\n middleware: computedMiddleware,\n });\n\nconst placedSide = computed(\n () => getSideAndAlignFromPlacement(placement.value)[0],\n);\nconst placedAlign = computed(\n () => getSideAndAlignFromPlacement(placement.value)[1],\n);\n\nwatchPostEffect(() => {\n if (isPositioned.value) emits(\"placed\");\n});\n\nconst cannotCenterArrow = computed(\n () => middlewareData.value.arrow?.centerOffset !== 0,\n);\n\nconst contentZIndex = ref(\"\");\nwatchEffect(() => {\n if (contentElement.value)\n contentZIndex.value = window.getComputedStyle(contentElement.value).zIndex;\n});\n\nconst arrowX = computed(() => middlewareData.value.arrow?.x ?? 0);\nconst arrowY = computed(() => middlewareData.value.arrow?.y ?? 0);\n\nprovidePopperContentContext({\n placedSide,\n onArrowChange: (element) => (arrow.value = element),\n arrowX,\n arrowY,\n shouldHideArrow: cannotCenterArrow,\n});\n</script>\n\n<template>\n <div\n ref=\"floatingRef\"\n data-reka-popper-content-wrapper=\"\"\n :style=\"{\n ...floatingStyles,\n transform: isPositioned\n ? floatingStyles.transform\n : 'translate(0, -200%)', // keep off the page when measuring\n minWidth: 'max-content',\n zIndex: contentZIndex,\n ['--reka-popper-transform-origin' as any]: [\n middlewareData.transformOrigin?.x,\n middlewareData.transformOrigin?.y,\n ].join(' '),\n\n // hide the content if using the hide middleware and should be hidden\n // set visibility to hidden and disable pointer events so the UI behaves\n // as if the PopperContent isn't there at all\n ...(middlewareData.hide?.referenceHidden && {\n visibility: 'hidden',\n pointerEvents: 'none',\n }),\n }\"\n >\n <Primitive\n :ref=\"forwardRef\"\n v-bind=\"$attrs\"\n :as-child=\"props.asChild\"\n :as=\"as\"\n :data-side=\"placedSide\"\n :data-align=\"placedAlign\"\n :style=\"{\n // if the PopperContent hasn't been placed yet (not all measurements done)\n // we prevent animations so that users's animation don't kick in too early referring wrong sides\n animation: !isPositioned ? 'none' : undefined,\n }\"\n >\n <slot />\n </Primitive>\n </div>\n</template>\n"],"names":["arrow","floatingUIarrow","_createElementBlock","_normalizeStyle","_unref","_createVNode","_mergeProps","$attrs","_renderSlot"],"mappings":";;;;;;;;;;;AAOO,MAAM,iCAAiC;AAAA,EAC5C,MAAM;AAAA,EACN,YAAY;AAAA,EACZ,UAAU;AAAA,EACV,OAAO;AAAA,EACP,aAAa;AAAA,EACb,WAAW;AAAA,EACX,cAAc;AAAA,EACd,iBAAiB;AAAA,EACjB,mBAAmB,MAAM,CAAA;AAAA,EACzB,kBAAkB;AAAA,EAClB,QAAQ;AAAA,EACR,kBAAkB;AAAA,EAClB,kBAAkB;AAAA,EAClB,wBAAwB;AAAA,EACxB,oBAAoB;AACtB;AAkJO,MAAM,CAAC,4BAA4B,2BAA2B,IACnE,cAAoC,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA6BrD,UAAM,QAAQ;AAGd,UAAM,QAAQ;AAId,UAAM,cAAc,wBAAA;AACpB,UAAM,EAAE,YAAY,gBAAgB,eAAA,IAAmB,iBAAA;AAEvD,UAAM,cAAc,IAAA;AAEpB,UAAMA,UAAQ,IAAA;AACd,UAAM,EAAE,OAAO,YAAY,QAAQ,YAAA,IAAgB,QAAQA,OAAK;AAEhE,UAAM,mBAAmB;AAAA,MACvB,MACG,MAAM,QACJ,MAAM,UAAU,WAAW,IAAI,MAAM,KAAK,KAAK;AAAA,IAAA;AAGtD,UAAM,mBAAmB,SAAS,MAAM;AACtC,aAAO,OAAO,MAAM,qBAAqB,WACrC,MAAM,mBACN,EAAE,KAAK,GAAG,OAAO,GAAG,QAAQ,GAAG,MAAM,GAAG,GAAG,MAAM,iBAAA;AAAA,IACvD,CAAC;AAED,UAAM,WAAW,SAAS,MAAM;AAC9B,aAAO,MAAM,QAAQ,MAAM,iBAAiB,IACxC,MAAM,oBACN,CAAC,MAAM,iBAAiB;AAAA,IAC9B,CAAC;AAED,UAAM,wBAAwB,SAAS,MAAM;AAC3C,aAAO;AAAA,QACL,SAAS,iBAAiB;AAAA,QAC1B,UAAU,SAAS,MAAM,OAAO,SAAS;AAAA;AAAA,QAEzC,aAAa,SAAS,MAAM,SAAS;AAAA,MAAA;AAAA,IAEzC,CAAC;AAED,UAAM,cAAc,SAAS,MAAM;AACjC,aAAO;AAAA,QACL,UAAU,MAAM;AAAA,QAChB,WAAW,MAAM;AAAA,MAAA;AAAA,IAErB,CAAC;AAED,UAAM,qBAAqB,cAAc,MAAM;AAC7C,aAAO;AAAA,QACL,OAAO;AAAA,UACL,UAAU,MAAM,aAAa,YAAY;AAAA,UACzC,eAAe,MAAM;AAAA,QAAA,CACtB;AAAA,QACD,MAAM,sBACJ,MAAM,mBACN,KAAK;AAAA,UACH,GAAG,sBAAsB;AAAA,UACzB,GAAG,YAAY;AAAA,QAAA,CAChB;AAAA,QACH,MAAM,mBACJ,MAAM;AAAA,UACJ,UAAU;AAAA,UACV,WAAW,CAAC,CAAC,MAAM;AAAA,UACnB,SAAS,MAAM,WAAW,YAAY,eAAe;AAAA,UACrD,GAAG,sBAAsB;AAAA,QAAA,CAC1B;AAAA,QACH,CAAC,MAAM,sBACL,MAAM,mBACN,KAAK;AAAA,UACH,GAAG,sBAAsB;AAAA,UACzB,GAAG,YAAY;AAAA,QAAA,CAChB;AAAA,QACH,KAAK;AAAA,UACH,GAAG,sBAAsB;AAAA,UACzB,OAAO,CAAC,EAAE,UAAU,OAAO,gBAAgB,sBAAsB;AAC/D,kBAAM,EAAE,OAAO,aAAa,QAAQ,aAAA,IAAiB,MAAM;AAC3D,kBAAM,eAAe,SAAS,SAAS;AACvC,yBAAa;AAAA,cACX;AAAA,cACA,GAAG,cAAc;AAAA,YAAA;AAEnB,yBAAa;AAAA,cACX;AAAA,cACA,GAAG,eAAe;AAAA,YAAA;AAEpB,yBAAa;AAAA,cACX;AAAA,cACA,GAAG,WAAW;AAAA,YAAA;AAEhB,yBAAa;AAAA,cACX;AAAA,cACA,GAAG,YAAY;AAAA,YAAA;AAAA,UAEnB;AAAA,QAAA,CACD;AAAA,QACDA,QAAM,SACJC,MAAgB,EAAE,SAASD,QAAM,OAAO,SAAS,MAAM,cAAc;AAAA,QACvE,gBAAgB;AAAA,UACd,YAAY,WAAW;AAAA,UACvB,aAAa,YAAY;AAAA,QAAA,CAC1B;AAAA,QACD,MAAM,oBACJ,KAAK,EAAE,UAAU,mBAAmB,GAAG,sBAAsB,MAAA,CAAO;AAAA,MAAA;AAAA,IAE1E,CAAC;AAGD,UAAM,YAAY,SAAS,MAAM,MAAM,aAAa,YAAY,OAAO,KAAK;AAE5E,UAAM,EAAE,gBAAgB,WAAW,cAAc,eAAuB,IACtE,YAAY,WAAW,aAAa;AAAA,MAClC,UAAU,MAAM;AAAA,MAChB,WAAW;AAAA,MACX,sBAAsB,IAAI,SAAS;AACjC,cAAM,UAAU,WAAW,GAAG,MAAM;AAAA,UAClC,aAAa,CAAC,MAAM;AAAA,UACpB,gBAAgB,MAAM,2BAA2B;AAAA,QAAA,CAClD;AACD,eAAO;AAAA,MACT;AAAA,MACA,YAAY;AAAA,IAAA,CACb;AAEH,UAAM,aAAa;AAAA,MACjB,MAAM,6BAA6B,UAAU,KAAK,EAAE,CAAC;AAAA,IAAA;AAEvD,UAAM,cAAc;AAAA,MAClB,MAAM,6BAA6B,UAAU,KAAK,EAAE,CAAC;AAAA,IAAA;AAGvD,oBAAgB,MAAM;AACpB,UAAI,aAAa,MAAO,OAAM,QAAQ;AAAA,IACxC,CAAC;AAED,UAAM,oBAAoB;AAAA,MACxB,MAAM,eAAe,MAAM,OAAO,iBAAiB;AAAA,IAAA;AAGrD,UAAM,gBAAgB,IAAI,EAAE;AAC5B,gBAAY,MAAM;AAChB,UAAI,eAAe;AACjB,sBAAc,QAAQ,OAAO,iBAAiB,eAAe,KAAK,EAAE;AAAA,IACxE,CAAC;AAED,UAAM,SAAS,SAAS,MAAM,eAAe,MAAM,OAAO,KAAK,CAAC;AAChE,UAAM,SAAS,SAAS,MAAM,eAAe,MAAM,OAAO,KAAK,CAAC;AAEhE,gCAA4B;AAAA,MAC1B;AAAA,MACA,eAAe,CAAC,YAAaA,QAAM,QAAQ;AAAA,MAC3C;AAAA,MACA;AAAA,MACA,iBAAiB;AAAA,IAAA,CAClB;;0BAICE,mBAuCM,OAAA;AAAA,iBAtCA;AAAA,QAAJ,KAAI;AAAA,QACJ,oCAAiC;AAAA,QAChC,OAAKC,eAAA;AAAA,aAAaC,MAAA,cAAA;AAAA,qBAAiCA,MAAA,YAAA,IAAuBA,MAAA,cAAA,EAAe;;;kBAA4H,cAAA;AAAA;YAA0EA,MAAA,cAAA,EAAe,iBAAiB;AAAA,YAAWA,MAAA,cAAA,EAAe,iBAAiB;AAAA,UAAA,EAAW,KAAI,GAAA;AAAA;AAAA;AAAA;AAAA,aAAiOA,MAAA,cAAA,EAAe,MAAM,mBAAe;AAAA;;;;;QAqB/nBC,YAcYD,kBAdZE,WAcY,EAbT,KAAKF,MAAA,UAAA,KACEG,KAAAA,QAAM;AAAA,UACb,YAAU,MAAM;AAAA,UAChB,IAAI,QAAA;AAAA,UACJ,aAAW,WAAA;AAAA,UACX,cAAY,YAAA;AAAA,UACZ,OAAK;AAAA;AAAA;AAAA,YAAoN,WAAA,CAAAH,MAAA,YAAA,aAAwB;AAAA,UAAA;AAAA;2BAMlP,MAAQ;AAAA,YAARI,WAAQ,KAAA,QAAA,SAAA;AAAA,UAAA;;;;;;;"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ReferenceElement } from '@floating-ui/vue';
|
|
2
|
+
import { Ref } from 'vue';
|
|
3
|
+
export interface Measurable {
|
|
4
|
+
getBoundingClientRect: () => DOMRect;
|
|
5
|
+
}
|
|
6
|
+
interface PopperRootContext {
|
|
7
|
+
anchor: Ref<ReferenceElement | undefined>;
|
|
8
|
+
onAnchorChange: (element: ReferenceElement | undefined) => void;
|
|
9
|
+
}
|
|
10
|
+
export declare const injectPopperRootContext: <T extends PopperRootContext | null | undefined = PopperRootContext>(fallback?: T | undefined) => T extends null ? PopperRootContext | null : PopperRootContext, providePopperRootContext: (contextValue: PopperRootContext) => PopperRootContext;
|
|
11
|
+
declare const _default: __VLS_WithTemplateSlots<import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>, {
|
|
12
|
+
default?(_: {}): any;
|
|
13
|
+
}>;
|
|
14
|
+
export default _default;
|
|
15
|
+
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
16
|
+
new (): {
|
|
17
|
+
$slots: S;
|
|
18
|
+
};
|
|
19
|
+
};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { defineComponent, ref, renderSlot } from "vue";
|
|
2
|
+
import { createContext } from "../../shared/createContext.js";
|
|
3
|
+
const [injectPopperRootContext, providePopperRootContext] = createContext("PopperRoot");
|
|
4
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
5
|
+
...{
|
|
6
|
+
inheritAttrs: false
|
|
7
|
+
},
|
|
8
|
+
__name: "PopperRoot",
|
|
9
|
+
setup(__props) {
|
|
10
|
+
const anchor = ref();
|
|
11
|
+
providePopperRootContext({
|
|
12
|
+
anchor,
|
|
13
|
+
onAnchorChange: (element) => anchor.value = element
|
|
14
|
+
});
|
|
15
|
+
return (_ctx, _cache) => {
|
|
16
|
+
return renderSlot(_ctx.$slots, "default");
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
export {
|
|
21
|
+
_sfc_main as default,
|
|
22
|
+
injectPopperRootContext,
|
|
23
|
+
providePopperRootContext
|
|
24
|
+
};
|
|
25
|
+
//# sourceMappingURL=PopperRoot.vue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PopperRoot.vue.js","sources":["../../../src/components/Popper/PopperRoot.vue"],"sourcesContent":["<script lang=\"ts\">\nimport type { ReferenceElement } from \"@floating-ui/vue\";\nimport type { Ref } from \"vue\";\nimport { createContext } from \"../../shared\";\n\nexport interface Measurable {\n getBoundingClientRect: () => DOMRect;\n}\n\ninterface PopperRootContext {\n anchor: Ref<ReferenceElement | undefined>;\n onAnchorChange: (element: ReferenceElement | undefined) => void;\n}\n\nexport const [injectPopperRootContext, providePopperRootContext] =\n createContext<PopperRootContext>(\"PopperRoot\");\n</script>\n\n<script setup lang=\"ts\">\nimport { ref } from \"vue\";\n\ndefineOptions({\n inheritAttrs: false,\n});\n\nconst anchor = ref<ReferenceElement>();\n\nprovidePopperRootContext({\n anchor,\n onAnchorChange: (element) => (anchor.value = element),\n});\n</script>\n\n<template>\n <slot />\n</template>\n"],"names":["_renderSlot"],"mappings":";;AAcO,MAAM,CAAC,yBAAyB,wBAAwB,IAC7D,cAAiC,YAAY;;;;;;;AAU/C,UAAM,SAAS,IAAA;AAEf,6BAAyB;AAAA,MACvB;AAAA,MACA,gBAAgB,CAAC,YAAa,OAAO,QAAQ;AAAA,IAAA,CAC9C;;aAICA,WAAQ,KAAA,QAAA,SAAA;AAAA;;;"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import _sfc_main from "./PopperRoot.vue.js";
|
|
2
|
+
import { injectPopperRootContext, providePopperRootContext } from "./PopperRoot.vue.js";
|
|
3
|
+
export {
|
|
4
|
+
_sfc_main as default,
|
|
5
|
+
injectPopperRootContext,
|
|
6
|
+
providePopperRootContext
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=PopperRoot.vue2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PopperRoot.vue2.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { default as PopperAnchor, type PopperAnchorProps, } from './PopperAnchor';
|
|
2
|
+
export { default as PopperArrow, type PopperArrowProps, } from './PopperArrow';
|
|
3
|
+
export { default as PopperContent, type PopperContentProps, PopperContentPropsDefaultValue, } from './PopperContent';
|
|
4
|
+
export { injectPopperRootContext, default as PopperRoot } from './PopperRoot';
|
|
5
|
+
export * from './utils';
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Middleware, Placement } from '@floating-ui/vue';
|
|
2
|
+
declare const SIDE_OPTIONS: readonly ["top", "right", "bottom", "left"];
|
|
3
|
+
declare const ALIGN_OPTIONS: readonly ["start", "center", "end"];
|
|
4
|
+
export type Side = (typeof SIDE_OPTIONS)[number];
|
|
5
|
+
export type Align = (typeof ALIGN_OPTIONS)[number];
|
|
6
|
+
export declare function isNotNull<T>(value: T | null): value is T;
|
|
7
|
+
export declare function transformOrigin(options: {
|
|
8
|
+
arrowWidth: number;
|
|
9
|
+
arrowHeight: number;
|
|
10
|
+
}): Middleware;
|
|
11
|
+
export declare function getSideAndAlignFromPlacement(placement: Placement): readonly ["top" | "right" | "bottom" | "left", "start" | "end" | "center"];
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
function isNotNull(value) {
|
|
2
|
+
return value !== null;
|
|
3
|
+
}
|
|
4
|
+
function transformOrigin(options) {
|
|
5
|
+
return {
|
|
6
|
+
name: "transformOrigin",
|
|
7
|
+
options,
|
|
8
|
+
fn(data) {
|
|
9
|
+
const { placement, rects, middlewareData } = data;
|
|
10
|
+
const cannotCenterArrow = middlewareData.arrow?.centerOffset !== 0;
|
|
11
|
+
const isArrowHidden = cannotCenterArrow;
|
|
12
|
+
const arrowWidth = isArrowHidden ? 0 : options.arrowWidth;
|
|
13
|
+
const arrowHeight = isArrowHidden ? 0 : options.arrowHeight;
|
|
14
|
+
const [placedSide, placedAlign] = getSideAndAlignFromPlacement(placement);
|
|
15
|
+
const noArrowAlign = { start: "0%", center: "50%", end: "100%" }[placedAlign];
|
|
16
|
+
const arrowXCenter = (middlewareData.arrow?.x ?? 0) + arrowWidth / 2;
|
|
17
|
+
const arrowYCenter = (middlewareData.arrow?.y ?? 0) + arrowHeight / 2;
|
|
18
|
+
let x = "";
|
|
19
|
+
let y = "";
|
|
20
|
+
if (placedSide === "bottom") {
|
|
21
|
+
x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`;
|
|
22
|
+
y = `${-arrowHeight}px`;
|
|
23
|
+
} else if (placedSide === "top") {
|
|
24
|
+
x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`;
|
|
25
|
+
y = `${rects.floating.height + arrowHeight}px`;
|
|
26
|
+
} else if (placedSide === "right") {
|
|
27
|
+
x = `${-arrowHeight}px`;
|
|
28
|
+
y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`;
|
|
29
|
+
} else if (placedSide === "left") {
|
|
30
|
+
x = `${rects.floating.width + arrowHeight}px`;
|
|
31
|
+
y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`;
|
|
32
|
+
}
|
|
33
|
+
return { data: { x, y } };
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
function getSideAndAlignFromPlacement(placement) {
|
|
38
|
+
const [side, align = "center"] = placement.split("-");
|
|
39
|
+
return [side, align];
|
|
40
|
+
}
|
|
41
|
+
export {
|
|
42
|
+
getSideAndAlignFromPlacement,
|
|
43
|
+
isNotNull,
|
|
44
|
+
transformOrigin
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sources":["../../../src/components/Popper/utils.ts"],"sourcesContent":["import type { Middleware, Placement } from '@floating-ui/vue'\n\nconst SIDE_OPTIONS = ['top', 'right', 'bottom', 'left'] as const\nconst ALIGN_OPTIONS = ['start', 'center', 'end'] as const\n\nexport type Side = (typeof SIDE_OPTIONS)[number]\nexport type Align = (typeof ALIGN_OPTIONS)[number]\n\nexport function isNotNull<T>(value: T | null): value is T {\n return value !== null\n}\n\nexport function transformOrigin(options: {\n arrowWidth: number\n arrowHeight: number\n}): Middleware {\n return {\n name: 'transformOrigin',\n options,\n fn(data) {\n const { placement, rects, middlewareData } = data\n\n const cannotCenterArrow = middlewareData.arrow?.centerOffset !== 0\n const isArrowHidden = cannotCenterArrow\n const arrowWidth = isArrowHidden ? 0 : options.arrowWidth\n const arrowHeight = isArrowHidden ? 0 : options.arrowHeight\n\n const [placedSide, placedAlign] = getSideAndAlignFromPlacement(placement)\n const noArrowAlign = { start: '0%', center: '50%', end: '100%' }[\n placedAlign\n ]\n\n const arrowXCenter = (middlewareData.arrow?.x ?? 0) + arrowWidth / 2\n const arrowYCenter = (middlewareData.arrow?.y ?? 0) + arrowHeight / 2\n\n let x = ''\n let y = ''\n\n if (placedSide === 'bottom') {\n x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`\n y = `${-arrowHeight}px`\n }\n else if (placedSide === 'top') {\n x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`\n y = `${rects.floating.height + arrowHeight}px`\n }\n else if (placedSide === 'right') {\n x = `${-arrowHeight}px`\n y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`\n }\n else if (placedSide === 'left') {\n x = `${rects.floating.width + arrowHeight}px`\n y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`\n }\n return { data: { x, y } }\n },\n }\n}\n\nexport function getSideAndAlignFromPlacement(placement: Placement) {\n const [side, align = 'center'] = placement.split('-')\n return [side as Side, align as Align] as const\n}\n"],"names":[],"mappings":"AAQO,SAAS,UAAa,OAA6B;AACxD,SAAO,UAAU;AACnB;AAEO,SAAS,gBAAgB,SAGjB;AACb,SAAO;AAAA,IACL,MAAM;AAAA,IACN;AAAA,IACA,GAAG,MAAM;AACP,YAAM,EAAE,WAAW,OAAO,eAAA,IAAmB;AAE7C,YAAM,oBAAoB,eAAe,OAAO,iBAAiB;AACjE,YAAM,gBAAgB;AACtB,YAAM,aAAa,gBAAgB,IAAI,QAAQ;AAC/C,YAAM,cAAc,gBAAgB,IAAI,QAAQ;AAEhD,YAAM,CAAC,YAAY,WAAW,IAAI,6BAA6B,SAAS;AACxE,YAAM,eAAe,EAAE,OAAO,MAAM,QAAQ,OAAO,KAAK,OAAA,EACtD,WACF;AAEA,YAAM,gBAAgB,eAAe,OAAO,KAAK,KAAK,aAAa;AACnE,YAAM,gBAAgB,eAAe,OAAO,KAAK,KAAK,cAAc;AAEpE,UAAI,IAAI;AACR,UAAI,IAAI;AAER,UAAI,eAAe,UAAU;AAC3B,YAAI,gBAAgB,eAAe,GAAG,YAAY;AAClD,YAAI,GAAG,CAAC,WAAW;AAAA,MACrB,WACS,eAAe,OAAO;AAC7B,YAAI,gBAAgB,eAAe,GAAG,YAAY;AAClD,YAAI,GAAG,MAAM,SAAS,SAAS,WAAW;AAAA,MAC5C,WACS,eAAe,SAAS;AAC/B,YAAI,GAAG,CAAC,WAAW;AACnB,YAAI,gBAAgB,eAAe,GAAG,YAAY;AAAA,MACpD,WACS,eAAe,QAAQ;AAC9B,YAAI,GAAG,MAAM,SAAS,QAAQ,WAAW;AACzC,YAAI,gBAAgB,eAAe,GAAG,YAAY;AAAA,MACpD;AACA,aAAO,EAAE,MAAM,EAAE,GAAG,IAAE;AAAA,IACxB;AAAA,EAAA;AAEJ;AAEO,SAAS,6BAA6B,WAAsB;AACjE,QAAM,CAAC,MAAM,QAAQ,QAAQ,IAAI,UAAU,MAAM,GAAG;AACpD,SAAO,CAAC,MAAc,KAAc;AACtC;"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { SlotsType, VNode } from 'vue';
|
|
2
|
+
export interface PresenceProps {
|
|
3
|
+
/**
|
|
4
|
+
* Conditional to mount or unmount the child element. Similar to `v-if`
|
|
5
|
+
*
|
|
6
|
+
* @required true
|
|
7
|
+
*/
|
|
8
|
+
present: boolean;
|
|
9
|
+
/**
|
|
10
|
+
* Force the element to render all the time.
|
|
11
|
+
*
|
|
12
|
+
* Useful for programmatically render grandchild component with the exposed `present`
|
|
13
|
+
*
|
|
14
|
+
* @defaultValue false
|
|
15
|
+
*/
|
|
16
|
+
forceMount?: boolean;
|
|
17
|
+
}
|
|
18
|
+
declare const _default: import('vue').DefineComponent<import('vue').ExtractPropTypes<{
|
|
19
|
+
present: {
|
|
20
|
+
type: BooleanConstructor;
|
|
21
|
+
required: true;
|
|
22
|
+
};
|
|
23
|
+
forceMount: {
|
|
24
|
+
type: BooleanConstructor;
|
|
25
|
+
};
|
|
26
|
+
}>, () => VNode<import('vue').RendererNode, import('vue').RendererElement, {
|
|
27
|
+
[key: string]: any;
|
|
28
|
+
}> | null, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<import('vue').ExtractPropTypes<{
|
|
29
|
+
present: {
|
|
30
|
+
type: BooleanConstructor;
|
|
31
|
+
required: true;
|
|
32
|
+
};
|
|
33
|
+
forceMount: {
|
|
34
|
+
type: BooleanConstructor;
|
|
35
|
+
};
|
|
36
|
+
}>> & Readonly<{}>, {
|
|
37
|
+
forceMount: boolean;
|
|
38
|
+
}, SlotsType<{
|
|
39
|
+
default: (opts: {
|
|
40
|
+
present: boolean;
|
|
41
|
+
}) => any;
|
|
42
|
+
}>, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
|
|
43
|
+
export default _default;
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { unrefElement } from "../../node_modules/.pnpm/@vueuse_core@14.1.0_vue@3.5.26_typescript@5.9.3_/node_modules/@vueuse/core/dist/index.js";
|
|
2
|
+
import { defineComponent, toRefs, ref, getCurrentInstance, h } from "vue";
|
|
3
|
+
import { renderSlotFragments } from "../../shared/renderSlotFragments.js";
|
|
4
|
+
import { usePresence } from "./usePresence.js";
|
|
5
|
+
const Presence = defineComponent({
|
|
6
|
+
name: "Presence",
|
|
7
|
+
props: {
|
|
8
|
+
present: {
|
|
9
|
+
type: Boolean,
|
|
10
|
+
required: true
|
|
11
|
+
},
|
|
12
|
+
forceMount: {
|
|
13
|
+
type: Boolean
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
slots: {},
|
|
17
|
+
setup(props, { slots, expose }) {
|
|
18
|
+
const { present, forceMount } = toRefs(props);
|
|
19
|
+
const node = ref();
|
|
20
|
+
const { isPresent } = usePresence(present, node);
|
|
21
|
+
expose({ present: isPresent });
|
|
22
|
+
let children = slots.default({ present: isPresent.value });
|
|
23
|
+
children = renderSlotFragments(children || []);
|
|
24
|
+
const instance = getCurrentInstance();
|
|
25
|
+
if (children && children?.length > 1) {
|
|
26
|
+
const componentName = instance?.parent?.type.name ? `<${instance.parent.type.name} />` : "component";
|
|
27
|
+
throw new Error(
|
|
28
|
+
[
|
|
29
|
+
`Detected an invalid children for \`${componentName}\` for \`Presence\` component.`,
|
|
30
|
+
"",
|
|
31
|
+
"Note: Presence works similarly to `v-if` directly, but it waits for animation/transition to finished before unmounting. So it expect only one direct child of valid VNode type.",
|
|
32
|
+
"You can apply a few solutions:",
|
|
33
|
+
[
|
|
34
|
+
"Provide a single child element so that `presence` directive attach correctly.",
|
|
35
|
+
"Ensure the first child is an actual element instead of a raw text node or comment node."
|
|
36
|
+
].map((line) => ` - ${line}`).join("\n")
|
|
37
|
+
].join("\n")
|
|
38
|
+
);
|
|
39
|
+
}
|
|
40
|
+
return () => {
|
|
41
|
+
if (forceMount.value || present.value || isPresent.value) {
|
|
42
|
+
return h(slots.default({ present: isPresent.value })[0], {
|
|
43
|
+
ref: (v) => {
|
|
44
|
+
const el = unrefElement(v);
|
|
45
|
+
if (typeof el?.hasAttribute === "undefined") return el;
|
|
46
|
+
if (el?.hasAttribute("data-reka-popper-content-wrapper"))
|
|
47
|
+
node.value = el.firstElementChild;
|
|
48
|
+
else node.value = el;
|
|
49
|
+
return el;
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
} else {
|
|
53
|
+
return null;
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
export {
|
|
59
|
+
Presence as default
|
|
60
|
+
};
|
|
61
|
+
//# sourceMappingURL=Presence.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Presence.js","sources":["../../../src/components/Presence/Presence.ts"],"sourcesContent":["import type { SlotsType, VNode } from \"vue\";\nimport { unrefElement } from \"@vueuse/core\";\nimport { defineComponent, getCurrentInstance, h, ref, toRefs } from \"vue\";\nimport { renderSlotFragments } from \"../../shared\";\nimport { usePresence } from \"./usePresence\";\n\nexport interface PresenceProps {\n /**\n * Conditional to mount or unmount the child element. Similar to `v-if`\n *\n * @required true\n */\n present: boolean;\n /**\n * Force the element to render all the time.\n *\n * Useful for programmatically render grandchild component with the exposed `present`\n *\n * @defaultValue false\n */\n forceMount?: boolean;\n}\n\nexport default defineComponent({\n name: \"Presence\",\n props: {\n present: {\n type: Boolean,\n required: true,\n },\n forceMount: {\n type: Boolean,\n },\n },\n slots: {} as SlotsType<{\n default: (opts: { present: boolean }) => any;\n }>,\n setup(props, { slots, expose }) {\n const { present, forceMount } = toRefs(props);\n\n const node = ref<HTMLElement>();\n // Mount composables once to prevent duplicated eventListener\n const { isPresent } = usePresence(present, node);\n expose({ present: isPresent });\n\n let children = slots.default({ present: isPresent.value });\n children = renderSlotFragments(children || []);\n const instance = getCurrentInstance();\n\n if (children && children?.length > 1) {\n const componentName = instance?.parent?.type.name\n ? `<${instance.parent.type.name} />`\n : \"component\";\n\n throw new Error(\n [\n `Detected an invalid children for \\`${componentName}\\` for \\`Presence\\` component.`,\n \"\",\n \"Note: Presence works similarly to `v-if` directly, but it waits for animation/transition to finished before unmounting. So it expect only one direct child of valid VNode type.\",\n \"You can apply a few solutions:\",\n [\n \"Provide a single child element so that `presence` directive attach correctly.\",\n \"Ensure the first child is an actual element instead of a raw text node or comment node.\",\n ]\n .map((line) => ` - ${line}`)\n .join(\"\\n\"),\n ].join(\"\\n\"),\n );\n }\n\n return () => {\n if (forceMount.value || present.value || isPresent.value) {\n return h(slots.default({ present: isPresent.value })[0] as VNode, {\n ref: (v) => {\n const el = unrefElement(v as HTMLElement);\n if (typeof el?.hasAttribute === \"undefined\") return el;\n\n // special case to handle animation for PopperContent\n if (el?.hasAttribute(\"data-reka-popper-content-wrapper\"))\n node.value = el.firstElementChild as HTMLElement;\n else node.value = el;\n\n return el;\n },\n });\n } else {\n return null;\n }\n };\n },\n});\n"],"names":[],"mappings":";;;;AAuBA,MAAA,WAAe,gBAAgB;AAAA,EAC7B,MAAM;AAAA,EACN,OAAO;AAAA,IACL,SAAS;AAAA,MACP,MAAM;AAAA,MACN,UAAU;AAAA,IAAA;AAAA,IAEZ,YAAY;AAAA,MACV,MAAM;AAAA,IAAA;AAAA,EACR;AAAA,EAEF,OAAO,CAAA;AAAA,EAGP,MAAM,OAAO,EAAE,OAAO,UAAU;AAC9B,UAAM,EAAE,SAAS,eAAe,OAAO,KAAK;AAE5C,UAAM,OAAO,IAAA;AAEb,UAAM,EAAE,UAAA,IAAc,YAAY,SAAS,IAAI;AAC/C,WAAO,EAAE,SAAS,WAAW;AAE7B,QAAI,WAAW,MAAM,QAAQ,EAAE,SAAS,UAAU,OAAO;AACzD,eAAW,oBAAoB,YAAY,EAAE;AAC7C,UAAM,WAAW,mBAAA;AAEjB,QAAI,YAAY,UAAU,SAAS,GAAG;AACpC,YAAM,gBAAgB,UAAU,QAAQ,KAAK,OACzC,IAAI,SAAS,OAAO,KAAK,IAAI,QAC7B;AAEJ,YAAM,IAAI;AAAA,QACR;AAAA,UACE,sCAAsC,aAAa;AAAA,UACnD;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,YACE;AAAA,YACA;AAAA,UAAA,EAEC,IAAI,CAAC,SAAS,OAAO,IAAI,EAAE,EAC3B,KAAK,IAAI;AAAA,QAAA,EACZ,KAAK,IAAI;AAAA,MAAA;AAAA,IAEf;AAEA,WAAO,MAAM;AACX,UAAI,WAAW,SAAS,QAAQ,SAAS,UAAU,OAAO;AACxD,eAAO,EAAE,MAAM,QAAQ,EAAE,SAAS,UAAU,MAAA,CAAO,EAAE,CAAC,GAAY;AAAA,UAChE,KAAK,CAAC,MAAM;AACV,kBAAM,KAAK,aAAa,CAAgB;AACxC,gBAAI,OAAO,IAAI,iBAAiB,YAAa,QAAO;AAGpD,gBAAI,IAAI,aAAa,kCAAkC;AACrD,mBAAK,QAAQ,GAAG;AAAA,sBACR,QAAQ;AAElB,mBAAO;AAAA,UACT;AAAA,QAAA,CACD;AAAA,MACH,OAAO;AACL,eAAO;AAAA,MACT;AAAA,IACF;AAAA,EACF;AACF,CAAC;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default as Presence, type PresenceProps } from './Presence';
|