@volverjs/ui-vue 0.0.6-beta.6 → 0.0.6
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/README.md +3 -5
- package/auto-imports.d.ts +11 -0
- package/dist/components/VvAccordion/VvAccordion.es.js +220 -4
- package/dist/components/VvAccordion/VvAccordion.umd.js +1 -1
- package/dist/components/VvAccordion/VvAccordion.vue.d.ts +8 -8
- package/dist/components/VvAccordion/index.d.ts +1 -4
- package/dist/components/VvAccordionGroup/VvAccordionGroup.es.js +221 -8
- package/dist/components/VvAccordionGroup/VvAccordionGroup.umd.js +1 -1
- package/dist/components/VvAccordionGroup/VvAccordionGroup.vue.d.ts +6 -6
- package/dist/components/VvAccordionGroup/index.d.ts +2 -5
- package/dist/components/VvAction/VvAction.es.js +12 -8
- package/dist/components/VvAction/VvAction.umd.js +1 -1
- package/dist/components/VvAction/VvAction.vue.d.ts +4 -4
- package/dist/components/VvAction/index.d.ts +1 -1
- package/dist/components/VvAlert/VvAlert.es.js +661 -0
- package/dist/components/VvAlert/VvAlert.umd.js +1 -0
- package/dist/components/VvAlert/VvAlert.vue.d.ts +104 -0
- package/dist/components/VvAlert/index.d.ts +95 -0
- package/dist/components/VvAlertGroup/VvAlertGroup.es.js +799 -0
- package/dist/components/VvAlertGroup/VvAlertGroup.umd.js +1 -0
- package/dist/components/VvAlertGroup/VvAlertGroup.vue.d.ts +89 -0
- package/dist/components/VvAlertGroup/index.d.ts +55 -0
- package/dist/components/VvAvatar/VvAvatar.es.js +3 -3
- package/dist/components/VvAvatar/VvAvatar.vue.d.ts +2 -2
- package/dist/components/VvAvatarGroup/VvAvatarGroup.es.js +3 -3
- package/dist/components/VvAvatarGroup/VvAvatarGroup.vue.d.ts +2 -2
- package/dist/components/VvBadge/VvBadge.es.js +3 -3
- package/dist/components/VvBadge/VvBadge.vue.d.ts +2 -2
- package/dist/components/VvBreadcrumb/VvBreadcrumb.es.js +3 -3
- package/dist/components/VvBreadcrumb/VvBreadcrumb.vue.d.ts +3 -3
- package/dist/components/VvButton/VvButton.es.js +39 -29
- package/dist/components/VvButton/VvButton.umd.js +1 -1
- package/dist/components/VvButton/VvButton.vue.d.ts +13 -13
- package/dist/components/VvButton/index.d.ts +2 -2
- package/dist/components/VvButtonGroup/VvButtonGroup.es.js +3 -3
- package/dist/components/VvButtonGroup/VvButtonGroup.vue.d.ts +4 -4
- package/dist/components/VvCard/VvCard.es.js +221 -2
- package/dist/components/VvCard/VvCard.umd.js +1 -1
- package/dist/components/VvCard/VvCard.vue.d.ts +5 -5
- package/dist/components/VvCheckbox/VvCheckbox.es.js +154 -101
- package/dist/components/VvCheckbox/VvCheckbox.umd.js +1 -1
- package/dist/components/VvCheckbox/VvCheckbox.vue.d.ts +46 -10
- package/dist/components/VvCheckbox/index.d.ts +8 -3
- package/dist/components/VvCheckboxGroup/VvCheckboxGroup.es.js +190 -104
- package/dist/components/VvCheckboxGroup/VvCheckboxGroup.umd.js +1 -1
- package/dist/components/VvCheckboxGroup/VvCheckboxGroup.vue.d.ts +44 -8
- package/dist/components/VvCheckboxGroup/index.d.ts +8 -3
- package/dist/components/VvCombobox/VvCombobox.es.js +271 -174
- package/dist/components/VvCombobox/VvCombobox.umd.js +1 -1
- package/dist/components/VvCombobox/VvCombobox.vue.d.ts +73 -37
- package/dist/components/VvCombobox/index.d.ts +13 -7
- package/dist/components/VvDialog/VvDialog.es.js +44 -33
- package/dist/components/VvDialog/VvDialog.umd.js +1 -1
- package/dist/components/VvDialog/VvDialog.vue.d.ts +7 -7
- package/dist/components/VvDialog/index.d.ts +2 -2
- package/dist/components/VvDropdown/VvDropdown.es.js +39 -25
- package/dist/components/VvDropdown/VvDropdown.umd.js +1 -1
- package/dist/components/VvDropdown/VvDropdown.vue.d.ts +21 -17
- package/dist/components/VvDropdown/VvDropdownAction.vue.d.ts +4 -4
- package/dist/components/VvDropdown/VvDropdownItem.vue.d.ts +2 -2
- package/dist/components/VvDropdown/VvDropdownOptgroup.vue.d.ts +1 -1
- package/dist/components/VvDropdown/VvDropdownOption.vue.d.ts +4 -4
- package/dist/components/VvDropdown/index.d.ts +1 -1
- package/dist/components/VvDropdownAction/VvDropdownAction.es.js +17 -11
- package/dist/components/VvDropdownAction/VvDropdownAction.umd.js +1 -1
- package/dist/components/VvDropdownItem/VvDropdownItem.es.js +9 -5
- package/dist/components/VvDropdownItem/VvDropdownItem.umd.js +1 -1
- package/dist/components/VvDropdownOptgroup/VvDropdownOptgroup.es.js +3 -3
- package/dist/components/VvDropdownOption/VvDropdownOption.es.js +12 -8
- package/dist/components/VvDropdownOption/VvDropdownOption.umd.js +1 -1
- package/dist/components/VvIcon/VvIcon.es.js +25 -19
- package/dist/components/VvIcon/VvIcon.umd.js +1 -1
- package/dist/components/VvIcon/VvIcon.vue.d.ts +3 -3
- package/dist/components/VvIcon/index.d.ts +2 -2
- package/dist/components/VvInputText/VvInputClearAction.d.ts +2 -2
- package/dist/components/VvInputText/VvInputPasswordAction.d.ts +1 -1
- package/dist/components/VvInputText/VvInputStepAction.d.ts +1 -1
- package/dist/components/VvInputText/VvInputText.es.js +165 -141
- package/dist/components/VvInputText/VvInputText.umd.js +1 -1
- package/dist/components/VvInputText/VvInputText.vue.d.ts +46 -22
- package/dist/components/VvInputText/index.d.ts +5 -5
- package/dist/components/VvNav/VvNav.es.js +12 -8
- package/dist/components/VvNav/VvNav.umd.js +1 -1
- package/dist/components/VvNav/VvNav.vue.d.ts +1 -1
- package/dist/components/VvNavItemTitle/VvNavItemTitle.vue.d.ts +1 -1
- package/dist/components/VvNavSeparator/VvNavSeparator.d.ts +1 -1
- package/dist/components/VvProgress/VvProgress.es.js +3 -3
- package/dist/components/VvProgress/VvProgress.vue.d.ts +1 -1
- package/dist/components/VvRadio/VvRadio.es.js +154 -101
- package/dist/components/VvRadio/VvRadio.umd.js +1 -1
- package/dist/components/VvRadio/VvRadio.vue.d.ts +46 -10
- package/dist/components/VvRadio/index.d.ts +8 -3
- package/dist/components/VvRadioGroup/VvRadioGroup.es.js +190 -104
- package/dist/components/VvRadioGroup/VvRadioGroup.umd.js +1 -1
- package/dist/components/VvRadioGroup/VvRadioGroup.vue.d.ts +44 -8
- package/dist/components/VvRadioGroup/index.d.ts +8 -3
- package/dist/components/VvSelect/VvSelect.es.js +166 -140
- package/dist/components/VvSelect/VvSelect.umd.js +1 -1
- package/dist/components/VvSelect/VvSelect.vue.d.ts +42 -18
- package/dist/components/VvSelect/index.d.ts +4 -4
- package/dist/components/VvTab/VvTab.es.js +12 -8
- package/dist/components/VvTab/VvTab.umd.js +1 -1
- package/dist/components/VvTab/VvTab.vue.d.ts +1 -1
- package/dist/components/VvTextarea/VvTextarea.es.js +163 -139
- package/dist/components/VvTextarea/VvTextarea.umd.js +1 -1
- package/dist/components/VvTextarea/VvTextarea.vue.d.ts +40 -16
- package/dist/components/VvTextarea/index.d.ts +3 -3
- package/dist/components/VvTooltip/VvTooltip.es.js +3 -3
- package/dist/components/VvTooltip/VvTooltip.vue.d.ts +2 -2
- package/dist/components/common/HintSlot.d.ts +38 -12
- package/dist/components/index.es.js +1066 -768
- package/dist/components/index.umd.js +1 -1
- package/dist/composables/alert/useInjectAlert.d.ts +9 -0
- package/dist/composables/alert/useProvideAlert.d.ts +10 -0
- package/dist/composables/dropdown/useInjectDropdown.d.ts +17 -16
- package/dist/composables/dropdown/useProvideDropdown.d.ts +7 -3
- package/dist/composables/useOptions.d.ts +2 -2
- package/dist/composables/useVolver.d.ts +1 -2
- package/dist/constants.d.ts +33 -4
- package/dist/directives/index.es.js +3 -3
- package/dist/directives/v-tooltip.es.js +3 -3
- package/dist/icons.es.js +3 -3
- package/dist/icons.umd.js +1 -1
- package/dist/props/index.d.ts +38 -16
- package/dist/resolvers/unplugin.es.js +6 -3
- package/dist/resolvers/unplugin.umd.js +1 -1
- package/dist/stories/Accordion/Accordion.settings.d.ts +18 -17
- package/dist/stories/Accordion/Accordion.stories.d.ts +7 -0
- package/dist/stories/Accordion/AccordionSlots.stories.d.ts +7 -0
- package/dist/stories/AccordionGroup/AccordionGroup.settings.d.ts +23 -4
- package/dist/stories/AccordionGroup/AccordionGroup.stories.d.ts +134 -0
- package/dist/stories/AccordionGroup/AccordionGroupSlots.stories.d.ts +894 -0
- package/dist/stories/Alert/Alert.settings.d.ts +105 -0
- package/dist/stories/Alert/Alert.stories.d.ts +9 -0
- package/dist/stories/Alert/Alert.test.d.ts +2 -0
- package/dist/stories/Alert/AlertModifiers.stories.d.ts +13 -0
- package/dist/stories/Alert/AlertSlots.stories.d.ts +10 -0
- package/dist/stories/AlertGroup/AlertGroup.settings.d.ts +97 -0
- package/dist/stories/AlertGroup/AlertGroup.stories.d.ts +8 -0
- package/dist/stories/AlertGroup/AlertGroup.test.d.ts +2 -0
- package/dist/stories/AlertGroup/AlertGroupPosition.stories.d.ts +14 -0
- package/dist/stories/AlertGroup/AlertGroupSlots.stories.d.ts +8 -0
- package/dist/stories/Avatar/Avatar.settings.d.ts +2 -33
- package/dist/stories/Avatar/Avatar.stories.d.ts +7 -0
- package/dist/stories/Avatar/AvatarBadge.stories.d.ts +6 -0
- package/dist/stories/Avatar/AvatarModifiers.stories.d.ts +13 -0
- package/dist/stories/Avatar/AvatarSlots.stories.d.ts +6 -0
- package/dist/stories/AvatarGroup/AvatarGroup.settings.d.ts +0 -6
- package/dist/stories/AvatarGroup/AvatarGroup.stories.d.ts +6 -0
- package/dist/stories/AvatarGroup/AvatarGroupModifiers.stories.d.ts +7 -0
- package/dist/stories/AvatarGroup/AvatarGroupSlotDefault.stories.d.ts +6 -0
- package/dist/stories/Badge/Badge.settings.d.ts +0 -3
- package/dist/stories/Badge/Badge.stories.d.ts +7 -0
- package/dist/stories/Badge/BadgeSlots.stories.d.ts +6 -0
- package/dist/stories/Breadcrumb/Breadcrumb.stories.d.ts +7 -0
- package/dist/stories/Breadcrumb/Breadcrumb.test.d.ts +1 -1
- package/dist/stories/Breadcrumb/BreadcrumbSlots.stories.d.ts +6 -0
- package/dist/stories/Button/Button.settings.d.ts +1 -18
- package/dist/stories/Button/Button.stories.d.ts +6 -0
- package/dist/stories/Button/ButtonIcon.stories.d.ts +10 -0
- package/dist/stories/Button/ButtonLink.stories.d.ts +7 -0
- package/dist/stories/Button/ButtonLoading.stories.d.ts +8 -0
- package/dist/stories/Button/ButtonModifiers.stories.d.ts +17 -0
- package/dist/stories/Button/ButtonSlots.stories.d.ts +9 -0
- package/dist/stories/Button/ButtonState.stories.d.ts +8 -0
- package/dist/stories/Button/ButtonToggle.stories.d.ts +9 -0
- package/dist/stories/ButtonGroup/ButtonGroup.settings.d.ts +0 -4
- package/dist/stories/ButtonGroup/ButtonGroup.stories.d.ts +6 -0
- package/dist/stories/ButtonGroup/ButtonGroupModifiers.stories.d.ts +8 -0
- package/dist/stories/ButtonGroup/ButtonGroupSlots.stories.d.ts +6 -0
- package/dist/stories/ButtonGroup/ButtonGroupToggle.stories.d.ts +8 -0
- package/dist/stories/Card/Card.settings.d.ts +0 -3
- package/dist/stories/Card/Card.stories.d.ts +6 -0
- package/dist/stories/Card/CardSlots.stories.d.ts +9 -0
- package/dist/stories/Checkbox/Checkbox.settings.d.ts +1 -21
- package/dist/stories/Checkbox/Checkbox.stories.d.ts +13 -0
- package/dist/stories/Checkbox/CheckboxBinary.stories.d.ts +7 -0
- package/dist/stories/Checkbox/CheckboxSlots.stories.d.ts +7 -0
- package/dist/stories/CheckboxGroup/CheckboxGroup.settings.d.ts +1 -27
- package/dist/stories/CheckboxGroup/CheckboxGroup.stories.d.ts +12 -0
- package/dist/stories/CheckboxGroup/CheckboxGroupOptions.stories.d.ts +8 -0
- package/dist/stories/CheckboxGroup/CheckboxGroupSlots.stories.d.ts +7 -0
- package/dist/stories/Combobox/Combobox.settings.d.ts +2 -54
- package/dist/stories/Combobox/Combobox.stories.d.ts +21 -0
- package/dist/stories/Combobox/ComboboxIconPosition.stories.d.ts +8 -0
- package/dist/stories/Combobox/ComboboxMultiple.stories.d.ts +8 -0
- package/dist/stories/Combobox/ComboboxOptions.stories.d.ts +9 -0
- package/dist/stories/Combobox/ComboboxSlots.stories.d.ts +10 -0
- package/dist/stories/Dialog/Dialog.settings.d.ts +1 -1
- package/dist/stories/Dialog/Dialog.stories.d.ts +7 -0
- package/dist/stories/Dialog/DialogSlots.stories.d.ts +8 -0
- package/dist/stories/Dropdown/Dropdown.settings.d.ts +1 -1
- package/dist/stories/Dropdown/Dropdown.stories.d.ts +9 -0
- package/dist/stories/Dropdown/DropdownContextmenuDirective.stories.d.ts +6 -0
- package/dist/stories/Dropdown/DropdownMultilevel.stories.d.ts +6 -0
- package/dist/stories/Dropdown/DropdownSlots.stories.d.ts +8 -0
- package/dist/stories/Icon/Icon.settings.d.ts +1 -3
- package/dist/stories/Icon/Icon.stories.d.ts +8 -0
- package/dist/stories/Icon/IconsCollection.stories.d.ts +6 -0
- package/dist/stories/InputText/InputText.settings.d.ts +1 -74
- package/dist/stories/InputText/InputText.stories.d.ts +15 -0
- package/dist/stories/InputText/InputTextIconPosition.stories.d.ts +8 -0
- package/dist/stories/InputText/InputTextLength.stories.d.ts +10 -0
- package/dist/stories/InputText/InputTextMinMax.stories.d.ts +9 -0
- package/dist/stories/InputText/InputTextSlots.stories.d.ts +8 -0
- package/dist/stories/InputText/InputTextType.stories.d.ts +18 -0
- package/dist/stories/Nav/Nav.settings.d.ts +0 -3
- package/dist/stories/Nav/Nav.stories.d.ts +6 -0
- package/dist/stories/Nav/NavModifiers.stories.d.ts +9 -0
- package/dist/stories/Progress/Progress.settings.d.ts +0 -6
- package/dist/stories/Progress/Progress.stories.d.ts +7 -0
- package/dist/stories/Radio/Radio.settings.d.ts +1 -19
- package/dist/stories/Radio/Radio.stories.d.ts +11 -0
- package/dist/stories/Radio/RadioSlots.stories.d.ts +7 -0
- package/dist/stories/RadioGroup/RadioGroup.settings.d.ts +1 -27
- package/dist/stories/RadioGroup/RadioGroup.stories.d.ts +12 -0
- package/dist/stories/RadioGroup/RadioGroupOptions.stories.d.ts +8 -0
- package/dist/stories/RadioGroup/RadioGroupSlots.stories.d.ts +7 -0
- package/dist/stories/Select/Select.settings.d.ts +1 -47
- package/dist/stories/Select/Select.stories.d.ts +15 -0
- package/dist/stories/Select/SelectIconPosition.stories.d.ts +8 -0
- package/dist/stories/Select/SelectOptions.stories.d.ts +9 -0
- package/dist/stories/Select/SelectSlots.stories.d.ts +8 -0
- package/dist/stories/Tab/Tab.stories.d.ts +6 -0
- package/dist/stories/Textarea/Textarea.settings.d.ts +1 -43
- package/dist/stories/Textarea/Textarea.stories.d.ts +14 -0
- package/dist/stories/Textarea/TextareaLength.stories.d.ts +10 -0
- package/dist/stories/Textarea/TextareaSlots.stories.d.ts +8 -0
- package/dist/stories/Textarea/TextareatIconPosition.stories.d.ts +8 -0
- package/dist/stories/Tooltip/Tooltip.settings.d.ts +2 -39
- package/dist/stories/Tooltip/Tooltip.stories.d.ts +6 -0
- package/dist/stories/Tooltip/TooltipDirective.stories.d.ts +10 -0
- package/dist/stories/argTypes.d.ts +5 -125
- package/package.json +68 -52
- package/src/assets/icons/detailed.json +1 -1
- package/src/assets/icons/normal.json +1 -1
- package/src/assets/icons/simple.json +1 -1
- package/src/components/VvAccordion/index.ts +2 -4
- package/src/components/VvAccordionGroup/index.ts +3 -4
- package/src/components/VvAction/VvAction.vue +1 -1
- package/src/components/VvAlert/VvAlert.vue +54 -0
- package/src/components/VvAlert/index.ts +162 -0
- package/src/components/VvAlertGroup/VvAlertGroup.vue +34 -0
- package/src/components/VvAlertGroup/index.ts +122 -0
- package/src/components/VvCard/index.ts +3 -1
- package/src/components/VvCheckbox/VvCheckbox.vue +23 -2
- package/src/components/VvCheckboxGroup/VvCheckboxGroup.vue +15 -2
- package/src/components/VvCombobox/VvCombobox.vue +41 -24
- package/src/components/VvCombobox/index.ts +9 -3
- package/src/components/VvDialog/VvDialog.vue +11 -7
- package/src/components/VvDialog/index.ts +2 -2
- package/src/components/VvDropdown/VvDropdown.vue +23 -5
- package/src/components/VvDropdown/VvDropdownItem.vue +2 -2
- package/src/components/VvIcon/VvIcon.vue +37 -34
- package/src/components/VvIcon/index.ts +2 -2
- package/src/components/VvInputText/VvInputText.vue +26 -9
- package/src/components/VvRadio/VvRadio.vue +23 -2
- package/src/components/VvRadioGroup/VvRadioGroup.vue +15 -2
- package/src/components/VvSelect/VvSelect.vue +26 -9
- package/src/components/VvTextarea/VvTextarea.vue +26 -9
- package/src/components/common/HintSlot.ts +129 -170
- package/src/composables/alert/useInjectAlert.ts +8 -0
- package/src/composables/alert/useProvideAlert.ts +23 -0
- package/src/composables/dropdown/useInjectDropdown.ts +3 -28
- package/src/composables/dropdown/useProvideDropdown.ts +14 -15
- package/src/composables/useOptions.ts +9 -7
- package/src/composables/useVolver.ts +1 -2
- package/src/constants.ts +42 -4
- package/src/props/index.ts +5 -3
- package/src/resolvers/unplugin.ts +6 -3
- package/src/stories/Accordion/Accordion.settings.ts +18 -7
- package/src/stories/Accordion/Accordion.stories.ts +45 -0
- package/src/stories/Accordion/AccordionSlots.stories.ts +29 -0
- package/src/stories/AccordionGroup/AccordionGroup.settings.ts +22 -0
- package/src/stories/AccordionGroup/AccordionGroup.stories.ts +62 -0
- package/src/stories/AccordionGroup/AccordionGroupSlots.stories.ts +53 -0
- package/src/stories/Alert/Alert.settings.ts +110 -0
- package/src/stories/Alert/Alert.stories.ts +60 -0
- package/src/stories/Alert/Alert.test.ts +95 -0
- package/src/stories/Alert/AlertModifiers.stories.ts +77 -0
- package/src/stories/Alert/AlertSlots.stories.ts +74 -0
- package/src/stories/AlertGroup/AlertGroup.settings.ts +110 -0
- package/src/stories/AlertGroup/AlertGroup.stories.ts +50 -0
- package/src/stories/AlertGroup/AlertGroup.test.ts +76 -0
- package/src/stories/AlertGroup/AlertGroupPosition.stories.ts +103 -0
- package/src/stories/AlertGroup/AlertGroupSlots.stories.ts +67 -0
- package/src/stories/Avatar/Avatar.settings.ts +7 -6
- package/src/stories/Avatar/Avatar.stories.ts +42 -0
- package/src/stories/Avatar/Avatar.test.ts +1 -1
- package/src/stories/Avatar/AvatarBadge.stories.ts +36 -0
- package/src/stories/Avatar/AvatarModifiers.stories.ts +100 -0
- package/src/stories/Avatar/AvatarSlots.stories.ts +34 -0
- package/src/stories/AvatarGroup/AvatarGroup.stories.ts +35 -0
- package/src/stories/AvatarGroup/AvatarGroupModifiers.stories.ts +31 -0
- package/src/stories/AvatarGroup/{AvatarGroupSlotDefault.stories.mdx → AvatarGroupSlotDefault.stories.ts} +24 -30
- package/src/stories/Badge/Badge.stories.ts +43 -0
- package/src/stories/Badge/BadgeSlots.stories.ts +23 -0
- package/src/stories/Breadcrumb/Breadcrumb.stories.ts +41 -0
- package/src/stories/Breadcrumb/Breadcrumb.test.ts +1 -1
- package/src/stories/Breadcrumb/BreadcrumbSlots.stories.ts +37 -0
- package/src/stories/Button/Button.settings.ts +2 -11
- package/src/stories/Button/Button.stories.ts +38 -0
- package/src/stories/Button/ButtonIcon.stories.ts +67 -0
- package/src/stories/Button/ButtonLink.stories.ts +40 -0
- package/src/stories/Button/ButtonLoading.stories.ts +41 -0
- package/src/stories/Button/ButtonModifiers.stories.ts +158 -0
- package/src/stories/Button/ButtonSlots.stories.ts +87 -0
- package/src/stories/Button/ButtonState.stories.ts +42 -0
- package/src/stories/Button/ButtonToggle.stories.ts +52 -0
- package/src/stories/ButtonGroup/ButtonGroup.stories.ts +39 -0
- package/src/stories/ButtonGroup/ButtonGroupModifiers.stories.ts +39 -0
- package/src/stories/ButtonGroup/ButtonGroupSlots.stories.ts +38 -0
- package/src/stories/ButtonGroup/ButtonGroupToggle.stories.ts +41 -0
- package/src/stories/Card/Card.stories.ts +46 -0
- package/src/stories/Card/CardSlots.stories.ts +81 -0
- package/src/stories/Checkbox/Checkbox.settings.ts +0 -2
- package/src/stories/Checkbox/Checkbox.stories.ts +97 -0
- package/src/stories/Checkbox/CheckboxBinary.stories.ts +33 -0
- package/src/stories/Checkbox/CheckboxSlots.stories.ts +31 -0
- package/src/stories/CheckboxGroup/CheckboxGroup.stories.ts +87 -0
- package/src/stories/CheckboxGroup/CheckboxGroupOptions.stories.ts +53 -0
- package/src/stories/CheckboxGroup/CheckboxGroupSlots.stories.ts +47 -0
- package/src/stories/Combobox/Combobox.settings.ts +3 -23
- package/src/stories/Combobox/Combobox.stories.ts +176 -0
- package/src/stories/Combobox/Combobox.test.ts +2 -2
- package/src/stories/Combobox/ComboboxIconPosition.stories.ts +43 -0
- package/src/stories/Combobox/ComboboxMultiple.stories.ts +41 -0
- package/src/stories/Combobox/ComboboxOptions.stories.ts +78 -0
- package/src/stories/Combobox/ComboboxSlots.stories.ts +104 -0
- package/src/stories/Dialog/Dialog.settings.ts +1 -1
- package/src/stories/Dialog/Dialog.stories.ts +51 -0
- package/src/stories/Dialog/Dialog.test.ts +2 -2
- package/src/stories/Dialog/DialogSlots.stories.ts +39 -0
- package/src/stories/Dropdown/Dropdown.stories.ts +107 -0
- package/src/stories/Dropdown/DropdownContextmenuDirective.stories.ts +49 -0
- package/src/stories/Dropdown/DropdownMultilevel.stories.ts +61 -0
- package/src/stories/Dropdown/DropdownSlots.stories.ts +95 -0
- package/src/stories/Icon/Icon.settings.ts +1 -0
- package/src/stories/Icon/Icon.stories.ts +48 -0
- package/src/stories/Icon/IconsCollection.stories.ts +53 -0
- package/src/stories/InputText/InputText.settings.ts +3 -39
- package/src/stories/InputText/InputText.stories.ts +121 -0
- package/src/stories/InputText/InputTextIconPosition.stories.ts +43 -0
- package/src/stories/InputText/InputTextLength.stories.ts +58 -0
- package/src/stories/InputText/InputTextMinMax.stories.ts +51 -0
- package/src/stories/InputText/InputTextSlots.stories.ts +39 -0
- package/src/stories/InputText/InputTextType.stories.ts +119 -0
- package/src/stories/Nav/Nav.stories.ts +33 -0
- package/src/stories/Nav/NavModifiers.stories.ts +47 -0
- package/src/stories/Progress/Progress.settings.ts +0 -3
- package/src/stories/Progress/Progress.stories.ts +41 -0
- package/src/stories/Radio/Radio.stories.ts +81 -0
- package/src/stories/Radio/RadioSlots.stories.ts +31 -0
- package/src/stories/RadioGroup/RadioGroup.stories.ts +88 -0
- package/src/stories/RadioGroup/RadioGroupOptions.stories.ts +53 -0
- package/src/stories/RadioGroup/RadioGroupSlots.stories.ts +47 -0
- package/src/stories/Select/Select.settings.ts +0 -5
- package/src/stories/Select/Select.stories.ts +113 -0
- package/src/stories/Select/SelectIconPosition.stories.ts +43 -0
- package/src/stories/Select/SelectOptions.stories.ts +77 -0
- package/src/stories/Select/SelectSlots.stories.ts +39 -0
- package/src/stories/Tab/Tab.stories.ts +70 -0
- package/src/stories/Textarea/Textarea.settings.ts +0 -8
- package/src/stories/Textarea/Textarea.stories.ts +107 -0
- package/src/stories/Textarea/TextareaLength.stories.ts +58 -0
- package/src/stories/Textarea/TextareaSlots.stories.ts +39 -0
- package/src/stories/Textarea/TextareatIconPosition.stories.ts +43 -0
- package/src/stories/Tooltip/Tooltip.settings.ts +4 -4
- package/src/stories/Tooltip/Tooltip.stories.ts +40 -0
- package/src/stories/Tooltip/TooltipDirective.stories.ts +68 -0
- package/src/stories/argTypes.ts +5 -59
- package/src/stories/Accordion/Accordion.stories.mdx +0 -45
- package/src/stories/Accordion/AccordionSlots.stories.mdx +0 -58
- package/src/stories/AccordionGroup/AccordionGroup.stories.mdx +0 -58
- package/src/stories/AccordionGroup/AccordionGroupSlots.stories.mdx +0 -59
- package/src/stories/Avatar/Avatar.stories.mdx +0 -40
- package/src/stories/Avatar/AvatarBadge.stories.mdx +0 -41
- package/src/stories/Avatar/AvatarModifiers.stories.mdx +0 -87
- package/src/stories/Avatar/AvatarSlotDefault.stories.mdx +0 -29
- package/src/stories/AvatarGroup/AvatarGroup.stories.mdx +0 -30
- package/src/stories/AvatarGroup/AvatarGroupModifiers.stories.mdx +0 -24
- package/src/stories/Badge/Badge.stories.mdx +0 -51
- package/src/stories/Badge/BadgeSlots.stories.mdx +0 -20
- package/src/stories/Breadcrumb/Breadcrumb.stories.mdx +0 -50
- package/src/stories/Breadcrumb/BreadcrumbSlots.stories.mdx +0 -43
- package/src/stories/Button/Button.stories.mdx +0 -35
- package/src/stories/Button/ButtonIcon.stories.mdx +0 -153
- package/src/stories/Button/ButtonLink.stories.mdx +0 -72
- package/src/stories/Button/ButtonLoading.stories.mdx +0 -108
- package/src/stories/Button/ButtonModifiers.stories.mdx +0 -257
- package/src/stories/Button/ButtonSlots.stories.mdx +0 -116
- package/src/stories/Button/ButtonState.stories.mdx +0 -66
- package/src/stories/Button/ButtonToggle.stories.mdx +0 -112
- package/src/stories/ButtonGroup/ButtonGroup.stories.mdx +0 -37
- package/src/stories/ButtonGroup/ButtonGroupModifiers.stories.mdx +0 -52
- package/src/stories/ButtonGroup/ButtonGroupSlots.stories.mdx +0 -37
- package/src/stories/ButtonGroup/ButtonGroupToggle.stories.mdx +0 -73
- package/src/stories/Card/Card.stories.mdx +0 -40
- package/src/stories/Card/CardSlots.stories.mdx +0 -98
- package/src/stories/Checkbox/Checkbox.stories.mdx +0 -164
- package/src/stories/Checkbox/CheckboxBinary.stories.mdx +0 -68
- package/src/stories/Checkbox/CheckboxSlots.stories.mdx +0 -46
- package/src/stories/CheckboxGroup/CheckboxGroup.stories.mdx +0 -135
- package/src/stories/CheckboxGroup/CheckboxGroupOptions.stories.mdx +0 -100
- package/src/stories/CheckboxGroup/CheckboxGroupSlots.stories.mdx +0 -68
- package/src/stories/Combobox/Combobox.stories.mdx +0 -324
- package/src/stories/Combobox/ComboboxIconPosition.stories.mdx +0 -78
- package/src/stories/Combobox/ComboboxMultiple.stories.mdx +0 -73
- package/src/stories/Combobox/ComboboxOptions.stories.mdx +0 -135
- package/src/stories/Combobox/ComboboxSlots.stories.mdx +0 -153
- package/src/stories/Dialog/Dialog.stories.mdx +0 -56
- package/src/stories/Dialog/DialogSlots.stories.mdx +0 -63
- package/src/stories/Dropdown/Dropdown.stories.mdx +0 -124
- package/src/stories/Dropdown/DropdownContextmenuDirective.stories.mdx +0 -41
- package/src/stories/Dropdown/DropdownMultilevel.stories.mdx +0 -56
- package/src/stories/Dropdown/DropdownSlots.stories.mdx +0 -114
- package/src/stories/Icon/Icon.stories.mdx +0 -91
- package/src/stories/Icon/IconsCollection.stories.mdx +0 -69
- package/src/stories/InputText/InputText.stories.mdx +0 -211
- package/src/stories/InputText/InputTextIconPosition.stories.mdx +0 -78
- package/src/stories/InputText/InputTextLength.stories.mdx +0 -110
- package/src/stories/InputText/InputTextMinMax.stories.mdx +0 -112
- package/src/stories/InputText/InputTextSlots.stories.mdx +0 -69
- package/src/stories/InputText/InputTextType.stories.mdx +0 -259
- package/src/stories/Nav/Nav.stories.mdx +0 -28
- package/src/stories/Nav/NavModifiers.stories.mdx +0 -48
- package/src/stories/Progress/Progress.stories.mdx +0 -30
- package/src/stories/Radio/Radio.stories.mdx +0 -128
- package/src/stories/Radio/RadioSlots.stories.mdx +0 -46
- package/src/stories/RadioGroup/RadioGroup.stories.mdx +0 -135
- package/src/stories/RadioGroup/RadioGroupOptions.stories.mdx +0 -100
- package/src/stories/RadioGroup/RadioGroupSlots.stories.mdx +0 -68
- package/src/stories/Select/Select.stories.mdx +0 -196
- package/src/stories/Select/SelectIconPosition.stories.mdx +0 -78
- package/src/stories/Select/SelectOptions.stories.mdx +0 -135
- package/src/stories/Select/SelectSlots.stories.mdx +0 -48
- package/src/stories/Tab/Tab.stories.mdx +0 -65
- package/src/stories/Textarea/Textarea.stories.mdx +0 -187
- package/src/stories/Textarea/TextareaLength.stories.mdx +0 -110
- package/src/stories/Textarea/TextareaSlots.stories.mdx +0 -69
- package/src/stories/Textarea/TextareatIconPosition.stories.mdx +0 -78
- package/src/stories/Tooltip/Tooltip.stories.mdx +0 -102
- package/src/stories/Tooltip/TooltipDirective.stories.mdx +0 -99
|
@@ -1 +1 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue"),require("@iconify/vue"),require("@floating-ui/vue"),require("nanoid"),require("@vueuse/core"),require("mitt")):"function"==typeof define&&define.amd?define(["vue","@iconify/vue","@floating-ui/vue","nanoid","@vueuse/core","mitt"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvCombobox=t(e.vue,e.vue$1,e.vue$2,e.nanoid,e.core,e.mitt)}(this,(function(e,t,l,o,n,a){"use strict";var r=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(r||{}),i=(e=>(e.topStart="top-start",e.topEnd="top-end",e.bottomStart="bottom-start",e.bottomEnd="bottom-end",e.leftStart="left-start",e.leftEnd="left-end",e.rightStart="right-start",e.rightEnd="right-end",e))(i||{}),u=(e=>(e.before="before",e.after="after",e))(u||{}),d=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(d||{}),s=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(s||{}),c=(e=>(e.listbox="listbox",e.menu="menu",e))(c||{}),p=(e=>(e.option="option",e.presentation="presentation",e))(p||{});const f=Symbol.for("volver"),v=Symbol.for("dropdownTrigger"),m=Symbol.for("dropdownItem"),b=Symbol.for("dropdownAction"),g={valid:Boolean,validLabel:[String,Array]},y={invalid:Boolean,invalidLabel:[String,Array]},h={loading:Boolean,loadingLabel:{type:String,default:"Loading..."}},k={disabled:Boolean},B={selected:Boolean},S=(Boolean,Boolean,{label:[String,Number]}),V={readonly:Boolean},w={modifiers:[String,Array]},x={hintLabel:{type:String,default:""}},E={options:{type:Array,default:()=>[]},labelKey:{type:[String,Function],default:"label"},valueKey:{type:[String,Function],default:"value"},disabledKey:{type:[String,Function],default:"disabled"}},N={icon:{type:[String,Object]},iconPosition:{type:String,default:u.before,validation:e=>Object.values(u).includes(e)}},P={tabindex:{type:[String,Number],default:0}},C={floating:Boolean},L={unselectable:{type:Boolean,default:!0}},_={id:[String,Number]},$={placement:{type:String,default:r.bottom,validator:e=>Object.values(r).includes(e)||Object.values(i).includes(e)},strategy:{type:String,default:"absolute",validator:e=>["fixed","absolute"].includes(e)},transitionName:{type:String},offset:{type:[Number,String,Object],default:0},shift:{type:[Boolean,Object],default:!1},flip:{type:[Boolean,Object],default:!0},size:{type:[Boolean,Object],default:()=>({padding:10})},autoPlacement:{type:[Boolean,Object],default:!1},arrow:{type:Boolean,default:!1},autoClose:{type:Boolean,default:!0},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean}},O={..._,name:{type:String,required:!0}},A={autofocus:Boolean},D={autocomplete:{type:String,default:"off"}};d.button;const j={...O,...P,...g,...y,...x,...h,...k,...V,...w,...E,...N,...C,...L,...$,...S,modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},noResultsLabel:{type:String,default:"No results"},noOptionsLabel:{type:String,default:"No options available"},selectedHintLabel:{type:String,default:"Selected"},deselectActionLabel:{type:String,default:"Deselect"},selectHintLabel:{type:String,default:"Press enter to select"},deselectHintLabel:{type:String,default:"Press enter to remove"},placeholder:String,searchable:Boolean,searchPlaceholder:{type:String,default:"Search..."},debounceSearch:{type:[Number,String],default:0},multiple:Boolean,maxValues:[Number,String],separator:{type:String,default:", "},native:Boolean,badges:Boolean,badgeModifiers:{type:[String,Array],default:"action sm"},triggerWidth:{...$.triggerWidth,default:!0},dropdownModifiers:{type:[String,Array]},autoOpen:Boolean,autoClose:Boolean},F={color:String,width:{type:[String,Number]},height:{type:[String,Number]},name:{type:String,required:!0},provider:{type:String},prefix:{type:String,default:"normal"},src:String,horizontalFlip:Boolean,verticalFlip:Boolean,flip:String,mode:String,inline:Boolean,rotate:[Number,String],onLoad:Function,svg:String,modifiers:{type:[String,Array]}};function R(){return e.inject(f)}function z(t,l,o){return e.computed((()=>{const n={[t]:!0},a="string"==typeof(null==l?void 0:l.value)?l.value.split(" "):null==l?void 0:l.value;return a&&Array.isArray(a)&&a.forEach((e=>{e&&(n[`${t}--${e}`]=!0)})),o&&Object.keys(o.value).forEach((l=>{n[`${t}--${l}`]=e.unref(o.value[l])})),n}))}const H=e.defineComponent({name:"VvIcon",props:F,setup(l){const o=l,n=e.ref(!0),a=R(),{modifiers:r}=e.toRefs(o),i=z("vv-icon",r),u=e.computed((()=>o.provider||(null==a?void 0:a.iconsProvider))),d=e.computed((()=>{const e=o.name??"",l=`@${u.value}:${o.prefix}:${o.name}`;return t.iconExists(e)?e:t.iconExists(l)?l:(null==a?void 0:a.iconsCollections.find((l=>{const o=`@${u.value}:${l.prefix}:${e}`;if(t.iconExists(o))return o})))||e}));function s(e){const l=function(e){let t=null;if("undefined"==typeof window){const{JSDOM:e}=require("jsdom");t=(new e).window}return(t?new t.DOMParser:new window.DOMParser).parseFromString(e,"text/html").querySelector("svg")}(e),n=(null==l?void 0:l.innerHTML.trim())||"";l&&n&&t.addIcon(`@${u.value}:${o.prefix}:${o.name}`,{body:n,height:l.viewBox.baseVal.height,width:l.viewBox.baseVal.width})}return a&&(o.src&&!t.iconExists(`@${u.value}:${o.prefix}:${o.name}`)?(n.value=!1,a.fetchIcon(o.src).then((e=>{e&&(s(e),n.value=!0)})).catch((e=>{throw new Error(`During fetch icon: ${null==e?void 0:e.message}`)}))):o.svg&&s(o.svg)),(l,o)=>e.unref(n)?(e.openBlock(),e.createBlock(e.unref(t.Icon),e.mergeProps({key:0,class:e.unref(i)},{inline:l.inline,width:l.width,height:l.height,horizontalFlip:l.horizontalFlip,verticalFlip:l.verticalFlip,flip:l.flip,rotate:l.rotate,color:l.color,onLoad:l.onLoad,icon:e.unref(d)}),null,16,["class"])):e.createCommentVNode("",!0)}}),I={..._,...w,...$,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:c.menu,validator:e=>Object.values(c).includes(e)}},T=t=>e.computed((()=>String((null==t?void 0:t.value)||o.nanoid())));const K=["id","tabindex","role","aria-labelledby"],q=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:I,emits:["update:modelValue"],setup(t,{expose:o,emit:r}){const i=t,{id:u}=e.toRefs(i),d=T(u),s=e.useAttrs(),f=e.ref("auto"),b=e.ref("auto"),g=e.ref(null),y=e.ref(null),h=e.ref(null),k=e.ref(null),B=e.computed({get:()=>i.reference??g.value,set:e=>{g.value=e}}),S=e.computed((()=>{const e=[];if(i.autoPlacement?"boolean"==typeof i.autoPlacement?e.push(l.autoPlacement()):e.push(l.autoPlacement(i.autoPlacement)):i.flip&&("boolean"==typeof i.flip?e.push(l.flip()):e.push(l.flip(i.flip))),i.shift&&("boolean"==typeof i.shift?e.push(l.shift()):e.push(l.shift(i.shift))),i.size){const t=({availableWidth:e,availableHeight:t})=>{f.value=`${e}px`,b.value=`${t}px`};"boolean"==typeof i.size?e.push(l.size({apply:t})):e.push(l.size({...i.size,apply:t}))}return i.offset&&(e.push(l.offset(Number(i.offset))),["string","number"].includes(typeof i.offset)?e.push(l.offset(Number(i.offset))):e.push(l.offset(i.offset))),i.arrow&&e.push(l.arrow({element:h})),e})),{x:V,y:w,strategy:x,middlewareData:E,placement:N}=l.useFloating(B,y,{whileElementsMounted:l.autoUpdate,placement:e.computed((()=>i.placement)),strategy:e.computed((()=>i.strategy)),middleware:S}),P=e.computed((()=>({position:x.value,top:`${w.value??0}px`,left:`${V.value??0}px`,maxWidth:f.value,maxHeight:b.value,width:i.triggerWidth&&B.value?`${B.value.offsetWidth}px`:void 0}))),C=e.computed((()=>N.value.split("-")[0])),L=e.computed((()=>({top:"bottom",right:"left",bottom:"top",left:"right"}[C.value]??"bottom"))),_=e.computed((()=>{var e,t,l,o;return["bottom","top"].includes(L.value)?{right:`${(null==(e=E.value.arrow)?void 0:e.x)??0}px`,[L.value]:-((null==(t=h.value)?void 0:t.offsetWidth)??0)/2+"px"}:{top:`${(null==(l=E.value.arrow)?void 0:l.y)??0}px`,[L.value]:-((null==(o=h.value)?void 0:o.offsetWidth)??0)/2+"px"}})),$=n.useVModel(i,"modelValue",r),O=e.ref(!1),A=e.computed({get:()=>$.value??O.value,set:e=>{void 0!==$.value?$.value=e:O.value=e}}),D=()=>{A.value=!0},j=()=>{A.value=!1},F=()=>{A.value=!A.value},R=e=>{B.value=e};o({toggle:F,show:D,hide:j,init:R}),e.watch(A,(t=>{t&&i.autofocusFirst&&e.nextTick((()=>{const e=X(y.value);e.length>0&&e[0].focus()}))})),n.onClickOutside(y,(()=>{i.autoClose&&(A.value=!1)}),{ignore:[B]});const H=e.computed((()=>{var e,t;return(null==(t=null==(e=B.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),I=e.computed((()=>({"aria-controls":d.value,"aria-haspopup":!0,"aria-expanded":A.value}))),{component:q,bus:W}=function({reference:t,id:l,expanded:o,aria:n}){const r=a(),i=e.defineComponent({name:"VvDropdownTriggerProvider",provide:()=>({[v]:{reference:t,id:l,expanded:o,aria:n,bus:r}}),setup:()=>({}),render(){var t,l;return e.h(e.Fragment,{},null==(l=(t=this.$slots).default)?void 0:l.call(t))}});return{bus:r,component:i}}({reference:B,id:d,expanded:A,aria:I});W.on("click",F);const{role:M,modifiers:U}=e.toRefs(i),{itemRole:G}=function({role:t,expanded:l}){const o=e.computed((()=>t.value===c.listbox?p.option:p.presentation));return e.provide(m,{role:o,expanded:l}),{itemRole:o}}({role:M,expanded:A}),J=z("vv-dropdown",U,e.computed((()=>({arrow:i.arrow})))),{focused:Q}=n.useFocusWithin(y);function X(e){return e?[...e.querySelectorAll('a[href], button, input, textarea, select, details,[tabindex]:not([tabindex="-1"])')].filter((e=>!e.hasAttribute("disabled")&&!e.getAttribute("aria-hidden"))):[]}return n.onKeyStroke("Escape",(e=>{A.value&&(e.preventDefault(),j())})),n.onKeyStroke("ArrowDown",(t=>{A.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=X(y.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t<e.length-1?e[t+1].focus():e[0].focus()}})))})),n.onKeyStroke("ArrowUp",(t=>{A.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=X(y.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t>0?e[t-1].focus():e[e.length-1].focus()}})))})),n.onKeyStroke([" ","Enter"],(e=>{if(A.value&&Q.value){e.preventDefault();document.activeElement.click()}})),(t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(e.unref(q),null,{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps({init:R,show:D,hide:j,toggle:F,expanded:e.unref(A),aria:e.unref(I)})))])),_:3}),e.createVNode(e.Transition,{name:t.transitionName},{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:y,style:e.normalizeStyle(e.unref(P)),class:e.normalizeClass(e.unref(J))},[i.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:h,style:e.normalizeStyle(e.unref(_)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(A)}))),e.createElementVNode("ul",e.mergeProps(e.unref(s),{id:e.unref(d),ref_key:"listEl",ref:k,tabindex:e.unref(A)?void 0:-1,role:e.unref(M),"aria-labelledby":e.unref(H),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(G)})))],16,K),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(A)})))],6),[[e.vShow,e.unref(A)]])])),_:3},8,["name"])],64))}});const W=e.defineComponent({name:"VvDropdownItem",setup(t){const{role:l,expanded:o}=e.inject(m,{}),a=e.ref(null);!function({expanded:t}){e.provide(b,{role:s.menuitem,expanded:t})}({expanded:o});const r=n.useElementHover(a),{focused:i}=n.useFocus(a),{focused:u}=n.useFocusWithin(a);return e.watch(r,(e=>{e&&(i.value=!0)})),(t,o)=>(e.openBlock(),e.createElementBlock("li",e.mergeProps({role:e.unref(l)},{ref_key:"element",ref:a,class:["vv-dropdown__item",{"focus-visible":e.unref(i)||e.unref(u)}]}),[e.renderSlot(t.$slots,"default")],16))}}),M=["title"],U=e.defineComponent({name:"VvDropdownOption",props:{...k,...B,...L,...w,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String}},setup(t){const l=t,{modifiers:o}=e.toRefs(l),n=z("vv-dropdown-option",o,e.computed((()=>({disabled:l.disabled,selected:l.selected,unselectable:l.unselectable&&l.selected})))),a=e.computed((()=>l.selected?l.unselectable?l.deselectHintLabel:l.selectedHintLabel:l.disabled?void 0:l.selectHintLabel));return(t,l)=>(e.openBlock(),e.createBlock(W,{class:e.normalizeClass(e.unref(n)),tabindex:t.disabled?-1:0,"aria-selected":t.selected,"aria-disabled":t.disabled},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default"),e.createElementVNode("span",{class:"vv-dropdown-option__hint",title:e.unref(a)},[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps({disabled:t.disabled,selected:t.selected,unselectable:t.unselectable})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(a)),1)]))],8,M)])),_:3},8,["class","tabindex","aria-selected","aria-disabled"]))}}),G={class:"vv-dropdown-optgroup",role:"presentation",tabindex:"-1"},J=e.defineComponent({name:"VvDropdownOptgroup",props:{...S},setup(t){const l=t;return(t,o)=>(e.openBlock(),e.createElementBlock("li",G,e.toDisplayString(l.label),1))}});function Q(e,t,l){return l?Y(e,l)===Y(t,l):X(e,t)}function X(e,t){if(e===t)return!0;if(e&&t&&"object"==typeof e&&"object"==typeof t){const l=Array.isArray(e),o=Array.isArray(t);let n,a,r;if(l&&o){if(a=e.length,a!=t.length)return!1;for(n=a;0!=n--;)if(!X(e[n],t[n]))return!1;return!0}if(l!=o)return!1;const i=e instanceof Date,u=t instanceof Date;if(i!=u)return!1;if(i&&u)return e.getTime()==t.getTime();const d=e instanceof RegExp,s=t instanceof RegExp;if(d!=s)return!1;if(d&&s)return e.toString()==t.toString();const c=Object.keys(e);if(a=c.length,a!==Object.keys(t).length)return!1;for(n=a;0!=n--;)if(!Object.prototype.hasOwnProperty.call(t,c[n]))return!1;for(n=a;0!=n--;)if(r=c[n],!X(e[r],t[r]))return!1;return!0}return e!=e&&t!=t}function Y(e,t){if(e&&Object.keys(e).length&&t){if(-1===t.indexOf("."))return e[t];{const l=t.split(".");let o=e;for(let t=0,n=l.length;t<n;++t){if(null==e)return null;o=o[l[t]]}return o}}return null}function Z(e,t){if(null!=e&&t&&t.length)for(const l of t)if(Q(e,l))return!0;return!1}function ee(t){return null==(l=e.unref(t))||""===l||Array.isArray(l)&&0===l.length||!(l instanceof Date)&&"object"==typeof l&&0===Object.keys(l).length;var l}function te(e,t){const l=function(e,t){let l=-1;if(t)for(let o=0;o<t.length;o++)if(Q(t[o],e)){l=o;break}return l}(e,t);return l>-1?t.filter(((e,t)=>t!==l)):t}function le(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}function oe(t,l){const{invalid:o,valid:a,hint:r,loading:i}=l,{hintLabel:u,modelValue:d,valid:s,validLabel:c,invalid:p,invalidLabel:f,...v}=e.toRefs(t),m=Y(v,"loading"),b=Y(v,"loadingLabel"),g=e.computed((()=>!!p.value&&(!(!p.value||!o)||(!!((null==f?void 0:f.value)&&Array.isArray(f.value)&&f.value.length>0)||!(!(null==f?void 0:f.value)||ee(f)))))),y=e.computed((()=>!!(u&&u.value||r))),h=e.computed((()=>!!(c&&c.value||a))),k=e.computed((()=>!!((null==m?void 0:m.value)&&i||(null==m?void 0:m.value)&&(null==b?void 0:b.value)))),B=e.computed((()=>y.value||h.value||g.value||k.value));return{hasInvalid:g,hasHint:y,hasValid:h,hasLoading:k,HintSlot:{name:"HintSlot",props:{params:{type:Object,default:()=>({})}},setup(t){const l=e.computed((()=>{const e=n.toReactive({hintLabel:u,modelValue:d,valid:s,validLabel:c,invalid:p,invalidLabel:f,loading:m,loadingLabel:b,...t.params});return(null==p?void 0:p.value)?(null==o?void 0:o(e))||le(null==f?void 0:f.value)||(null==u?void 0:u.value):(null==s?void 0:s.value)?(null==a?void 0:a(e))||le(null==c?void 0:c.value)||(null==u?void 0:u.value):(null==m?void 0:m.value)?(null==i?void 0:i(e))||le(null==b?void 0:b.value)||(null==u?void 0:u.value):(null==r?void 0:r(e))||le(null==u?void 0:u.value)||(null==u?void 0:u.value)}));return{isVisible:B,hasInvalid:g,hasValid:h,hintContent:l}},render(){if(this.isVisible)return e.h("small",{role:this.hasInvalid?"alert":this.hasValid?"status":void 0},this.hintContent)}}}}const ne={...O,...A,...D,...P,...g,...y,...x,...h,...k,...V,...w,...E,...N,...C,...L,...S,multiple:Boolean,required:Boolean,size:[String,Number],modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},placeholder:String};function ae(t,l){const{focused:o}=n.useFocus(t);return e.watch(o,(o=>{l(o?"focus":"blur",e.unref(t))})),{focused:o}}function re(t,l){const o=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===u.before))),n=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===u.after))),a=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.left))),i=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.right))),d=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.top))),s=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.bottom)));return{hasIcon:e.computed((()=>"string"==typeof(null==t?void 0:t.value)?{name:null==t?void 0:t.value}:null==t?void 0:t.value)),hasIconLeft:a,hasIconRight:i,hasIconTop:d,hasIconBottom:s,hasIconBefore:o,hasIconAfter:n}}function ie(t){const{options:l,labelKey:o,valueKey:n,disabledKey:a}=e.toRefs(t);return{options:l,getOptionLabel:e=>"object"!=typeof e&&null!==e?e:"function"==typeof o.value?o.value(e):e[o.value],getOptionValue:e=>"object"!=typeof e&&null!==e?e:"function"==typeof n.value?n.value(e):e[n.value],getOptionDisabled:e=>("object"==typeof e||null===e)&&("function"==typeof a.value?a.value(e):e[a.value]),getOptionGrouped:e=>"object"!=typeof e&&null!==e?[]:e.options||[]}}const ue=["for"],de={class:"vv-select__wrapper"},se={key:0,class:"vv-select__input-before"},ce={class:"vv-select__inner"},pe=["id"],fe=["disabled","hidden"],ve=["disabled","value"],me=["disabled","label"],be=["disabled","value"],ge={key:1,class:"vv-select__input-after"},ye=e.defineComponent({name:"VvSelect",props:ne,emits:["update:modelValue","focus","blur"],setup(t,{emit:l}){const o=t,a=e.useSlots(),r=e.ref(),{HintSlot:i,hasHint:u,hasInvalid:d}=oe(o,a),{id:s,modifiers:c,disabled:p,readonly:f,loading:v,icon:m,iconPosition:b,invalid:g,valid:y,floating:h,multiple:k}=e.toRefs(o),B=T(s),S=e.computed((()=>`${B.value}-hint`)),{focused:V}=ae(r,l),w=n.useElementVisibility(r);e.watch(w,(e=>{e&&o.autofocus&&(V.value=!0)}));const{hasIcon:x,hasIconBefore:E,hasIconAfter:N}=re(m,b),P=e.computed((()=>!ee(o.modelValue))),C=e.computed((()=>o.disabled||o.readonly)),L=e.computed((()=>C.value?-1:o.tabindex)),_=e.computed((()=>!0===o.invalid||!0!==o.valid&&void 0)),$=z("vv-select",c,e.computed((()=>({valid:y.value,invalid:g.value,loading:v.value,disabled:p.value,readonly:f.value,"icon-before":E.value,"icon-after":N.value,dirty:P.value,focus:V.value,floating:h.value,multiple:k.value})))),O=e.computed((()=>({name:o.name,tabindex:L.value,disabled:C.value,required:o.required,size:o.size,autocomplete:o.autocomplete,multiple:o.multiple,"aria-invalid":_.value,"aria-describedby":!d.value&&u.value?S.value:void 0,"aria-errormessage":d.value?S.value:void 0}))),A=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue}))),{getOptionLabel:D,getOptionValue:j,getOptionDisabled:F,getOptionGrouped:R}=ie(o),I=e.computed({get:()=>o.modelValue,set:e=>{Array.isArray(e)&&(e=e.filter((e=>void 0!==e))),l("update:modelValue",e)}}),K=e=>"string"!=typeof e&&(e&&e.options&&e.options.length>0);return(t,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref($))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(B)},e.toDisplayString(t.label),9,ue)):e.createCommentVNode("",!0),e.createElementVNode("div",de,[t.$slots.before?(e.openBlock(),e.createElementBlock("div",se,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(A))))])):e.createCommentVNode("",!0),e.createElementVNode("div",ce,[e.unref(E)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:0,class:"vv-select__icon"},e.unref(x)),null,16)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("select",e.mergeProps({id:e.unref(B),ref_key:"select",ref:r,"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(I)?I.value=t:null)},e.unref(O)),[t.placeholder?(e.openBlock(),e.createElementBlock("option",{key:0,value:void 0,disabled:!t.unselectable,hidden:!t.unselectable},e.toDisplayString(t.placeholder),9,fe)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.options,((t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[K(t)?(e.openBlock(),e.createElementBlock("optgroup",{key:`group-${l}`,disabled:e.unref(F)(t),label:e.unref(D)(t)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(R)(t),((t,o)=>(e.openBlock(),e.createElementBlock("option",{key:`group-${l}-item-${o}`,disabled:e.unref(F)(t),value:e.unref(j)(t)},e.toDisplayString(e.unref(D)(t)),9,be)))),128))],8,me)):(e.openBlock(),e.createElementBlock("option",{key:l,disabled:e.unref(F)(t),value:e.unref(j)(t)},e.toDisplayString(e.unref(D)(t)),9,ve))],64)))),256))],16,pe),[[e.vModelSelect,e.unref(I)]]),e.unref(N)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:1,class:"vv-select__icon vv-select__icon-after"},e.unref(x)),null,16)):e.createCommentVNode("",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",ge,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(A))))])):e.createCommentVNode("",!0)]),e.createVNode(e.unref(i),{id:e.unref(S),class:"vv-select__hint"},null,8,["id"])],2))}}),he={...w,value:[String,Number]},ke=e.defineComponent({name:"VvBadge",props:he,setup(t){const l=t,{modifiers:o}=e.toRefs(l),n=z("vv-badge",o);return(t,l)=>(e.openBlock(),e.createElementBlock("span",{class:e.normalizeClass(e.unref(n)),role:"status"},[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.value),1)]))],2))}});const Be=["id"],Se=["id","for"],Ve=["id","aria-controls","aria-labelledby","aria-describedby","placeholder"],we={key:0,class:"vv-select__input-before"},xe={class:"vv-select__inner"},Ee=["aria-labelledby","tabindex"],Ne=["aria-label","onClick"],Pe={key:1,class:"vv-select__input-after"},Ce={name:"VvCombobox",components:{VvDropdown:q,VvDropdownOption:U,VvDropdownOptgroup:J}};return e.defineComponent({...Ce,props:j,emits:["update:modelValue","change:search","focus","blur"],setup(t,{emit:l}){const o=t,a=e.useSlots(),r=function(t,l,o){const n=R(),a=e.computed((()=>{var e;if(n&&(null==(e=n.defaults.value)?void 0:e[t]))return n.defaults.value[t]}));return e.computed((()=>{if(void 0===a.value)return o;const e=a.value,t=l,n=o;return Object.keys(t).reduce(((l,o)=>{const a=n[o];if(l[o]=a,o in e){if(Array.isArray(t[o])){const n=t[o];n.length&&n[0]===a&&(l[o]=e[o])}if("function"==typeof t[o]&&(0,t[o])()===a&&(l[o]=e[o]),"object"==typeof t[o]){let n=t[o].default;"function"==typeof n&&(n=n()),"object"==typeof n?JSON.stringify(n)===JSON.stringify(a)&&(l[o]=e[o]):n===a&&(l[o]=e[o])}}return l}),{})}))}("VvCombobox",j,o),i=e=>"string"!=typeof e&&(e.options&&e.options.length>0),{HintSlot:u}=oe(o,a),d=e.ref(null),s=e.ref(null),p=e.ref(null),{focused:f}=ae(d,l),{focused:v}=n.useFocusWithin(p);e.watch(f,(e=>{o.autoOpen&&(!e||g.value?e||!g.value||v.value||k():h())})),e.watch(v,(e=>{f.value||e||!g.value||k()}));const m=e.ref(""),b=n.refDebounced(m,Number(o.debounceSearch));e.watch(b,(()=>l("change:search",b.value)));const g=e.ref(!1),y=()=>{o.disabled||o.readonly||(g.value=!g.value)},h=()=>{o.disabled||o.readonly||g.value||(g.value=!0)},k=()=>{o.disabled||o.readonly||!g.value||(g.value=!1)};e.watch(g,(t=>{_.value&&e.nextTick((()=>{t?s.value&&s.value.focus():m.value=""}))}));const{id:B,icon:S,iconPosition:V,modifiers:w,disabled:x,readonly:E,loading:N,valid:P,invalid:C,floating:L,searchable:_}=e.toRefs(o),$=T(B),O=e.computed((()=>`${$.value}-hint`)),A=e.computed((()=>`${$.value}-dropdown`)),D=e.computed((()=>`${$.value}-search`)),F=e.computed((()=>`${$.value}-label`)),{hasIcon:I,hasIconBefore:K,hasIconAfter:W}=re(S,V),M=e.computed((()=>!ee(o.modelValue))),G=e.computed((()=>x.value||E.value?-1:o.tabindex)),X=z("vv-select",w,e.computed((()=>({disabled:x.value,loading:N.value,readonly:E.value,"icon-before":Boolean(K.value),"icon-after":Boolean(W.value),valid:P.value,invalid:C.value,dirty:M.value,focus:f.value,floating:L.value})))),Y=e.computed((()=>o.searchable?se.value:o.options)),{getOptionLabel:le,getOptionValue:ne,getOptionDisabled:ue,getOptionGrouped:de}=ie(o),se=e.computed((()=>{var e;return null==(e=o.options)?void 0:e.filter((e=>le(e).toLowerCase().includes(b.value.toLowerCase().trim())))}));function ce(e){return Array.isArray(o.modelValue)?Z(e,o.modelValue)||Z(ne(e),o.modelValue):Q(e,o.modelValue)||Q(ne(e),o.modelValue)}const pe=e.computed((()=>{let e=[];Array.isArray(o.modelValue)?e=o.modelValue:o.modelValue&&(e=[o.modelValue]);return o.options.reduce(((e,t)=>i(t)?[...e,...de(t)]:[...e,t]),[]).filter((t=>i(t)?de(t).some((t=>e.includes(ne(t)))):e.includes(ne(t))))})),fe=e.computed((()=>pe.value.map((e=>le(e))).join(o.separator)));e.watch(pe,(()=>{!o.multiple&&o.autoClose&&k()}));const ve=()=>{o.autoOpen?h():y()},me=e=>{var t;if(o.disabled||o.readonly)return;const n=ne(e);let a=n;if(o.multiple)if(Array.isArray(o.modelValue)){const e=Number(o.maxValues);if(void 0!==o.maxValues&&e>=0&&(null==(t=o.modelValue)?void 0:t.length)>=e&&!Z(n,o.modelValue))return;a=Z(n,o.modelValue)?te(n,o.modelValue):[...o.modelValue,n]}else a=[n];else o.autoClose&&k(),o.unselectable&&n===o.modelValue&&(a=void 0);l("update:modelValue",a)},be=e.computed((()=>({id:$.value,name:o.name,tabindex:G.value,valid:P.value,validLabel:r.value.validLabel,invalid:C.value,invalidLabel:r.value.invalidLabel,hintLabel:r.value.hintLabel,loading:N.value,loadingLabel:r.value.loadingLabel,disabled:x.value,readonly:E.value,modifiers:o.modifiers,options:Y.value,labelKey:o.labelKey,valueKey:o.valueKey,icon:o.icon,iconPosition:o.iconPosition,floating:o.floating,unselectable:o.unselectable,multiple:o.multiple,label:o.label,placeholder:o.placeholder,modelValue:o.modelValue}))),ge=e.computed((()=>({id:A.value,reference:p.value,placement:o.placement,strategy:o.strategy,transitionName:o.transitionName,offset:o.offset,shift:o.shift,flip:o.flip,autoPlacement:o.autoPlacement,arrow:o.arrow,autoClose:o.autoClose,autofocusFirst:!_.value&&o.autofocusFirst,triggerWidth:o.triggerWidth,modifiers:o.dropdownModifiers}))),he=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue})));return n.onKeyStroke([" ","Enter"],(e=>{o.autoOpen||!g.value&&f.value&&(e.preventDefault(),e.stopImmediatePropagation(),y())})),(t,o)=>t.native?(e.openBlock(),e.createBlock(ye,e.mergeProps({key:1},e.unref(be),{"onUpdate:modelValue":o[2]||(o[2]=e=>l("update:modelValue",e))}),null,16)):(e.openBlock(),e.createElementBlock("div",{key:0,id:e.unref($),class:e.normalizeClass(e.unref(X))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,id:e.unref(F),for:e.unref(_)?e.unref(D):void 0},e.toDisplayString(t.label),9,Se)):e.createCommentVNode("",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:p,class:"vv-select__wrapper"},[e.createVNode(q,e.mergeProps({modelValue:e.unref(g),"onUpdate:modelValue":o[1]||(o[1]=t=>e.isRef(g)?g.value=t:null)},e.unref(ge),{role:e.unref(c).listbox}),e.createSlots({default:e.withCtx((({aria:l})=>[t.$slots.before?(e.openBlock(),e.createElementBlock("div",we,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(he))))])):e.createCommentVNode("",!0),e.createElementVNode("div",xe,[e.unref(K)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:0,class:"vv-select__icon"},e.unref(I)),null,16)):e.createCommentVNode("",!0),e.createElementVNode("div",e.mergeProps({ref_key:"inputEl",ref:d},l,{"aria-labelledby":e.unref(F),class:"vv-select__input",role:"combobox",tabindex:e.unref(G),onClickPassive:ve}),[e.renderSlot(t.$slots,"value",e.normalizeProps(e.guardReactiveProps({selectedOptions:e.unref(pe),onInput:me})),(()=>[e.unref(fe)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[t.badges?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(e.unref(pe),((l,o)=>(e.openBlock(),e.createBlock(ke,{key:o,modifiers:t.badgeModifiers,class:"vv-select__badge"},{default:e.withCtx((()=>[e.createTextVNode(e.toDisplayString(e.unref(le)(l))+" ",1),!t.unselectable||e.unref(E)||e.unref(x)?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("button",{key:0,"aria-label":e.unref(r).deselectActionLabel,onClick:e.withModifiers((e=>me(l)),["stop"])},[e.createVNode(H,{name:"close"})],8,Ne))])),_:2},1032,["modifiers"])))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(e.unref(fe)),1)],64))],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(t.placeholder),1)],64))]))],16,Ee),e.unref(W)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:1,class:"vv-select__icon vv-select__icon-after"},e.unref(I)),null,16)):e.createCommentVNode("",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",Pe,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(he))))])):e.createCommentVNode("",!0)])),items:e.withCtx((()=>[e.unref(se).length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(e.unref(se),((l,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:o},[i(l)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createVNode(J,{label:e.unref(le)(l)},null,8,["label"]),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(de)(l),((o,n)=>(e.openBlock(),e.createBlock(U,e.mergeProps({disabled:e.unref(ue)(o),selected:ce(o),unselectable:t.unselectable,deselectHintLabel:e.unref(r).deselectHintLabel,selectHintLabel:e.unref(r).selectHintLabel,selectedHintLabel:e.unref(r).selectedHintLabel},{key:n,class:"vv-dropdown-option",onClickPassive:e=>me(o)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(pe),selected:ce(o),disabled:e.unref(ue)(o)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(le)(o)),1)]))])),_:2},1040,["onClickPassive"])))),128))],64)):(e.openBlock(),e.createBlock(U,e.mergeProps({key:1},{disabled:e.unref(ue)(l),selected:ce(l),unselectable:t.unselectable,deselectHintLabel:e.unref(r).deselectHintLabel,selectHintLabel:e.unref(r).selectHintLabel,selectedHintLabel:e.unref(r).selectedHintLabel},{class:"vv-dropdown-option",onClickPassive:e=>me(l)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(pe),selected:ce(l),disabled:e.unref(ue)(l)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(le)(l)),1)]))])),_:2},1040,["onClickPassive"]))],64)))),128)):t.options.length?(e.openBlock(),e.createBlock(U,{key:2,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-results",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(r).noResultsLabel),1)]))])),_:3})):(e.openBlock(),e.createBlock(U,{key:1,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-options",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(r).noOptionsLabel),1)]))])),_:3}))])),_:2},[e.unref(_)||t.$slots["dropdown::before"]?{name:"before",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::before"),e.unref(_)?e.withDirectives((e.openBlock(),e.createElementBlock("input",{key:0,id:e.unref(D),ref_key:"inputSearchEl",ref:s,"onUpdate:modelValue":o[0]||(o[0]=t=>e.isRef(m)?m.value=t:null),"aria-autocomplete":"list","aria-controls":e.unref(A),"aria-labelledby":e.unref(F),"aria-describedby":e.unref(O),autocomplete:"off",spellcheck:"false",type:"search",class:"vv-dropdown__search",placeholder:e.unref(r).searchPlaceholder},null,8,Ve)),[[e.vShow,e.unref(g)],[e.vModelText,e.unref(m)]]):e.createCommentVNode("",!0)])),key:"0"}:void 0,t.$slots["dropdown::after"]?{name:"after",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::after")])),key:"1"}:void 0]),1040,["modelValue","role"])],512),e.createVNode(e.unref(u),{id:e.unref(O),class:"vv-select__hint"},null,8,["id"])],10,Be))}})}));
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("vue"),require("@iconify/vue"),require("@floating-ui/vue"),require("nanoid"),require("@vueuse/core"),require("mitt")):"function"==typeof define&&define.amd?define(["vue","@iconify/vue","@floating-ui/vue","nanoid","@vueuse/core","mitt"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).VvCombobox=t(e.vue,e.vue$1,e.vue$2,e.nanoid,e.core,e.mitt)}(this,(function(e,t,l,o,n,a){"use strict";var r=(e=>(e.left="left",e.right="right",e.top="top",e.bottom="bottom",e))(r||{}),i=(e=>(e.topStart="top-start",e.topEnd="top-end",e.bottomStart="bottom-start",e.bottomEnd="bottom-end",e.leftStart="left-start",e.leftEnd="left-end",e.rightStart="right-start",e.rightEnd="right-end",e))(i||{}),u=(e=>(e.before="before",e.after="after",e))(u||{}),s=(e=>(e.button="button",e.submit="submit",e.reset="reset",e))(s||{}),d=(e=>(e.button="button",e.link="link",e.menuitem="menuitem",e))(d||{}),c=(e=>(e.listbox="listbox",e.menu="menu",e))(c||{}),p=(e=>(e.option="option",e.presentation="presentation",e))(p||{});const f=Symbol.for("volver"),v=Symbol.for("dropdownTrigger"),m=Symbol.for("dropdownItem"),b=Symbol.for("dropdownAction"),g={valid:Boolean,validLabel:[String,Array]},h={invalid:Boolean,invalidLabel:[String,Array]},y={loading:Boolean,loadingLabel:{type:String,default:"Loading..."}},k={disabled:Boolean},S={selected:Boolean},B=(Boolean,Boolean,{label:[String,Number]}),x={readonly:Boolean},V={modifiers:[String,Array]},w={hintLabel:{type:String,default:""}},L={options:{type:Array,default:()=>[]},labelKey:{type:[String,Function],default:"label"},valueKey:{type:[String,Function],default:"value"},disabledKey:{type:[String,Function],default:"disabled"}},$={icon:{type:[String,Object]},iconPosition:{type:String,default:u.before,validation:e=>Object.values(u).includes(e)}},P={tabindex:{type:[String,Number],default:0}},O={floating:Boolean},E={unselectable:{type:Boolean,default:!0}},C={id:[String,Number]},N={placement:{type:String,default:r.bottom,validator:e=>Object.values(r).includes(e)||Object.values(i).includes(e)},strategy:{type:String,default:"absolute",validator:e=>["fixed","absolute"].includes(e)},transitionName:{type:String},offset:{type:[Number,String,Object],default:0},shift:{type:[Boolean,Object],default:!1},flip:{type:[Boolean,Object],default:!0},size:{type:[Boolean,Object],default:()=>({padding:10})},autoPlacement:{type:[Boolean,Object],default:!1},arrow:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1},autofocusFirst:{type:Boolean,default:!0},triggerWidth:{type:Boolean}},_={...C,name:{type:String,required:!0}},A={autofocus:Boolean},D={autocomplete:{type:String,default:"off"}};s.button;const z={..._,...P,...g,...h,...w,...y,...k,...x,...V,...L,...$,...O,...E,...N,...B,modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},noResultsLabel:{type:String,default:"No results"},noOptionsLabel:{type:String,default:"No options available"},selectedHintLabel:{type:String,default:"Selected"},deselectActionLabel:{type:String,default:"Deselect"},selectHintLabel:{type:String,default:"Press enter to select"},deselectHintLabel:{type:String,default:"Press enter to remove"},placeholder:String,searchable:Boolean,searchPlaceholder:{type:String,default:"Search..."},debounceSearch:{type:[Number,String],default:0},multiple:Boolean,maxValues:[Number,String],separator:{type:String,default:", "},native:Boolean,badges:Boolean,badgeModifiers:{type:[String,Array],default:"action sm"},triggerWidth:{...N.triggerWidth,default:!0},dropdownModifiers:{type:[String,Array]},autoOpen:{type:Boolean,default:!1},keepOpen:{type:Boolean,default:!1}},R={color:String,width:{type:[String,Number]},height:{type:[String,Number]},name:{type:String,required:!0},provider:{type:String},prefix:{type:String,default:"normal"},src:String,horizontalFlip:Boolean,verticalFlip:Boolean,flip:String,mode:String,inline:Boolean,rotate:[Number,String],onLoad:Function,svg:String,modifiers:{type:[String,Array]}};function j(){return e.inject(f)}function F(t,l,o){return e.computed((()=>{const n={[t]:!0},a="string"==typeof(null==l?void 0:l.value)?l.value.split(" "):null==l?void 0:l.value;return a&&Array.isArray(a)&&a.forEach((e=>{e&&(n[`${t}--${e}`]=!0)})),o&&Object.keys(o.value).forEach((l=>{n[`${t}--${l}`]=e.unref(o.value[l])})),n}))}const H=e.defineComponent({name:"VvIcon",props:R,setup(l){const o=l,n=e.computed((()=>"string"==typeof o.rotate?parseFloat(o.rotate):o.rotate)),a=e.ref(!0),r=j(),{modifiers:i}=e.toRefs(o),u=F("vv-icon",i),s=e.computed((()=>o.provider||(null==r?void 0:r.iconsProvider))),d=e.computed((()=>{const e=o.name??"",l=`@${s.value}:${o.prefix}:${e}`;if(t.iconExists(l))return l;const n=null==r?void 0:r.iconsCollections.find((l=>{const o=`@${s.value}:${l.prefix}:${e}`;return t.iconExists(o)}));return n?`@${s.value}:${n.prefix}:${e}`:e}));function c(e){const l=function(e){let t;if("undefined"==typeof window){const{JSDOM:e}=require("jsdom");t=(new e).window}return(t?new t.DOMParser:new window.DOMParser).parseFromString(e,"text/html").querySelector("svg")}(e),n=(null==l?void 0:l.innerHTML.trim())||"";l&&n&&t.addIcon(`@${s.value}:${o.prefix}:${o.name}`,{body:n,height:l.viewBox.baseVal.height,width:l.viewBox.baseVal.width})}return r&&o.src&&!t.iconExists(`@${s.value}:${o.prefix}:${o.name}`)&&(a.value=!1,r.fetchIcon(o.src).then((e=>{e&&(c(e),a.value=!0)})).catch((e=>{throw new Error(`Error during fetch icon: ${null==e?void 0:e.message}`)}))),o.svg&&c(o.svg),(l,o)=>e.unref(a)?(e.openBlock(),e.createBlock(e.unref(t.Icon),e.mergeProps({key:0,class:e.unref(u)},{inline:l.inline,width:l.width,height:l.height,horizontalFlip:l.horizontalFlip,verticalFlip:l.verticalFlip,flip:l.flip,rotate:e.unref(n),color:l.color,onLoad:l.onLoad,icon:e.unref(d)}),null,16,["class"])):e.createCommentVNode("",!0)}}),I={...C,...V,...N,modelValue:{type:Boolean,default:void 0},reference:{type:Object,default:null},role:{type:String,default:c.menu,validator:e=>Object.values(c).includes(e)}},T=t=>e.computed((()=>String((null==t?void 0:t.value)||o.nanoid())));const K=["id","tabindex","role","aria-labelledby"],q=e.defineComponent({name:"VvDropdown",inheritAttrs:!1,props:I,emits:["update:modelValue","beforeExpand","beforeCollapse","afterExpand","afterCollapse"],setup(t,{expose:o,emit:r}){const i=t,{id:u}=e.toRefs(i),s=T(u),d=e.useAttrs(),f=e.ref("auto"),b=e.ref("auto"),g=e.ref(null),h=e.ref(null),y=e.ref(null),k=e.ref(null),S=e.computed({get:()=>i.reference??g.value,set:e=>{g.value=e}}),B=e.computed((()=>{const e=[];if(i.autoPlacement?"boolean"==typeof i.autoPlacement?e.push(l.autoPlacement()):e.push(l.autoPlacement(i.autoPlacement)):i.flip&&("boolean"==typeof i.flip?e.push(l.flip()):e.push(l.flip(i.flip))),i.shift&&("boolean"==typeof i.shift?e.push(l.shift()):e.push(l.shift(i.shift))),i.size){const t=({availableWidth:e,availableHeight:t})=>{f.value=`${e}px`,b.value=`${t}px`};"boolean"==typeof i.size?e.push(l.size({apply:t})):e.push(l.size({...i.size,apply:t}))}return i.offset&&(e.push(l.offset(Number(i.offset))),["string","number"].includes(typeof i.offset)?e.push(l.offset(Number(i.offset))):e.push(l.offset(i.offset))),i.arrow&&e.push(l.arrow({element:y})),e})),{x:x,y:V,strategy:w,middlewareData:L,placement:$}=l.useFloating(S,h,{whileElementsMounted:l.autoUpdate,placement:e.computed((()=>i.placement)),strategy:e.computed((()=>i.strategy)),middleware:B}),P=e.computed((()=>({position:w.value,top:`${V.value??0}px`,left:`${x.value??0}px`,maxWidth:f.value,maxHeight:b.value,width:i.triggerWidth&&S.value?`${S.value.offsetWidth}px`:void 0}))),O=e.computed((()=>$.value.split("-")[0])),E=e.computed((()=>({top:"bottom",right:"left",bottom:"top",left:"right"}[O.value]??"bottom"))),C=e.computed((()=>{var e,t,l,o;return["bottom","top"].includes(E.value)?{right:`${(null==(e=L.value.arrow)?void 0:e.x)??0}px`,[E.value]:-((null==(t=y.value)?void 0:t.offsetWidth)??0)/2+"px"}:{top:`${(null==(l=L.value.arrow)?void 0:l.y)??0}px`,[E.value]:-((null==(o=y.value)?void 0:o.offsetWidth)??0)/2+"px"}})),N=n.useVModel(i,"modelValue",r),_=e.ref(!1),A=e.computed({get:()=>N.value??_.value,set:e=>{void 0!==N.value?N.value=e:_.value=e}}),D=()=>{A.value=!0},z=()=>{A.value=!1},R=()=>{A.value=!A.value},j=e=>{S.value=e};o({toggle:R,show:D,hide:z,init:j}),e.watch(A,(t=>{t&&i.autofocusFirst&&e.nextTick((()=>{const e=X(h.value);e.length>0&&e[0].focus()}))})),n.onClickOutside(h,(()=>{i.keepOpen||(A.value=!1)}),{ignore:[S]});const H=e.computed((()=>{var e,t;return(null==(t=null==(e=S.value)?void 0:e.getAttribute)?void 0:t.call(e,"id"))??void 0})),I=e.computed((()=>({"aria-controls":s.value,"aria-haspopup":!0,"aria-expanded":A.value}))),{component:q,bus:W}=function({reference:t,id:l,expanded:o,aria:n}){const r=a(),i=e.defineComponent({name:"VvDropdownTriggerProvider",setup(){e.provide(v,{reference:t,id:l,expanded:o,aria:n,bus:r})},render(){var t,l;return e.h(e.Fragment,{},null==(l=(t=this.$slots).default)?void 0:l.call(t))}});return{bus:r,component:i}}({reference:S,id:s,expanded:A,aria:I});W.on("click",R);const{role:M,modifiers:U}=e.toRefs(i),{itemRole:G}=function({role:t,expanded:l}){const o=e.computed((()=>t.value===c.listbox?p.option:p.presentation));return e.provide(m,{role:o,expanded:l}),{itemRole:o}}({role:M,expanded:A}),J=F("vv-dropdown",U,e.computed((()=>({arrow:i.arrow})))),{focused:Q}=n.useFocusWithin(h);function X(e){return e?[...e.querySelectorAll('a[href], button, input, textarea, select, details,[tabindex]:not([tabindex="-1"])')].filter((e=>!e.hasAttribute("disabled")&&!e.getAttribute("aria-hidden"))):[]}n.onKeyStroke("Escape",(e=>{A.value&&(e.preventDefault(),z())})),n.onKeyStroke("ArrowDown",(t=>{A.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=X(h.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t<e.length-1?e[t+1].focus():e[0].focus()}})))})),n.onKeyStroke("ArrowUp",(t=>{A.value&&Q.value&&(t.preventDefault(),e.nextTick((()=>{if(Q.value){const e=X(h.value);if(0===e.length||!document.activeElement)return;const t=e.indexOf(document.activeElement);t>0?e[t-1].focus():e[e.length-1].focus()}})))})),n.onKeyStroke([" ","Enter"],(e=>{if(A.value&&Q.value){e.preventDefault();document.activeElement.click()}}));const Y=()=>{r(A.value?"beforeExpand":"beforeCollapse")},Z=()=>{r(A.value?"afterExpand":"afterCollapse")};return(t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createVNode(e.unref(q),null,{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default",e.normalizeProps(e.guardReactiveProps({init:j,show:D,hide:z,toggle:R,expanded:e.unref(A),aria:e.unref(I)})))])),_:3}),e.createVNode(e.Transition,e.mergeProps({name:t.transitionName},e.toHandlers({beforeEnter:Y,onAfterLeave:Z})),{default:e.withCtx((()=>[e.withDirectives(e.createElementVNode("div",{ref_key:"floatingEl",ref:h,style:e.normalizeStyle(e.unref(P)),class:e.normalizeClass(e.unref(J))},[i.arrow?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"arrowEl",ref:y,style:e.normalizeStyle(e.unref(C)),class:"vv-dropdown__arrow"},null,4)):e.createCommentVNode("",!0),e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(A)}))),e.createElementVNode("div",e.mergeProps(e.unref(d),{id:e.unref(s),ref_key:"listEl",ref:k,tabindex:e.unref(A)?void 0:-1,role:e.unref(M),"aria-labelledby":e.unref(H),class:"vv-dropdown__list"}),[e.renderSlot(t.$slots,"items",e.normalizeProps(e.guardReactiveProps({role:e.unref(G)})))],16,K),e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps({expanded:e.unref(A)})))],6),[[e.vShow,e.unref(A)]])])),_:3},16,["name"])],64))}});const W=e.defineComponent({name:"VvDropdownItem",setup(t){const{role:l,expanded:o}=e.inject(m,{}),a=e.ref(null);!function({expanded:t}){e.provide(b,{role:e.ref(d.menuitem),expanded:t})}({expanded:o});const r=n.useElementHover(a),{focused:i}=n.useFocus(a),{focused:u}=n.useFocusWithin(a);return e.watch(r,(e=>{e&&(i.value=!0)})),(t,o)=>(e.openBlock(),e.createElementBlock("div",e.mergeProps({role:e.unref(l)},{ref_key:"element",ref:a,class:["vv-dropdown__item",{"focus-visible":e.unref(i)||e.unref(u)}]}),[e.renderSlot(t.$slots,"default")],16))}}),M=["title"],U=e.defineComponent({name:"VvDropdownOption",props:{...k,...S,...E,...V,deselectHintLabel:{type:String},selectHintLabel:{type:String},selectedHintLabel:{type:String}},setup(t){const l=t,{modifiers:o}=e.toRefs(l),n=F("vv-dropdown-option",o,e.computed((()=>({disabled:l.disabled,selected:l.selected,unselectable:l.unselectable&&l.selected})))),a=e.computed((()=>l.selected?l.unselectable?l.deselectHintLabel:l.selectedHintLabel:l.disabled?void 0:l.selectHintLabel));return(t,l)=>(e.openBlock(),e.createBlock(W,{class:e.normalizeClass(e.unref(n)),tabindex:t.disabled?-1:0,"aria-selected":t.selected,"aria-disabled":t.disabled},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"default"),e.createElementVNode("span",{class:"vv-dropdown-option__hint",title:e.unref(a)},[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps({disabled:t.disabled,selected:t.selected,unselectable:t.unselectable})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(a)),1)]))],8,M)])),_:3},8,["class","tabindex","aria-selected","aria-disabled"]))}}),G={class:"vv-dropdown-optgroup",role:"presentation",tabindex:"-1"},J=e.defineComponent({name:"VvDropdownOptgroup",props:{...B},setup(t){const l=t;return(t,o)=>(e.openBlock(),e.createElementBlock("li",G,e.toDisplayString(l.label),1))}});function Q(e,t,l){return l?Y(e,l)===Y(t,l):X(e,t)}function X(e,t){if(e===t)return!0;if(e&&t&&"object"==typeof e&&"object"==typeof t){const l=Array.isArray(e),o=Array.isArray(t);let n,a,r;if(l&&o){if(a=e.length,a!=t.length)return!1;for(n=a;0!=n--;)if(!X(e[n],t[n]))return!1;return!0}if(l!=o)return!1;const i=e instanceof Date,u=t instanceof Date;if(i!=u)return!1;if(i&&u)return e.getTime()==t.getTime();const s=e instanceof RegExp,d=t instanceof RegExp;if(s!=d)return!1;if(s&&d)return e.toString()==t.toString();const c=Object.keys(e);if(a=c.length,a!==Object.keys(t).length)return!1;for(n=a;0!=n--;)if(!Object.prototype.hasOwnProperty.call(t,c[n]))return!1;for(n=a;0!=n--;)if(r=c[n],!X(e[r],t[r]))return!1;return!0}return e!=e&&t!=t}function Y(e,t){if(e&&Object.keys(e).length&&t){if(-1===t.indexOf("."))return e[t];{const l=t.split(".");let o=e;for(let t=0,n=l.length;t<n;++t){if(null==e)return null;o=o[l[t]]}return o}}return null}function Z(e,t){if(null!=e&&t&&t.length)for(const l of t)if(Q(e,l))return!0;return!1}function ee(t){return null==(l=e.unref(t))||""===l||Array.isArray(l)&&0===l.length||!(l instanceof Date)&&"object"==typeof l&&0===Object.keys(l).length;var l}function te(e,t){const l=function(e,t){let l=-1;if(t)for(let o=0;o<t.length;o++)if(Q(t[o],e)){l=o;break}return l}(e,t);return l>-1?t.filter(((e,t)=>t!==l)):t}function le(e){return Array.isArray(e)?e.filter((e=>{return"string"==typeof(t=e)||t instanceof String;var t})).join(" "):e}function oe(t,l){const o=e.computed((()=>le(t.invalidLabel))),n=e.computed((()=>le(t.validLabel))),a=e.computed((()=>t.loadingLabel)),r=e.computed((()=>t.hintLabel)),i=e.computed((()=>Boolean(t.loading&&(l.loading||a.value)))),u=e.computed((()=>!i.value&&Boolean(t.invalid&&(l.invalid||o.value)))),s=e.computed((()=>!i.value&&!u.value&&Boolean(t.valid&&(l.valid||n.value)))),d=e.computed((()=>!i.value&&!u.value&&!s.value&&Boolean(l.hint||r.value))),c=e.computed((()=>u.value||s.value||i.value||d.value)),p=e.computed((()=>({modelValue:t.modelValue,valid:t.valid,invalid:t.invalid,loading:t.loading}))),f=e.defineComponent({name:"HintSlot",props:{tag:{type:String,default:"small"}},setup:()=>({isVisible:c,invalidLabel:o,validLabel:n,loadingLabel:a,hintLabel:r,hasInvalidLabelOrSlot:u,hasValidLabelOrSlot:s,hasLoadingLabelOrSlot:i,hasHintLabelOrSlot:d}),render(){var t,l,o,n,a,r,i,u;if(this.isVisible){let s;return this.hasInvalidLabelOrSlot&&(s="alert"),this.hasValidLabelOrSlot&&(s="status"),this.hasLoadingLabelOrSlot?e.h(this.tag,{role:s},(null==(l=(t=this.$slots).loading)?void 0:l.call(t))??this.loadingLabel):this.hasInvalidLabelOrSlot?e.h(this.tag,{role:s},(null==(n=(o=this.$slots).invalid)?void 0:n.call(o))??this.$slots.invalid??this.invalidLabel):this.hasValidLabelOrSlot?e.h(this.tag,{role:s},(null==(r=(a=this.$slots).valid)?void 0:r.call(a))??this.validLabel):e.h(this.tag,{role:s},(null==(u=(i=this.$slots).hint)?void 0:u.call(i))??this.$slots.hint??this.hintLabel)}return null}});return{hasInvalidLabelOrSlot:u,hasHintLabelOrSlot:d,hasValidLabelOrSlot:s,hasLoadingLabelOrSlot:i,hintSlotScope:p,HintSlot:f}}const ne={..._,...A,...D,...P,...g,...h,...w,...y,...k,...x,...V,...L,...$,...O,...E,...B,multiple:Boolean,required:Boolean,size:[String,Number],modelValue:{type:[String,Number,Boolean,Object,Array],default:void 0},placeholder:String};function ae(t,l){const{focused:o}=n.useFocus(t);return e.watch(o,(o=>{l(o?"focus":"blur",e.unref(t))})),{focused:o}}function re(t,l){const o=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===u.before))),n=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===u.after))),a=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.left))),i=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.right))),s=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.top))),d=e.computed((()=>Boolean((null==t?void 0:t.value)&&l.value===r.bottom)));return{hasIcon:e.computed((()=>"string"==typeof(null==t?void 0:t.value)?{name:null==t?void 0:t.value}:null==t?void 0:t.value)),hasIconLeft:a,hasIconRight:i,hasIconTop:s,hasIconBottom:d,hasIconBefore:o,hasIconAfter:n}}function ie(t){const{options:l,labelKey:o,valueKey:n,disabledKey:a}=e.toRefs(t);return{options:l,getOptionLabel:e=>"object"!=typeof e&&null!==e?e:String("function"==typeof o.value?o.value(e):e[o.value]),getOptionValue:e=>"object"!=typeof e&&null!==e?e:"function"==typeof n.value?n.value(e):e[n.value],getOptionDisabled:e=>("object"==typeof e||null===e)&&("function"==typeof a.value?a.value(e):e[a.value]),getOptionGrouped:e=>"object"!=typeof e&&null!==e?[]:e.options||[]}}const ue=["for"],se={class:"vv-select__wrapper"},de={key:0,class:"vv-select__input-before"},ce={class:"vv-select__inner"},pe=["id"],fe=["disabled","hidden"],ve=["disabled","value"],me=["disabled","label"],be=["disabled","value"],ge={key:1,class:"vv-select__input-after"},he=e.defineComponent({name:"VvSelect",props:ne,emits:["update:modelValue","focus","blur"],setup(t,{emit:l}){const o=t,a=e.useSlots(),r=e.ref(),{HintSlot:i,hasHintLabelOrSlot:u,hasInvalidLabelOrSlot:s,hintSlotScope:d}=oe(o,a),{id:c,modifiers:p,disabled:f,readonly:v,loading:m,icon:b,iconPosition:g,invalid:h,valid:y,floating:k,multiple:S}=e.toRefs(o),B=T(c),x=e.computed((()=>`${B.value}-hint`)),{focused:V}=ae(r,l),w=n.useElementVisibility(r);e.watch(w,(e=>{e&&o.autofocus&&(V.value=!0)}));const{hasIcon:L,hasIconBefore:$,hasIconAfter:P}=re(b,g),O=e.computed((()=>!ee(o.modelValue))),E=e.computed((()=>o.disabled||o.readonly)),C=e.computed((()=>E.value?-1:o.tabindex)),N=e.computed((()=>!0===o.invalid||!0!==o.valid&&void 0)),_=F("vv-select",p,e.computed((()=>({valid:y.value,invalid:h.value,loading:m.value,disabled:f.value,readonly:v.value,"icon-before":$.value,"icon-after":P.value,dirty:O.value,focus:V.value,floating:k.value,multiple:S.value})))),A=e.computed((()=>({name:o.name,tabindex:C.value,disabled:E.value,required:o.required,size:o.size,autocomplete:o.autocomplete,multiple:o.multiple,"aria-invalid":N.value,"aria-describedby":u.value?x.value:void 0,"aria-errormessage":s.value?x.value:void 0}))),D=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue}))),{getOptionLabel:z,getOptionValue:R,getOptionDisabled:j,getOptionGrouped:I}=ie(o),K=e.computed({get:()=>o.modelValue,set:e=>{Array.isArray(e)&&(e=e.filter((e=>void 0!==e))),l("update:modelValue",e)}}),q=e=>"string"!=typeof e&&(e&&e.options&&e.options.length>0);return(t,l)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(e.unref(_))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,for:e.unref(B)},e.toDisplayString(t.label),9,ue)):e.createCommentVNode("",!0),e.createElementVNode("div",se,[t.$slots.before?(e.openBlock(),e.createElementBlock("div",de,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(D))))])):e.createCommentVNode("",!0),e.createElementVNode("div",ce,[e.unref($)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:0,class:"vv-select__icon"},e.unref(L)),null,16)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("select",e.mergeProps({id:e.unref(B),ref_key:"select",ref:r,"onUpdate:modelValue":l[0]||(l[0]=t=>e.isRef(K)?K.value=t:null)},e.unref(A)),[t.placeholder?(e.openBlock(),e.createElementBlock("option",{key:0,value:void 0,disabled:!t.unselectable,hidden:!t.unselectable},e.toDisplayString(t.placeholder),9,fe)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.options,((t,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[q(t)?(e.openBlock(),e.createElementBlock("optgroup",{key:`group-${l}`,disabled:e.unref(j)(t),label:e.unref(z)(t)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(I)(t),((t,o)=>(e.openBlock(),e.createElementBlock("option",{key:`group-${l}-item-${o}`,disabled:e.unref(j)(t),value:e.unref(R)(t)},e.toDisplayString(e.unref(z)(t)),9,be)))),128))],8,me)):(e.openBlock(),e.createElementBlock("option",{key:l,disabled:e.unref(j)(t),value:e.unref(R)(t)},e.toDisplayString(e.unref(z)(t)),9,ve))],64)))),256))],16,pe),[[e.vModelSelect,e.unref(K)]]),e.unref(P)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:1,class:"vv-select__icon vv-select__icon-after"},e.unref(L)),null,16)):e.createCommentVNode("",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",ge,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(D))))])):e.createCommentVNode("",!0)]),e.createVNode(e.unref(i),{id:e.unref(x),class:"vv-select__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(d))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(d))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(d))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(d))))])),key:"3"}:void 0]),1032,["id"])],2))}}),ye={...V,value:[String,Number]},ke=e.defineComponent({name:"VvBadge",props:ye,setup(t){const l=t,{modifiers:o}=e.toRefs(l),n=F("vv-badge",o);return(t,l)=>(e.openBlock(),e.createElementBlock("span",{class:e.normalizeClass(e.unref(n)),role:"status"},[e.renderSlot(t.$slots,"default",{},(()=>[e.createTextVNode(e.toDisplayString(t.value),1)]))],2))}});const Se=["id"],Be=["id","for"],xe=["id","aria-controls","placeholder"],Ve={key:0,class:"vv-select__input-before"},we={class:"vv-select__inner"},Le=["aria-expanded","aria-labelledby","aria-describedby","aria-errormessage","tabindex"],$e=["aria-label","onClick"],Pe={key:1,class:"vv-select__input-after"},Oe={name:"VvCombobox",components:{VvDropdown:q,VvDropdownOption:U,VvDropdownOptgroup:J}};return e.defineComponent({...Oe,props:z,emits:["update:modelValue","change:search","focus","blur"],setup(t,{emit:l}){const o=t,a=e.useSlots(),r=function(t,l,o){const n=j(),a=e.computed((()=>{var e;if(n&&(null==(e=n.defaults.value)?void 0:e[t]))return n.defaults.value[t]}));return e.computed((()=>{if(void 0===a.value)return o;const e=a.value,t=l,n=o;return Object.keys(t).reduce(((l,o)=>{const a=n[o];if(l[o]=a,o in e){if(Array.isArray(t[o])){const n=t[o];n.length&&n[0]===a&&(l[o]=e[o])}if("function"==typeof t[o]&&(0,t[o])()===a&&(l[o]=e[o]),"object"==typeof t[o]){let n=t[o].default;"function"==typeof n&&(n=n()),"object"==typeof n?JSON.stringify(n)===JSON.stringify(a)&&(l[o]=e[o]):n===a&&(l[o]=e[o])}}return l}),{})}))}("VvCombobox",z,o),i=e=>"string"!=typeof e&&(e.options&&e.options.length>0),{HintSlot:u,hasHintLabelOrSlot:s,hasInvalidLabelOrSlot:d,hintSlotScope:p}=oe(o,a),f=e.ref(null),v=e.ref(null),m=e.ref(null),{focused:b}=ae(f,l),{focused:g}=n.useFocusWithin(m);e.watch(b,(e=>{o.autoOpen&&(!e||k.value?e||!k.value||g.value||x():B())})),e.watch(g,(e=>{b.value||e||!k.value||x()}));const h=e.ref(""),y=n.refDebounced(h,Number(o.debounceSearch));e.watch(y,(()=>l("change:search",y.value)));const k=e.ref(!1),S=()=>{o.disabled||o.readonly||(k.value=!k.value)},B=()=>{o.disabled||o.readonly||k.value||(k.value=!0)},x=()=>{o.disabled||o.readonly||!k.value||(k.value=!1)},V=()=>{R.value&&v.value&&v.value.focus()},w=()=>{R.value&&(h.value="")},{id:L,icon:$,iconPosition:P,modifiers:O,disabled:E,readonly:C,loading:N,valid:_,invalid:A,floating:D,searchable:R}=e.toRefs(o),I=T(L),K=e.computed((()=>`${I.value}-hint`)),W=e.computed((()=>`${I.value}-dropdown`)),M=e.computed((()=>`${I.value}-search`)),G=e.computed((()=>`${I.value}-label`)),{hasIcon:X,hasIconBefore:Y,hasIconAfter:le}=re($,P),ne=e.computed((()=>!ee(o.modelValue))),ue=e.computed((()=>E.value||C.value?-1:o.tabindex)),se=F("vv-select",O,e.computed((()=>({disabled:E.value,loading:N.value,readonly:C.value,"icon-before":Boolean(Y.value),"icon-after":Boolean(le.value),valid:_.value,invalid:A.value,dirty:ne.value,focus:b.value,floating:D.value})))),de=e.computed((()=>o.searchable?me.value:o.options)),{getOptionLabel:ce,getOptionValue:pe,getOptionDisabled:fe,getOptionGrouped:ve}=ie(o),me=e.computed((()=>{var e;return null==(e=o.options)?void 0:e.filter((e=>ce(e).toLowerCase().includes(y.value.toLowerCase().trim())))}));function be(e){return Array.isArray(o.modelValue)?Z(e,o.modelValue)||Z(pe(e),o.modelValue):Q(e,o.modelValue)||Q(pe(e),o.modelValue)}const ge=e.computed((()=>{let e=[];Array.isArray(o.modelValue)?e=o.modelValue:o.modelValue&&(e=[o.modelValue]);return o.options.reduce(((e,t)=>i(t)?[...e,...ve(t)]:[...e,t]),[]).filter((t=>i(t)?ve(t).some((t=>e.includes(pe(t)))):e.includes(pe(t))))})),ye=e.computed((()=>ge.value.map((e=>ce(e))).join(o.separator))),Oe=()=>{o.autoOpen?B():S()},Ee=e=>{var t;if(o.disabled||o.readonly)return;const n=pe(e);let a=n;if(o.multiple)if(Array.isArray(o.modelValue)){const e=Number(o.maxValues);if(void 0!==o.maxValues&&e>=0&&(null==(t=o.modelValue)?void 0:t.length)>=e&&!Z(n,o.modelValue))return;a=Z(n,o.modelValue)?te(n,o.modelValue):[...o.modelValue,n]}else a=[n];else o.keepOpen||x(),o.unselectable&&n===o.modelValue&&(a=void 0);l("update:modelValue",a)},Ce=e.computed((()=>({id:I.value,name:o.name,tabindex:ue.value,valid:_.value,validLabel:r.value.validLabel,invalid:A.value,invalidLabel:r.value.invalidLabel,hintLabel:r.value.hintLabel,loading:N.value,loadingLabel:r.value.loadingLabel,disabled:E.value,readonly:C.value,modifiers:o.modifiers,options:de.value,labelKey:o.labelKey,valueKey:o.valueKey,icon:o.icon,iconPosition:o.iconPosition,floating:o.floating,unselectable:o.unselectable,multiple:o.multiple,label:o.label,placeholder:o.placeholder,modelValue:o.modelValue}))),Ne=e.computed((()=>({id:W.value,reference:m.value,placement:o.placement,strategy:o.strategy,transitionName:o.transitionName,offset:o.offset,shift:o.shift,flip:o.flip,autoPlacement:o.autoPlacement,arrow:o.arrow,autofocusFirst:!R.value&&o.autofocusFirst,triggerWidth:o.triggerWidth,modifiers:o.dropdownModifiers}))),_e=e.computed((()=>({valid:o.valid,invalid:o.invalid,modelValue:o.modelValue})));return n.onKeyStroke([" ","Enter"],(e=>{o.autoOpen||!k.value&&b.value&&(e.preventDefault(),e.stopImmediatePropagation(),S())})),(t,o)=>t.native?(e.openBlock(),e.createBlock(he,e.mergeProps({key:1},e.unref(Ce),{"onUpdate:modelValue":o[2]||(o[2]=e=>l("update:modelValue",e))}),null,16)):(e.openBlock(),e.createElementBlock("div",{key:0,id:e.unref(I),class:e.normalizeClass(e.unref(se))},[t.label?(e.openBlock(),e.createElementBlock("label",{key:0,id:e.unref(G),for:e.unref(R)?e.unref(M):void 0},e.toDisplayString(t.label),9,Be)):e.createCommentVNode("",!0),e.createElementVNode("div",{ref_key:"wrapperEl",ref:m,class:"vv-select__wrapper"},[e.createVNode(q,e.mergeProps({modelValue:e.unref(k),"onUpdate:modelValue":o[1]||(o[1]=t=>e.isRef(k)?k.value=t:null)},e.unref(Ne),{role:e.unref(c).listbox,onAfterExpand:V,onAfterCollapse:w}),e.createSlots({default:e.withCtx((({aria:l})=>[t.$slots.before?(e.openBlock(),e.createElementBlock("div",Ve,[e.renderSlot(t.$slots,"before",e.normalizeProps(e.guardReactiveProps(e.unref(_e))))])):e.createCommentVNode("",!0),e.createElementVNode("div",we,[e.unref(Y)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:0,class:"vv-select__icon"},e.unref(X)),null,16)):e.createCommentVNode("",!0),e.createElementVNode("div",e.mergeProps({ref_key:"inputEl",ref:f},l,{class:"vv-select__input",role:"combobox","aria-expanded":e.unref(k),"aria-labelledby":e.unref(G),"aria-describedby":e.unref(s)?e.unref(K):void 0,"aria-errormessage":e.unref(d)?e.unref(K):void 0,tabindex:e.unref(ue),onClickPassive:Oe}),[e.renderSlot(t.$slots,"value",e.normalizeProps(e.guardReactiveProps({selectedOptions:e.unref(ge),onInput:Ee})),(()=>[e.unref(ye)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[t.badges?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(e.unref(ge),((l,o)=>(e.openBlock(),e.createBlock(ke,{key:o,modifiers:t.badgeModifiers,class:"vv-select__badge"},{default:e.withCtx((()=>[e.createTextVNode(e.toDisplayString(e.unref(ce)(l))+" ",1),!t.unselectable||e.unref(C)||e.unref(E)?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("button",{key:0,"aria-label":e.unref(r).deselectActionLabel,onClick:e.withModifiers((e=>Ee(l)),["stop"])},[e.createVNode(H,{name:"close"})],8,$e))])),_:2},1032,["modifiers"])))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(e.unref(ye)),1)],64))],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(t.placeholder),1)],64))]))],16,Le),e.unref(le)?(e.openBlock(),e.createBlock(H,e.mergeProps({key:1,class:"vv-select__icon vv-select__icon-after"},e.unref(X)),null,16)):e.createCommentVNode("",!0)]),t.$slots.after?(e.openBlock(),e.createElementBlock("div",Pe,[e.renderSlot(t.$slots,"after",e.normalizeProps(e.guardReactiveProps(e.unref(_e))))])):e.createCommentVNode("",!0)])),items:e.withCtx((()=>[e.unref(me).length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(e.unref(me),((l,o)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:o},[i(l)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createVNode(J,{label:e.unref(ce)(l)},null,8,["label"]),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(ve)(l),((o,n)=>(e.openBlock(),e.createBlock(U,e.mergeProps({disabled:e.unref(fe)(o),selected:be(o),unselectable:t.unselectable,deselectHintLabel:e.unref(r).deselectHintLabel,selectHintLabel:e.unref(r).selectHintLabel,selectedHintLabel:e.unref(r).selectedHintLabel},{key:n,class:"vv-dropdown-option",onClickPassive:e=>Ee(o)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(ge),selected:be(o),disabled:e.unref(fe)(o)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(ce)(o)),1)]))])),_:2},1040,["onClickPassive"])))),128))],64)):(e.openBlock(),e.createBlock(U,e.mergeProps({key:1},{disabled:e.unref(fe)(l),selected:be(l),unselectable:t.unselectable,deselectHintLabel:e.unref(r).deselectHintLabel,selectHintLabel:e.unref(r).selectHintLabel,selectedHintLabel:e.unref(r).selectedHintLabel},{class:"vv-dropdown-option",onClickPassive:e=>Ee(l)}),{default:e.withCtx((()=>[e.renderSlot(t.$slots,"option",e.normalizeProps(e.guardReactiveProps({option:l,selectedOptions:e.unref(ge),selected:be(l),disabled:e.unref(fe)(l)})),(()=>[e.createTextVNode(e.toDisplayString(e.unref(ce)(l)),1)]))])),_:2},1040,["onClickPassive"]))],64)))),128)):t.options.length?(e.openBlock(),e.createBlock(U,{key:2,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-results",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(r).noResultsLabel),1)]))])),_:3})):(e.openBlock(),e.createBlock(U,{key:1,modifiers:"inert"},{default:e.withCtx((()=>[e.renderSlot(t.$slots,"no-options",{},(()=>[e.createTextVNode(e.toDisplayString(e.unref(r).noOptionsLabel),1)]))])),_:3}))])),_:2},[e.unref(R)||t.$slots["dropdown::before"]?{name:"before",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::before"),e.unref(R)?e.withDirectives((e.openBlock(),e.createElementBlock("input",{key:0,id:e.unref(M),ref_key:"inputSearchEl",ref:v,"onUpdate:modelValue":o[0]||(o[0]=t=>e.isRef(h)?h.value=t:null),"aria-autocomplete":"list","aria-controls":e.unref(W),autocomplete:"off",spellcheck:"false",type:"search",class:"vv-dropdown__search",placeholder:e.unref(r).searchPlaceholder},null,8,xe)),[[e.vShow,e.unref(k)],[e.vModelText,e.unref(h)]]):e.createCommentVNode("",!0)])),key:"0"}:void 0,t.$slots["dropdown::after"]?{name:"after",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"dropdown::after")])),key:"1"}:void 0]),1040,["modelValue","role"])],512),e.createVNode(e.unref(u),{id:e.unref(K),class:"vv-select__hint"},e.createSlots({_:2},[t.$slots.hint?{name:"hint",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"hint",e.normalizeProps(e.guardReactiveProps(e.unref(p))))])),key:"0"}:void 0,t.$slots.loading?{name:"loading",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"loading",e.normalizeProps(e.guardReactiveProps(e.unref(p))))])),key:"1"}:void 0,t.$slots.valid?{name:"valid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"valid",e.normalizeProps(e.guardReactiveProps(e.unref(p))))])),key:"2"}:void 0,t.$slots.invalid?{name:"invalid",fn:e.withCtx((()=>[e.renderSlot(t.$slots,"invalid",e.normalizeProps(e.guardReactiveProps(e.unref(p))))])),key:"3"}:void 0]),1032,["id"])],10,Se))}})}));
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { Option } from '../../types/generic';
|
|
2
2
|
declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
3
3
|
modelValue: {
|
|
4
|
-
type: (
|
|
4
|
+
type: (ObjectConstructor | ArrayConstructor | StringConstructor | BooleanConstructor | NumberConstructor)[];
|
|
5
5
|
default: undefined;
|
|
6
6
|
};
|
|
7
7
|
noResultsLabel: {
|
|
@@ -57,8 +57,14 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
57
57
|
dropdownModifiers: {
|
|
58
58
|
type: globalThis.PropType<string | string[]>;
|
|
59
59
|
};
|
|
60
|
-
autoOpen:
|
|
61
|
-
|
|
60
|
+
autoOpen: {
|
|
61
|
+
type: BooleanConstructor;
|
|
62
|
+
default: boolean;
|
|
63
|
+
};
|
|
64
|
+
keepOpen: {
|
|
65
|
+
type: BooleanConstructor;
|
|
66
|
+
default: boolean;
|
|
67
|
+
};
|
|
62
68
|
label: (StringConstructor | NumberConstructor)[];
|
|
63
69
|
placement: {
|
|
64
70
|
type: globalThis.PropType<"left" | "right" | "top" | "bottom" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "left-start" | "left-end" | "right-start" | "right-end">;
|
|
@@ -148,7 +154,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
148
154
|
};
|
|
149
155
|
floating: BooleanConstructor;
|
|
150
156
|
icon: {
|
|
151
|
-
type: (
|
|
157
|
+
type: (ObjectConstructor | StringConstructor)[];
|
|
152
158
|
};
|
|
153
159
|
iconPosition: {
|
|
154
160
|
type: globalThis.PropType<"before" | "after">;
|
|
@@ -184,9 +190,9 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
184
190
|
default: string;
|
|
185
191
|
};
|
|
186
192
|
invalid: BooleanConstructor;
|
|
187
|
-
invalidLabel: (
|
|
193
|
+
invalidLabel: (ArrayConstructor | StringConstructor)[];
|
|
188
194
|
valid: BooleanConstructor;
|
|
189
|
-
validLabel: (
|
|
195
|
+
validLabel: (ArrayConstructor | StringConstructor)[];
|
|
190
196
|
tabindex: {
|
|
191
197
|
type: (StringConstructor | NumberConstructor)[];
|
|
192
198
|
default: number;
|
|
@@ -198,7 +204,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
198
204
|
id: (StringConstructor | NumberConstructor)[];
|
|
199
205
|
}, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, string[], string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
200
206
|
modelValue: {
|
|
201
|
-
type: (
|
|
207
|
+
type: (ObjectConstructor | ArrayConstructor | StringConstructor | BooleanConstructor | NumberConstructor)[];
|
|
202
208
|
default: undefined;
|
|
203
209
|
};
|
|
204
210
|
noResultsLabel: {
|
|
@@ -254,8 +260,14 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
254
260
|
dropdownModifiers: {
|
|
255
261
|
type: globalThis.PropType<string | string[]>;
|
|
256
262
|
};
|
|
257
|
-
autoOpen:
|
|
258
|
-
|
|
263
|
+
autoOpen: {
|
|
264
|
+
type: BooleanConstructor;
|
|
265
|
+
default: boolean;
|
|
266
|
+
};
|
|
267
|
+
keepOpen: {
|
|
268
|
+
type: BooleanConstructor;
|
|
269
|
+
default: boolean;
|
|
270
|
+
};
|
|
259
271
|
label: (StringConstructor | NumberConstructor)[];
|
|
260
272
|
placement: {
|
|
261
273
|
type: globalThis.PropType<"left" | "right" | "top" | "bottom" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "left-start" | "left-end" | "right-start" | "right-end">;
|
|
@@ -345,7 +357,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
345
357
|
};
|
|
346
358
|
floating: BooleanConstructor;
|
|
347
359
|
icon: {
|
|
348
|
-
type: (
|
|
360
|
+
type: (ObjectConstructor | StringConstructor)[];
|
|
349
361
|
};
|
|
350
362
|
iconPosition: {
|
|
351
363
|
type: globalThis.PropType<"before" | "after">;
|
|
@@ -381,9 +393,9 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
381
393
|
default: string;
|
|
382
394
|
};
|
|
383
395
|
invalid: BooleanConstructor;
|
|
384
|
-
invalidLabel: (
|
|
396
|
+
invalidLabel: (ArrayConstructor | StringConstructor)[];
|
|
385
397
|
valid: BooleanConstructor;
|
|
386
|
-
validLabel: (
|
|
398
|
+
validLabel: (ArrayConstructor | StringConstructor)[];
|
|
387
399
|
tabindex: {
|
|
388
400
|
type: (StringConstructor | NumberConstructor)[];
|
|
389
401
|
default: number;
|
|
@@ -396,8 +408,6 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
396
408
|
}>> & {
|
|
397
409
|
[x: `on${Capitalize<string>}`]: ((...args: any[]) => any) | undefined;
|
|
398
410
|
}, {
|
|
399
|
-
modelValue: string | number | boolean | unknown[] | Record<string, any>;
|
|
400
|
-
disabled: boolean;
|
|
401
411
|
shift: boolean | Partial<import("@floating-ui/core").ShiftOptions & {
|
|
402
412
|
rootBoundary: import("@floating-ui/core").RootBoundary;
|
|
403
413
|
elementContext: import("@floating-ui/core").ElementContext;
|
|
@@ -405,8 +415,12 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
405
415
|
padding: import("@floating-ui/core").Padding;
|
|
406
416
|
boundary: import("@floating-ui/dom").Boundary;
|
|
407
417
|
}> | undefined;
|
|
418
|
+
disabled: boolean;
|
|
408
419
|
options: (string | Option)[];
|
|
409
420
|
floating: boolean;
|
|
421
|
+
modelValue: string | number | boolean | unknown[] | Record<string, any>;
|
|
422
|
+
tabindex: string | number;
|
|
423
|
+
unselectable: boolean;
|
|
410
424
|
flip: boolean | Partial<import("@floating-ui/core").FlipOptions & {
|
|
411
425
|
rootBoundary: import("@floating-ui/core").RootBoundary;
|
|
412
426
|
elementContext: import("@floating-ui/core").ElementContext;
|
|
@@ -417,19 +431,11 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
417
431
|
iconPosition: "before" | "after";
|
|
418
432
|
loading: boolean;
|
|
419
433
|
loadingLabel: string;
|
|
420
|
-
unselectable: boolean;
|
|
421
434
|
multiple: boolean;
|
|
422
435
|
readonly: boolean;
|
|
423
436
|
hintLabel: string;
|
|
424
437
|
invalid: boolean;
|
|
425
438
|
valid: boolean;
|
|
426
|
-
tabindex: string | number;
|
|
427
|
-
labelKey: string | Function;
|
|
428
|
-
valueKey: string | Function;
|
|
429
|
-
disabledKey: string | Function;
|
|
430
|
-
placement: "left" | "right" | "top" | "bottom" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "left-start" | "left-end" | "right-start" | "right-end";
|
|
431
|
-
strategy: "fixed" | "absolute";
|
|
432
|
-
offset: string | import("@floating-ui/core").OffsetOptions | undefined;
|
|
433
439
|
size: boolean | Partial<{
|
|
434
440
|
apply: (args: {
|
|
435
441
|
x: number;
|
|
@@ -452,6 +458,12 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
452
458
|
padding: import("@floating-ui/core").Padding;
|
|
453
459
|
boundary: import("@floating-ui/dom").Boundary;
|
|
454
460
|
}> | undefined;
|
|
461
|
+
labelKey: string | Function;
|
|
462
|
+
valueKey: string | Function;
|
|
463
|
+
disabledKey: string | Function;
|
|
464
|
+
placement: "left" | "right" | "top" | "bottom" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "left-start" | "left-end" | "right-start" | "right-end";
|
|
465
|
+
strategy: "fixed" | "absolute";
|
|
466
|
+
offset: string | import("@floating-ui/core").OffsetOptions | undefined;
|
|
455
467
|
autoPlacement: boolean | Partial<import("@floating-ui/core").AutoPlacementOptions & {
|
|
456
468
|
rootBoundary: import("@floating-ui/core").RootBoundary;
|
|
457
469
|
elementContext: import("@floating-ui/core").ElementContext;
|
|
@@ -460,7 +472,7 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
460
472
|
boundary: import("@floating-ui/dom").Boundary;
|
|
461
473
|
}> | undefined;
|
|
462
474
|
arrow: boolean;
|
|
463
|
-
|
|
475
|
+
keepOpen: boolean;
|
|
464
476
|
autofocusFirst: boolean;
|
|
465
477
|
triggerWidth: boolean;
|
|
466
478
|
deselectHintLabel: string;
|
|
@@ -477,31 +489,55 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
|
|
|
477
489
|
badges: boolean;
|
|
478
490
|
badgeModifiers: string | string[];
|
|
479
491
|
autoOpen: boolean;
|
|
480
|
-
}>, {
|
|
481
|
-
|
|
482
|
-
before
|
|
492
|
+
}, {}>, {
|
|
493
|
+
"dropdown::before"?(_: {}): any;
|
|
494
|
+
before?(_: {
|
|
483
495
|
valid: boolean;
|
|
484
496
|
invalid: boolean;
|
|
485
497
|
modelValue: string | number | boolean | unknown[] | Record<string, any> | undefined;
|
|
486
|
-
})
|
|
487
|
-
value
|
|
498
|
+
}): any;
|
|
499
|
+
value?(_: {
|
|
488
500
|
selectedOptions: (string | Option)[];
|
|
489
501
|
onInput: (option: string | Option) => void;
|
|
490
|
-
})
|
|
491
|
-
after
|
|
502
|
+
}): any;
|
|
503
|
+
after?(_: {
|
|
492
504
|
valid: boolean;
|
|
493
505
|
invalid: boolean;
|
|
494
506
|
modelValue: string | number | boolean | unknown[] | Record<string, any> | undefined;
|
|
495
|
-
})
|
|
496
|
-
option
|
|
507
|
+
}): any;
|
|
508
|
+
option?(_: {
|
|
497
509
|
option: string | Option;
|
|
498
510
|
selectedOptions: (string | Option)[];
|
|
499
511
|
selected: boolean;
|
|
500
|
-
disabled:
|
|
501
|
-
})
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
512
|
+
disabled: boolean;
|
|
513
|
+
}): any;
|
|
514
|
+
"no-options"?(_: {}): any;
|
|
515
|
+
"no-results"?(_: {}): any;
|
|
516
|
+
"dropdown::after"?(_: {}): any;
|
|
517
|
+
hint?(_: {
|
|
518
|
+
modelValue: any;
|
|
519
|
+
valid: boolean;
|
|
520
|
+
invalid: boolean;
|
|
521
|
+
loading: boolean;
|
|
522
|
+
}): any;
|
|
523
|
+
loading?(_: {
|
|
524
|
+
modelValue: any;
|
|
525
|
+
valid: boolean;
|
|
526
|
+
invalid: boolean;
|
|
527
|
+
loading: boolean;
|
|
528
|
+
}): any;
|
|
529
|
+
valid?(_: {
|
|
530
|
+
modelValue: any;
|
|
531
|
+
valid: boolean;
|
|
532
|
+
invalid: boolean;
|
|
533
|
+
loading: boolean;
|
|
534
|
+
}): any;
|
|
535
|
+
invalid?(_: {
|
|
536
|
+
modelValue: any;
|
|
537
|
+
valid: boolean;
|
|
538
|
+
invalid: boolean;
|
|
539
|
+
loading: boolean;
|
|
540
|
+
}): any;
|
|
505
541
|
}>;
|
|
506
542
|
export default _default;
|
|
507
543
|
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
@@ -5,7 +5,7 @@ export declare const VvComboboxProps: {
|
|
|
5
5
|
* modelValue can be a string, number, boolean, object or array of string, number, boolean, object
|
|
6
6
|
*/
|
|
7
7
|
modelValue: {
|
|
8
|
-
type: (
|
|
8
|
+
type: (ObjectConstructor | ArrayConstructor | StringConstructor | BooleanConstructor | NumberConstructor)[];
|
|
9
9
|
default: undefined;
|
|
10
10
|
};
|
|
11
11
|
/**
|
|
@@ -118,11 +118,17 @@ export declare const VvComboboxProps: {
|
|
|
118
118
|
/**
|
|
119
119
|
* Open dropdown on focus
|
|
120
120
|
*/
|
|
121
|
-
autoOpen:
|
|
121
|
+
autoOpen: {
|
|
122
|
+
type: BooleanConstructor;
|
|
123
|
+
default: boolean;
|
|
124
|
+
};
|
|
122
125
|
/**
|
|
123
|
-
*
|
|
126
|
+
* Keep open dropdown on single select
|
|
124
127
|
*/
|
|
125
|
-
|
|
128
|
+
keepOpen: {
|
|
129
|
+
type: BooleanConstructor;
|
|
130
|
+
default: boolean;
|
|
131
|
+
};
|
|
126
132
|
label: (StringConstructor | NumberConstructor)[];
|
|
127
133
|
placement: {
|
|
128
134
|
type: PropType<"left" | "right" | "top" | "bottom" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "left-start" | "left-end" | "right-start" | "right-end">;
|
|
@@ -212,7 +218,7 @@ export declare const VvComboboxProps: {
|
|
|
212
218
|
};
|
|
213
219
|
floating: BooleanConstructor;
|
|
214
220
|
icon: {
|
|
215
|
-
type: (
|
|
221
|
+
type: (ObjectConstructor | StringConstructor)[];
|
|
216
222
|
};
|
|
217
223
|
iconPosition: {
|
|
218
224
|
type: PropType<"before" | "after">;
|
|
@@ -250,9 +256,9 @@ export declare const VvComboboxProps: {
|
|
|
250
256
|
default: string;
|
|
251
257
|
};
|
|
252
258
|
invalid: BooleanConstructor;
|
|
253
|
-
invalidLabel: (
|
|
259
|
+
invalidLabel: (ArrayConstructor | StringConstructor)[];
|
|
254
260
|
valid: BooleanConstructor;
|
|
255
|
-
validLabel: (
|
|
261
|
+
validLabel: (ArrayConstructor | StringConstructor)[];
|
|
256
262
|
tabindex: {
|
|
257
263
|
type: (StringConstructor | NumberConstructor)[];
|
|
258
264
|
default: number;
|
|
@@ -166,6 +166,12 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
|
|
|
166
166
|
props: VvIconProps,
|
|
167
167
|
setup(__props) {
|
|
168
168
|
const props = __props;
|
|
169
|
+
const hasRotate = computed(() => {
|
|
170
|
+
if (typeof props.rotate === "string") {
|
|
171
|
+
return parseFloat(props.rotate);
|
|
172
|
+
}
|
|
173
|
+
return props.rotate;
|
|
174
|
+
});
|
|
169
175
|
const show = ref(true);
|
|
170
176
|
const volver = useVolver();
|
|
171
177
|
const { modifiers } = toRefs(props);
|
|
@@ -174,25 +180,24 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
|
|
|
174
180
|
return props.provider || (volver == null ? void 0 : volver.iconsProvider);
|
|
175
181
|
});
|
|
176
182
|
const icon = computed(() => {
|
|
177
|
-
const
|
|
178
|
-
const iconName = `@${provider.value}:${props.prefix}:${
|
|
179
|
-
if (iconExists(
|
|
180
|
-
return _name;
|
|
181
|
-
} else if (iconExists(iconName)) {
|
|
183
|
+
const name = props.name ?? "";
|
|
184
|
+
const iconName = `@${provider.value}:${props.prefix}:${name}`;
|
|
185
|
+
if (iconExists(iconName)) {
|
|
182
186
|
return iconName;
|
|
183
|
-
} else {
|
|
184
|
-
return (volver == null ? void 0 : volver.iconsCollections.find(
|
|
185
|
-
(iconsCollection) => {
|
|
186
|
-
const icon2 = `@${provider.value}:${iconsCollection.prefix}:${_name}`;
|
|
187
|
-
if (iconExists(icon2)) {
|
|
188
|
-
return icon2;
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
)) || _name;
|
|
192
187
|
}
|
|
188
|
+
const iconsCollection = volver == null ? void 0 : volver.iconsCollections.find(
|
|
189
|
+
(iconsCollection2) => {
|
|
190
|
+
const icon2 = `@${provider.value}:${iconsCollection2.prefix}:${name}`;
|
|
191
|
+
return iconExists(icon2);
|
|
192
|
+
}
|
|
193
|
+
);
|
|
194
|
+
if (iconsCollection) {
|
|
195
|
+
return `@${provider.value}:${iconsCollection.prefix}:${name}`;
|
|
196
|
+
}
|
|
197
|
+
return name;
|
|
193
198
|
});
|
|
194
199
|
function getSvgContent(svg) {
|
|
195
|
-
let dom
|
|
200
|
+
let dom;
|
|
196
201
|
if (typeof window === "undefined") {
|
|
197
202
|
const { JSDOM } = require("jsdom");
|
|
198
203
|
dom = new JSDOM().window;
|
|
@@ -223,12 +228,13 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
|
|
|
223
228
|
show.value = true;
|
|
224
229
|
}
|
|
225
230
|
}).catch((e) => {
|
|
226
|
-
throw new Error(`
|
|
231
|
+
throw new Error(`Error during fetch icon: ${e == null ? void 0 : e.message}`);
|
|
227
232
|
});
|
|
228
|
-
} else if (props.svg) {
|
|
229
|
-
addIconFromSvg(props.svg);
|
|
230
233
|
}
|
|
231
234
|
}
|
|
235
|
+
if (props.svg) {
|
|
236
|
+
addIconFromSvg(props.svg);
|
|
237
|
+
}
|
|
232
238
|
return (_ctx, _cache) => {
|
|
233
239
|
return unref(show) ? (openBlock(), createBlock(unref(Icon), mergeProps({
|
|
234
240
|
key: 0,
|
|
@@ -240,7 +246,7 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
|
|
|
240
246
|
horizontalFlip: _ctx.horizontalFlip,
|
|
241
247
|
verticalFlip: _ctx.verticalFlip,
|
|
242
248
|
flip: _ctx.flip,
|
|
243
|
-
rotate:
|
|
249
|
+
rotate: unref(hasRotate),
|
|
244
250
|
color: _ctx.color,
|
|
245
251
|
onLoad: _ctx.onLoad,
|
|
246
252
|
icon: unref(icon)
|
|
@@ -397,11 +403,11 @@ const IdProps = {
|
|
|
397
403
|
default: false
|
|
398
404
|
},
|
|
399
405
|
/**
|
|
400
|
-
*
|
|
406
|
+
* Keep open dropdown on click outside
|
|
401
407
|
*/
|
|
402
|
-
|
|
408
|
+
keepOpen: {
|
|
403
409
|
type: Boolean,
|
|
404
|
-
default:
|
|
410
|
+
default: false
|
|
405
411
|
},
|
|
406
412
|
/**
|
|
407
413
|
* Autofocus first item on dropdown open
|
|
@@ -455,9 +461,9 @@ const VvDialogProps = {
|
|
|
455
461
|
*/
|
|
456
462
|
size: String,
|
|
457
463
|
/**
|
|
458
|
-
*
|
|
464
|
+
* Keep open dialog on click outside
|
|
459
465
|
*/
|
|
460
|
-
|
|
466
|
+
keepOpen: { type: Boolean, default: false }
|
|
461
467
|
};
|
|
462
468
|
const _hoisted_1 = {
|
|
463
469
|
key: 0,
|
|
@@ -475,8 +481,9 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
475
481
|
...__default__,
|
|
476
482
|
props: VvDialogProps,
|
|
477
483
|
emits: VvDialogEvents,
|
|
478
|
-
setup(__props, { expose, emit }) {
|
|
484
|
+
setup(__props, { expose: __expose, emit }) {
|
|
479
485
|
const props = __props;
|
|
486
|
+
const dialogEl = ref();
|
|
480
487
|
const localModelValue = ref(false);
|
|
481
488
|
const modelValue = computed({
|
|
482
489
|
get() {
|
|
@@ -489,13 +496,11 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
489
496
|
emit("update:modelValue", value);
|
|
490
497
|
}
|
|
491
498
|
});
|
|
492
|
-
const htmlAttrIsOpen = ref(true);
|
|
493
499
|
const modalWrapper = ref(null);
|
|
494
500
|
const dialogAttrs = computed(() => {
|
|
495
501
|
const { id } = props;
|
|
496
502
|
return {
|
|
497
|
-
id
|
|
498
|
-
open: htmlAttrIsOpen.value
|
|
503
|
+
id
|
|
499
504
|
};
|
|
500
505
|
});
|
|
501
506
|
const dialogClass = computed(() => {
|
|
@@ -507,16 +512,18 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
507
512
|
const transitioName = computed(() => `vv-dialog--${props.transition}`);
|
|
508
513
|
const dialogTransitionHandlers = {
|
|
509
514
|
"before-enter": () => {
|
|
510
|
-
|
|
515
|
+
var _a;
|
|
516
|
+
(_a = dialogEl.value) == null ? void 0 : _a.showModal();
|
|
511
517
|
emit("open");
|
|
512
518
|
},
|
|
513
519
|
"after-leave": () => {
|
|
514
|
-
|
|
520
|
+
var _a;
|
|
521
|
+
(_a = dialogEl.value) == null ? void 0 : _a.close();
|
|
515
522
|
emit("close");
|
|
516
523
|
}
|
|
517
524
|
};
|
|
518
525
|
onClickOutside(modalWrapper, () => {
|
|
519
|
-
if (props.
|
|
526
|
+
if (!props.keepOpen) {
|
|
520
527
|
modelValue.value = false;
|
|
521
528
|
}
|
|
522
529
|
});
|
|
@@ -526,7 +533,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
526
533
|
function open() {
|
|
527
534
|
modelValue.value = true;
|
|
528
535
|
}
|
|
529
|
-
|
|
536
|
+
__expose({ close, open });
|
|
530
537
|
onKeyStroke("Escape", (e) => {
|
|
531
538
|
if (modelValue.value) {
|
|
532
539
|
e.preventDefault();
|
|
@@ -536,7 +543,11 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
536
543
|
return (_ctx, _cache) => {
|
|
537
544
|
return openBlock(), createBlock(Transition, mergeProps({ name: unref(transitioName) }, toHandlers(dialogTransitionHandlers)), {
|
|
538
545
|
default: withCtx(() => [
|
|
539
|
-
withDirectives(createElementVNode("dialog", mergeProps(unref(dialogAttrs), {
|
|
546
|
+
withDirectives(createElementVNode("dialog", mergeProps(unref(dialogAttrs), {
|
|
547
|
+
ref_key: "dialogEl",
|
|
548
|
+
ref: dialogEl,
|
|
549
|
+
class: unref(dialogClass)
|
|
550
|
+
}), [
|
|
540
551
|
createElementVNode("article", {
|
|
541
552
|
ref_key: "modalWrapper",
|
|
542
553
|
ref: modalWrapper,
|