vuetify 3.2.4 → 3.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/_component-variables-labs.sass +1 -0
- package/dist/json/attributes.json +2503 -2151
- package/dist/json/importMap-labs.json +12 -4
- package/dist/json/importMap.json +28 -28
- package/dist/json/tags.json +107 -9
- package/dist/json/web-types.json +10785 -7110
- package/dist/vuetify-labs.css +263 -153
- package/dist/vuetify-labs.d.ts +35870 -16257
- package/dist/vuetify-labs.esm.js +1466 -934
- package/dist/vuetify-labs.esm.js.map +1 -1
- package/dist/vuetify-labs.js +1465 -933
- package/dist/vuetify-labs.min.css +2 -2
- package/dist/vuetify.css +246 -168
- package/dist/vuetify.d.ts +27883 -14061
- package/dist/vuetify.esm.js +477 -300
- package/dist/vuetify.esm.js.map +1 -1
- package/dist/vuetify.js +476 -299
- package/dist/vuetify.js.map +1 -1
- package/dist/vuetify.min.css +2 -2
- package/dist/vuetify.min.js +811 -806
- package/dist/vuetify.min.js.map +1 -1
- package/lib/blueprints/{index.d.ts → index.d.mts} +5 -1
- package/lib/blueprints/{md1.d.ts → md1.d.mts} +5 -1
- package/lib/blueprints/{md2.d.ts → md2.d.mts} +5 -1
- package/lib/blueprints/{md3.d.ts → md3.d.mts} +5 -1
- package/lib/components/VAlert/VAlert.mjs.map +1 -1
- package/lib/components/VAlert/{index.d.ts → index.d.mts} +284 -69
- package/lib/components/VApp/{index.d.ts → index.d.mts} +80 -19
- package/lib/components/VAppBar/{index.d.ts → index.d.mts} +391 -119
- package/lib/components/VAutocomplete/VAutocomplete.css +15 -9
- package/lib/components/VAutocomplete/VAutocomplete.mjs +82 -34
- package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
- package/lib/components/VAutocomplete/VAutocomplete.sass +15 -11
- package/lib/components/VAutocomplete/index.d.mts +2048 -0
- package/lib/components/VAvatar/{index.d.ts → index.d.mts} +85 -30
- package/lib/components/VBadge/_variables.scss +1 -1
- package/lib/components/VBadge/{index.d.ts → index.d.mts} +105 -42
- package/lib/components/VBanner/{index.d.ts → index.d.mts} +282 -63
- package/lib/components/VBottomNavigation/{index.d.ts → index.d.mts} +93 -45
- package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +1 -1
- package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
- package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs +1 -1
- package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs.map +1 -1
- package/lib/components/VBreadcrumbs/{index.d.ts → index.d.mts} +348 -212
- package/lib/components/VBtn/{index.d.ts → index.d.mts} +139 -53
- package/lib/components/VBtnGroup/{index.d.ts → index.d.mts} +84 -27
- package/lib/components/VBtnToggle/{index.d.ts → index.d.mts} +88 -35
- package/lib/components/VCalendar/util/props.mjs.map +1 -1
- package/lib/components/VCard/VCard.mjs.map +1 -1
- package/lib/components/VCard/{index.d.ts → index.d.mts} +957 -419
- package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
- package/lib/components/VCarousel/{index.d.ts → index.d.mts} +616 -111
- package/lib/components/VCheckbox/VCheckboxBtn.mjs +3 -3
- package/lib/components/VCheckbox/VCheckboxBtn.mjs.map +1 -1
- package/lib/components/VCheckbox/{index.d.ts → index.d.mts} +408 -141
- package/lib/components/VChip/VChip.css +4 -2
- package/lib/components/VChip/VChip.mjs.map +1 -1
- package/lib/components/VChip/VChip.sass +3 -2
- package/lib/components/VChip/{index.d.ts → index.d.mts} +376 -85
- package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
- package/lib/components/VChipGroup/index.d.mts +470 -0
- package/lib/components/VCode/{index.d.ts → index.d.mts} +78 -17
- package/lib/components/VColorPicker/VColorPicker.mjs +9 -4
- package/lib/components/VColorPicker/VColorPicker.mjs.map +1 -1
- package/lib/components/VColorPicker/VColorPickerEdit.mjs.map +1 -1
- package/lib/components/VColorPicker/VColorPickerSwatches.mjs +5 -4
- package/lib/components/VColorPicker/VColorPickerSwatches.mjs.map +1 -1
- package/lib/components/VColorPicker/{index.d.ts → index.d.mts} +241 -109
- package/lib/components/VColorPicker/util/index.mjs +2 -22
- package/lib/components/VColorPicker/util/index.mjs.map +1 -1
- package/lib/components/VCombobox/VCombobox.css +15 -9
- package/lib/components/VCombobox/VCombobox.mjs +82 -37
- package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
- package/lib/components/VCombobox/VCombobox.sass +15 -11
- package/lib/components/VCombobox/index.d.mts +2060 -0
- package/lib/components/VCounter/VCounter.mjs.map +1 -1
- package/lib/components/VCounter/{index.d.ts → index.d.mts} +105 -45
- package/lib/components/VDefaultsProvider/{index.d.ts → index.d.mts} +82 -20
- package/lib/components/VDialog/{index.d.ts → index.d.mts} +571 -305
- package/lib/components/VDivider/{index.d.ts → index.d.mts} +81 -21
- package/lib/components/VExpansionPanel/{index.d.ts → index.d.mts} +374 -110
- package/lib/components/VField/VField.css +49 -16
- package/lib/components/VField/VField.mjs +12 -2
- package/lib/components/VField/VField.mjs.map +1 -1
- package/lib/components/VField/VField.sass +40 -11
- package/lib/components/VField/_variables.scss +8 -2
- package/lib/components/VField/index.d.mts +682 -0
- package/lib/components/VFileInput/VFileInput.css +3 -0
- package/lib/components/VFileInput/VFileInput.mjs +7 -1
- package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
- package/lib/components/VFileInput/VFileInput.sass +6 -1
- package/lib/components/VFileInput/{index.d.ts → index.d.mts} +1033 -399
- package/lib/components/VFooter/{index.d.ts → index.d.mts} +85 -29
- package/lib/components/VForm/VForm.mjs.map +1 -1
- package/lib/components/VForm/index.d.mts +993 -0
- package/lib/components/VGrid/{index.d.ts → index.d.mts} +334 -100
- package/lib/components/VHover/VHover.mjs.map +1 -1
- package/lib/components/VHover/{index.d.ts → index.d.mts} +120 -37
- package/lib/components/VIcon/{index.d.ts → index.d.mts} +322 -81
- package/lib/components/VImg/VImg.css +2 -4
- package/lib/components/VImg/VImg.mjs +25 -24
- package/lib/components/VImg/VImg.mjs.map +1 -1
- package/lib/components/VImg/VImg.sass +4 -3
- package/lib/components/VImg/{index.d.ts → index.d.mts} +177 -40
- package/lib/components/VInput/VInput.css +10 -4
- package/lib/components/VInput/VInput.mjs +9 -3
- package/lib/components/VInput/VInput.mjs.map +1 -1
- package/lib/components/VInput/VInput.sass +7 -2
- package/lib/components/VInput/_variables.scss +1 -0
- package/lib/components/VInput/{index.d.ts → index.d.mts} +237 -93
- package/lib/components/VItemGroup/VItem.mjs +1 -1
- package/lib/components/VItemGroup/VItem.mjs.map +1 -1
- package/lib/components/VItemGroup/VItemGroup.mjs.map +1 -1
- package/lib/components/VItemGroup/index.d.mts +781 -0
- package/lib/components/VKbd/{index.d.ts → index.d.mts} +78 -17
- package/lib/components/VLabel/{index.d.ts → index.d.mts} +79 -18
- package/lib/components/VLayout/{index.d.ts → index.d.mts} +161 -42
- package/lib/components/VLazy/{index.d.ts → index.d.mts} +82 -27
- package/lib/components/VList/VList.mjs +6 -1
- package/lib/components/VList/VList.mjs.map +1 -1
- package/lib/components/VList/VListChildren.mjs +4 -8
- package/lib/components/VList/VListChildren.mjs.map +1 -1
- package/lib/components/VList/VListGroup.mjs +3 -0
- package/lib/components/VList/VListGroup.mjs.map +1 -1
- package/lib/components/VList/VListItem.mjs +11 -6
- package/lib/components/VList/VListItem.mjs.map +1 -1
- package/lib/components/VList/{index.d.ts → index.d.mts} +1245 -619
- package/lib/components/VLocaleProvider/{index.d.ts → index.d.mts} +80 -19
- package/lib/components/VMain/{index.d.ts → index.d.mts} +79 -19
- package/lib/components/VMenu/{index.d.ts → index.d.mts} +567 -299
- package/lib/components/VMessages/VMessages.mjs.map +1 -1
- package/lib/components/VMessages/{index.d.ts → index.d.mts} +87 -34
- package/lib/components/VNavigationDrawer/VNavigationDrawer.css +2 -0
- package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
- package/lib/components/VNavigationDrawer/VNavigationDrawer.sass +2 -0
- package/lib/components/VNavigationDrawer/{index.d.ts → index.d.mts} +139 -57
- package/lib/components/VOverlay/{index.d.ts → index.d.mts} +159 -75
- package/lib/components/VPagination/VPagination.mjs.map +1 -1
- package/lib/components/VPagination/{index.d.ts → index.d.mts} +229 -125
- package/lib/components/VParallax/{index.d.ts → index.d.mts} +118 -18
- package/lib/components/VProgressCircular/VProgressCircular.mjs.map +1 -1
- package/lib/components/VProgressCircular/{index.d.ts → index.d.mts} +148 -45
- package/lib/components/VProgressLinear/{index.d.ts → index.d.mts} +119 -52
- package/lib/components/VRadio/{index.d.ts → index.d.mts} +139 -40
- package/lib/components/VRadioGroup/{index.d.ts → index.d.mts} +265 -93
- package/lib/components/VRangeSlider/VRangeSlider.mjs +4 -4
- package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
- package/lib/components/VRangeSlider/{index.d.ts → index.d.mts} +313 -132
- package/lib/components/VRating/{index.d.ts → index.d.mts} +108 -49
- package/lib/components/VResponsive/VResponsive.css +13 -5
- package/lib/components/VResponsive/VResponsive.mjs +4 -1
- package/lib/components/VResponsive/VResponsive.mjs.map +1 -1
- package/lib/components/VResponsive/VResponsive.sass +12 -4
- package/lib/components/VResponsive/{index.d.ts → index.d.mts} +99 -16
- package/lib/components/VSelect/VSelect.css +15 -9
- package/lib/components/VSelect/VSelect.mjs +23 -18
- package/lib/components/VSelect/VSelect.mjs.map +1 -1
- package/lib/components/VSelect/VSelect.sass +14 -11
- package/lib/components/VSelect/index.d.mts +1986 -0
- package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
- package/lib/components/VSelectionControl/index.d.mts +403 -0
- package/lib/components/VSelectionControlGroup/{index.d.ts → index.d.mts} +90 -38
- package/lib/components/VSheet/{index.d.ts → index.d.mts} +81 -21
- package/lib/components/VSlideGroup/{index.d.ts → index.d.mts} +236 -61
- package/lib/components/VSlider/VSlider.mjs +2 -2
- package/lib/components/VSlider/VSlider.mjs.map +1 -1
- package/lib/components/VSlider/VSliderThumb.mjs +1 -1
- package/lib/components/VSlider/VSliderThumb.mjs.map +1 -1
- package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
- package/lib/components/VSlider/{index.d.ts → index.d.mts} +308 -126
- package/lib/components/VSlider/slider.mjs +8 -2
- package/lib/components/VSlider/slider.mjs.map +1 -1
- package/lib/components/VSnackbar/{index.d.ts → index.d.mts} +566 -297
- package/lib/components/VSwitch/VSwitch.css +3 -3
- package/lib/components/VSwitch/VSwitch.sass +4 -3
- package/lib/components/VSwitch/{index.d.ts → index.d.mts} +284 -101
- package/lib/components/VSystemBar/{index.d.ts → index.d.mts} +84 -27
- package/lib/components/VTable/{index.d.ts → index.d.mts} +122 -26
- package/lib/components/VTabs/VTabs.mjs.map +1 -1
- package/lib/components/VTabs/{index.d.ts → index.d.mts} +203 -113
- package/lib/components/VTextField/VTextField.css +9 -1
- package/lib/components/VTextField/VTextField.mjs +4 -2
- package/lib/components/VTextField/VTextField.mjs.map +1 -1
- package/lib/components/VTextField/VTextField.sass +8 -1
- package/lib/components/VTextField/index.d.mts +2735 -0
- package/lib/components/VTextarea/VTextarea.mjs +13 -4
- package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
- package/lib/components/VTextarea/{index.d.ts → index.d.mts} +933 -393
- package/lib/components/VThemeProvider/{index.d.ts → index.d.mts} +80 -20
- package/lib/components/VTimeline/{index.d.ts → index.d.mts} +201 -62
- package/lib/components/VToolbar/{index.d.ts → index.d.mts} +325 -73
- package/lib/components/VTooltip/{index.d.ts → index.d.mts} +568 -297
- package/lib/components/VValidation/VValidation.mjs.map +1 -1
- package/lib/components/VValidation/index.d.mts +634 -0
- package/lib/components/VVirtualScroll/VVirtualScroll.mjs.map +1 -1
- package/lib/components/VVirtualScroll/index.d.mts +229 -0
- package/lib/components/VWindow/{index.d.ts → index.d.mts} +271 -68
- package/lib/components/{index.d.ts → index.d.mts} +27847 -14031
- package/lib/components/index.mjs +2 -3
- package/lib/components/index.mjs.map +1 -1
- package/lib/components/transitions/{index.d.ts → index.d.mts} +1330 -355
- package/lib/composables/display.mjs +6 -6
- package/lib/composables/display.mjs.map +1 -1
- package/lib/composables/filter.mjs +5 -4
- package/lib/composables/filter.mjs.map +1 -1
- package/lib/composables/form.mjs +2 -3
- package/lib/composables/form.mjs.map +1 -1
- package/lib/composables/forwardRefs.mjs.map +1 -1
- package/lib/composables/group.mjs +13 -13
- package/lib/composables/group.mjs.map +1 -1
- package/lib/composables/icons.mjs.map +1 -1
- package/lib/composables/{items.mjs → list-items.mjs} +9 -6
- package/lib/composables/list-items.mjs.map +1 -0
- package/lib/composables/nested/nested.mjs.map +1 -1
- package/lib/composables/nested/selectStrategies.mjs.map +1 -1
- package/lib/composables/scroll.mjs +2 -2
- package/lib/composables/scroll.mjs.map +1 -1
- package/lib/composables/validation.mjs +44 -16
- package/lib/composables/validation.mjs.map +1 -1
- package/lib/entry-bundler.mjs +1 -1
- package/lib/framework.mjs +1 -1
- package/lib/framework.mjs.map +1 -1
- package/lib/{index.d.ts → index.d.mts} +16 -10
- package/lib/labs/VBottomSheet/VBottomSheet.css +33 -0
- package/lib/labs/VBottomSheet/VBottomSheet.mjs +40 -0
- package/lib/labs/VBottomSheet/VBottomSheet.mjs.map +1 -0
- package/lib/labs/VBottomSheet/VBottomSheet.sass +37 -0
- package/lib/labs/VBottomSheet/_variables.scss +5 -0
- package/lib/labs/VBottomSheet/index.d.mts +871 -0
- package/lib/labs/VBottomSheet/index.mjs +2 -0
- package/lib/labs/VBottomSheet/index.mjs.map +1 -0
- package/lib/labs/VDataIterator/VDataIterator.mjs +160 -0
- package/lib/labs/VDataIterator/VDataIterator.mjs.map +1 -0
- package/lib/labs/VDataIterator/composables/items.mjs +37 -0
- package/lib/labs/VDataIterator/composables/items.mjs.map +1 -0
- package/lib/labs/VDataIterator/index.d.mts +704 -0
- package/lib/labs/VDataIterator/index.mjs +2 -0
- package/lib/labs/VDataIterator/index.mjs.map +1 -0
- package/lib/labs/VDataTable/VDataTable.mjs +58 -20
- package/lib/labs/VDataTable/VDataTable.mjs.map +1 -1
- package/lib/labs/VDataTable/VDataTableFooter.mjs.map +1 -1
- package/lib/labs/VDataTable/VDataTableGroupHeaderRow.mjs.map +1 -1
- package/lib/labs/VDataTable/VDataTableHeaders.mjs +17 -10
- package/lib/labs/VDataTable/VDataTableHeaders.mjs.map +1 -1
- package/lib/labs/VDataTable/VDataTableRows.mjs +1 -1
- package/lib/labs/VDataTable/VDataTableRows.mjs.map +1 -1
- package/lib/labs/VDataTable/VDataTableServer.mjs +50 -14
- package/lib/labs/VDataTable/VDataTableServer.mjs.map +1 -1
- package/lib/labs/VDataTable/VDataTableVirtual.mjs +50 -13
- package/lib/labs/VDataTable/VDataTableVirtual.mjs.map +1 -1
- package/lib/labs/VDataTable/composables/expand.mjs.map +1 -1
- package/lib/labs/VDataTable/composables/group.mjs +8 -6
- package/lib/labs/VDataTable/composables/group.mjs.map +1 -1
- package/lib/labs/VDataTable/composables/headers.mjs +2 -3
- package/lib/labs/VDataTable/composables/headers.mjs.map +1 -1
- package/lib/labs/VDataTable/composables/items.mjs +31 -32
- package/lib/labs/VDataTable/composables/items.mjs.map +1 -1
- package/lib/labs/VDataTable/composables/paginate.mjs +14 -2
- package/lib/labs/VDataTable/composables/paginate.mjs.map +1 -1
- package/lib/labs/VDataTable/composables/select.mjs +3 -3
- package/lib/labs/VDataTable/composables/select.mjs.map +1 -1
- package/lib/labs/VDataTable/composables/sort.mjs +17 -17
- package/lib/labs/VDataTable/composables/sort.mjs.map +1 -1
- package/lib/labs/VDataTable/composables/virtual.mjs.map +1 -1
- package/lib/labs/VDataTable/index.d.mts +9681 -0
- package/lib/labs/VDataTable/index.mjs +1 -1
- package/lib/labs/VDataTable/index.mjs.map +1 -1
- package/lib/labs/VDataTable/types.mjs.map +1 -1
- package/lib/labs/VInfiniteScroll/VInfiniteScroll.mjs.map +1 -1
- package/lib/labs/VInfiniteScroll/{index.d.ts → index.d.mts} +161 -54
- package/lib/labs/VSkeletonLoader/VSkeletonLoader.mjs.map +1 -1
- package/lib/labs/VSkeletonLoader/{index.d.ts → index.d.mts} +92 -31
- package/lib/labs/components.d.mts +11806 -0
- package/lib/labs/components.mjs +2 -0
- package/lib/labs/components.mjs.map +1 -1
- package/lib/labs/date/date.mjs.map +1 -1
- package/lib/labs/date/index.d.mts +70 -0
- package/lib/labs/date/index.mjs +1 -1
- package/lib/labs/date/index.mjs.map +1 -1
- package/lib/styles/settings/_variables.scss +3 -3
- package/lib/util/colorUtils.mjs +68 -3
- package/lib/util/colorUtils.mjs.map +1 -1
- package/lib/util/console.mjs +12 -81
- package/lib/util/console.mjs.map +1 -1
- package/lib/util/defineComponent.mjs.map +1 -1
- package/lib/util/helpers.mjs +4 -18
- package/lib/util/helpers.mjs.map +1 -1
- package/lib/util/propsFactory.mjs +2 -0
- package/lib/util/propsFactory.mjs.map +1 -1
- package/package.json +13 -9
- package/lib/components/VAutocomplete/index.d.ts +0 -2050
- package/lib/components/VBottomSheet/VBottomSheet.mjs +0 -29
- package/lib/components/VBottomSheet/VBottomSheet.mjs.map +0 -1
- package/lib/components/VBottomSheet/VBottomSheet.sass +0 -23
- package/lib/components/VBottomSheet/_variables.scss +0 -3
- package/lib/components/VBottomSheet/index.mjs +0 -4
- package/lib/components/VBottomSheet/index.mjs.map +0 -1
- package/lib/components/VChipGroup/index.d.ts +0 -280
- package/lib/components/VCombobox/index.d.ts +0 -2086
- package/lib/components/VData/VData.mjs +0 -374
- package/lib/components/VData/VData.mjs.map +0 -1
- package/lib/components/VData/index.mjs +0 -4
- package/lib/components/VData/index.mjs.map +0 -1
- package/lib/components/VDataIterator/VDataFooter.mjs +0 -194
- package/lib/components/VDataIterator/VDataFooter.mjs.map +0 -1
- package/lib/components/VDataIterator/VDataFooter.sass +0 -71
- package/lib/components/VDataIterator/VDataIterator.mjs +0 -316
- package/lib/components/VDataIterator/VDataIterator.mjs.map +0 -1
- package/lib/components/VDataIterator/_variables.scss +0 -13
- package/lib/components/VDataIterator/index.mjs +0 -10
- package/lib/components/VDataIterator/index.mjs.map +0 -1
- package/lib/components/VField/index.d.ts +0 -563
- package/lib/components/VForm/index.d.ts +0 -284
- package/lib/components/VItemGroup/index.d.ts +0 -396
- package/lib/components/VSelect/index.d.ts +0 -1981
- package/lib/components/VSelectionControl/index.d.ts +0 -387
- package/lib/components/VTextField/index.d.ts +0 -2061
- package/lib/components/VValidation/index.d.ts +0 -243
- package/lib/components/VVirtualScroll/index.d.ts +0 -197
- package/lib/composables/items.mjs.map +0 -1
- package/lib/labs/VDataTable/index.d.ts +0 -5415
- package/lib/labs/components.d.ts +0 -5945
- package/lib/labs/date/index.d.ts +0 -38
- /package/lib/components/VNoSsr/{index.d.ts → index.d.mts} +0 -0
- /package/lib/directives/{index.d.ts → index.d.mts} +0 -0
- /package/lib/iconsets/{fa-svg.d.ts → fa-svg.d.mts} +0 -0
- /package/lib/iconsets/{fa.d.ts → fa.d.mts} +0 -0
- /package/lib/iconsets/{fa4.d.ts → fa4.d.mts} +0 -0
- /package/lib/iconsets/{md.d.ts → md.d.mts} +0 -0
- /package/lib/iconsets/{mdi-svg.d.ts → mdi-svg.d.mts} +0 -0
- /package/lib/iconsets/{mdi.d.ts → mdi.d.mts} +0 -0
- /package/lib/labs/date/adapters/{vuetify.d.ts → vuetify.d.mts} +0 -0
- /package/lib/locale/adapters/{vue-i18n.d.ts → vue-i18n.d.mts} +0 -0
- /package/lib/locale/adapters/{vuetify.d.ts → vuetify.d.mts} +0 -0
- /package/lib/locale/{index.d.ts → index.d.mts} +0 -0
|
@@ -15,14 +15,13 @@
|
|
|
15
15
|
.v-autocomplete .v-field .v-field__input, .v-autocomplete .v-field.v-field {
|
|
16
16
|
cursor: text;
|
|
17
17
|
}
|
|
18
|
+
.v-autocomplete .v-field--variant-outlined {
|
|
19
|
+
--autocomplete-chips-margin-bottom: 2px;
|
|
20
|
+
}
|
|
18
21
|
.v-autocomplete .v-field .v-field__input > input {
|
|
19
22
|
align-self: flex-start;
|
|
20
23
|
flex: 1 1;
|
|
21
24
|
}
|
|
22
|
-
.v-autocomplete .v-field .v-field__append-inner > .v-icon {
|
|
23
|
-
margin-inline-start: 4px;
|
|
24
|
-
transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
|
|
25
|
-
}
|
|
26
25
|
.v-autocomplete .v-field:not(.v-field--focused) input {
|
|
27
26
|
min-width: 0;
|
|
28
27
|
}
|
|
@@ -49,15 +48,14 @@
|
|
|
49
48
|
line-height: inherit;
|
|
50
49
|
max-width: 100%;
|
|
51
50
|
}
|
|
52
|
-
.v-autocomplete--
|
|
53
|
-
|
|
54
|
-
transform: rotate(180deg);
|
|
51
|
+
.v-autocomplete--chips .v-field__input, .v-autocomplete--selection-slot .v-field__input {
|
|
52
|
+
min-height: calc(var(--v-field-input-min-height) + var(--autocomplete-chips-margin-bottom) + 2px);
|
|
55
53
|
}
|
|
56
|
-
.v-autocomplete--chips .v-autocomplete__selection {
|
|
54
|
+
.v-autocomplete--chips .v-autocomplete__selection, .v-autocomplete--selection-slot .v-autocomplete__selection {
|
|
57
55
|
margin-top: 2px;
|
|
58
56
|
margin-bottom: var(--autocomplete-chips-margin-bottom);
|
|
59
57
|
}
|
|
60
|
-
.v-autocomplete--chips .v-autocomplete__selection:first-child {
|
|
58
|
+
.v-autocomplete--chips .v-autocomplete__selection:first-child, .v-autocomplete--selection-slot .v-autocomplete__selection:first-child {
|
|
61
59
|
margin-inline-start: 0;
|
|
62
60
|
}
|
|
63
61
|
.v-autocomplete--selecting-index .v-autocomplete__selection {
|
|
@@ -86,4 +84,12 @@
|
|
|
86
84
|
}
|
|
87
85
|
.v-autocomplete--single .v-field--focused .v-autocomplete__selection {
|
|
88
86
|
opacity: 0;
|
|
87
|
+
}
|
|
88
|
+
.v-autocomplete__menu-icon {
|
|
89
|
+
margin-inline-start: 4px;
|
|
90
|
+
transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
|
|
91
|
+
}
|
|
92
|
+
.v-autocomplete--active-menu .v-autocomplete__menu-icon {
|
|
93
|
+
opacity: var(--v-high-emphasis-opacity);
|
|
94
|
+
transform: rotate(180deg);
|
|
89
95
|
}
|
|
@@ -15,12 +15,12 @@ import { forwardRefs } from "../../composables/forwardRefs.mjs";
|
|
|
15
15
|
import { makeFilterProps, useFilter } from "../../composables/filter.mjs";
|
|
16
16
|
import { makeTransitionProps } from "../../composables/transition.mjs";
|
|
17
17
|
import { useForm } from "../../composables/form.mjs";
|
|
18
|
-
import { useItems } from "../../composables/items.mjs";
|
|
18
|
+
import { useItems } from "../../composables/list-items.mjs";
|
|
19
19
|
import { useLocale } from "../../composables/locale.mjs";
|
|
20
20
|
import { useProxiedModel } from "../../composables/proxiedModel.mjs";
|
|
21
21
|
import { useTextColor } from "../../composables/color.mjs"; // Utility
|
|
22
22
|
import { computed, mergeProps, nextTick, ref, shallowRef, watch } from 'vue';
|
|
23
|
-
import { genericComponent, omit, propsFactory, useRender, wrapInArray } from "../../util/index.mjs";
|
|
23
|
+
import { genericComponent, noop, omit, propsFactory, useRender, wrapInArray } from "../../util/index.mjs";
|
|
24
24
|
import { makeVTextFieldProps } from "../VTextField/VTextField.mjs"; // Types
|
|
25
25
|
function highlightResult(text, matches, length) {
|
|
26
26
|
if (matches == null) return text;
|
|
@@ -34,8 +34,9 @@ function highlightResult(text, matches, length) {
|
|
|
34
34
|
}, [text.substr(matches + length)])]) : text;
|
|
35
35
|
}
|
|
36
36
|
export const makeVAutocompleteProps = propsFactory({
|
|
37
|
-
|
|
38
|
-
|
|
37
|
+
autoSelectFirst: {
|
|
38
|
+
type: [Boolean, String]
|
|
39
|
+
},
|
|
39
40
|
search: String,
|
|
40
41
|
...makeFilterProps({
|
|
41
42
|
filterKeys: ['title']
|
|
@@ -67,6 +68,7 @@ export const VAutocomplete = genericComponent()({
|
|
|
67
68
|
const vTextFieldRef = ref();
|
|
68
69
|
const isFocused = shallowRef(false);
|
|
69
70
|
const isPristine = shallowRef(true);
|
|
71
|
+
const listHasFocus = ref(false);
|
|
70
72
|
const vMenuRef = ref();
|
|
71
73
|
const _menu = useProxiedModel(props, 'menu');
|
|
72
74
|
const menu = computed({
|
|
@@ -110,6 +112,10 @@ export const VAutocomplete = genericComponent()({
|
|
|
110
112
|
});
|
|
111
113
|
const selected = computed(() => selections.value.map(selection => selection.props.value));
|
|
112
114
|
const selection = computed(() => selections.value[selectionIndex.value]);
|
|
115
|
+
const highlightFirst = computed(() => {
|
|
116
|
+
const selectFirst = props.autoSelectFirst === true || props.autoSelectFirst === 'exact' && search.value === displayItems.value[0]?.title;
|
|
117
|
+
return selectFirst && displayItems.value.length > 0 && !isPristine.value && !listHasFocus.value;
|
|
118
|
+
});
|
|
113
119
|
const listRef = ref();
|
|
114
120
|
function onClear(e) {
|
|
115
121
|
if (props.openOnClear) {
|
|
@@ -121,6 +127,13 @@ export const VAutocomplete = genericComponent()({
|
|
|
121
127
|
if (props.hideNoData && !items.value.length || props.readonly || form?.isReadonly.value) return;
|
|
122
128
|
menu.value = true;
|
|
123
129
|
}
|
|
130
|
+
function onMousedownMenuIcon(e) {
|
|
131
|
+
if (isFocused.value) {
|
|
132
|
+
e.preventDefault();
|
|
133
|
+
e.stopPropagation();
|
|
134
|
+
}
|
|
135
|
+
menu.value = !menu.value;
|
|
136
|
+
}
|
|
124
137
|
function onKeydown(e) {
|
|
125
138
|
if (props.readonly || form?.isReadonly.value) return;
|
|
126
139
|
const selectionStart = vTextFieldRef.value.selectionStart;
|
|
@@ -135,10 +148,16 @@ export const VAutocomplete = genericComponent()({
|
|
|
135
148
|
menu.value = false;
|
|
136
149
|
}
|
|
137
150
|
if (['Enter', 'Escape', 'Tab'].includes(e.key)) {
|
|
151
|
+
if (highlightFirst.value && ['Enter', 'Tab'].includes(e.key)) {
|
|
152
|
+
select(filteredItems.value[0]);
|
|
153
|
+
}
|
|
138
154
|
isPristine.value = true;
|
|
139
155
|
}
|
|
140
156
|
if (e.key === 'ArrowDown') {
|
|
141
157
|
listRef.value?.focus('next');
|
|
158
|
+
if (highlightFirst.value) {
|
|
159
|
+
listRef.value?.focus('next');
|
|
160
|
+
}
|
|
142
161
|
} else if (e.key === 'ArrowUp') {
|
|
143
162
|
listRef.value?.focus('prev');
|
|
144
163
|
}
|
|
@@ -186,6 +205,12 @@ export const VAutocomplete = genericComponent()({
|
|
|
186
205
|
}
|
|
187
206
|
function onFocusin(e) {
|
|
188
207
|
isFocused.value = true;
|
|
208
|
+
setTimeout(() => {
|
|
209
|
+
listHasFocus.value = true;
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
function onFocusout(e) {
|
|
213
|
+
listHasFocus.value = false;
|
|
189
214
|
}
|
|
190
215
|
const isSelecting = shallowRef(false);
|
|
191
216
|
function select(item) {
|
|
@@ -207,14 +232,22 @@ export const VAutocomplete = genericComponent()({
|
|
|
207
232
|
nextTick(() => isSelecting.value = false);
|
|
208
233
|
}
|
|
209
234
|
}
|
|
210
|
-
watch(isFocused, val => {
|
|
235
|
+
watch(isFocused, (val, oldVal) => {
|
|
236
|
+
if (val === oldVal) return;
|
|
211
237
|
if (val) {
|
|
212
238
|
isSelecting.value = true;
|
|
213
239
|
search.value = props.multiple ? '' : String(selections.value.at(-1)?.props.title ?? '');
|
|
214
240
|
isPristine.value = true;
|
|
215
241
|
nextTick(() => isSelecting.value = false);
|
|
216
242
|
} else {
|
|
217
|
-
if (!props.multiple && !search.value) model.value = [];
|
|
243
|
+
if (!props.multiple && !search.value) model.value = [];else if (highlightFirst.value && !listHasFocus.value && !selections.value.some(_ref2 => {
|
|
244
|
+
let {
|
|
245
|
+
value
|
|
246
|
+
} = _ref2;
|
|
247
|
+
return value === displayItems.value[0].value;
|
|
248
|
+
})) {
|
|
249
|
+
select(displayItems.value[0]);
|
|
250
|
+
}
|
|
218
251
|
menu.value = false;
|
|
219
252
|
search.value = '';
|
|
220
253
|
selectionIndex.value = -1;
|
|
@@ -245,10 +278,10 @@ export const VAutocomplete = genericComponent()({
|
|
|
245
278
|
"class": ['v-autocomplete', `v-autocomplete--${props.multiple ? 'multiple' : 'single'}`, {
|
|
246
279
|
'v-autocomplete--active-menu': menu.value,
|
|
247
280
|
'v-autocomplete--chips': !!props.chips,
|
|
281
|
+
'v-autocomplete--selection-slot': !!slots.selection,
|
|
248
282
|
'v-autocomplete--selecting-index': selectionIndex.value > -1
|
|
249
283
|
}, props.class],
|
|
250
284
|
"style": props.style,
|
|
251
|
-
"appendInnerIcon": props.menuIcon,
|
|
252
285
|
"readonly": props.readonly,
|
|
253
286
|
"placeholder": isDirty ? undefined : props.placeholder,
|
|
254
287
|
"onClick:clear": onClear,
|
|
@@ -274,36 +307,40 @@ export const VAutocomplete = genericComponent()({
|
|
|
274
307
|
"selected": selected.value,
|
|
275
308
|
"selectStrategy": props.multiple ? 'independent' : 'single-independent',
|
|
276
309
|
"onMousedown": e => e.preventDefault(),
|
|
277
|
-
"onFocusin": onFocusin
|
|
310
|
+
"onFocusin": onFocusin,
|
|
311
|
+
"onFocusout": onFocusout
|
|
278
312
|
}, {
|
|
279
313
|
default: () => [!displayItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? _createVNode(VListItem, {
|
|
280
314
|
"title": t(props.noDataText)
|
|
281
|
-
}, null)), slots['prepend-item']?.(), displayItems.value.map(item =>
|
|
282
|
-
item,
|
|
283
|
-
|
|
315
|
+
}, null)), slots['prepend-item']?.(), displayItems.value.map((item, index) => {
|
|
316
|
+
const itemProps = mergeProps(item.props, {
|
|
317
|
+
key: index,
|
|
318
|
+
active: highlightFirst.value && index === 0 ? true : undefined,
|
|
284
319
|
onClick: () => select(item)
|
|
285
|
-
})
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
320
|
+
});
|
|
321
|
+
return slots.item?.({
|
|
322
|
+
item,
|
|
323
|
+
index,
|
|
324
|
+
props: itemProps
|
|
325
|
+
}) ?? _createVNode(VListItem, itemProps, {
|
|
326
|
+
prepend: _ref3 => {
|
|
327
|
+
let {
|
|
328
|
+
isSelected
|
|
329
|
+
} = _ref3;
|
|
330
|
+
return _createVNode(_Fragment, null, [props.multiple && !props.hideSelected ? _createVNode(VCheckboxBtn, {
|
|
331
|
+
"key": item.value,
|
|
332
|
+
"modelValue": isSelected,
|
|
333
|
+
"ripple": false,
|
|
334
|
+
"tabindex": "-1"
|
|
335
|
+
}, null) : undefined, item.props.prependIcon && _createVNode(VIcon, {
|
|
336
|
+
"icon": item.props.prependIcon
|
|
337
|
+
}, null)]);
|
|
338
|
+
},
|
|
339
|
+
title: () => {
|
|
340
|
+
return isPristine.value ? item.title : highlightResult(item.title, getMatches(item)?.title, search.value?.length ?? 0);
|
|
341
|
+
}
|
|
342
|
+
});
|
|
343
|
+
}), slots['append-item']?.()]
|
|
307
344
|
})]
|
|
308
345
|
}), selections.value.map((item, index) => {
|
|
309
346
|
function onChipClose(e) {
|
|
@@ -352,7 +389,18 @@ export const VAutocomplete = genericComponent()({
|
|
|
352
389
|
}, [item.title, props.multiple && index < selections.value.length - 1 && _createVNode("span", {
|
|
353
390
|
"class": "v-autocomplete__selection-comma"
|
|
354
391
|
}, [_createTextVNode(",")])])]);
|
|
355
|
-
})])
|
|
392
|
+
})]),
|
|
393
|
+
'append-inner': function () {
|
|
394
|
+
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
395
|
+
args[_key] = arguments[_key];
|
|
396
|
+
}
|
|
397
|
+
return _createVNode(_Fragment, null, [slots['append-inner']?.(...args), props.menuIcon ? _createVNode(VIcon, {
|
|
398
|
+
"class": "v-autocomplete__menu-icon",
|
|
399
|
+
"icon": props.menuIcon,
|
|
400
|
+
"onMousedown": onMousedownMenuIcon,
|
|
401
|
+
"onClick": noop
|
|
402
|
+
}, null) : undefined]);
|
|
403
|
+
}
|
|
356
404
|
});
|
|
357
405
|
});
|
|
358
406
|
return forwardRefs({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VAutocomplete.mjs","names":["makeSelectProps","VCheckboxBtn","VChip","VDefaultsProvider","VIcon","VList","VListItem","VMenu","VTextField","forwardRefs","makeFilterProps","useFilter","makeTransitionProps","useForm","useItems","useLocale","useProxiedModel","useTextColor","computed","mergeProps","nextTick","ref","shallowRef","watch","genericComponent","omit","propsFactory","useRender","wrapInArray","makeVTextFieldProps","highlightResult","text","matches","length","Array","isArray","Error","_createVNode","_Fragment","substr","makeVAutocompleteProps","search","String","filterKeys","modelValue","transition","VAutocomplete","name","props","emits","focused","val","setup","_ref","slots","t","vTextFieldRef","isFocused","isPristine","vMenuRef","_menu","menu","get","value","set","v","ΨopenChildren","selectionIndex","color","items","transformIn","transformOut","textColorClasses","textColorStyles","model","transformed","multiple","form","filteredItems","getMatches","undefined","selections","map","find","item","valueComparator","displayItems","hideSelected","filter","filteredItem","some","s","selected","selection","listRef","onClear","e","openOnClear","onMousedownControl","hideNoData","readonly","isReadonly","onKeydown","selectionStart","includes","key","preventDefault","focus","originalSelectionIndex","select","prev","setSelectionRange","next","onInput","target","onAfterLeave","onFocusin","isSelecting","index","findIndex","splice","title","at","hasChips","chips","chip","hasList","prepend","append","isDirty","textFieldProps","filterProps","_mergeProps","$event","externalValue","class","style","menuIcon","placeholder","default","eager","menuProps","noDataText","onClick","_ref2","isSelected","prependIcon","onChipClose","stopPropagation","slotProps","onMousedown","closableChips","closable","size","_createTextVNode"],"sources":["../../../src/components/VAutocomplete/VAutocomplete.tsx"],"sourcesContent":["// Styles\nimport './VAutocomplete.sass'\n\n// Components\nimport { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VIcon } from '@/components/VIcon'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { forwardRefs } from '@/composables/forwardRefs'\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { useForm } from '@/composables/form'\nimport { useItems } from '@/composables/items'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useTextColor } from '@/composables/color'\n\n// Utility\nimport { computed, mergeProps, nextTick, ref, shallowRef, watch } from 'vue'\nimport { genericComponent, omit, propsFactory, useRender, wrapInArray } from '@/util'\nimport { makeVTextFieldProps } from '@/components/VTextField/VTextField'\n\n// Types\nimport type { FilterMatch } from '@/composables/filter'\nimport type { InternalItem } from '@/composables/items'\nimport type { GenericProps } from '@/util'\nimport type { VFieldSlots } from '@/components/VField/VField'\nimport type { VInputSlots } from '@/components/VInput/VInput'\n\nfunction highlightResult (text: string, matches: FilterMatch | undefined, length: number) {\n if (matches == null) return text\n\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-autocomplete__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-autocomplete__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-autocomplete__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\ntype Primitive = string | number | boolean | symbol\n\ntype Val <T, ReturnObject extends boolean> = T extends Primitive\n ? T\n : (ReturnObject extends true ? T : any)\n\ntype Value <T, ReturnObject extends boolean, Multiple extends boolean> =\n Multiple extends true\n ? readonly Val<T, ReturnObject>[]\n : Val<T, ReturnObject> | null\n\nexport const makeVAutocompleteProps = propsFactory({\n // TODO: implement post keyboard support\n // autoSelectFirst: Boolean,\n search: String,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps(),\n ...omit(makeVTextFieldProps({\n modelValue: null,\n }), ['validationValue', 'dirty', 'appendInnerIcon']),\n ...makeTransitionProps({ transition: false }),\n}, 'v-autocomplete')\n\nexport const VAutocomplete = genericComponent<new <\n T extends readonly any[],\n Item = T extends (infer U)[] ? U : never,\n ReturnObject extends boolean = false,\n Multiple extends boolean = false,\n V extends Value<Item, ReturnObject, Multiple> = Value<Item, ReturnObject, Multiple>\n>(props: {\n items?: T\n returnObject?: ReturnObject\n multiple?: Multiple\n modelValue?: V | null\n 'onUpdate:modelValue'?: (val: V) => void\n}) => GenericProps<typeof props, Omit<VInputSlots & VFieldSlots, 'default'> & {\n item: [{ item: InternalItem<Item>, index: number, props: Record<string, unknown> }]\n chip: [{ item: InternalItem<Item>, index: number, props: Record<string, unknown> }]\n selection: [{ item: InternalItem<Item>, index: number }]\n 'prepend-item': []\n 'append-item': []\n 'no-data': []\n}>>()({\n name: 'VAutocomplete',\n\n props: makeVAutocompleteProps(),\n\n emits: {\n 'update:focused': (focused: boolean) => true,\n 'update:search': (val: any) => true,\n 'update:modelValue': (val: any) => true,\n 'update:menu': (val: boolean) => true,\n },\n\n setup (props, { slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const isFocused = shallowRef(false)\n const isPristine = shallowRef(true)\n const vMenuRef = ref<VMenu>()\n const _menu = useProxiedModel(props, 'menu')\n const menu = computed({\n get: () => _menu.value,\n set: v => {\n if (_menu.value && !v && vMenuRef.value?.ΨopenChildren) return\n _menu.value = v\n },\n })\n const selectionIndex = shallowRef(-1)\n const color = computed(() => vTextFieldRef.value?.color)\n const { items, transformIn, transformOut } = useItems(props)\n const { textColorClasses, textColorStyles } = useTextColor(color)\n const search = useProxiedModel(props, 'search', '')\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => transformIn(wrapInArray(v)),\n v => {\n const transformed = transformOut(v)\n return props.multiple ? transformed : (transformed[0] ?? null)\n }\n )\n const form = useForm()\n const { filteredItems, getMatches } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n const selections = computed(() => {\n return model.value.map(v => {\n return items.value.find(item => props.valueComparator(item.value, v.value)) || v\n })\n })\n\n const displayItems = computed(() => {\n if (props.hideSelected) {\n return filteredItems.value.filter(filteredItem => !selections.value.some(s => s.value === filteredItem.value))\n }\n return filteredItems.value\n })\n\n const selected = computed(() => selections.value.map(selection => selection.props.value))\n const selection = computed(() => selections.value[selectionIndex.value])\n const listRef = ref<VList>()\n\n function onClear (e: MouseEvent) {\n if (props.openOnClear) {\n menu.value = true\n }\n\n search.value = ''\n }\n function onMousedownControl () {\n if (\n (props.hideNoData && !items.value.length) ||\n props.readonly || form?.isReadonly.value\n ) return\n\n menu.value = true\n }\n function onKeydown (e: KeyboardEvent) {\n if (props.readonly || form?.isReadonly.value) return\n\n const selectionStart = vTextFieldRef.value.selectionStart\n const length = selected.value.length\n\n if (\n selectionIndex.value > -1 ||\n ['Enter', 'ArrowDown', 'ArrowUp'].includes(e.key)\n ) {\n e.preventDefault()\n }\n\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n isPristine.value = true\n }\n\n if (e.key === 'ArrowDown') {\n listRef.value?.focus('next')\n } else if (e.key === 'ArrowUp') {\n listRef.value?.focus('prev')\n }\n\n if (!props.multiple) return\n\n if (['Backspace', 'Delete'].includes(e.key)) {\n if (selectionIndex.value < 0) {\n if (e.key === 'Backspace' && !search.value) {\n selectionIndex.value = length - 1\n }\n\n return\n }\n\n const originalSelectionIndex = selectionIndex.value\n\n if (selection.value) select(selection.value)\n\n selectionIndex.value = originalSelectionIndex >= length - 1 ? (length - 2) : originalSelectionIndex\n }\n\n if (e.key === 'ArrowLeft') {\n if (selectionIndex.value < 0 && selectionStart > 0) return\n\n const prev = selectionIndex.value > -1\n ? selectionIndex.value - 1\n : length - 1\n\n if (selections.value[prev]) {\n selectionIndex.value = prev\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(search.value?.length, search.value?.length)\n }\n }\n\n if (e.key === 'ArrowRight') {\n if (selectionIndex.value < 0) return\n\n const next = selectionIndex.value + 1\n\n if (selections.value[next]) {\n selectionIndex.value = next\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(0, 0)\n }\n }\n }\n\n function onInput (e: InputEvent) {\n search.value = (e.target as HTMLInputElement).value\n }\n\n function onAfterLeave () {\n if (isFocused.value) {\n isPristine.value = true\n vTextFieldRef.value?.focus()\n }\n }\n\n function onFocusin (e: FocusEvent) {\n isFocused.value = true\n }\n\n const isSelecting = shallowRef(false)\n\n function select (item: InternalItem) {\n if (props.multiple) {\n const index = selected.value.findIndex(selection => props.valueComparator(selection, item.value))\n\n if (index === -1) {\n model.value = [...model.value, item]\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n } else {\n model.value = [item]\n\n isSelecting.value = true\n\n search.value = item.title\n\n menu.value = false\n isPristine.value = true\n\n nextTick(() => (isSelecting.value = false))\n }\n }\n\n watch(isFocused, val => {\n if (val) {\n isSelecting.value = true\n search.value = props.multiple ? '' : String(selections.value.at(-1)?.props.title ?? '')\n isPristine.value = true\n\n nextTick(() => isSelecting.value = false)\n } else {\n if (!props.multiple && !search.value) model.value = []\n menu.value = false\n search.value = ''\n selectionIndex.value = -1\n }\n })\n\n watch(search, val => {\n if (!isFocused.value || isSelecting.value) return\n\n if (val) menu.value = true\n\n isPristine.value = !val\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n const hasList = !!((!props.hideNoData || displayItems.value.length) || slots.prepend || slots.append || slots['no-data'])\n const isDirty = model.value.length > 0\n const [textFieldProps] = VTextField.filterProps(props)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n { ...textFieldProps }\n modelValue={ search.value }\n onUpdate:modelValue={ v => { if (v == null) model.value = [] } }\n v-model:focused={ isFocused.value }\n validationValue={ model.externalValue }\n dirty={ isDirty }\n onInput={ onInput }\n class={[\n 'v-autocomplete',\n `v-autocomplete--${props.multiple ? 'multiple' : 'single'}`,\n {\n 'v-autocomplete--active-menu': menu.value,\n 'v-autocomplete--chips': !!props.chips,\n 'v-autocomplete--selecting-index': selectionIndex.value > -1,\n },\n props.class,\n ]}\n style={ props.style }\n appendInnerIcon={ props.menuIcon }\n readonly={ props.readonly }\n placeholder={ isDirty ? undefined : props.placeholder }\n onClick:clear={ onClear }\n onMousedown:control={ onMousedownControl }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n ref={ vMenuRef }\n v-model={ menu.value }\n activator=\"parent\"\n contentClass=\"v-autocomplete__content\"\n eager={ props.eager }\n maxHeight={ 310 }\n openOnClick={ false }\n closeOnContentClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n { ...props.menuProps }\n >\n { hasList && (\n <VList\n ref={ listRef }\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n onFocusin={ onFocusin }\n >\n { !displayItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? (\n <VListItem title={ t(props.noDataText) } />\n ))}\n\n { slots['prepend-item']?.() }\n\n { displayItems.value.map(item => slots.item?.({\n item,\n props: mergeProps(item.props, { onClick: () => select(item) }),\n }) ?? (\n <VListItem\n key={ item.value }\n { ...item.props }\n onClick={ () => select(item) }\n >\n {{\n prepend: ({ isSelected }) => (\n <>\n { props.multiple && !props.hideSelected ? (\n <VCheckboxBtn\n modelValue={ isSelected }\n ripple={ false }\n tabindex=\"-1\"\n />\n ) : undefined }\n\n { item.props.prependIcon && (\n <VIcon icon={ item.props.prependIcon } />\n )}\n </>\n ),\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, getMatches(item)?.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n ))}\n\n { slots['append-item']?.() }\n </VList>\n )}\n </VMenu>\n\n { selections.value.map((item, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(item)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n onMousedown (e: MouseEvent) {\n e.preventDefault()\n e.stopPropagation()\n },\n modelValue: true,\n 'onUpdate:modelValue': undefined,\n }\n\n return (\n <div\n key={ item.value }\n class={[\n 'v-autocomplete__selection',\n index === selectionIndex.value && [\n 'v-autocomplete__selection--selected',\n textColorClasses.value,\n ],\n ]}\n style={ index === selectionIndex.value ? textColorStyles.value : {} }\n >\n { hasChips ? (\n !slots.chip ? (\n <VChip\n key=\"chip\"\n closable={ props.closableChips }\n size=\"small\"\n text={ item.title }\n { ...slotProps }\n />\n ) : (\n <VDefaultsProvider\n key=\"chip-defaults\"\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip?.({ item, index, props: slotProps }) }\n </VDefaultsProvider>\n )\n ) : (\n slots.selection?.({ item, index }) ?? (\n <span class=\"v-autocomplete__selection-text\">\n { item.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-autocomplete__selection-comma\">,</span>\n )}\n </span>\n )\n )}\n </div>\n )\n })}\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return forwardRefs({\n isFocused,\n isPristine,\n menu,\n search,\n filteredItems,\n select,\n }, vTextFieldRef)\n },\n})\n\nexport type VAutocomplete = InstanceType<typeof VAutocomplete>\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"VAutocomplete.mjs","names":["makeSelectProps","VCheckboxBtn","VChip","VDefaultsProvider","VIcon","VList","VListItem","VMenu","VTextField","forwardRefs","makeFilterProps","useFilter","makeTransitionProps","useForm","useItems","useLocale","useProxiedModel","useTextColor","computed","mergeProps","nextTick","ref","shallowRef","watch","genericComponent","noop","omit","propsFactory","useRender","wrapInArray","makeVTextFieldProps","highlightResult","text","matches","length","Array","isArray","Error","_createVNode","_Fragment","substr","makeVAutocompleteProps","autoSelectFirst","type","Boolean","String","search","filterKeys","modelValue","transition","VAutocomplete","name","props","emits","focused","val","setup","_ref","slots","t","vTextFieldRef","isFocused","isPristine","listHasFocus","vMenuRef","_menu","menu","get","value","set","v","ΨopenChildren","selectionIndex","color","items","transformIn","transformOut","textColorClasses","textColorStyles","model","transformed","multiple","form","filteredItems","getMatches","undefined","selections","map","find","item","valueComparator","displayItems","hideSelected","filter","filteredItem","some","s","selected","selection","highlightFirst","selectFirst","title","listRef","onClear","e","openOnClear","onMousedownControl","hideNoData","readonly","isReadonly","onMousedownMenuIcon","preventDefault","stopPropagation","onKeydown","selectionStart","includes","key","select","focus","originalSelectionIndex","prev","setSelectionRange","next","onInput","target","onAfterLeave","onFocusin","setTimeout","onFocusout","isSelecting","index","findIndex","splice","oldVal","at","_ref2","hasChips","chips","chip","hasList","prepend","append","isDirty","textFieldProps","filterProps","_mergeProps","$event","externalValue","class","style","placeholder","default","eager","menuProps","noDataText","itemProps","active","onClick","_ref3","isSelected","prependIcon","onChipClose","slotProps","onMousedown","closableChips","closable","size","_createTextVNode","append-inner","_len","arguments","args","_key","menuIcon"],"sources":["../../../src/components/VAutocomplete/VAutocomplete.tsx"],"sourcesContent":["// Styles\nimport './VAutocomplete.sass'\n\n// Components\nimport { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VIcon } from '@/components/VIcon'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { forwardRefs } from '@/composables/forwardRefs'\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { useForm } from '@/composables/form'\nimport { useItems } from '@/composables/list-items'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useTextColor } from '@/composables/color'\n\n// Utility\nimport { computed, mergeProps, nextTick, ref, shallowRef, watch } from 'vue'\nimport { genericComponent, noop, omit, propsFactory, useRender, wrapInArray } from '@/util'\nimport { makeVTextFieldProps } from '@/components/VTextField/VTextField'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { GenericProps } from '@/util'\nimport type { FilterMatch } from '@/composables/filter'\nimport type { ListItem } from '@/composables/list-items'\nimport type { VFieldSlots } from '@/components/VField/VField'\nimport type { VInputSlots } from '@/components/VInput/VInput'\n\nfunction highlightResult (text: string, matches: FilterMatch | undefined, length: number) {\n if (matches == null) return text\n\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-autocomplete__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-autocomplete__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-autocomplete__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\ntype Primitive = string | number | boolean | symbol\n\ntype Val <T, ReturnObject extends boolean> = [T] extends [Primitive]\n ? T\n : (ReturnObject extends true ? T : any)\n\ntype Value <T, ReturnObject extends boolean, Multiple extends boolean> =\n Multiple extends true\n ? readonly Val<T, ReturnObject>[]\n : Val<T, ReturnObject> | null\n\nexport const makeVAutocompleteProps = propsFactory({\n autoSelectFirst: {\n type: [Boolean, String] as PropType<boolean | 'exact'>,\n },\n search: String,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps(),\n ...omit(makeVTextFieldProps({\n modelValue: null,\n }), ['validationValue', 'dirty', 'appendInnerIcon']),\n ...makeTransitionProps({ transition: false }),\n}, 'v-autocomplete')\n\nexport const VAutocomplete = genericComponent<new <\n T extends readonly any[],\n Item = T extends readonly (infer U)[] ? U : never,\n ReturnObject extends boolean = false,\n Multiple extends boolean = false,\n V extends Value<Item, ReturnObject, Multiple> = Value<Item, ReturnObject, Multiple>\n>(\n props: {\n items?: T\n returnObject?: ReturnObject\n multiple?: Multiple\n modelValue?: V | null\n 'onUpdate:modelValue'?: (val: V) => void\n },\n slots: Omit<VInputSlots & VFieldSlots, 'default'> & {\n item: [{ item: ListItem<Item>, index: number, props: Record<string, unknown> }]\n chip: [{ item: ListItem<Item>, index: number, props: Record<string, unknown> }]\n selection: [{ item: ListItem<Item>, index: number }]\n 'prepend-item': []\n 'append-item': []\n 'no-data': []\n }\n) => GenericProps<typeof props, typeof slots>>()({\n name: 'VAutocomplete',\n\n props: makeVAutocompleteProps(),\n\n emits: {\n 'update:focused': (focused: boolean) => true,\n 'update:search': (val: any) => true,\n 'update:modelValue': (val: any) => true,\n 'update:menu': (val: boolean) => true,\n },\n\n setup (props, { slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const isFocused = shallowRef(false)\n const isPristine = shallowRef(true)\n const listHasFocus = ref(false)\n const vMenuRef = ref<VMenu>()\n const _menu = useProxiedModel(props, 'menu')\n const menu = computed({\n get: () => _menu.value,\n set: v => {\n if (_menu.value && !v && vMenuRef.value?.ΨopenChildren) return\n _menu.value = v\n },\n })\n const selectionIndex = shallowRef(-1)\n const color = computed(() => vTextFieldRef.value?.color)\n const { items, transformIn, transformOut } = useItems(props)\n const { textColorClasses, textColorStyles } = useTextColor(color)\n const search = useProxiedModel(props, 'search', '')\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => transformIn(wrapInArray(v)),\n v => {\n const transformed = transformOut(v)\n return props.multiple ? transformed : (transformed[0] ?? null)\n }\n )\n const form = useForm()\n const { filteredItems, getMatches } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n const selections = computed(() => {\n return model.value.map(v => {\n return items.value.find(item => props.valueComparator(item.value, v.value)) || v\n })\n })\n\n const displayItems = computed(() => {\n if (props.hideSelected) {\n return filteredItems.value.filter(filteredItem => !selections.value.some(s => s.value === filteredItem.value))\n }\n return filteredItems.value\n })\n\n const selected = computed(() => selections.value.map(selection => selection.props.value))\n const selection = computed(() => selections.value[selectionIndex.value])\n const highlightFirst = computed(() => {\n const selectFirst = props.autoSelectFirst === true ||\n (props.autoSelectFirst === 'exact' && search.value === displayItems.value[0]?.title)\n return selectFirst &&\n displayItems.value.length > 0 &&\n !isPristine.value &&\n !listHasFocus.value\n })\n const listRef = ref<VList>()\n\n function onClear (e: MouseEvent) {\n if (props.openOnClear) {\n menu.value = true\n }\n\n search.value = ''\n }\n function onMousedownControl () {\n if (\n (props.hideNoData && !items.value.length) ||\n props.readonly || form?.isReadonly.value\n ) return\n\n menu.value = true\n }\n function onMousedownMenuIcon (e: MouseEvent) {\n if (isFocused.value) {\n e.preventDefault()\n e.stopPropagation()\n }\n menu.value = !menu.value\n }\n function onKeydown (e: KeyboardEvent) {\n if (props.readonly || form?.isReadonly.value) return\n\n const selectionStart = vTextFieldRef.value.selectionStart\n const length = selected.value.length\n\n if (\n selectionIndex.value > -1 ||\n ['Enter', 'ArrowDown', 'ArrowUp'].includes(e.key)\n ) {\n e.preventDefault()\n }\n\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n if (highlightFirst.value && ['Enter', 'Tab'].includes(e.key)) {\n select(filteredItems.value[0])\n }\n\n isPristine.value = true\n }\n\n if (e.key === 'ArrowDown') {\n listRef.value?.focus('next')\n if (highlightFirst.value) {\n listRef.value?.focus('next')\n }\n } else if (e.key === 'ArrowUp') {\n listRef.value?.focus('prev')\n }\n\n if (!props.multiple) return\n\n if (['Backspace', 'Delete'].includes(e.key)) {\n if (selectionIndex.value < 0) {\n if (e.key === 'Backspace' && !search.value) {\n selectionIndex.value = length - 1\n }\n\n return\n }\n\n const originalSelectionIndex = selectionIndex.value\n\n if (selection.value) select(selection.value)\n\n selectionIndex.value = originalSelectionIndex >= length - 1 ? (length - 2) : originalSelectionIndex\n }\n\n if (e.key === 'ArrowLeft') {\n if (selectionIndex.value < 0 && selectionStart > 0) return\n\n const prev = selectionIndex.value > -1\n ? selectionIndex.value - 1\n : length - 1\n\n if (selections.value[prev]) {\n selectionIndex.value = prev\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(search.value?.length, search.value?.length)\n }\n }\n\n if (e.key === 'ArrowRight') {\n if (selectionIndex.value < 0) return\n\n const next = selectionIndex.value + 1\n\n if (selections.value[next]) {\n selectionIndex.value = next\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(0, 0)\n }\n }\n }\n\n function onInput (e: InputEvent) {\n search.value = (e.target as HTMLInputElement).value\n }\n\n function onAfterLeave () {\n if (isFocused.value) {\n isPristine.value = true\n vTextFieldRef.value?.focus()\n }\n }\n\n function onFocusin (e: FocusEvent) {\n isFocused.value = true\n setTimeout(() => {\n listHasFocus.value = true\n })\n }\n function onFocusout (e: FocusEvent) {\n listHasFocus.value = false\n }\n\n const isSelecting = shallowRef(false)\n\n function select (item: ListItem) {\n if (props.multiple) {\n const index = selected.value.findIndex(selection => props.valueComparator(selection, item.value))\n\n if (index === -1) {\n model.value = [...model.value, item]\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n } else {\n model.value = [item]\n\n isSelecting.value = true\n\n search.value = item.title\n\n menu.value = false\n isPristine.value = true\n\n nextTick(() => (isSelecting.value = false))\n }\n }\n\n watch(isFocused, (val, oldVal) => {\n if (val === oldVal) return\n\n if (val) {\n isSelecting.value = true\n search.value = props.multiple ? '' : String(selections.value.at(-1)?.props.title ?? '')\n isPristine.value = true\n\n nextTick(() => isSelecting.value = false)\n } else {\n if (!props.multiple && !search.value) model.value = []\n else if (\n highlightFirst.value &&\n !listHasFocus.value &&\n !selections.value.some(({ value }) => value === displayItems.value[0].value)\n ) {\n select(displayItems.value[0])\n }\n menu.value = false\n search.value = ''\n selectionIndex.value = -1\n }\n })\n\n watch(search, val => {\n if (!isFocused.value || isSelecting.value) return\n\n if (val) menu.value = true\n\n isPristine.value = !val\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n const hasList = !!((!props.hideNoData || displayItems.value.length) || slots.prepend || slots.append || slots['no-data'])\n const isDirty = model.value.length > 0\n const [textFieldProps] = VTextField.filterProps(props)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n { ...textFieldProps }\n modelValue={ search.value }\n onUpdate:modelValue={ v => { if (v == null) model.value = [] } }\n v-model:focused={ isFocused.value }\n validationValue={ model.externalValue }\n dirty={ isDirty }\n onInput={ onInput }\n class={[\n 'v-autocomplete',\n `v-autocomplete--${props.multiple ? 'multiple' : 'single'}`,\n {\n 'v-autocomplete--active-menu': menu.value,\n 'v-autocomplete--chips': !!props.chips,\n 'v-autocomplete--selection-slot': !!slots.selection,\n 'v-autocomplete--selecting-index': selectionIndex.value > -1,\n },\n props.class,\n ]}\n style={ props.style }\n readonly={ props.readonly }\n placeholder={ isDirty ? undefined : props.placeholder }\n onClick:clear={ onClear }\n onMousedown:control={ onMousedownControl }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n ref={ vMenuRef }\n v-model={ menu.value }\n activator=\"parent\"\n contentClass=\"v-autocomplete__content\"\n eager={ props.eager }\n maxHeight={ 310 }\n openOnClick={ false }\n closeOnContentClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n { ...props.menuProps }\n >\n { hasList && (\n <VList\n ref={ listRef }\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n onFocusin={ onFocusin }\n onFocusout={ onFocusout }\n >\n { !displayItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? (\n <VListItem title={ t(props.noDataText) } />\n ))}\n\n { slots['prepend-item']?.() }\n\n { displayItems.value.map((item, index) => {\n const itemProps = mergeProps(item.props, {\n key: index,\n active: (highlightFirst.value && index === 0) ? true : undefined,\n onClick: () => select(item),\n })\n\n return slots.item?.({\n item,\n index,\n props: itemProps,\n }) ?? (\n <VListItem { ...itemProps }>\n {{\n prepend: ({ isSelected }) => (\n <>\n { props.multiple && !props.hideSelected ? (\n <VCheckboxBtn\n key={ item.value }\n modelValue={ isSelected }\n ripple={ false }\n tabindex=\"-1\"\n />\n ) : undefined }\n\n { item.props.prependIcon && (\n <VIcon icon={ item.props.prependIcon } />\n )}\n </>\n ),\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, getMatches(item)?.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )\n })}\n\n { slots['append-item']?.() }\n </VList>\n )}\n </VMenu>\n\n { selections.value.map((item, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(item)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n onMousedown (e: MouseEvent) {\n e.preventDefault()\n e.stopPropagation()\n },\n modelValue: true,\n 'onUpdate:modelValue': undefined,\n }\n\n return (\n <div\n key={ item.value }\n class={[\n 'v-autocomplete__selection',\n index === selectionIndex.value && [\n 'v-autocomplete__selection--selected',\n textColorClasses.value,\n ],\n ]}\n style={ index === selectionIndex.value ? textColorStyles.value : {} }\n >\n { hasChips ? (\n !slots.chip ? (\n <VChip\n key=\"chip\"\n closable={ props.closableChips }\n size=\"small\"\n text={ item.title }\n { ...slotProps }\n />\n ) : (\n <VDefaultsProvider\n key=\"chip-defaults\"\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip?.({ item, index, props: slotProps }) }\n </VDefaultsProvider>\n )\n ) : (\n slots.selection?.({ item, index }) ?? (\n <span class=\"v-autocomplete__selection-text\">\n { item.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-autocomplete__selection-comma\">,</span>\n )}\n </span>\n )\n )}\n </div>\n )\n })}\n </>\n ),\n 'append-inner': (...args) => (\n <>\n { slots['append-inner']?.(...args) }\n { props.menuIcon ? (\n <VIcon\n class=\"v-autocomplete__menu-icon\"\n icon={ props.menuIcon }\n onMousedown={ onMousedownMenuIcon }\n onClick={ noop }\n />\n ) : undefined }\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return forwardRefs({\n isFocused,\n isPristine,\n menu,\n search,\n filteredItems,\n select,\n }, vTextFieldRef)\n },\n})\n\nexport type VAutocomplete = InstanceType<typeof VAutocomplete>\n"],"mappings":"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"}
|
|
@@ -16,17 +16,15 @@
|
|
|
16
16
|
&.v-field
|
|
17
17
|
cursor: text
|
|
18
18
|
|
|
19
|
+
&--variant-outlined
|
|
20
|
+
--autocomplete-chips-margin-bottom: #{$autocomplete-chips-margin-top}
|
|
21
|
+
|
|
19
22
|
.v-field
|
|
20
23
|
.v-field__input
|
|
21
24
|
> input
|
|
22
25
|
align-self: flex-start
|
|
23
26
|
flex: 1 1
|
|
24
27
|
|
|
25
|
-
.v-field__append-inner
|
|
26
|
-
> .v-icon
|
|
27
|
-
margin-inline-start: 4px
|
|
28
|
-
transition: $autocomplete-transition
|
|
29
|
-
|
|
30
28
|
.v-field:not(.v-field--focused)
|
|
31
29
|
input
|
|
32
30
|
min-width: 0
|
|
@@ -57,13 +55,11 @@
|
|
|
57
55
|
line-height: inherit
|
|
58
56
|
max-width: 100%
|
|
59
57
|
|
|
60
|
-
&--
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
transform: rotate(180deg)
|
|
58
|
+
&--chips,
|
|
59
|
+
&--selection-slot
|
|
60
|
+
.v-field__input
|
|
61
|
+
min-height: calc(var(--v-field-input-min-height) + var(--autocomplete-chips-margin-bottom) + $autocomplete-chips-margin-top)
|
|
65
62
|
|
|
66
|
-
&--chips
|
|
67
63
|
.v-autocomplete__selection
|
|
68
64
|
margin-top: $autocomplete-chips-margin-top
|
|
69
65
|
margin-bottom: var(--autocomplete-chips-margin-bottom)
|
|
@@ -102,3 +98,11 @@
|
|
|
102
98
|
.v-field--focused
|
|
103
99
|
.v-autocomplete__selection
|
|
104
100
|
opacity: 0
|
|
101
|
+
|
|
102
|
+
&__menu-icon
|
|
103
|
+
margin-inline-start: 4px
|
|
104
|
+
transition: $autocomplete-transition
|
|
105
|
+
|
|
106
|
+
.v-autocomplete--active-menu &
|
|
107
|
+
opacity: var(--v-high-emphasis-opacity)
|
|
108
|
+
transform: rotate(180deg)
|