@vuetify/nightly 3.0.0-alpha.11 → 3.0.0-beta.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/CHANGELOG.md +2 -28
- package/dist/json/attributes.json +2472 -520
- package/dist/json/importMap.json +134 -14
- package/dist/json/tags.json +753 -112
- package/dist/json/web-types.json +11494 -5089
- package/dist/vuetify.css +4937 -2974
- package/dist/vuetify.d.ts +11788 -3139
- package/dist/vuetify.esm.js +12489 -5014
- package/dist/vuetify.esm.js.map +1 -1
- package/dist/vuetify.js +12486 -5010
- package/dist/vuetify.js.map +1 -1
- package/dist/vuetify.min.css +3 -3
- package/dist/vuetify.min.js +1393 -2
- package/dist/vuetify.min.js.map +1 -1
- package/lib/components/VAlert/VAlert.css +80 -92
- package/lib/components/VAlert/VAlert.mjs +55 -65
- package/lib/components/VAlert/VAlert.mjs.map +1 -1
- package/lib/components/VAlert/VAlert.sass +56 -76
- package/lib/components/VAlert/VAlertTitle.mjs +3 -0
- package/lib/components/VAlert/VAlertTitle.mjs.map +1 -0
- package/lib/components/VAlert/_variables.scss +18 -30
- package/lib/components/VAlert/index.mjs +2 -1
- package/lib/components/VAlert/index.mjs.map +1 -1
- package/lib/components/VApp/VApp.css +1 -2
- package/lib/components/VApp/VApp.mjs +23 -13
- package/lib/components/VApp/VApp.mjs.map +1 -1
- package/lib/components/VApp/VApp.sass +1 -2
- package/lib/components/VApp/index.mjs +1 -1
- package/lib/components/VApp/index.mjs.map +1 -1
- package/lib/components/VAppBar/VAppBar.css +4 -94
- package/lib/components/VAppBar/VAppBar.mjs +39 -100
- package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
- package/lib/components/VAppBar/VAppBar.sass +4 -87
- package/lib/components/VAppBar/VAppBarNavIcon.mjs +6 -5
- package/lib/components/VAppBar/VAppBarNavIcon.mjs.map +1 -1
- package/lib/components/VAppBar/VAppBarTitle.mjs +10 -19
- package/lib/components/VAppBar/VAppBarTitle.mjs.map +1 -1
- package/lib/components/VAppBar/_variables.scss +1 -1
- package/lib/components/VAppBar/index.mjs +3 -3
- package/lib/components/VAppBar/index.mjs.map +1 -1
- package/lib/components/VAutocomplete/VAutocomplete.css +57 -0
- package/lib/components/VAutocomplete/VAutocomplete.mjs +229 -359
- package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
- package/lib/components/VAutocomplete/VAutocomplete.sass +69 -33
- package/lib/components/VAutocomplete/_variables.scss +7 -4
- package/lib/components/VAutocomplete/index.mjs +1 -3
- package/lib/components/VAutocomplete/index.mjs.map +1 -1
- package/lib/components/VAvatar/VAvatar.css +3 -16
- package/lib/components/VAvatar/VAvatar.mjs +16 -15
- package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
- package/lib/components/VAvatar/VAvatar.sass +2 -17
- package/lib/components/VAvatar/_variables.scss +9 -2
- package/lib/components/VAvatar/index.mjs +1 -1
- package/lib/components/VAvatar/index.mjs.map +1 -1
- package/lib/components/VBadge/VBadge.css +2 -2
- package/lib/components/VBadge/VBadge.mjs +29 -19
- package/lib/components/VBadge/VBadge.mjs.map +1 -1
- package/lib/components/VBadge/VBadge.sass +2 -2
- package/lib/components/VBadge/_variables.scss +3 -2
- package/lib/components/VBadge/index.mjs +1 -1
- package/lib/components/VBadge/index.mjs.map +1 -1
- package/lib/components/VBanner/VBanner.css +16 -28
- package/lib/components/VBanner/VBanner.mjs +53 -46
- package/lib/components/VBanner/VBanner.mjs.map +1 -1
- package/lib/components/VBanner/VBanner.sass +8 -20
- package/lib/components/VBanner/VBannerActions.mjs +1 -1
- package/lib/components/VBanner/VBannerActions.mjs.map +1 -1
- package/lib/components/VBanner/VBannerText.mjs +1 -1
- package/lib/components/VBanner/VBannerText.mjs.map +1 -1
- package/lib/components/VBanner/_variables.scss +2 -6
- package/lib/components/VBanner/index.mjs +3 -5
- package/lib/components/VBanner/index.mjs.map +1 -1
- package/lib/components/VBottomNavigation/VBottomNavigation.css +38 -7
- package/lib/components/VBottomNavigation/VBottomNavigation.mjs +50 -30
- package/lib/components/VBottomNavigation/VBottomNavigation.mjs.map +1 -1
- package/lib/components/VBottomNavigation/VBottomNavigation.sass +43 -7
- package/lib/components/VBottomNavigation/_variables.scss +19 -2
- package/lib/components/VBottomNavigation/index.mjs +1 -1
- package/lib/components/VBottomNavigation/index.mjs.map +1 -1
- package/lib/components/VBreadcrumbs/VBreadcrumbs.css +7 -7
- package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +52 -47
- 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/VBreadcrumbsItem.mjs +30 -34
- package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs.map +1 -1
- package/lib/components/VBreadcrumbs/_variables.scss +1 -1
- package/lib/components/VBreadcrumbs/index.mjs +3 -3
- package/lib/components/VBreadcrumbs/index.mjs.map +1 -1
- package/lib/components/VBtn/VBtn.css +25 -91
- package/lib/components/VBtn/VBtn.mjs +31 -25
- package/lib/components/VBtn/VBtn.mjs.map +1 -1
- package/lib/components/VBtn/VBtn.sass +17 -68
- package/lib/components/VBtn/_variables.scss +6 -22
- package/lib/components/VBtn/index.mjs +1 -1
- package/lib/components/VBtn/index.mjs.map +1 -1
- package/lib/components/VBtnGroup/VBtnGroup.css +49 -0
- package/lib/components/VBtnGroup/VBtnGroup.mjs +67 -0
- package/lib/components/VBtnGroup/VBtnGroup.mjs.map +1 -0
- package/lib/components/VBtnGroup/VBtnGroup.sass +44 -0
- package/lib/components/VBtnGroup/_variables.scss +25 -0
- package/lib/components/VBtnGroup/index.mjs +2 -0
- package/lib/components/VBtnGroup/index.mjs.map +1 -0
- package/lib/components/VBtnToggle/VBtnToggle.css +3 -0
- package/lib/components/VBtnToggle/VBtnToggle.mjs +45 -39
- package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
- package/lib/components/VBtnToggle/VBtnToggle.sass +5 -97
- package/lib/components/VBtnToggle/_variables.scss +3 -10
- package/lib/components/VBtnToggle/index.mjs +1 -3
- package/lib/components/VBtnToggle/index.mjs.map +1 -1
- package/lib/components/VCalendar/VCalendar.mjs +8 -4
- package/lib/components/VCalendar/VCalendar.mjs.map +1 -1
- package/lib/components/VCalendar/VCalendarCategory.sass +67 -0
- package/lib/components/VCalendar/_variables.scss +4 -0
- package/lib/components/VCalendar/mixins/calendar-base.mjs +5 -4
- package/lib/components/VCalendar/mixins/calendar-base.mjs.map +1 -1
- package/lib/components/VCalendar/mixins/calendar-with-events.mjs +17 -11
- package/lib/components/VCalendar/mixins/calendar-with-events.mjs.map +1 -1
- package/lib/components/VCalendar/mixins/calendar-with-events.sass +7 -1
- package/lib/components/VCalendar/mixins/calendar-with-intervals.mjs +2 -1
- package/lib/components/VCalendar/mixins/calendar-with-intervals.mjs.map +1 -1
- package/lib/components/VCalendar/mixins/mouse.mjs +19 -0
- package/lib/components/VCalendar/mixins/mouse.mjs.map +1 -1
- package/lib/components/VCalendar/modes/common.mjs +7 -3
- package/lib/components/VCalendar/modes/common.mjs.map +1 -1
- package/lib/components/VCalendar/modes/stack.mjs +2 -1
- package/lib/components/VCalendar/modes/stack.mjs.map +1 -1
- package/lib/components/VCalendar/util/events.mjs +3 -1
- package/lib/components/VCalendar/util/events.mjs.map +1 -1
- package/lib/components/VCalendar/util/timestamp.mjs +19 -7
- package/lib/components/VCalendar/util/timestamp.mjs.map +1 -1
- package/lib/components/VCard/VCard.css +18 -17
- package/lib/components/VCard/VCard.mjs +67 -49
- package/lib/components/VCard/VCard.mjs.map +1 -1
- package/lib/components/VCard/VCard.sass +9 -2
- package/lib/components/VCard/VCardActions.mjs +29 -2
- package/lib/components/VCard/VCardActions.mjs.map +1 -1
- package/lib/components/VCard/VCardAvatar.mjs +1 -1
- package/lib/components/VCard/VCardAvatar.mjs.map +1 -1
- package/lib/components/VCard/VCardHeader.mjs +1 -1
- package/lib/components/VCard/VCardHeader.mjs.map +1 -1
- package/lib/components/VCard/VCardHeaderText.mjs +1 -1
- package/lib/components/VCard/VCardHeaderText.mjs.map +1 -1
- package/lib/components/VCard/VCardImg.mjs +1 -1
- package/lib/components/VCard/VCardImg.mjs.map +1 -1
- package/lib/components/VCard/VCardSubtitle.mjs +1 -1
- package/lib/components/VCard/VCardSubtitle.mjs.map +1 -1
- package/lib/components/VCard/VCardText.mjs +1 -1
- package/lib/components/VCard/VCardText.mjs.map +1 -1
- package/lib/components/VCard/VCardTitle.mjs +1 -1
- package/lib/components/VCard/VCardTitle.mjs.map +1 -1
- package/lib/components/VCard/_variables.scss +5 -5
- package/lib/components/VCard/index.mjs +9 -10
- package/lib/components/VCard/index.mjs.map +1 -1
- package/lib/components/VCarousel/VCarousel.css +63 -0
- package/lib/components/VCarousel/VCarousel.mjs +100 -179
- package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
- package/lib/components/VCarousel/VCarousel.sass +7 -2
- package/lib/components/VCarousel/VCarouselItem.mjs +23 -58
- package/lib/components/VCarousel/VCarouselItem.mjs.map +1 -1
- package/lib/components/VCarousel/_variables.scss +1 -3
- package/lib/components/VCarousel/index.mjs +2 -9
- package/lib/components/VCarousel/index.mjs.map +1 -1
- package/lib/components/VCheckbox/VCheckbox.css +3 -0
- package/lib/components/VCheckbox/VCheckbox.mjs +56 -83
- package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
- package/lib/components/VCheckbox/VCheckbox.sass +8 -8
- package/lib/components/VCheckbox/_variables.scss +2 -4
- package/lib/components/VCheckbox/index.mjs +1 -9
- package/lib/components/VCheckbox/index.mjs.map +1 -1
- package/lib/components/VChip/VChip.css +101 -81
- package/lib/components/VChip/VChip.mjs +48 -27
- package/lib/components/VChip/VChip.mjs.map +1 -1
- package/lib/components/VChip/VChip.sass +16 -15
- package/lib/components/VChip/_mixins.scss +5 -3
- package/lib/components/VChip/_variables.scss +6 -15
- package/lib/components/VChip/index.mjs +1 -1
- package/lib/components/VChip/index.mjs.map +1 -1
- package/lib/components/VChipGroup/VChipGroup.css +18 -0
- package/lib/components/VChipGroup/VChipGroup.mjs +66 -38
- package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
- package/lib/components/VChipGroup/VChipGroup.sass +11 -17
- package/lib/components/VChipGroup/_variables.scss +3 -5
- package/lib/components/VChipGroup/index.mjs +1 -3
- package/lib/components/VChipGroup/index.mjs.map +1 -1
- package/lib/components/VColorPicker/VColorPicker.css +21 -0
- package/lib/components/VColorPicker/VColorPicker.mjs +98 -128
- package/lib/components/VColorPicker/VColorPicker.mjs.map +1 -1
- package/lib/components/VColorPicker/VColorPicker.sass +10 -17
- package/lib/components/VColorPicker/VColorPickerCanvas.css +21 -0
- package/lib/components/VColorPicker/VColorPickerCanvas.mjs +139 -121
- package/lib/components/VColorPicker/VColorPickerCanvas.mjs.map +1 -1
- package/lib/components/VColorPicker/VColorPickerCanvas.sass +5 -3
- package/lib/components/VColorPicker/VColorPickerEdit.css +31 -0
- package/lib/components/VColorPicker/VColorPickerEdit.mjs +70 -130
- package/lib/components/VColorPicker/VColorPickerEdit.mjs.map +1 -1
- package/lib/components/VColorPicker/VColorPickerEdit.sass +9 -6
- package/lib/components/VColorPicker/VColorPickerPreview.css +67 -0
- package/lib/components/VColorPicker/VColorPickerPreview.mjs +64 -82
- package/lib/components/VColorPicker/VColorPickerPreview.mjs.map +1 -1
- package/lib/components/VColorPicker/VColorPickerPreview.sass +42 -39
- package/lib/components/VColorPicker/VColorPickerSwatches.css +35 -0
- package/lib/components/VColorPicker/VColorPickerSwatches.mjs +33 -53
- package/lib/components/VColorPicker/VColorPickerSwatches.mjs.map +1 -1
- package/lib/components/VColorPicker/VColorPickerSwatches.sass +6 -4
- package/lib/components/VColorPicker/_variables.scss +5 -9
- package/lib/components/VColorPicker/index.mjs +1 -5
- package/lib/components/VColorPicker/index.mjs.map +1 -1
- package/lib/components/VColorPicker/util/index.mjs +141 -97
- package/lib/components/VColorPicker/util/index.mjs.map +1 -1
- package/lib/components/VCombobox/VCombobox.css +66 -0
- package/lib/components/VCombobox/VCombobox.mjs +317 -213
- package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
- package/lib/components/VCombobox/VCombobox.sass +91 -0
- package/lib/components/VCombobox/_variables.scss +8 -0
- package/lib/components/VCombobox/index.mjs +1 -3
- package/lib/components/VCombobox/index.mjs.map +1 -1
- package/lib/components/VCounter/VCounter.css +2 -0
- package/lib/components/VCounter/VCounter.mjs +29 -14
- package/lib/components/VCounter/VCounter.mjs.map +1 -1
- package/lib/components/VCounter/VCounter.sass +3 -0
- package/lib/components/VCounter/_variables.scss +2 -0
- package/lib/components/VDataIterator/VDataIterator.mjs +14 -6
- package/lib/components/VDataIterator/VDataIterator.mjs.map +1 -1
- package/lib/components/VDataTable/MobileRow.mjs +6 -5
- package/lib/components/VDataTable/MobileRow.mjs.map +1 -1
- package/lib/components/VDataTable/Row.mjs +19 -11
- package/lib/components/VDataTable/Row.mjs.map +1 -1
- package/lib/components/VDataTable/RowGroup.mjs +5 -4
- package/lib/components/VDataTable/RowGroup.mjs.map +1 -1
- package/lib/components/VDataTable/VDataTable.mjs +5 -3
- package/lib/components/VDataTable/VDataTable.mjs.map +1 -1
- package/lib/components/VDataTable/VDataTableHeader.mjs +6 -5
- package/lib/components/VDataTable/VDataTableHeader.mjs.map +1 -1
- package/lib/components/VDataTable/VDataTableHeaderMobile.mjs +2 -2
- package/lib/components/VDataTable/VDataTableHeaderMobile.mjs.map +1 -1
- package/lib/components/VDataTable/VEditDialog.mjs +6 -5
- package/lib/components/VDataTable/VEditDialog.mjs.map +1 -1
- package/lib/components/VDatePicker/VDatePicker.mjs +2 -2
- package/lib/components/VDatePicker/VDatePicker.mjs.map +1 -1
- package/lib/components/VDatePicker/VDatePickerHeader.mjs +3 -3
- package/lib/components/VDatePicker/VDatePickerHeader.mjs.map +1 -1
- package/lib/components/VDatePicker/VDatePickerTitle.mjs +1 -1
- package/lib/components/VDatePicker/VDatePickerTitle.mjs.map +1 -1
- package/lib/components/VDatePicker/VDatePickerYears.mjs +2 -2
- package/lib/components/VDatePicker/VDatePickerYears.mjs.map +1 -1
- package/lib/components/VDatePicker/mixins/date-picker-table.mjs +5 -4
- package/lib/components/VDatePicker/mixins/date-picker-table.mjs.map +1 -1
- package/lib/components/VDatePicker/util/createNativeLocaleFormatter.mjs +6 -4
- package/lib/components/VDatePicker/util/createNativeLocaleFormatter.mjs.map +1 -1
- package/lib/components/VDatePicker/util/pad.mjs +4 -1
- package/lib/components/VDatePicker/util/pad.mjs.map +1 -1
- package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs +26 -8
- package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs.map +1 -1
- package/lib/components/VDefaultsProvider/index.mjs +1 -1
- package/lib/components/VDefaultsProvider/index.mjs.map +1 -1
- package/lib/components/VDialog/VDialog.css +8 -1
- package/lib/components/VDialog/VDialog.mjs +9 -7
- package/lib/components/VDialog/VDialog.mjs.map +1 -1
- package/lib/components/VDialog/VDialog.sass +7 -0
- package/lib/components/VDialog/index.mjs +1 -2
- package/lib/components/VDialog/index.mjs.map +1 -1
- package/lib/components/VDivider/VDivider.mjs +17 -10
- package/lib/components/VDivider/VDivider.mjs.map +1 -1
- package/lib/components/VDivider/index.mjs +1 -1
- package/lib/components/VDivider/index.mjs.map +1 -1
- package/lib/components/VExpansionPanel/VExpansionPanel.css +5 -3
- package/lib/components/VExpansionPanel/VExpansionPanel.mjs +32 -28
- package/lib/components/VExpansionPanel/VExpansionPanel.mjs.map +1 -1
- package/lib/components/VExpansionPanel/VExpansionPanel.sass +5 -1
- package/lib/components/VExpansionPanel/VExpansionPanelText.mjs +12 -10
- package/lib/components/VExpansionPanel/VExpansionPanelText.mjs.map +1 -1
- package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs +17 -15
- package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs.map +1 -1
- package/lib/components/VExpansionPanel/VExpansionPanels.mjs +26 -20
- package/lib/components/VExpansionPanel/VExpansionPanels.mjs.map +1 -1
- package/lib/components/VExpansionPanel/_variables.scss +1 -1
- package/lib/components/VExpansionPanel/index.mjs +4 -4
- package/lib/components/VExpansionPanel/index.mjs.map +1 -1
- package/lib/components/VField/VField.css +182 -160
- package/lib/components/VField/VField.mjs +124 -158
- package/lib/components/VField/VField.mjs.map +1 -1
- package/lib/components/VField/VField.sass +173 -151
- package/lib/components/VField/VFieldLabel.mjs +12 -14
- package/lib/components/VField/VFieldLabel.mjs.map +1 -1
- package/lib/components/VField/_variables.scss +14 -6
- package/lib/components/VField/index.mjs +1 -1
- package/lib/components/VField/index.mjs.map +1 -1
- package/lib/components/VFileInput/VFileInput.css +0 -33
- package/lib/components/VFileInput/VFileInput.mjs +144 -99
- package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
- package/lib/components/VFileInput/VFileInput.sass +0 -37
- package/lib/components/VFileInput/index.mjs +1 -1
- package/lib/components/VFileInput/index.mjs.map +1 -1
- package/lib/components/VFooter/VFooter.css +2 -2
- package/lib/components/VFooter/VFooter.mjs +22 -14
- package/lib/components/VFooter/VFooter.mjs.map +1 -1
- package/lib/components/VFooter/_variables.scss +2 -2
- package/lib/components/VFooter/index.mjs +1 -1
- package/lib/components/VFooter/index.mjs.map +1 -1
- package/lib/components/VForm/VForm.mjs +46 -127
- package/lib/components/VForm/VForm.mjs.map +1 -1
- package/lib/components/VForm/index.mjs +1 -3
- package/lib/components/VForm/index.mjs.map +1 -1
- package/lib/components/VGrid/VCol.mjs +5 -4
- package/lib/components/VGrid/VCol.mjs.map +1 -1
- package/lib/components/VGrid/VContainer.mjs +6 -5
- package/lib/components/VGrid/VContainer.mjs.map +1 -1
- package/lib/components/VGrid/VGrid.css +1 -1
- package/lib/components/VGrid/VRow.mjs +5 -4
- package/lib/components/VGrid/VRow.mjs.map +1 -1
- package/lib/components/VGrid/VSpacer.mjs +1 -1
- package/lib/components/VGrid/VSpacer.mjs.map +1 -1
- package/lib/components/VGrid/index.mjs +4 -4
- package/lib/components/VGrid/index.mjs.map +1 -1
- package/lib/components/VHover/VHover.mjs +8 -7
- package/lib/components/VHover/VHover.mjs.map +1 -1
- package/lib/components/VHover/index.mjs +1 -1
- package/lib/components/VHover/index.mjs.map +1 -1
- package/lib/components/VIcon/VIcon.css +2 -6
- package/lib/components/VIcon/VIcon.mjs +15 -9
- package/lib/components/VIcon/VIcon.mjs.map +1 -1
- package/lib/components/VIcon/VIcon.sass +2 -8
- package/lib/components/VIcon/_variables.scss +0 -1
- package/lib/components/VIcon/index.mjs +1 -1
- package/lib/components/VIcon/index.mjs.map +1 -1
- package/lib/components/VImg/VImg.css +8 -0
- package/lib/components/VImg/VImg.mjs +58 -27
- package/lib/components/VImg/VImg.mjs.map +1 -1
- package/lib/components/VImg/VImg.sass +10 -5
- package/lib/components/VImg/index.mjs +1 -1
- package/lib/components/VImg/index.mjs.map +1 -1
- package/lib/components/VInput/VInput.css +68 -11
- package/lib/components/VInput/VInput.mjs +95 -29
- package/lib/components/VInput/VInput.mjs.map +1 -1
- package/lib/components/VInput/VInput.sass +51 -12
- package/lib/components/VInput/_variables.scss +1 -1
- package/lib/components/VItemGroup/VItem.mjs +7 -5
- package/lib/components/VItemGroup/VItem.mjs.map +1 -1
- package/lib/components/VItemGroup/VItemGroup.mjs +8 -7
- package/lib/components/VItemGroup/VItemGroup.mjs.map +1 -1
- package/lib/components/VItemGroup/index.mjs +2 -2
- package/lib/components/VItemGroup/index.mjs.map +1 -1
- package/lib/components/VLabel/VLabel.css +12 -0
- package/lib/components/VLabel/VLabel.mjs +18 -56
- package/lib/components/VLabel/VLabel.mjs.map +1 -1
- package/lib/components/VLabel/VLabel.sass +13 -11
- package/lib/components/VLabel/_variables.scss +7 -4
- package/lib/components/VLabel/index.mjs +1 -3
- package/lib/components/VLabel/index.mjs.map +1 -1
- package/lib/components/VLayout/VLayout.css +1 -0
- package/lib/components/VLayout/VLayout.mjs +12 -7
- package/lib/components/VLayout/VLayout.mjs.map +1 -1
- package/lib/components/VLayout/VLayout.sass +1 -0
- package/lib/components/VLayout/VLayoutItem.css +1 -1
- package/lib/components/VLayout/VLayoutItem.mjs +20 -11
- package/lib/components/VLayout/VLayoutItem.mjs.map +1 -1
- package/lib/components/VLayout/VLayoutItem.sass +1 -1
- package/lib/components/VLayout/index.mjs +2 -2
- package/lib/components/VLayout/index.mjs.map +1 -1
- package/lib/components/VLazy/VLazy.mjs +7 -6
- package/lib/components/VLazy/VLazy.mjs.map +1 -1
- package/lib/components/VLazy/index.mjs +1 -1
- package/lib/components/VLazy/index.mjs.map +1 -1
- package/lib/components/VList/VList.css +6 -2
- package/lib/components/VList/VList.mjs +77 -28
- package/lib/components/VList/VList.mjs.map +1 -1
- package/lib/components/VList/VList.sass +6 -2
- package/lib/components/VList/VListChildren.mjs +53 -0
- package/lib/components/VList/VListChildren.mjs.map +1 -0
- package/lib/components/VList/VListGroup.mjs +84 -0
- package/lib/components/VList/VListGroup.mjs.map +1 -0
- package/lib/components/VList/VListImg.mjs +1 -1
- package/lib/components/VList/VListImg.mjs.map +1 -1
- package/lib/components/VList/VListItem.css +37 -18
- package/lib/components/VList/VListItem.mjs +95 -46
- package/lib/components/VList/VListItem.mjs.map +1 -1
- package/lib/components/VList/VListItem.sass +26 -6
- package/lib/components/VList/VListItemAvatar.mjs +6 -5
- package/lib/components/VList/VListItemAvatar.mjs.map +1 -1
- package/lib/components/VList/VListItemHeader.mjs +1 -1
- package/lib/components/VList/VListItemHeader.mjs.map +1 -1
- package/lib/components/VList/VListItemMedia.mjs +6 -5
- package/lib/components/VList/VListItemMedia.mjs.map +1 -1
- package/lib/components/VList/VListItemSubtitle.mjs +1 -1
- package/lib/components/VList/VListItemSubtitle.mjs.map +1 -1
- package/lib/components/VList/VListItemTitle.mjs +1 -1
- package/lib/components/VList/VListItemTitle.mjs.map +1 -1
- package/lib/components/VList/VListSubheader.mjs +25 -16
- package/lib/components/VList/VListSubheader.mjs.map +1 -1
- package/lib/components/VList/_variables.scss +4 -4
- package/lib/components/VList/index.mjs +10 -9
- package/lib/components/VList/index.mjs.map +1 -1
- package/lib/components/VList/list.mjs +31 -0
- package/lib/components/VList/list.mjs.map +1 -0
- package/lib/components/VLocaleProvider/VLocaleProvider.mjs +6 -5
- package/lib/components/VLocaleProvider/VLocaleProvider.mjs.map +1 -1
- package/lib/components/VLocaleProvider/index.mjs +1 -1
- package/lib/components/VLocaleProvider/index.mjs.map +1 -1
- package/lib/components/VMain/VMain.mjs +8 -7
- package/lib/components/VMain/VMain.mjs.map +1 -1
- package/lib/components/VMain/index.mjs +1 -1
- package/lib/components/VMain/index.mjs.map +1 -1
- package/lib/components/VMenu/VMenu.css +0 -3
- package/lib/components/VMenu/VMenu.mjs +9 -7
- package/lib/components/VMenu/VMenu.mjs.map +1 -1
- package/lib/components/VMenu/VMenu.sass +1 -3
- package/lib/components/VMenu/_variables.scss +0 -1
- package/lib/components/VMenu/index.mjs +1 -2
- package/lib/components/VMenu/index.mjs.map +1 -1
- package/lib/components/VMessages/VMessages.css +16 -0
- package/lib/components/VMessages/VMessages.mjs +42 -41
- package/lib/components/VMessages/VMessages.mjs.map +1 -1
- package/lib/components/VMessages/VMessages.sass +5 -10
- package/lib/components/VMessages/_variables.scss +3 -2
- package/lib/components/VMessages/index.mjs +1 -3
- package/lib/components/VMessages/index.mjs.map +1 -1
- package/lib/components/VNavigationDrawer/VNavigationDrawer.css +21 -9
- package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +89 -26
- package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
- package/lib/components/VNavigationDrawer/VNavigationDrawer.sass +19 -8
- package/lib/components/VNavigationDrawer/_variables.scss +1 -1
- package/lib/components/VNavigationDrawer/index.mjs +1 -1
- package/lib/components/VNavigationDrawer/index.mjs.map +1 -1
- package/lib/components/VNavigationDrawer/touch.mjs +139 -0
- package/lib/components/VNavigationDrawer/touch.mjs.map +1 -0
- package/lib/components/VNoSsr/VNoSsr.mjs +10 -18
- package/lib/components/VNoSsr/VNoSsr.mjs.map +1 -1
- package/lib/components/VNoSsr/index.mjs +1 -1
- package/lib/components/VNoSsr/index.mjs.map +1 -1
- package/lib/components/VOtpInput/VOtpInput.mjs +345 -0
- package/lib/components/VOtpInput/VOtpInput.mjs.map +1 -0
- package/lib/components/VOtpInput/VOtpInput.sass +37 -0
- package/lib/components/VOtpInput/_variables.scss +4 -0
- package/lib/components/VOtpInput/index.mjs +4 -0
- package/lib/components/VOtpInput/index.mjs.map +1 -0
- package/lib/components/VOverlay/VOverlay.css +8 -2
- package/lib/components/VOverlay/VOverlay.mjs +69 -40
- package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
- package/lib/components/VOverlay/VOverlay.sass +6 -2
- package/lib/components/VOverlay/_variables.scss +0 -1
- package/lib/components/VOverlay/index.mjs +1 -2
- package/lib/components/VOverlay/index.mjs.map +1 -1
- package/lib/components/VOverlay/positionStrategies.mjs +18 -11
- package/lib/components/VOverlay/positionStrategies.mjs.map +1 -1
- package/lib/components/VOverlay/scrollStrategies.mjs +14 -1
- package/lib/components/VOverlay/scrollStrategies.mjs.map +1 -1
- package/lib/components/VOverlay/useActivator.mjs +38 -22
- package/lib/components/VOverlay/useActivator.mjs.map +1 -1
- package/lib/components/VOverlay/util/anchor.mjs.map +1 -1
- package/lib/components/VOverlay/util/point.mjs.map +1 -1
- package/lib/components/VPagination/VPagination.mjs +44 -47
- package/lib/components/VPagination/VPagination.mjs.map +1 -1
- package/lib/components/VPagination/index.mjs +1 -2
- package/lib/components/VPagination/index.mjs.map +1 -1
- package/lib/components/VParallax/VParallax.css +7 -0
- package/lib/components/VParallax/VParallax.mjs +71 -77
- package/lib/components/VParallax/VParallax.mjs.map +1 -1
- package/lib/components/VParallax/VParallax.sass +1 -32
- package/lib/components/VParallax/index.mjs +1 -3
- package/lib/components/VParallax/index.mjs.map +1 -1
- package/lib/components/VPicker/VPicker.mjs +3 -3
- package/lib/components/VPicker/VPicker.mjs.map +1 -1
- package/lib/components/VProgressCircular/VProgressCircular.css +1 -1
- package/lib/components/VProgressCircular/VProgressCircular.mjs +26 -16
- package/lib/components/VProgressCircular/VProgressCircular.mjs.map +1 -1
- package/lib/components/VProgressCircular/_variables.scss +1 -1
- package/lib/components/VProgressCircular/index.mjs +1 -1
- package/lib/components/VProgressCircular/index.mjs.map +1 -1
- package/lib/components/VProgressLinear/VProgressLinear.css +0 -1
- package/lib/components/VProgressLinear/VProgressLinear.mjs +17 -19
- package/lib/components/VProgressLinear/VProgressLinear.mjs.map +1 -1
- package/lib/components/VProgressLinear/VProgressLinear.sass +0 -1
- package/lib/components/VProgressLinear/index.mjs +1 -1
- package/lib/components/VProgressLinear/index.mjs.map +1 -1
- package/lib/components/VRadio/VRadio.mjs +34 -0
- package/lib/components/VRadio/VRadio.mjs.map +1 -0
- package/lib/components/VRadio/index.mjs +2 -0
- package/lib/components/VRadio/index.mjs.map +1 -0
- package/lib/components/VRadioGroup/VRadioGroup.css +10 -0
- package/lib/components/VRadioGroup/VRadioGroup.mjs +66 -69
- package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
- package/lib/components/VRadioGroup/VRadioGroup.sass +7 -37
- package/lib/components/VRadioGroup/_variables.scss +3 -3
- package/lib/components/VRadioGroup/index.mjs +1 -9
- package/lib/components/VRadioGroup/index.mjs.map +1 -1
- package/lib/components/VRangeSlider/VRangeSlider.mjs +192 -211
- package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
- package/lib/components/VRangeSlider/index.mjs +1 -3
- package/lib/components/VRangeSlider/index.mjs.map +1 -1
- package/lib/components/VRating/VRating.css +1 -1
- package/lib/components/VRating/VRating.mjs +30 -24
- package/lib/components/VRating/VRating.mjs.map +1 -1
- package/lib/components/VRating/VRating.sass +3 -2
- package/lib/components/VRating/index.mjs +1 -1
- package/lib/components/VRating/index.mjs.map +1 -1
- package/lib/components/VResponsive/VResponsive.css +1 -0
- package/lib/components/VResponsive/VResponsive.mjs +7 -6
- package/lib/components/VResponsive/VResponsive.mjs.map +1 -1
- package/lib/components/VResponsive/VResponsive.sass +1 -0
- package/lib/components/VResponsive/index.mjs +1 -1
- package/lib/components/VResponsive/index.mjs.map +1 -1
- package/lib/components/VSelect/VSelect.css +34 -0
- package/lib/components/VSelect/VSelect.mjs +185 -772
- package/lib/components/VSelect/VSelect.mjs.map +1 -1
- package/lib/components/VSelect/VSelect.sass +44 -153
- package/lib/components/VSelect/_variables.scss +7 -21
- package/lib/components/VSelect/index.mjs +1 -3
- package/lib/components/VSelect/index.mjs.map +1 -1
- package/lib/components/VSelectionControl/VSelectionControl.css +97 -0
- package/lib/components/VSelectionControl/VSelectionControl.mjs +209 -0
- package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -0
- package/lib/components/VSelectionControl/VSelectionControl.sass +96 -0
- package/lib/components/VSelectionControl/_variables.scss +9 -0
- package/lib/components/VSelectionControl/index.mjs +2 -0
- package/lib/components/VSelectionControl/index.mjs.map +1 -0
- package/lib/components/VSelectionControlGroup/VSelectionControlGroup.css +3 -0
- package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +64 -0
- package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -0
- package/lib/components/VSelectionControlGroup/VSelectionControlGroup.sass +9 -0
- package/lib/components/VSelectionControlGroup/_variables.scss +4 -0
- package/lib/components/VSelectionControlGroup/index.mjs +2 -0
- package/lib/components/VSelectionControlGroup/index.mjs.map +1 -0
- package/lib/components/VSheet/VSheet.css +2 -1
- package/lib/components/VSheet/VSheet.mjs +12 -14
- package/lib/components/VSheet/VSheet.mjs.map +1 -1
- package/lib/components/VSheet/VSheet.sass +2 -0
- package/lib/components/VSheet/_variables.scss +1 -1
- package/lib/components/VSheet/index.mjs +1 -1
- package/lib/components/VSheet/index.mjs.map +1 -1
- package/lib/components/VSkeletonLoader/VSkeletonLoader.mjs +2 -2
- package/lib/components/VSkeletonLoader/VSkeletonLoader.mjs.map +1 -1
- package/lib/components/VSlideGroup/VSlideGroup.css +47 -0
- package/lib/components/VSlideGroup/VSlideGroup.mjs +275 -357
- package/lib/components/VSlideGroup/VSlideGroup.mjs.map +1 -1
- package/lib/components/VSlideGroup/VSlideGroup.sass +21 -21
- package/lib/components/VSlideGroup/VSlideGroupItem.mjs +27 -0
- package/lib/components/VSlideGroup/VSlideGroupItem.mjs.map +1 -0
- package/lib/components/VSlideGroup/_variables.scss +4 -1
- package/lib/components/VSlideGroup/helpers.mjs +54 -0
- package/lib/components/VSlideGroup/helpers.mjs.map +1 -0
- package/lib/components/VSlideGroup/index.mjs +2 -9
- package/lib/components/VSlideGroup/index.mjs.map +1 -1
- package/lib/components/VSlider/VSlider.css +48 -0
- package/lib/components/VSlider/VSlider.mjs +108 -537
- package/lib/components/VSlider/VSlider.mjs.map +1 -1
- package/lib/components/VSlider/VSlider.sass +29 -280
- package/lib/components/VSlider/VSliderThumb.css +142 -0
- package/lib/components/VSlider/VSliderThumb.mjs +165 -0
- package/lib/components/VSlider/VSliderThumb.mjs.map +1 -0
- package/lib/components/VSlider/VSliderThumb.sass +147 -0
- package/lib/components/VSlider/VSliderTrack.css +150 -0
- package/lib/components/VSlider/VSliderTrack.mjs +121 -0
- package/lib/components/VSlider/VSliderTrack.mjs.map +1 -0
- package/lib/components/VSlider/VSliderTrack.sass +159 -0
- package/lib/components/VSlider/_variables.scss +18 -13
- package/lib/components/VSlider/index.mjs +1 -3
- package/lib/components/VSlider/index.mjs.map +1 -1
- package/lib/components/VSlider/slider.mjs +300 -0
- package/lib/components/VSlider/slider.mjs.map +1 -0
- package/lib/components/VSnackbar/VSnackbar.css +136 -0
- package/lib/components/VSnackbar/VSnackbar.mjs +88 -167
- package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
- package/lib/components/VSnackbar/VSnackbar.sass +34 -69
- package/lib/components/VSnackbar/_variables.scss +20 -21
- package/lib/components/VSnackbar/index.mjs +1 -3
- package/lib/components/VSnackbar/index.mjs.map +1 -1
- package/lib/components/VSparkline/VSparkline.mjs +1 -1
- package/lib/components/VSparkline/VSparkline.mjs.map +1 -1
- package/lib/components/VSparkline/helpers/path.mjs +3 -1
- package/lib/components/VSparkline/helpers/path.mjs.map +1 -1
- package/lib/components/VSpeedDial/VSpeedDial.mjs +1 -1
- package/lib/components/VStepper/VStepper.mjs +1 -1
- package/lib/components/VStepper/VStepper.mjs.map +1 -1
- package/lib/components/VStepper/VStepper.sass +5 -1
- package/lib/components/VStepper/VStepperStep.mjs +1 -1
- package/lib/components/VStepper/_variables.scss +2 -1
- package/lib/components/VSwitch/VSwitch.css +69 -0
- package/lib/components/VSwitch/VSwitch.mjs +100 -111
- package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
- package/lib/components/VSwitch/VSwitch.sass +71 -129
- package/lib/components/VSwitch/_variables.scss +10 -23
- package/lib/components/VSwitch/index.mjs +1 -3
- package/lib/components/VSwitch/index.mjs.map +1 -1
- package/lib/components/VSystemBar/VSystemBar.css +16 -13
- package/lib/components/VSystemBar/VSystemBar.mjs +19 -19
- package/lib/components/VSystemBar/VSystemBar.mjs.map +1 -1
- package/lib/components/VSystemBar/VSystemBar.sass +11 -15
- package/lib/components/VSystemBar/_variables.scss +25 -16
- package/lib/components/VSystemBar/index.mjs +1 -1
- package/lib/components/VSystemBar/index.mjs.map +1 -1
- package/lib/components/VTable/VTable.css +143 -0
- package/lib/components/VTable/VTable.mjs +54 -0
- package/lib/components/VTable/VTable.mjs.map +1 -0
- package/lib/components/VTable/VTable.sass +156 -0
- package/lib/components/VTable/_mixins.scss +25 -0
- package/lib/components/VTable/_variables.scss +21 -0
- package/lib/components/VTable/index.mjs +2 -0
- package/lib/components/VTable/index.mjs.map +1 -0
- package/lib/components/VTabs/VTab.css +29 -0
- package/lib/components/VTabs/VTab.mjs +114 -70
- package/lib/components/VTabs/VTab.mjs.map +1 -1
- package/lib/components/VTabs/VTab.sass +30 -0
- package/lib/components/VTabs/VTabs.css +67 -0
- package/lib/components/VTabs/VTabs.mjs +81 -277
- package/lib/components/VTabs/VTabs.mjs.map +1 -1
- package/lib/components/VTabs/VTabs.sass +37 -207
- package/lib/components/VTabs/_variables.scss +10 -16
- package/lib/components/VTabs/index.mjs +2 -15
- package/lib/components/VTabs/index.mjs.map +1 -1
- package/lib/components/VTextField/VTextField.css +55 -33
- package/lib/components/VTextField/VTextField.mjs +138 -82
- package/lib/components/VTextField/VTextField.mjs.map +1 -1
- package/lib/components/VTextField/VTextField.sass +62 -38
- package/lib/components/VTextField/_variables.scss +7 -48
- package/lib/components/VTextarea/VTextarea.css +34 -0
- package/lib/components/VTextarea/VTextarea.mjs +210 -74
- package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
- package/lib/components/VTextarea/VTextarea.sass +32 -76
- package/lib/components/VTextarea/_variables.scss +2 -4
- package/lib/components/VTextarea/index.mjs +1 -3
- package/lib/components/VTextarea/index.mjs.map +1 -1
- package/lib/components/VThemeProvider/VThemeProvider.mjs +8 -7
- package/lib/components/VThemeProvider/VThemeProvider.mjs.map +1 -1
- package/lib/components/VThemeProvider/index.mjs +1 -1
- package/lib/components/VThemeProvider/index.mjs.map +1 -1
- package/lib/components/VTimePicker/VTimePicker.mjs +2 -2
- package/lib/components/VTimePicker/VTimePicker.mjs.map +1 -1
- package/lib/components/VTimePicker/VTimePickerClock.mjs +2 -2
- package/lib/components/VTimePicker/VTimePickerClock.mjs.map +1 -1
- package/lib/components/VTimePicker/VTimePickerTitle.mjs +1 -1
- package/lib/components/VTimePicker/VTimePickerTitle.mjs.map +1 -1
- package/lib/components/VTimeline/VTimeline.css +3 -3
- package/lib/components/VTimeline/VTimeline.mjs +12 -12
- package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
- package/lib/components/VTimeline/VTimelineDivider.mjs +7 -6
- package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
- package/lib/components/VTimeline/VTimelineItem.mjs +9 -10
- package/lib/components/VTimeline/VTimelineItem.mjs.map +1 -1
- package/lib/components/VTimeline/index.mjs +2 -2
- package/lib/components/VTimeline/index.mjs.map +1 -1
- package/lib/components/VToolbar/VToolbar.css +138 -0
- package/lib/components/VToolbar/VToolbar.mjs +138 -141
- package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
- package/lib/components/VToolbar/VToolbar.sass +74 -123
- package/lib/components/VToolbar/VToolbarItems.mjs +33 -0
- package/lib/components/VToolbar/VToolbarItems.mjs.map +1 -0
- package/lib/components/VToolbar/VToolbarTitle.mjs +34 -0
- package/lib/components/VToolbar/VToolbarTitle.mjs.map +1 -0
- package/lib/components/VToolbar/_variables.scss +53 -15
- package/lib/components/VToolbar/index.mjs +3 -14
- package/lib/components/VToolbar/index.mjs.map +1 -1
- package/lib/components/VTooltip/VTooltip.css +3 -2
- package/lib/components/VTooltip/VTooltip.mjs +18 -12
- package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
- package/lib/components/VTooltip/VTooltip.sass +1 -0
- package/lib/components/VTooltip/_variables.scss +2 -2
- package/lib/components/VTooltip/index.mjs +1 -1
- package/lib/components/VTooltip/index.mjs.map +1 -1
- package/lib/components/VTreeview/VTreeview.mjs +14 -7
- package/lib/components/VTreeview/VTreeview.mjs.map +1 -1
- package/lib/components/VTreeview/VTreeviewNode.mjs +4 -2
- package/lib/components/VTreeview/VTreeviewNode.mjs.map +1 -1
- package/lib/components/VValidation/VValidation.mjs +26 -0
- package/lib/components/VValidation/VValidation.mjs.map +1 -0
- package/lib/components/VValidation/index.mjs +2 -0
- package/lib/components/VValidation/index.mjs.map +1 -0
- package/lib/components/VWindow/VWindow.css +70 -0
- package/lib/components/VWindow/VWindow.mjs +166 -233
- package/lib/components/VWindow/VWindow.mjs.map +1 -1
- package/lib/components/VWindow/VWindow.sass +26 -50
- package/lib/components/VWindow/VWindowItem.mjs +72 -98
- package/lib/components/VWindow/VWindowItem.mjs.map +1 -1
- package/lib/components/VWindow/_variables.scss +2 -3
- package/lib/components/VWindow/index.mjs +2 -9
- package/lib/components/VWindow/index.mjs.map +1 -1
- package/lib/components/index.d.ts +11597 -3077
- package/lib/components/index.mjs +46 -39
- package/lib/components/index.mjs.map +1 -1
- package/lib/components/transitions/createTransition.mjs +14 -14
- package/lib/components/transitions/createTransition.mjs.map +1 -1
- package/lib/components/transitions/dialog-transition.mjs +6 -5
- package/lib/components/transitions/dialog-transition.mjs.map +1 -1
- package/lib/components/transitions/expand-transition.mjs +3 -1
- package/lib/components/transitions/expand-transition.mjs.map +1 -1
- package/lib/components/transitions/index.mjs +1 -1
- package/lib/components/transitions/index.mjs.map +1 -1
- package/lib/composables/border.mjs +3 -2
- package/lib/composables/border.mjs.map +1 -1
- package/lib/composables/defaults.mjs +29 -5
- package/lib/composables/defaults.mjs.map +1 -1
- package/lib/composables/density.mjs +3 -2
- package/lib/composables/density.mjs.map +1 -1
- package/lib/composables/display.mjs +2 -1
- package/lib/composables/display.mjs.map +1 -1
- package/lib/composables/elevation.mjs +4 -3
- package/lib/composables/elevation.mjs.map +1 -1
- package/lib/composables/filter.mjs +87 -0
- package/lib/composables/filter.mjs.map +1 -0
- package/lib/composables/focus.mjs +35 -0
- package/lib/composables/focus.mjs.map +1 -0
- package/lib/composables/form.mjs +103 -0
- package/lib/composables/form.mjs.map +1 -0
- package/lib/composables/forwardRef.mjs +42 -0
- package/lib/composables/forwardRef.mjs.map +1 -0
- package/lib/composables/group.mjs +51 -37
- package/lib/composables/group.mjs.map +1 -1
- package/lib/composables/hydration.mjs +12 -0
- package/lib/composables/hydration.mjs.map +1 -0
- package/lib/composables/icons.mjs +7 -6
- package/lib/composables/icons.mjs.map +1 -1
- package/lib/composables/index.mjs +1 -0
- package/lib/composables/index.mjs.map +1 -1
- package/lib/composables/intersectionObserver.mjs +21 -16
- package/lib/composables/intersectionObserver.mjs.map +1 -1
- package/lib/composables/layout.mjs +126 -41
- package/lib/composables/layout.mjs.map +1 -1
- package/lib/composables/loader.mjs +39 -0
- package/lib/composables/loader.mjs.map +1 -0
- package/lib/composables/locale.mjs +10 -6
- package/lib/composables/locale.mjs.map +1 -1
- package/lib/composables/nested/nested.mjs +194 -0
- package/lib/composables/nested/nested.mjs.map +1 -0
- package/lib/composables/nested/openStrategies.mjs +49 -0
- package/lib/composables/nested/openStrategies.mjs.map +1 -0
- package/lib/composables/nested/selectStrategies.mjs +157 -0
- package/lib/composables/nested/selectStrategies.mjs.map +1 -0
- package/lib/composables/overlay.mjs +30 -0
- package/lib/composables/overlay.mjs.map +1 -0
- package/lib/composables/position.mjs +3 -2
- package/lib/composables/position.mjs.map +1 -1
- package/lib/composables/proxiedModel.mjs +10 -5
- package/lib/composables/proxiedModel.mjs.map +1 -1
- package/lib/composables/refs.mjs.map +1 -1
- package/lib/composables/resizeObserver.mjs +27 -21
- package/lib/composables/resizeObserver.mjs.map +1 -1
- package/lib/composables/rounded.mjs +9 -10
- package/lib/composables/rounded.mjs.map +1 -1
- package/lib/composables/router.mjs +7 -5
- package/lib/composables/router.mjs.map +1 -1
- package/lib/composables/scroll.mjs +2 -1
- package/lib/composables/scroll.mjs.map +1 -1
- package/lib/composables/size.mjs +3 -2
- package/lib/composables/size.mjs.map +1 -1
- package/lib/composables/stack.mjs +33 -0
- package/lib/composables/stack.mjs.map +1 -0
- package/lib/composables/theme.mjs +100 -64
- package/lib/composables/theme.mjs.map +1 -1
- package/lib/composables/touch.mjs +129 -0
- package/lib/composables/touch.mjs.map +1 -0
- package/lib/composables/transition.mjs +4 -3
- package/lib/composables/transition.mjs.map +1 -1
- package/lib/composables/validation.mjs +116 -0
- package/lib/composables/validation.mjs.map +1 -0
- package/lib/composables/variant.mjs +5 -4
- package/lib/composables/variant.mjs.map +1 -1
- package/lib/directives/click-outside/index.mjs +23 -11
- package/lib/directives/click-outside/index.mjs.map +1 -1
- package/lib/directives/index.d.ts +3 -3
- package/lib/directives/intersect/index.mjs +19 -12
- package/lib/directives/intersect/index.mjs.map +1 -1
- package/lib/directives/mutate/index.mjs +13 -7
- package/lib/directives/mutate/index.mjs.map +1 -1
- package/lib/directives/resize/index.mjs +8 -5
- package/lib/directives/resize/index.mjs.map +1 -1
- package/lib/directives/ripple/index.mjs +5 -2
- package/lib/directives/ripple/index.mjs.map +1 -1
- package/lib/directives/scroll/index.mjs +9 -6
- package/lib/directives/scroll/index.mjs.map +1 -1
- package/lib/directives/touch/index.mjs +8 -4
- package/lib/directives/touch/index.mjs.map +1 -1
- package/lib/entry-bundler.mjs +3 -2
- package/lib/entry-bundler.mjs.map +1 -1
- package/lib/framework.mjs +5 -2
- package/lib/framework.mjs.map +1 -1
- package/lib/index.d.ts +282 -6
- package/lib/locale/adapters/vue-i18n.mjs +64 -0
- package/lib/locale/adapters/vue-i18n.mjs.map +1 -0
- package/lib/locale/adapters/vue-intl.mjs +67 -0
- package/lib/locale/adapters/vue-intl.mjs.map +1 -0
- package/lib/locale/cs.mjs +3 -3
- package/lib/locale/cs.mjs.map +1 -1
- package/lib/locale/es.mjs +2 -2
- package/lib/locale/es.mjs.map +1 -1
- package/lib/locale/fr.mjs +1 -1
- package/lib/locale/fr.mjs.map +1 -1
- package/lib/services/goto/easing-patterns.mjs +0 -3
- package/lib/services/goto/easing-patterns.mjs.map +1 -1
- package/lib/services/goto/index.mjs +16 -18
- package/lib/services/goto/index.mjs.map +1 -1
- package/lib/styles/generic/_colors.scss +19 -0
- package/lib/styles/main.css +297 -10
- package/lib/styles/settings/_colors.scss +430 -6
- package/lib/styles/settings/_utilities.scss +8 -0
- package/lib/styles/settings/_variables.scss +15 -13
- package/lib/styles/tools/_absolute.sass +3 -2
- package/lib/styles/tools/_variant.sass +9 -9
- package/lib/util/animation.mjs +7 -9
- package/lib/util/animation.mjs.map +1 -1
- package/lib/util/box.mjs +32 -0
- package/lib/util/box.mjs.map +1 -0
- package/lib/util/colorUtils.mjs +3 -0
- package/lib/util/colorUtils.mjs.map +1 -1
- package/lib/util/console.mjs +2 -1
- package/lib/util/console.mjs.map +1 -1
- package/lib/util/createSimpleFunctional.mjs +7 -4
- package/lib/util/createSimpleFunctional.mjs.map +1 -1
- package/lib/util/dateTimeUtils.mjs +3 -1
- package/lib/util/dateTimeUtils.mjs.map +1 -1
- package/lib/util/defineComponent.mjs +5 -1
- package/lib/util/defineComponent.mjs.map +1 -1
- package/lib/util/getCurrentInstance.mjs +19 -0
- package/lib/util/getCurrentInstance.mjs.map +1 -0
- package/lib/util/getScrollParent.mjs +1 -2
- package/lib/util/getScrollParent.mjs.map +1 -1
- package/lib/util/globals.mjs +1 -0
- package/lib/util/globals.mjs.map +1 -1
- package/lib/util/helpers.mjs +124 -17
- package/lib/util/helpers.mjs.map +1 -1
- package/lib/util/index.mjs +1 -0
- package/lib/util/propsFactory.mjs.map +1 -1
- package/lib/util/useRender.mjs +4 -2
- package/lib/util/useRender.mjs.map +1 -1
- package/package.json +57 -53
- package/lib/components/VAppBar/VAppBarTitle.css +0 -10
- package/lib/components/VAppBar/VAppBarTitle.sass +0 -10
- package/lib/components/VBanner/VBannerAvatar.mjs +0 -28
- package/lib/components/VBanner/VBannerAvatar.mjs.map +0 -1
- package/lib/components/VBanner/VBannerContent.mjs +0 -3
- package/lib/components/VBanner/VBannerContent.mjs.map +0 -1
- package/lib/components/VCheckbox/VSimpleCheckbox.mjs +0 -92
- package/lib/components/VCheckbox/VSimpleCheckbox.mjs.map +0 -1
- package/lib/components/VCheckbox/VSimpleCheckbox.sass +0 -16
- package/lib/components/VDataTable/VSimpleTable.mjs +0 -48
- package/lib/components/VDataTable/VSimpleTable.mjs.map +0 -1
- package/lib/components/VDataTable/VSimpleTable.sass +0 -179
- package/lib/components/VPagination/VPaginationBtn.mjs +0 -8
- package/lib/components/VPagination/VPaginationBtn.mjs.map +0 -1
- package/lib/components/VParallax/_variables.scss +0 -4
- package/lib/components/VRadioGroup/VRadio.mjs +0 -179
- package/lib/components/VRadioGroup/VRadio.mjs.map +0 -1
- package/lib/components/VRadioGroup/VRadio.sass +0 -25
- package/lib/components/VRangeSlider/VRangeSlider.sass +0 -19
- package/lib/components/VSelect/VSelectList.mjs +0 -251
- package/lib/components/VSelect/VSelectList.mjs.map +0 -1
- package/lib/components/VSlideGroup/VSlideItem.mjs +0 -14
- package/lib/components/VSlideGroup/VSlideItem.mjs.map +0 -1
- package/lib/components/VTabs/VTabItem.mjs +0 -23
- package/lib/components/VTabs/VTabItem.mjs.map +0 -1
- package/lib/components/VTabs/VTabsBar.mjs +0 -86
- package/lib/components/VTabs/VTabsBar.mjs.map +0 -1
- package/lib/components/VTabs/VTabsItems.mjs +0 -37
- package/lib/components/VTabs/VTabsItems.mjs.map +0 -1
- package/lib/components/VTabs/VTabsSlider.mjs +0 -20
- package/lib/components/VTabs/VTabsSlider.mjs.map +0 -1
- package/lib/components/VToolbar/_index.scss +0 -2
- package/lib/composables/index.d.ts +0 -173
- package/lib/globals.d.mjs +0 -2
- package/lib/globals.d.mjs.map +0 -1
- package/lib/mixins/activatable/index.mjs +0 -199
- package/lib/mixins/activatable/index.mjs.map +0 -1
- package/lib/mixins/applicationable/index.mjs +0 -72
- package/lib/mixins/applicationable/index.mjs.map +0 -1
- package/lib/mixins/binds-attrs/index.mjs +0 -42
- package/lib/mixins/binds-attrs/index.mjs.map +0 -1
- package/lib/mixins/button-group/index.mjs +0 -28
- package/lib/mixins/button-group/index.mjs.map +0 -1
- package/lib/mixins/colorable/index.mjs +0 -78
- package/lib/mixins/colorable/index.mjs.map +0 -1
- package/lib/mixins/comparable/index.mjs +0 -15
- package/lib/mixins/comparable/index.mjs.map +0 -1
- package/lib/mixins/dependent/index.mjs +0 -73
- package/lib/mixins/dependent/index.mjs.map +0 -1
- package/lib/mixins/elevatable/index.mjs +0 -26
- package/lib/mixins/elevatable/index.mjs.map +0 -1
- package/lib/mixins/filterable/index.mjs +0 -16
- package/lib/mixins/filterable/index.mjs.map +0 -1
- package/lib/mixins/loadable/index.mjs +0 -45
- package/lib/mixins/loadable/index.mjs.map +0 -1
- package/lib/mixins/localable/index.mjs +0 -17
- package/lib/mixins/localable/index.mjs.map +0 -1
- package/lib/mixins/mobile/index.mjs +0 -50
- package/lib/mixins/mobile/index.mjs.map +0 -1
- package/lib/mixins/overlayable/index.mjs +0 -212
- package/lib/mixins/overlayable/index.mjs.map +0 -1
- package/lib/mixins/picker/index.mjs +0 -75
- package/lib/mixins/picker/index.mjs.map +0 -1
- package/lib/mixins/picker-button/index.mjs +0 -35
- package/lib/mixins/picker-button/index.mjs.map +0 -1
- package/lib/mixins/proxyable/index.mjs +0 -50
- package/lib/mixins/proxyable/index.mjs.map +0 -1
- package/lib/mixins/returnable/index.mjs +0 -36
- package/lib/mixins/returnable/index.mjs.map +0 -1
- package/lib/mixins/rippleable/index.mjs +0 -35
- package/lib/mixins/rippleable/index.mjs.map +0 -1
- package/lib/mixins/roundable/index.mjs +0 -37
- package/lib/mixins/roundable/index.mjs.map +0 -1
- package/lib/mixins/routable/index.mjs +0 -148
- package/lib/mixins/routable/index.mjs.map +0 -1
- package/lib/mixins/selectable/index.mjs +0 -167
- package/lib/mixins/selectable/index.mjs.map +0 -1
- package/lib/mixins/stackable/index.mjs +0 -55
- package/lib/mixins/stackable/index.mjs.map +0 -1
- package/lib/mixins/themeable/index.mjs +0 -111
- package/lib/mixins/themeable/index.mjs.map +0 -1
- package/lib/mixins/toggleable/index.mjs +0 -40
- package/lib/mixins/toggleable/index.mjs.map +0 -1
- package/lib/mixins/translatable/index.mjs +0 -59
- package/lib/mixins/translatable/index.mjs.map +0 -1
- package/lib/mixins/validatable/index.mjs +0 -263
- package/lib/mixins/validatable/index.mjs.map +0 -1
- package/lib/services/application/index.mjs +0 -58
- package/lib/services/application/index.mjs.map +0 -1
- package/lib/services/breakpoint/index.mjs +0 -175
- package/lib/services/breakpoint/index.mjs.map +0 -1
- package/lib/services/index.mjs +0 -10
- package/lib/services/index.mjs.map +0 -1
- package/lib/services/lang/index.mjs +0 -73
- package/lib/services/lang/index.mjs.map +0 -1
- package/lib/services/service/index.mjs +0 -13
- package/lib/services/service/index.mjs.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/components/VIcon/VIcon.tsx"],"names":["makeSizeProps","useSize","makeTagProps","useIcon","useTextColor","computed","toRef","convertToUnit","defineComponent","flattenFragments","name","props","color","String","left","Boolean","right","icon","type","Object","tag","setup","slots","slotIcon","default","slot","filter","node","children","iconData","sizeClasses","textColorClasses","textColorStyles","value","fontSize","size","width","height","undefined"],"mappings":";AAAA;AACA,qB,CAEA;;SACSA,a,EAAeC,O;SACfC,Y;SACAC,O;SACAC,Y,
|
|
1
|
+
{"version":3,"sources":["../../../src/components/VIcon/VIcon.tsx"],"names":["makeSizeProps","useSize","makeTagProps","useIcon","useTextColor","makeThemeProps","provideTheme","computed","toRef","convertToUnit","defineComponent","flattenFragments","VIcon","name","props","color","String","left","Boolean","right","icon","type","Object","tag","setup","slots","slotIcon","default","slot","filter","node","children","themeClasses","iconData","sizeClasses","textColorClasses","textColorStyles","value","fontSize","size","width","height","undefined"],"mappings":";AAAA;AACA,qB,CAEA;;SACSA,a,EAAeC,O;SACfC,Y;SACAC,O;SACAC,Y;SACAC,c,EAAgBC,Y,uCAEzB;;AACA,SAASC,QAAT,EAAmBC,KAAnB,QAAgC,KAAhC;SACSC,a,EAAeC,e,EAAiBC,gB,gCAEzC;;AAIA,OAAO,MAAMC,KAAK,GAAGF,eAAe,CAAC;AACnCG,EAAAA,IAAI,EAAE,OAD6B;AAGnCC,EAAAA,KAAK,EAAE;AACLC,IAAAA,KAAK,EAAEC,MADF;AAELC,IAAAA,IAAI,EAAEC,OAFD;AAGLC,IAAAA,KAAK,EAAED,OAHF;AAILE,IAAAA,IAAI,EAAE;AACJC,MAAAA,IAAI,EAAE,CAACL,MAAD,EAASM,MAAT;AADF,KAJD;AAOL,OAAGtB,aAAa,EAPX;AAQL,OAAGE,YAAY,CAAC;AAAEqB,MAAAA,GAAG,EAAE;AAAP,KAAD,CARV;AASL,OAAGlB,cAAc;AATZ,GAH4B;;AAenCmB,EAAAA,KAAK,CAAEV,KAAF,QAAoB;AAAA,QAAX;AAAEW,MAAAA;AAAF,KAAW;AACvB,QAAIC,QAAJ;;AACA,QAAID,KAAK,CAACE,OAAV,EAAmB;AACjBD,MAAAA,QAAQ,GAAGnB,QAAQ,CAAC,MAAM;AAAA;;AACxB,cAAMqB,IAAI,qBAAGH,KAAK,CAACE,OAAT,qBAAG,oBAAAF,KAAK,CAAlB;AACA,YAAI,CAACG,IAAL,EAAW;AAEX,wCAAOjB,gBAAgB,CAACiB,IAAD,CAAhB,CAAuBC,MAAvB,CAA8BC,IAAI,IACvCA,IAAI,CAACC,QAAL,IAAiB,OAAOD,IAAI,CAACC,QAAZ,KAAyB,QADrC,EAEL,CAFK,CAAP,qBAAO,sBAEDA,QAFN;AAGD,OAPkB,CAAnB;AAQD;;AAED,UAAM;AAAEC,MAAAA;AAAF,QAAmB1B,YAAY,CAACQ,KAAD,CAArC;AACA,UAAM;AAAEmB,MAAAA;AAAF,QAAe9B,OAAO,CAACuB,QAAQ,IAAIZ,KAAb,CAA5B;AACA,UAAM;AAAEoB,MAAAA;AAAF,QAAkBjC,OAAO,CAACa,KAAD,CAA/B;AACA,UAAM;AAAEqB,MAAAA,gBAAF;AAAoBC,MAAAA;AAApB,QAAwChC,YAAY,CAACI,KAAK,CAACM,KAAD,EAAQ,OAAR,CAAN,CAA1D;AAEA,WAAO,MAAM;AACX;AAAA,eAEUA,KAAK,CAACS,GAFhB;AAAA,gBAGWU,QAAQ,CAACI,KAAT,CAAejB,IAH1B;AAAA,iBAIW,CACL,QADK,EAEL,aAFK,EAGLc,WAAW,CAACG,KAHP,EAILF,gBAAgB,CAACE,KAJZ,EAKLL,YAAY,CAACK,KALR,EAML;AACE,0BAAgBvB,KAAK,CAACG,IADxB;AAEE,2BAAiBH,KAAK,CAACK;AAFzB,SANK,CAJX;AAAA,iBAeW,CACL,CAACe,WAAW,CAACG,KAAb,GAAsB;AACpBC,UAAAA,QAAQ,EAAE7B,aAAa,CAACK,KAAK,CAACyB,IAAP,CADH;AAEpBC,UAAAA,KAAK,EAAE/B,aAAa,CAACK,KAAK,CAACyB,IAAP,CAFA;AAGpBE,UAAAA,MAAM,EAAEhC,aAAa,CAACK,KAAK,CAACyB,IAAP;AAHD,SAAtB,GAIKG,SALA,EAMLN,eAAe,CAACC,KANX,CAfX;AAAA,uBAuBgB;AAvBhB;AA0BD,KA3BD;AA4BD;;AA7DkC,CAAD,CAA7B","sourcesContent":["// Styles\nimport './VIcon.sass'\n\n// Composables\nimport { makeSizeProps, useSize } from '@/composables/size'\nimport { makeTagProps } from '@/composables/tag'\nimport { useIcon } from '@/composables/icons'\nimport { useTextColor } from '@/composables/color'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\n\n// Utilities\nimport { computed, toRef } from 'vue'\nimport { convertToUnit, defineComponent, flattenFragments } from '@/util'\n\n// Types\nimport type { IconValue } from '@/composables/icons'\nimport type { ComputedRef, PropType } from 'vue'\n\nexport const VIcon = defineComponent({\n name: 'VIcon',\n\n props: {\n color: String,\n left: Boolean,\n right: Boolean,\n icon: {\n type: [String, Object] as PropType<IconValue>,\n },\n ...makeSizeProps(),\n ...makeTagProps({ tag: 'i' }),\n ...makeThemeProps(),\n },\n\n setup (props, { slots }) {\n let slotIcon: ComputedRef<string | undefined> | undefined\n if (slots.default) {\n slotIcon = computed(() => {\n const slot = slots.default?.()\n if (!slot) return\n\n return flattenFragments(slot).filter(node =>\n node.children && typeof node.children === 'string'\n )[0]?.children as string\n })\n }\n\n const { themeClasses } = provideTheme(props)\n const { iconData } = useIcon(slotIcon || props)\n const { sizeClasses } = useSize(props)\n const { textColorClasses, textColorStyles } = useTextColor(toRef(props, 'color'))\n\n return () => {\n return (\n <iconData.value.component\n tag={ props.tag }\n icon={ iconData.value.icon }\n class={[\n 'v-icon',\n 'notranslate',\n sizeClasses.value,\n textColorClasses.value,\n themeClasses.value,\n {\n 'v-icon--left': props.left,\n 'v-icon--right': props.right,\n },\n ]}\n style={[\n !sizeClasses.value ? ({\n fontSize: convertToUnit(props.size),\n width: convertToUnit(props.size),\n height: convertToUnit(props.size),\n }) : undefined,\n textColorStyles.value,\n ]}\n aria-hidden=\"true\"\n />\n )\n }\n },\n})\n"],"file":"VIcon.mjs"}
|
|
@@ -29,16 +29,10 @@
|
|
|
29
29
|
|
|
30
30
|
.v-icon__svg
|
|
31
31
|
fill: currentColor
|
|
32
|
+
width: 100%
|
|
33
|
+
height: 100%
|
|
32
34
|
|
|
33
35
|
.v-icon
|
|
34
|
-
&--size-default
|
|
35
|
-
.v-btn:not(.v-btn--icon):not(.v-btn--stacked) &
|
|
36
|
-
.v-bottom-navigation &
|
|
37
|
-
font-size: $icon-btn-bottom-navigation-font-size
|
|
38
|
-
|
|
39
|
-
.v-bottom-navigation:not(.v-bottom-navigation--horizontal) &
|
|
40
|
-
margin: 0
|
|
41
|
-
|
|
42
36
|
&--left
|
|
43
37
|
.v-btn:not(.v-btn--icon) &
|
|
44
38
|
margin-inline-start: $icon-btn-margin-start
|
|
@@ -3,7 +3,6 @@
|
|
|
3
3
|
@use '../../styles/tools';
|
|
4
4
|
|
|
5
5
|
// Defaults
|
|
6
|
-
$icon-btn-bottom-navigation-font-size: 24px !default;
|
|
7
6
|
$icon-btn-margin-start-multiplier: -9 !default;
|
|
8
7
|
$icon-btn-margin-end-multiplier: 4.5 !default;
|
|
9
8
|
$icon-btn-margin-start: calc(var(--v-btn-height) / #{$icon-btn-margin-start-multiplier}) !default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/components/VIcon/index.ts"],"names":["
|
|
1
|
+
{"version":3,"sources":["../../../src/components/VIcon/index.ts"],"names":["VIcon","VComponentIcon","VSvgIcon","VLigatureIcon","VClassIcon"],"mappings":"SAASA,K;SAEPC,c,EACAC,Q,EACAC,a,EACAC,U","sourcesContent":["export { VIcon } from './VIcon'\nexport {\n VComponentIcon,\n VSvgIcon,\n VLigatureIcon,\n VClassIcon,\n} from '@/composables/icons'\n"],"file":"index.mjs"}
|
|
@@ -2,9 +2,13 @@
|
|
|
2
2
|
--v-theme-overlay-multiplier: 3;
|
|
3
3
|
z-index: 0;
|
|
4
4
|
}
|
|
5
|
+
.v-img--booting .v-responsive__sizer {
|
|
6
|
+
transition: none;
|
|
7
|
+
}
|
|
5
8
|
|
|
6
9
|
.v-img__img,
|
|
7
10
|
.v-img__picture,
|
|
11
|
+
.v-img__gradient,
|
|
8
12
|
.v-img__placeholder,
|
|
9
13
|
.v-img__error {
|
|
10
14
|
z-index: -1;
|
|
@@ -23,4 +27,8 @@
|
|
|
23
27
|
}
|
|
24
28
|
.v-img__img--cover {
|
|
25
29
|
object-fit: cover;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
.v-img__gradient {
|
|
33
|
+
background-repeat: no-repeat;
|
|
26
34
|
}
|
|
@@ -8,9 +8,9 @@ import intersect from "../../directives/intersect/index.mjs"; // Composables
|
|
|
8
8
|
import { makeTransitionProps, MaybeTransition } from "../../composables/transition.mjs"; // Utilities
|
|
9
9
|
|
|
10
10
|
import { computed, h, nextTick, onBeforeMount, ref, vShow, watch, withDirectives } from 'vue';
|
|
11
|
-
import { defineComponent, SUPPORTS_INTERSECTION, useRender } from "../../util/index.mjs"; // Types
|
|
11
|
+
import { convertToUnit, defineComponent, SUPPORTS_INTERSECTION, useRender } from "../../util/index.mjs"; // Types
|
|
12
12
|
|
|
13
|
-
export
|
|
13
|
+
export const VImg = defineComponent({
|
|
14
14
|
name: 'VImg',
|
|
15
15
|
directives: {
|
|
16
16
|
intersect
|
|
@@ -20,6 +20,7 @@ export default defineComponent({
|
|
|
20
20
|
alt: String,
|
|
21
21
|
cover: Boolean,
|
|
22
22
|
eager: Boolean,
|
|
23
|
+
gradient: String,
|
|
23
24
|
lazySrc: String,
|
|
24
25
|
options: {
|
|
25
26
|
type: Object,
|
|
@@ -31,24 +32,22 @@ export default defineComponent({
|
|
|
31
32
|
threshold: undefined
|
|
32
33
|
})
|
|
33
34
|
},
|
|
34
|
-
position: {
|
|
35
|
-
type: String,
|
|
36
|
-
default: 'center center'
|
|
37
|
-
},
|
|
38
35
|
sizes: String,
|
|
39
36
|
src: {
|
|
40
37
|
type: [String, Object],
|
|
41
38
|
default: ''
|
|
42
39
|
},
|
|
43
40
|
srcset: String,
|
|
41
|
+
width: [String, Number],
|
|
44
42
|
...makeTransitionProps()
|
|
45
43
|
},
|
|
46
44
|
emits: ['loadstart', 'load', 'error'],
|
|
47
45
|
|
|
48
|
-
setup(props, {
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
46
|
+
setup(props, _ref) {
|
|
47
|
+
let {
|
|
48
|
+
emit,
|
|
49
|
+
slots
|
|
50
|
+
} = _ref;
|
|
52
51
|
const currentSrc = ref(''); // Set from srcset
|
|
53
52
|
|
|
54
53
|
const image = ref();
|
|
@@ -81,6 +80,14 @@ export default defineComponent({
|
|
|
81
80
|
if (props.eager && isIntersecting) return;
|
|
82
81
|
if (SUPPORTS_INTERSECTION && !isIntersecting && !props.eager) return;
|
|
83
82
|
state.value = 'loading';
|
|
83
|
+
|
|
84
|
+
if (normalisedSrc.value.lazySrc) {
|
|
85
|
+
const lazyImg = new Image();
|
|
86
|
+
lazyImg.src = normalisedSrc.value.lazySrc;
|
|
87
|
+
pollForSize(lazyImg, null);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
if (!normalisedSrc.value.src) return;
|
|
84
91
|
nextTick(() => {
|
|
85
92
|
var _image$value, _image$value2;
|
|
86
93
|
|
|
@@ -99,12 +106,6 @@ export default defineComponent({
|
|
|
99
106
|
getSrc();
|
|
100
107
|
}
|
|
101
108
|
});
|
|
102
|
-
|
|
103
|
-
if (normalisedSrc.value.lazySrc) {
|
|
104
|
-
const lazyImg = new Image();
|
|
105
|
-
lazyImg.src = normalisedSrc.value.lazySrc;
|
|
106
|
-
pollForSize(lazyImg, null);
|
|
107
|
-
}
|
|
108
109
|
}
|
|
109
110
|
|
|
110
111
|
function onLoad() {
|
|
@@ -127,7 +128,9 @@ export default defineComponent({
|
|
|
127
128
|
if (img) currentSrc.value = img.currentSrc || img.src;
|
|
128
129
|
}
|
|
129
130
|
|
|
130
|
-
function pollForSize(img
|
|
131
|
+
function pollForSize(img) {
|
|
132
|
+
let timeout = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 100;
|
|
133
|
+
|
|
131
134
|
const poll = () => {
|
|
132
135
|
const {
|
|
133
136
|
naturalHeight: imgHeight,
|
|
@@ -173,9 +176,8 @@ export default defineComponent({
|
|
|
173
176
|
}, {
|
|
174
177
|
default: () => [withDirectives(sources ? _createVNode("picture", {
|
|
175
178
|
"class": "v-img__picture"
|
|
176
|
-
}, [sources, img]) : img, [[vShow, state.value === 'loaded']])]
|
|
177
|
-
|
|
178
|
-
}, 8, ["transition", "appear"]);
|
|
179
|
+
}, [sources, img]) : img, [[vShow, state.value === 'loaded']])]
|
|
180
|
+
});
|
|
179
181
|
});
|
|
180
182
|
|
|
181
183
|
const __preloadImage = computed(() => _createVNode(MaybeTransition, {
|
|
@@ -185,8 +187,8 @@ export default defineComponent({
|
|
|
185
187
|
"class": ['v-img__img', 'v-img__img--preload', containClasses.value],
|
|
186
188
|
"src": normalisedSrc.value.lazySrc,
|
|
187
189
|
"alt": ""
|
|
188
|
-
}, null
|
|
189
|
-
}
|
|
190
|
+
}, null)]
|
|
191
|
+
}));
|
|
190
192
|
|
|
191
193
|
const __placeholder = computed(() => {
|
|
192
194
|
if (!slots.placeholder) return;
|
|
@@ -197,7 +199,7 @@ export default defineComponent({
|
|
|
197
199
|
default: () => [(state.value === 'loading' || state.value === 'error' && !slots.error) && _createVNode("div", {
|
|
198
200
|
"class": "v-img__placeholder"
|
|
199
201
|
}, [slots.placeholder()])]
|
|
200
|
-
}
|
|
202
|
+
});
|
|
201
203
|
});
|
|
202
204
|
|
|
203
205
|
const __error = computed(() => {
|
|
@@ -209,18 +211,47 @@ export default defineComponent({
|
|
|
209
211
|
default: () => [state.value === 'error' && _createVNode("div", {
|
|
210
212
|
"class": "v-img__error"
|
|
211
213
|
}, [slots.error()])]
|
|
212
|
-
}
|
|
214
|
+
});
|
|
213
215
|
});
|
|
214
216
|
|
|
217
|
+
const __gradient = computed(() => {
|
|
218
|
+
if (!props.gradient) return;
|
|
219
|
+
return _createVNode("div", {
|
|
220
|
+
"class": "v-img__gradient",
|
|
221
|
+
"style": {
|
|
222
|
+
backgroundImage: `linear-gradient(${props.gradient})`
|
|
223
|
+
}
|
|
224
|
+
}, null);
|
|
225
|
+
});
|
|
226
|
+
|
|
227
|
+
const isBooted = ref(false);
|
|
228
|
+
{
|
|
229
|
+
const stop = watch(aspectRatio, val => {
|
|
230
|
+
if (val) {
|
|
231
|
+
// Doesn't work with nextTick, idk why
|
|
232
|
+
requestAnimationFrame(() => {
|
|
233
|
+
requestAnimationFrame(() => {
|
|
234
|
+
isBooted.value = true;
|
|
235
|
+
});
|
|
236
|
+
});
|
|
237
|
+
stop();
|
|
238
|
+
}
|
|
239
|
+
});
|
|
240
|
+
}
|
|
215
241
|
useRender(() => _withDirectives(_createVNode(VResponsive, {
|
|
216
|
-
"class":
|
|
242
|
+
"class": ['v-img', {
|
|
243
|
+
'v-img--booting': !isBooted.value
|
|
244
|
+
}],
|
|
245
|
+
"style": {
|
|
246
|
+
width: convertToUnit(props.width === 'auto' ? naturalWidth.value : props.width)
|
|
247
|
+
},
|
|
217
248
|
"aspectRatio": aspectRatio.value,
|
|
218
249
|
"aria-label": props.alt,
|
|
219
250
|
"role": props.alt ? 'img' : undefined
|
|
220
251
|
}, {
|
|
221
|
-
additional: () => [__image.value, __preloadImage.value, __placeholder.value, __error.value],
|
|
252
|
+
additional: () => [__image.value, __preloadImage.value, __gradient.value, __placeholder.value, __error.value],
|
|
222
253
|
default: slots.default
|
|
223
|
-
}
|
|
254
|
+
}), [[_resolveDirective("intersect"), {
|
|
224
255
|
handler: init,
|
|
225
256
|
options: props.options
|
|
226
257
|
}, null, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/components/VImg/VImg.tsx"],"names":["VResponsive","intersect","makeTransitionProps","MaybeTransition","computed","h","nextTick","onBeforeMount","ref","vShow","watch","withDirectives","defineComponent","SUPPORTS_INTERSECTION","useRender","name","directives","props","aspectRatio","String","Number","alt","cover","Boolean","eager","lazySrc","options","type","Object","default","root","undefined","rootMargin","threshold","position","sizes","src","srcset","emits","setup","emit","slots","currentSrc","image","state","naturalWidth","naturalHeight","normalisedSrc","aspect","value","init","isIntersecting","complete","onError","pollForSize","onLoad","getSrc","lazyImg","Image","img","timeout","poll","imgHeight","imgWidth","setTimeout","endsWith","startsWith","containClasses","__image","class","sources","transition","__preloadImage","__placeholder","placeholder","error","__error","additional","handler"],"mappings":"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","sourcesContent":["import './VImg.sass'\n\n// Components\nimport { VResponsive } from '@/components/VResponsive'\n\n// Directives\nimport intersect from '@/directives/intersect'\n\n// Composables\nimport { makeTransitionProps, MaybeTransition } from '@/composables/transition'\n\n// Utilities\nimport {\n computed,\n h,\n nextTick,\n onBeforeMount,\n ref,\n vShow,\n watch,\n withDirectives,\n} from 'vue'\nimport {\n defineComponent,\n SUPPORTS_INTERSECTION,\n useRender,\n} from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\n// not intended for public use, this is passed in by vuetify-loader\nexport interface srcObject {\n src?: string\n srcset?: string\n lazySrc?: string\n aspect: number\n}\n\nexport default defineComponent({\n name: 'VImg',\n\n directives: { intersect },\n\n props: {\n aspectRatio: [String, Number],\n alt: String,\n cover: Boolean,\n eager: Boolean,\n lazySrc: String,\n options: {\n type: Object as PropType<IntersectionObserverInit>,\n // For more information on types, navigate to:\n // https://developer.mozilla.org/en-US/docs/Web/API/Intersection_Observer_API\n default: () => ({\n root: undefined,\n rootMargin: undefined,\n threshold: undefined,\n }),\n },\n position: {\n type: String,\n default: 'center center',\n },\n sizes: String,\n src: {\n type: [String, Object] as PropType<string | srcObject>,\n default: '',\n },\n srcset: String,\n\n ...makeTransitionProps(),\n },\n\n emits: ['loadstart', 'load', 'error'],\n\n setup (props, { emit, slots }) {\n const currentSrc = ref('') // Set from srcset\n const image = ref<HTMLImageElement>()\n const state = ref<'idle' | 'loading' | 'loaded' | 'error'>(props.eager ? 'loading' : 'idle')\n const naturalWidth = ref<number>()\n const naturalHeight = ref<number>()\n\n const normalisedSrc = computed<srcObject>(() => {\n return props.src && typeof props.src === 'object'\n ? {\n src: props.src.src,\n srcset: props.srcset || props.src.srcset,\n lazySrc: props.lazySrc || props.src.lazySrc,\n aspect: Number(props.aspectRatio || props.src.aspect),\n } : {\n src: props.src,\n srcset: props.srcset,\n lazySrc: props.lazySrc,\n aspect: Number(props.aspectRatio || 0),\n }\n })\n const aspectRatio = computed(() => {\n return normalisedSrc.value.aspect || naturalWidth.value! / naturalHeight.value! || 0\n })\n\n watch(() => props.src, () => {\n init(state.value !== 'idle')\n })\n // TODO: getSrc when window width changes\n\n onBeforeMount(() => init())\n\n function init (isIntersecting?: boolean) {\n if (props.eager && isIntersecting) return\n if (\n SUPPORTS_INTERSECTION &&\n !isIntersecting &&\n !props.eager\n ) return\n\n state.value = 'loading'\n nextTick(() => {\n emit('loadstart', image.value?.currentSrc || normalisedSrc.value.src)\n\n if (image.value?.complete) {\n if (!image.value.naturalWidth) {\n onError()\n }\n\n if (state.value === 'error') return\n\n if (!aspectRatio.value) pollForSize(image.value, null)\n onLoad()\n } else {\n if (!aspectRatio.value) pollForSize(image.value!)\n getSrc()\n }\n })\n\n if (normalisedSrc.value.lazySrc) {\n const lazyImg = new Image()\n lazyImg.src = normalisedSrc.value.lazySrc\n pollForSize(lazyImg, null)\n }\n }\n\n function onLoad () {\n getSrc()\n state.value = 'loaded'\n emit('load', image.value?.currentSrc || normalisedSrc.value.src)\n }\n\n function onError () {\n state.value = 'error'\n emit('error', image.value?.currentSrc || normalisedSrc.value.src)\n }\n\n function getSrc () {\n const img = image.value\n if (img) currentSrc.value = img.currentSrc || img.src\n }\n\n function pollForSize (img: HTMLImageElement, timeout: number | null = 100) {\n const poll = () => {\n const { naturalHeight: imgHeight, naturalWidth: imgWidth } = img\n\n if (imgHeight || imgWidth) {\n naturalWidth.value = imgWidth\n naturalHeight.value = imgHeight\n } else if (!img.complete && state.value === 'loading' && timeout != null) {\n setTimeout(poll, timeout)\n } else if (img.currentSrc.endsWith('.svg') || img.currentSrc.startsWith('data:image/svg+xml')) {\n naturalWidth.value = 1\n naturalHeight.value = 1\n }\n }\n\n poll()\n }\n\n const containClasses = computed(() => ({\n 'v-img__img--cover': props.cover,\n 'v-img__img--contain': !props.cover,\n }))\n\n const __image = computed(() => {\n if (!normalisedSrc.value.src || state.value === 'idle') return\n\n const img = h('img', {\n class: ['v-img__img', containClasses.value],\n src: normalisedSrc.value.src,\n srcset: normalisedSrc.value.srcset,\n sizes: props.sizes,\n ref: image,\n onLoad,\n onError,\n })\n\n const sources = slots.sources?.()\n\n return (\n <MaybeTransition transition={ props.transition } appear>\n {\n withDirectives(\n sources\n ? <picture class=\"v-img__picture\">{ sources }{ img }</picture>\n : img,\n [[vShow, state.value === 'loaded']]\n )\n }\n </MaybeTransition>\n )\n })\n\n const __preloadImage = computed(() => (\n <MaybeTransition transition={ props.transition }>\n { normalisedSrc.value.lazySrc && state.value !== 'loaded' && (\n <img\n class={['v-img__img', 'v-img__img--preload', containClasses.value]}\n src={ normalisedSrc.value.lazySrc }\n alt=\"\"\n />\n )}\n </MaybeTransition>\n ))\n\n const __placeholder = computed(() => {\n if (!slots.placeholder) return\n\n return (\n <MaybeTransition transition={ props.transition } appear>\n { (state.value === 'loading' || (state.value === 'error' && !slots.error)) &&\n <div class=\"v-img__placeholder\">{ slots.placeholder() }</div>\n }\n </MaybeTransition>\n )\n })\n\n const __error = computed(() => {\n if (!slots.error) return\n\n return (\n <MaybeTransition transition={ props.transition } appear>\n { state.value === 'error' &&\n <div class=\"v-img__error\">{ slots.error() }</div>\n }\n </MaybeTransition>\n )\n })\n\n useRender(() => (\n <VResponsive\n class=\"v-img\"\n aspectRatio={ aspectRatio.value }\n aria-label={ props.alt }\n role={ props.alt ? 'img' : undefined }\n v-intersect={[{\n handler: init,\n options: props.options,\n }, null, ['once']]}\n v-slots={{\n additional: () => [__image.value, __preloadImage.value, __placeholder.value, __error.value],\n default: slots.default,\n }}\n />\n ))\n\n return {\n currentSrc,\n image,\n state,\n naturalWidth,\n naturalHeight,\n }\n },\n})\n"],"file":"VImg.mjs"}
|
|
1
|
+
{"version":3,"sources":["../../../src/components/VImg/VImg.tsx"],"names":["VResponsive","intersect","makeTransitionProps","MaybeTransition","computed","h","nextTick","onBeforeMount","ref","vShow","watch","withDirectives","convertToUnit","defineComponent","SUPPORTS_INTERSECTION","useRender","VImg","name","directives","props","aspectRatio","String","Number","alt","cover","Boolean","eager","gradient","lazySrc","options","type","Object","default","root","undefined","rootMargin","threshold","sizes","src","srcset","width","emits","setup","emit","slots","currentSrc","image","state","naturalWidth","naturalHeight","normalisedSrc","aspect","value","init","isIntersecting","lazyImg","Image","pollForSize","complete","onError","onLoad","getSrc","img","timeout","poll","imgHeight","imgWidth","setTimeout","endsWith","startsWith","containClasses","__image","class","sources","transition","__preloadImage","__placeholder","placeholder","error","__error","__gradient","backgroundImage","isBooted","stop","val","requestAnimationFrame","additional","handler"],"mappings":"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","sourcesContent":["import './VImg.sass'\n\n// Components\nimport { VResponsive } from '@/components/VResponsive'\n\n// Directives\nimport intersect from '@/directives/intersect'\n\n// Composables\nimport { makeTransitionProps, MaybeTransition } from '@/composables/transition'\n\n// Utilities\nimport {\n computed,\n h,\n nextTick,\n onBeforeMount,\n ref,\n vShow,\n watch,\n withDirectives,\n} from 'vue'\nimport {\n convertToUnit,\n defineComponent,\n SUPPORTS_INTERSECTION,\n useRender,\n} from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\n// not intended for public use, this is passed in by vuetify-loader\nexport interface srcObject {\n src?: string\n srcset?: string\n lazySrc?: string\n aspect: number\n}\n\nexport const VImg = defineComponent({\n name: 'VImg',\n\n directives: { intersect },\n\n props: {\n aspectRatio: [String, Number],\n alt: String,\n cover: Boolean,\n eager: Boolean,\n gradient: String,\n lazySrc: String,\n options: {\n type: Object as PropType<IntersectionObserverInit>,\n // For more information on types, navigate to:\n // https://developer.mozilla.org/en-US/docs/Web/API/Intersection_Observer_API\n default: () => ({\n root: undefined,\n rootMargin: undefined,\n threshold: undefined,\n }),\n },\n sizes: String,\n src: {\n type: [String, Object] as PropType<string | srcObject>,\n default: '',\n },\n srcset: String,\n width: [String, Number],\n\n ...makeTransitionProps(),\n },\n\n emits: ['loadstart', 'load', 'error'],\n\n setup (props, { emit, slots }) {\n const currentSrc = ref('') // Set from srcset\n const image = ref<HTMLImageElement>()\n const state = ref<'idle' | 'loading' | 'loaded' | 'error'>(props.eager ? 'loading' : 'idle')\n const naturalWidth = ref<number>()\n const naturalHeight = ref<number>()\n\n const normalisedSrc = computed<srcObject>(() => {\n return props.src && typeof props.src === 'object'\n ? {\n src: props.src.src,\n srcset: props.srcset || props.src.srcset,\n lazySrc: props.lazySrc || props.src.lazySrc,\n aspect: Number(props.aspectRatio || props.src.aspect),\n } : {\n src: props.src,\n srcset: props.srcset,\n lazySrc: props.lazySrc,\n aspect: Number(props.aspectRatio || 0),\n }\n })\n const aspectRatio = computed(() => {\n return normalisedSrc.value.aspect || naturalWidth.value! / naturalHeight.value! || 0\n })\n\n watch(() => props.src, () => {\n init(state.value !== 'idle')\n })\n // TODO: getSrc when window width changes\n\n onBeforeMount(() => init())\n\n function init (isIntersecting?: boolean) {\n if (props.eager && isIntersecting) return\n if (\n SUPPORTS_INTERSECTION &&\n !isIntersecting &&\n !props.eager\n ) return\n\n state.value = 'loading'\n\n if (normalisedSrc.value.lazySrc) {\n const lazyImg = new Image()\n lazyImg.src = normalisedSrc.value.lazySrc\n pollForSize(lazyImg, null)\n }\n\n if (!normalisedSrc.value.src) return\n\n nextTick(() => {\n emit('loadstart', image.value?.currentSrc || normalisedSrc.value.src)\n\n if (image.value?.complete) {\n if (!image.value.naturalWidth) {\n onError()\n }\n\n if (state.value === 'error') return\n\n if (!aspectRatio.value) pollForSize(image.value, null)\n onLoad()\n } else {\n if (!aspectRatio.value) pollForSize(image.value!)\n getSrc()\n }\n })\n }\n\n function onLoad () {\n getSrc()\n state.value = 'loaded'\n emit('load', image.value?.currentSrc || normalisedSrc.value.src)\n }\n\n function onError () {\n state.value = 'error'\n emit('error', image.value?.currentSrc || normalisedSrc.value.src)\n }\n\n function getSrc () {\n const img = image.value\n if (img) currentSrc.value = img.currentSrc || img.src\n }\n\n function pollForSize (img: HTMLImageElement, timeout: number | null = 100) {\n const poll = () => {\n const { naturalHeight: imgHeight, naturalWidth: imgWidth } = img\n\n if (imgHeight || imgWidth) {\n naturalWidth.value = imgWidth\n naturalHeight.value = imgHeight\n } else if (!img.complete && state.value === 'loading' && timeout != null) {\n setTimeout(poll, timeout)\n } else if (img.currentSrc.endsWith('.svg') || img.currentSrc.startsWith('data:image/svg+xml')) {\n naturalWidth.value = 1\n naturalHeight.value = 1\n }\n }\n\n poll()\n }\n\n const containClasses = computed(() => ({\n 'v-img__img--cover': props.cover,\n 'v-img__img--contain': !props.cover,\n }))\n\n const __image = computed(() => {\n if (!normalisedSrc.value.src || state.value === 'idle') return\n\n const img = h('img', {\n class: ['v-img__img', containClasses.value],\n src: normalisedSrc.value.src,\n srcset: normalisedSrc.value.srcset,\n sizes: props.sizes,\n ref: image,\n onLoad,\n onError,\n })\n\n const sources = slots.sources?.()\n\n return (\n <MaybeTransition transition={ props.transition } appear>\n {\n withDirectives(\n sources\n ? <picture class=\"v-img__picture\">{ sources }{ img }</picture>\n : img,\n [[vShow, state.value === 'loaded']]\n )\n }\n </MaybeTransition>\n )\n })\n\n const __preloadImage = computed(() => (\n <MaybeTransition transition={ props.transition }>\n { normalisedSrc.value.lazySrc && state.value !== 'loaded' && (\n <img\n class={['v-img__img', 'v-img__img--preload', containClasses.value]}\n src={ normalisedSrc.value.lazySrc }\n alt=\"\"\n />\n )}\n </MaybeTransition>\n ))\n\n const __placeholder = computed(() => {\n if (!slots.placeholder) return\n\n return (\n <MaybeTransition transition={ props.transition } appear>\n { (state.value === 'loading' || (state.value === 'error' && !slots.error)) &&\n <div class=\"v-img__placeholder\">{ slots.placeholder() }</div>\n }\n </MaybeTransition>\n )\n })\n\n const __error = computed(() => {\n if (!slots.error) return\n\n return (\n <MaybeTransition transition={ props.transition } appear>\n { state.value === 'error' &&\n <div class=\"v-img__error\">{ slots.error() }</div>\n }\n </MaybeTransition>\n )\n })\n\n const __gradient = computed(() => {\n if (!props.gradient) return\n\n return <div class=\"v-img__gradient\" style={{ backgroundImage: `linear-gradient(${props.gradient})` }} />\n })\n\n const isBooted = ref(false)\n {\n const stop = watch(aspectRatio, val => {\n if (val) {\n // Doesn't work with nextTick, idk why\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n isBooted.value = true\n })\n })\n stop()\n }\n })\n }\n\n useRender(() => (\n <VResponsive\n class={[\n 'v-img',\n { 'v-img--booting': !isBooted.value },\n ]}\n style={{ width: convertToUnit(props.width === 'auto' ? naturalWidth.value : props.width) }}\n aspectRatio={ aspectRatio.value }\n aria-label={ props.alt }\n role={ props.alt ? 'img' : undefined }\n v-intersect={[{\n handler: init,\n options: props.options,\n }, null, ['once']]}\n v-slots={{\n additional: () => [__image.value, __preloadImage.value, __gradient.value, __placeholder.value, __error.value],\n default: slots.default,\n }}\n />\n ))\n\n return {\n currentSrc,\n image,\n state,\n naturalWidth,\n naturalHeight,\n }\n },\n})\n\nexport type VImg = InstanceType<typeof VImg>\n"],"file":"VImg.mjs"}
|
|
@@ -1,20 +1,22 @@
|
|
|
1
1
|
@forward './variables'
|
|
2
|
+
@use '../../styles/tools'
|
|
2
3
|
@use './variables' as *
|
|
3
4
|
|
|
4
5
|
.v-img
|
|
5
6
|
--v-theme-overlay-multiplier: 3
|
|
6
7
|
z-index: 0
|
|
7
8
|
|
|
9
|
+
&--booting .v-responsive__sizer
|
|
10
|
+
transition: none
|
|
11
|
+
|
|
8
12
|
.v-img__img,
|
|
9
13
|
.v-img__picture,
|
|
14
|
+
.v-img__gradient,
|
|
10
15
|
.v-img__placeholder,
|
|
11
16
|
.v-img__error
|
|
12
17
|
z-index: -1
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
left: 0
|
|
16
|
-
width: 100%
|
|
17
|
-
height: 100%
|
|
18
|
+
|
|
19
|
+
@include tools.absolute()
|
|
18
20
|
|
|
19
21
|
.v-img__img
|
|
20
22
|
&--preload
|
|
@@ -25,3 +27,6 @@
|
|
|
25
27
|
|
|
26
28
|
&--cover
|
|
27
29
|
object-fit: cover
|
|
30
|
+
|
|
31
|
+
.v-img__gradient
|
|
32
|
+
background-repeat: no-repeat
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {
|
|
1
|
+
export { VImg } from "./VImg.mjs";
|
|
2
2
|
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/components/VImg/index.ts"],"names":["
|
|
1
|
+
{"version":3,"sources":["../../../src/components/VImg/index.ts"],"names":["VImg"],"mappings":"SAASA,I","sourcesContent":["export { VImg } from './VImg'\n"],"file":"index.mjs"}
|
|
@@ -1,53 +1,110 @@
|
|
|
1
1
|
.v-input {
|
|
2
2
|
display: grid;
|
|
3
3
|
flex: 1 1 auto;
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
4
|
+
}
|
|
5
|
+
.v-input--disabled {
|
|
6
|
+
pointer-events: none;
|
|
7
7
|
}
|
|
8
8
|
.v-input--density-default {
|
|
9
9
|
--v-input-control-height: 56px;
|
|
10
|
+
--v-input-padding-top: 16px;
|
|
10
11
|
}
|
|
11
12
|
|
|
12
13
|
.v-input--density-comfortable {
|
|
13
14
|
--v-input-control-height: 48px;
|
|
15
|
+
--v-input-padding-top: 12px;
|
|
14
16
|
}
|
|
15
17
|
|
|
16
18
|
.v-input--density-compact {
|
|
17
19
|
--v-input-control-height: 40px;
|
|
20
|
+
--v-input-padding-top: 8px;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
.v-input--vertical {
|
|
24
|
+
grid-template-areas: "append" "control" "prepend";
|
|
25
|
+
grid-template-rows: max-content auto max-content;
|
|
26
|
+
grid-template-columns: min-content;
|
|
27
|
+
}
|
|
28
|
+
.v-input--vertical .v-input__prepend {
|
|
29
|
+
margin-block-start: 16px;
|
|
30
|
+
}
|
|
31
|
+
.v-input--vertical .v-input__append {
|
|
32
|
+
margin-block-end: 16px;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
.v-input--horizontal {
|
|
36
|
+
grid-template-areas: "prepend control append" "a messages b";
|
|
37
|
+
grid-template-columns: max-content auto max-content;
|
|
38
|
+
grid-template-rows: auto auto;
|
|
39
|
+
}
|
|
40
|
+
.v-input--horizontal .v-input__prepend {
|
|
41
|
+
margin-inline-end: 16px;
|
|
42
|
+
}
|
|
43
|
+
.v-input--horizontal .v-input__append {
|
|
44
|
+
margin-inline-start: 16px;
|
|
18
45
|
}
|
|
19
46
|
|
|
20
47
|
.v-input__details {
|
|
21
48
|
align-items: flex-end;
|
|
22
|
-
color: rgba(0, 0, 0, 0.6);
|
|
23
49
|
display: flex;
|
|
24
50
|
font-size: 0.75rem;
|
|
25
51
|
font-weight: 400;
|
|
26
52
|
grid-area: messages;
|
|
27
53
|
letter-spacing: 0.0333333333em;
|
|
28
54
|
line-height: normal;
|
|
55
|
+
margin-bottom: 16px;
|
|
29
56
|
min-height: 22px;
|
|
30
57
|
padding-top: 6px;
|
|
31
58
|
overflow: hidden;
|
|
32
|
-
padding-inline-start: 16px;
|
|
33
|
-
padding-inline-end: 16px;
|
|
34
59
|
justify-content: space-between;
|
|
35
|
-
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.v-input__details > .v-icon,
|
|
63
|
+
.v-input__prepend > .v-icon,
|
|
64
|
+
.v-input__append > .v-icon {
|
|
65
|
+
opacity: var(--v-medium-emphasis-opacity);
|
|
66
|
+
}
|
|
67
|
+
.v-input--disabled .v-input__details > .v-icon,
|
|
68
|
+
.v-input--disabled .v-input__details .v-messages, .v-input--error .v-input__details > .v-icon,
|
|
69
|
+
.v-input--error .v-input__details .v-messages,
|
|
70
|
+
.v-input--disabled .v-input__prepend > .v-icon,
|
|
71
|
+
.v-input--disabled .v-input__prepend .v-messages,
|
|
72
|
+
.v-input--error .v-input__prepend > .v-icon,
|
|
73
|
+
.v-input--error .v-input__prepend .v-messages,
|
|
74
|
+
.v-input--disabled .v-input__append > .v-icon,
|
|
75
|
+
.v-input--disabled .v-input__append .v-messages,
|
|
76
|
+
.v-input--error .v-input__append > .v-icon,
|
|
77
|
+
.v-input--error .v-input__append .v-messages {
|
|
78
|
+
opacity: 1;
|
|
79
|
+
}
|
|
80
|
+
.v-input--disabled .v-input__details,
|
|
81
|
+
.v-input--disabled .v-input__prepend,
|
|
82
|
+
.v-input--disabled .v-input__append {
|
|
83
|
+
opacity: var(--v-disabled-opacity);
|
|
84
|
+
}
|
|
85
|
+
.v-input--error:not(.v-input--disabled) .v-input__details > .v-icon,
|
|
86
|
+
.v-input--error:not(.v-input--disabled) .v-input__details .v-messages,
|
|
87
|
+
.v-input--error:not(.v-input--disabled) .v-input__prepend > .v-icon,
|
|
88
|
+
.v-input--error:not(.v-input--disabled) .v-input__prepend .v-messages,
|
|
89
|
+
.v-input--error:not(.v-input--disabled) .v-input__append > .v-icon,
|
|
90
|
+
.v-input--error:not(.v-input--disabled) .v-input__append .v-messages {
|
|
91
|
+
color: rgb(var(--v-theme-error));
|
|
36
92
|
}
|
|
37
93
|
|
|
38
94
|
.v-input__prepend,
|
|
39
95
|
.v-input__append {
|
|
40
96
|
display: flex;
|
|
41
|
-
|
|
42
|
-
align-self: center;
|
|
97
|
+
padding-top: var(--v-input-padding-top);
|
|
43
98
|
}
|
|
44
99
|
|
|
45
100
|
.v-input__prepend {
|
|
46
|
-
margin-inline-end: 16px;
|
|
47
101
|
grid-area: prepend;
|
|
48
102
|
}
|
|
49
103
|
|
|
50
104
|
.v-input__append {
|
|
51
|
-
margin-inline-start: 16px;
|
|
52
105
|
grid-area: append;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
.v-input__control {
|
|
109
|
+
grid-area: control;
|
|
53
110
|
}
|