vuetify 3.3.2 → 3.3.4
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 +2 -0
- package/dist/json/attributes.json +460 -20
- package/dist/json/importMap-labs.json +32 -0
- package/dist/json/importMap.json +24 -24
- package/dist/json/tags.json +150 -0
- package/dist/json/web-types.json +1639 -40
- package/dist/vuetify-labs.css +499 -230
- package/dist/vuetify-labs.d.ts +5421 -326
- package/dist/vuetify-labs.esm.js +2124 -1098
- package/dist/vuetify-labs.esm.js.map +1 -1
- package/dist/vuetify-labs.js +2123 -1097
- package/dist/vuetify-labs.min.css +2 -2
- package/dist/vuetify.css +219 -210
- package/dist/vuetify.d.ts +314 -165
- package/dist/vuetify.esm.js +330 -179
- package/dist/vuetify.esm.js.map +1 -1
- package/dist/vuetify.js +329 -178
- package/dist/vuetify.js.map +1 -1
- package/dist/vuetify.min.css +2 -2
- package/dist/vuetify.min.js +792 -784
- package/dist/vuetify.min.js.map +1 -1
- package/lib/blueprints/index.d.mts +34 -27
- package/lib/blueprints/md1.d.mts +34 -27
- package/lib/blueprints/md2.d.mts +34 -27
- package/lib/blueprints/md3.d.mts +34 -27
- package/lib/components/VAppBar/VAppBar.mjs +3 -10
- package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
- package/lib/components/VAppBar/index.d.mts +24 -8
- package/lib/components/VAutocomplete/VAutocomplete.css +4 -22
- package/lib/components/VAutocomplete/VAutocomplete.mjs +17 -12
- package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
- package/lib/components/VAutocomplete/VAutocomplete.sass +6 -17
- package/lib/components/VBreadcrumbs/index.d.mts +7 -7
- package/lib/components/VBtn/VBtn.css +11 -11
- package/lib/components/VBtn/VBtn.mjs +1 -1
- package/lib/components/VBtn/VBtn.mjs.map +1 -1
- package/lib/components/VBtn/VBtn.sass +1 -1
- package/lib/components/VBtn/_mixins.scss +1 -1
- package/lib/components/VBtn/index.d.mts +24 -8
- package/lib/components/VCard/VCard.mjs +1 -1
- package/lib/components/VCard/VCard.mjs.map +1 -1
- package/lib/components/VCard/index.d.mts +44 -28
- package/lib/components/VCheckbox/VCheckbox.mjs +8 -1
- package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
- package/lib/components/VCheckbox/index.d.mts +7 -1
- package/lib/components/VChip/VChip.css +67 -67
- package/lib/components/VChip/VChip.mjs +2 -2
- package/lib/components/VChip/VChip.mjs.map +1 -1
- package/lib/components/VChip/_variables.scss +1 -1
- package/lib/components/VChip/index.d.mts +48 -32
- package/lib/components/VCombobox/VCombobox.css +4 -22
- package/lib/components/VCombobox/VCombobox.mjs +16 -8
- package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
- package/lib/components/VCombobox/VCombobox.sass +6 -17
- package/lib/components/VCombobox/_variables.scss +3 -3
- package/lib/components/VCounter/index.d.mts +8 -8
- package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs +1 -1
- package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs.map +1 -1
- package/lib/components/VExpansionPanel/index.d.mts +56 -24
- package/lib/components/VField/VField.css +72 -8
- package/lib/components/VField/VField.sass +10 -5
- package/lib/components/VField/_mixins.sass +7 -0
- package/lib/components/VFileInput/VFileInput.css +2 -17
- package/lib/components/VFileInput/VFileInput.mjs +0 -2
- package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
- package/lib/components/VFileInput/VFileInput.sass +2 -11
- package/lib/components/VFileInput/_variables.scss +3 -3
- package/lib/components/VIcon/VIcon.mjs +2 -2
- package/lib/components/VIcon/VIcon.mjs.map +1 -1
- package/lib/components/VInput/VInput.css +14 -1
- package/lib/components/VInput/VInput.sass +6 -0
- package/lib/components/VInput/_variables.scss +5 -1
- package/lib/components/VList/VListItem.mjs +2 -2
- package/lib/components/VList/VListItem.mjs.map +1 -1
- package/lib/components/VList/index.d.mts +24 -8
- package/lib/components/VMenu/VMenu.mjs +29 -3
- package/lib/components/VMenu/VMenu.mjs.map +1 -1
- package/lib/components/VOverlay/VOverlay.mjs +7 -4
- package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
- package/lib/components/VOverlay/useActivator.mjs +29 -35
- package/lib/components/VOverlay/useActivator.mjs.map +1 -1
- package/lib/components/VSelect/VSelect.css +2 -20
- package/lib/components/VSelect/VSelect.mjs +16 -11
- package/lib/components/VSelect/VSelect.mjs.map +1 -1
- package/lib/components/VSelect/VSelect.sass +2 -12
- package/lib/components/VSelect/_variables.scss +3 -3
- package/lib/components/VSlider/VSliderThumb.mjs +2 -2
- package/lib/components/VSlider/VSliderThumb.mjs.map +1 -1
- package/lib/components/VTabs/VTab.mjs +2 -2
- package/lib/components/VTabs/VTab.mjs.map +1 -1
- package/lib/components/VTabs/VTabs.css +1 -0
- package/lib/components/VTabs/VTabs.sass +1 -0
- package/lib/components/VTabs/index.d.mts +24 -8
- package/lib/components/VTextarea/VTextarea.css +7 -7
- package/lib/components/VTextarea/VTextarea.sass +9 -9
- package/lib/components/VTimePicker/VTimePickerTitle.mjs +1 -1
- package/lib/components/index.d.mts +266 -132
- package/lib/components/index.mjs +1 -2
- package/lib/components/index.mjs.map +1 -1
- package/lib/composables/icons.mjs.map +1 -1
- package/lib/composables/list-items.mjs +5 -2
- package/lib/composables/list-items.mjs.map +1 -1
- package/lib/composables/nested/nested.mjs +1 -1
- package/lib/composables/nested/nested.mjs.map +1 -1
- package/lib/composables/theme.mjs +1 -1
- package/lib/composables/theme.mjs.map +1 -1
- package/lib/entry-bundler.mjs +1 -1
- package/lib/framework.mjs +1 -1
- package/lib/iconsets/fa-svg.d.mts +1 -0
- package/lib/iconsets/fa.d.mts +1 -0
- package/lib/iconsets/fa.mjs +2 -1
- package/lib/iconsets/fa.mjs.map +1 -1
- package/lib/iconsets/fa4.d.mts +1 -0
- package/lib/iconsets/fa4.mjs +2 -1
- package/lib/iconsets/fa4.mjs.map +1 -1
- package/lib/iconsets/md.d.mts +1 -0
- package/lib/iconsets/md.mjs +2 -1
- package/lib/iconsets/md.mjs.map +1 -1
- package/lib/iconsets/mdi-svg.d.mts +1 -0
- package/lib/iconsets/mdi-svg.mjs +36 -35
- package/lib/iconsets/mdi-svg.mjs.map +1 -1
- package/lib/iconsets/mdi.d.mts +1 -0
- package/lib/iconsets/mdi.mjs +2 -1
- package/lib/iconsets/mdi.mjs.map +1 -1
- package/lib/index.d.mts +48 -33
- package/lib/labs/VDataTable/VDataTable.css +4 -14
- package/lib/labs/VDataTable/VDataTable.sass +6 -15
- package/lib/labs/VDataTable/VDataTableHeaders.mjs +2 -2
- package/lib/labs/VDataTable/VDataTableHeaders.mjs.map +1 -1
- package/lib/labs/VDataTable/VDataTableVirtual.mjs +16 -12
- package/lib/labs/VDataTable/VDataTableVirtual.mjs.map +1 -1
- package/lib/labs/VDataTable/composables/headers.mjs +2 -5
- package/lib/labs/VDataTable/composables/headers.mjs.map +1 -1
- package/lib/labs/VDataTable/composables/select.mjs +3 -2
- package/lib/labs/VDataTable/composables/select.mjs.map +1 -1
- package/lib/labs/VDateInput/VDateInput.mjs +127 -0
- package/lib/labs/VDateInput/VDateInput.mjs.map +1 -0
- package/lib/labs/VDateInput/VDateInput.sass +11 -0
- package/lib/labs/VDateInput/VDateRangeInput.mjs +223 -0
- package/lib/labs/VDateInput/VDateRangeInput.mjs.map +1 -0
- package/lib/labs/VDateInput/VDateRangeInput.sass +10 -0
- package/lib/labs/VDateInput/composables.mjs +59 -0
- package/lib/labs/VDateInput/composables.mjs.map +1 -0
- package/lib/labs/VDateInput/index.d.mts +1352 -0
- package/lib/labs/VDateInput/index.mjs +3 -0
- package/lib/labs/VDateInput/index.mjs.map +1 -0
- package/lib/labs/VDatePicker/VDateCard.css +33 -0
- package/lib/labs/VDatePicker/VDateCard.mjs +112 -0
- package/lib/labs/VDatePicker/VDateCard.mjs.map +1 -0
- package/lib/labs/VDatePicker/VDateCard.sass +32 -0
- package/lib/labs/VDatePicker/VDatePicker.css +23 -0
- package/lib/labs/VDatePicker/VDatePicker.mjs +172 -0
- package/lib/labs/VDatePicker/VDatePicker.mjs.map +1 -0
- package/lib/labs/VDatePicker/VDatePicker.sass +23 -0
- package/lib/labs/VDatePicker/VDatePickerControls.css +15 -0
- package/lib/labs/VDatePicker/VDatePickerControls.mjs +80 -0
- package/lib/labs/VDatePicker/VDatePickerControls.mjs.map +1 -0
- package/lib/labs/VDatePicker/VDatePickerControls.sass +15 -0
- package/lib/labs/VDatePicker/VDatePickerHeader.css +54 -0
- package/lib/labs/VDatePicker/VDatePickerHeader.mjs +75 -0
- package/lib/labs/VDatePicker/VDatePickerHeader.mjs.map +1 -0
- package/lib/labs/VDatePicker/VDatePickerHeader.sass +51 -0
- package/lib/labs/VDatePicker/VDatePickerInput.sass +17 -0
- package/lib/labs/VDatePicker/VDatePickerMonth.css +77 -0
- package/lib/labs/VDatePicker/VDatePickerMonth.mjs +286 -0
- package/lib/labs/VDatePicker/VDatePickerMonth.mjs.map +1 -0
- package/lib/labs/VDatePicker/VDatePickerMonth.sass +69 -0
- package/lib/{components → labs}/VDatePicker/VDatePickerTitle.mjs +1 -1
- package/lib/labs/VDatePicker/VDatePickerTitle.mjs.map +1 -0
- package/lib/labs/VDatePicker/VDatePickerYears.css +18 -0
- package/lib/labs/VDatePicker/VDatePickerYears.mjs +64 -0
- package/lib/labs/VDatePicker/VDatePickerYears.mjs.map +1 -0
- package/lib/labs/VDatePicker/VDatePickerYears.sass +16 -0
- package/lib/labs/VDatePicker/composables.mjs +33 -0
- package/lib/labs/VDatePicker/composables.mjs.map +1 -0
- package/lib/labs/VDatePicker/index.d.mts +4430 -0
- package/lib/labs/VDatePicker/index.mjs +7 -0
- package/lib/labs/VDatePicker/index.mjs.map +1 -0
- package/lib/labs/VDatePicker/mixins/date-picker-table.mjs.map +1 -0
- package/lib/labs/VDatePicker/util/createNativeLocaleFormatter.mjs.map +1 -0
- package/lib/labs/VDatePicker/util/eventHelpers.mjs.map +1 -0
- package/lib/labs/VDatePicker/util/index.mjs.map +1 -0
- package/lib/labs/VDatePicker/util/isDateAllowed.mjs.map +1 -0
- package/lib/labs/VDatePicker/util/monthChange.mjs.map +1 -0
- package/lib/labs/VDatePicker/util/pad.mjs.map +1 -0
- package/lib/labs/VDatePicker/util/sanitizeDateString.mjs.map +1 -0
- package/lib/labs/VDatePicker/utils.mjs +69 -0
- package/lib/labs/VDatePicker/utils.mjs.map +1 -0
- package/lib/labs/VDateRangePicker/VDateRangeCard.mjs +87 -0
- package/lib/labs/VDateRangePicker/VDateRangeCard.mjs.map +1 -0
- package/lib/labs/VDateRangePicker/VDateRangeCard.sass +33 -0
- package/lib/labs/VDateRangePicker/VDateRangePicker.mjs +131 -0
- package/lib/labs/VDateRangePicker/VDateRangePicker.mjs.map +1 -0
- package/lib/labs/VDateRangePicker/VDateRangePicker.sass +21 -0
- package/lib/labs/VDateRangePicker/VDateRangePickerHeader.mjs +103 -0
- package/lib/labs/VDateRangePicker/VDateRangePickerHeader.mjs.map +1 -0
- package/lib/labs/VDateRangePicker/VDateRangePickerHeader.sass +39 -0
- package/lib/labs/VDateRangePicker/VDateRangePickerMonth.mjs +61 -0
- package/lib/labs/VDateRangePicker/VDateRangePickerMonth.mjs.map +1 -0
- package/lib/labs/VDateRangePicker/VDateRangePickerMonth.sass +12 -0
- package/lib/labs/VDateRangePicker/index.d.mts +1065 -0
- package/lib/labs/VDateRangePicker/index.mjs +3 -0
- package/lib/labs/VDateRangePicker/index.mjs.map +1 -0
- package/lib/labs/VPicker/VPicker.css +57 -0
- package/lib/labs/VPicker/VPicker.mjs +47 -0
- package/lib/labs/VPicker/VPicker.mjs.map +1 -0
- package/lib/labs/VPicker/VPicker.sass +53 -0
- package/lib/labs/VPicker/VPickerTitle.mjs +4 -0
- package/lib/labs/VPicker/VPickerTitle.mjs.map +1 -0
- package/lib/labs/VPicker/index.d.mts +541 -0
- package/lib/labs/VPicker/index.mjs +3 -0
- package/lib/labs/VPicker/index.mjs.map +1 -0
- package/lib/labs/components.d.mts +5136 -198
- package/lib/labs/components.mjs +2 -0
- package/lib/labs/components.mjs.map +1 -1
- package/lib/labs/date/DateAdapter.mjs.map +1 -1
- package/lib/labs/date/adapters/vuetify.d.mts +28 -25
- package/lib/labs/date/adapters/vuetify.mjs +65 -75
- package/lib/labs/date/adapters/vuetify.mjs.map +1 -1
- package/lib/labs/date/date.mjs +82 -11
- package/lib/labs/date/date.mjs.map +1 -1
- package/lib/labs/date/index.d.mts +31 -30
- package/lib/locale/af.mjs +14 -5
- package/lib/locale/af.mjs.map +1 -1
- package/lib/locale/ar.mjs +14 -5
- package/lib/locale/ar.mjs.map +1 -1
- package/lib/locale/az.mjs +14 -5
- package/lib/locale/az.mjs.map +1 -1
- package/lib/locale/bg.mjs +14 -5
- package/lib/locale/bg.mjs.map +1 -1
- package/lib/locale/ca.mjs +14 -5
- package/lib/locale/ca.mjs.map +1 -1
- package/lib/locale/ckb.mjs +14 -5
- package/lib/locale/ckb.mjs.map +1 -1
- package/lib/locale/cs.mjs +14 -5
- package/lib/locale/cs.mjs.map +1 -1
- package/lib/locale/da.mjs +14 -5
- package/lib/locale/da.mjs.map +1 -1
- package/lib/locale/de.mjs +14 -5
- package/lib/locale/de.mjs.map +1 -1
- package/lib/locale/el.mjs +14 -5
- package/lib/locale/el.mjs.map +1 -1
- package/lib/locale/en.mjs +14 -5
- package/lib/locale/en.mjs.map +1 -1
- package/lib/locale/es.mjs +14 -5
- package/lib/locale/es.mjs.map +1 -1
- package/lib/locale/et.mjs +14 -5
- package/lib/locale/et.mjs.map +1 -1
- package/lib/locale/fa.mjs +14 -5
- package/lib/locale/fa.mjs.map +1 -1
- package/lib/locale/fi.mjs +14 -5
- package/lib/locale/fi.mjs.map +1 -1
- package/lib/locale/fr.mjs +14 -5
- package/lib/locale/fr.mjs.map +1 -1
- package/lib/locale/he.mjs +14 -5
- package/lib/locale/he.mjs.map +1 -1
- package/lib/locale/hr.mjs +14 -5
- package/lib/locale/hr.mjs.map +1 -1
- package/lib/locale/hu.mjs +14 -5
- package/lib/locale/hu.mjs.map +1 -1
- package/lib/locale/id.mjs +14 -5
- package/lib/locale/id.mjs.map +1 -1
- package/lib/locale/index.d.mts +588 -210
- package/lib/locale/it.mjs +14 -5
- package/lib/locale/it.mjs.map +1 -1
- package/lib/locale/ja.mjs +14 -5
- package/lib/locale/ja.mjs.map +1 -1
- package/lib/locale/ko.mjs +14 -5
- package/lib/locale/ko.mjs.map +1 -1
- package/lib/locale/lt.mjs +14 -5
- package/lib/locale/lt.mjs.map +1 -1
- package/lib/locale/lv.mjs +14 -5
- package/lib/locale/lv.mjs.map +1 -1
- package/lib/locale/nl.mjs +14 -5
- package/lib/locale/nl.mjs.map +1 -1
- package/lib/locale/no.mjs +14 -5
- package/lib/locale/no.mjs.map +1 -1
- package/lib/locale/pl.mjs +14 -5
- package/lib/locale/pl.mjs.map +1 -1
- package/lib/locale/pt.mjs +14 -5
- package/lib/locale/pt.mjs.map +1 -1
- package/lib/locale/ro.mjs +14 -5
- package/lib/locale/ro.mjs.map +1 -1
- package/lib/locale/ru.mjs +14 -5
- package/lib/locale/ru.mjs.map +1 -1
- package/lib/locale/sk.mjs +14 -5
- package/lib/locale/sk.mjs.map +1 -1
- package/lib/locale/sl.mjs +14 -5
- package/lib/locale/sl.mjs.map +1 -1
- package/lib/locale/sr-Cyrl.mjs +14 -5
- package/lib/locale/sr-Cyrl.mjs.map +1 -1
- package/lib/locale/sr-Latn.mjs +14 -5
- package/lib/locale/sr-Latn.mjs.map +1 -1
- package/lib/locale/sv.mjs +14 -5
- package/lib/locale/sv.mjs.map +1 -1
- package/lib/locale/th.mjs +14 -5
- package/lib/locale/th.mjs.map +1 -1
- package/lib/locale/tr.mjs +14 -5
- package/lib/locale/tr.mjs.map +1 -1
- package/lib/locale/uk.mjs +14 -5
- package/lib/locale/uk.mjs.map +1 -1
- package/lib/locale/vi.mjs +14 -5
- package/lib/locale/vi.mjs.map +1 -1
- package/lib/locale/zh-Hans.mjs +14 -5
- package/lib/locale/zh-Hans.mjs.map +1 -1
- package/lib/locale/zh-Hant.mjs +14 -5
- package/lib/locale/zh-Hant.mjs.map +1 -1
- package/lib/util/bindProps.mjs +49 -0
- package/lib/util/bindProps.mjs.map +1 -0
- package/lib/util/dateTimeUtils.mjs +68 -0
- package/lib/util/dateTimeUtils.mjs.map +1 -1
- package/lib/util/helpers.mjs +3 -0
- package/lib/util/helpers.mjs.map +1 -1
- package/lib/util/index.mjs +1 -0
- package/lib/util/index.mjs.map +1 -1
- package/package.json +5 -2
- package/lib/components/VDatePicker/VDatePicker.mjs +0 -475
- package/lib/components/VDatePicker/VDatePicker.mjs.map +0 -1
- package/lib/components/VDatePicker/VDatePickerDateTable.mjs +0 -120
- package/lib/components/VDatePicker/VDatePickerDateTable.mjs.map +0 -1
- package/lib/components/VDatePicker/VDatePickerHeader.mjs +0 -136
- package/lib/components/VDatePicker/VDatePickerHeader.mjs.map +0 -1
- package/lib/components/VDatePicker/VDatePickerHeader.sass +0 -46
- package/lib/components/VDatePicker/VDatePickerMonthTable.mjs +0 -48
- package/lib/components/VDatePicker/VDatePickerMonthTable.mjs.map +0 -1
- package/lib/components/VDatePicker/VDatePickerTitle.mjs.map +0 -1
- package/lib/components/VDatePicker/VDatePickerYears.mjs +0 -84
- package/lib/components/VDatePicker/VDatePickerYears.mjs.map +0 -1
- package/lib/components/VDatePicker/VDatePickerYears.sass +0 -30
- package/lib/components/VDatePicker/index.mjs +0 -18
- package/lib/components/VDatePicker/index.mjs.map +0 -1
- package/lib/components/VDatePicker/mixins/date-picker-table.mjs.map +0 -1
- package/lib/components/VDatePicker/util/createNativeLocaleFormatter.mjs.map +0 -1
- package/lib/components/VDatePicker/util/eventHelpers.mjs.map +0 -1
- package/lib/components/VDatePicker/util/index.mjs.map +0 -1
- package/lib/components/VDatePicker/util/isDateAllowed.mjs.map +0 -1
- package/lib/components/VDatePicker/util/monthChange.mjs.map +0 -1
- package/lib/components/VDatePicker/util/pad.mjs.map +0 -1
- package/lib/components/VDatePicker/util/sanitizeDateString.mjs.map +0 -1
- package/lib/components/VPicker/VPicker.mjs +0 -86
- package/lib/components/VPicker/VPicker.mjs.map +0 -1
- package/lib/components/VPicker/VPicker.sass +0 -94
- package/lib/components/VPicker/index.mjs +0 -4
- package/lib/components/VPicker/index.mjs.map +0 -1
- /package/lib/{components → labs}/VDatePicker/VDatePickerTable.sass +0 -0
- /package/lib/{components → labs}/VDatePicker/VDatePickerTitle.sass +0 -0
- /package/lib/{components → labs}/VDatePicker/_variables.scss +0 -0
- /package/lib/{components → labs}/VDatePicker/mixins/date-picker-table.mjs +0 -0
- /package/lib/{components → labs}/VDatePicker/util/createNativeLocaleFormatter.mjs +0 -0
- /package/lib/{components → labs}/VDatePicker/util/eventHelpers.mjs +0 -0
- /package/lib/{components → labs}/VDatePicker/util/index.mjs +0 -0
- /package/lib/{components → labs}/VDatePicker/util/isDateAllowed.mjs +0 -0
- /package/lib/{components → labs}/VDatePicker/util/monthChange.mjs +0 -0
- /package/lib/{components → labs}/VDatePicker/util/pad.mjs +0 -0
- /package/lib/{components → labs}/VDatePicker/util/sanitizeDateString.mjs +0 -0
- /package/lib/{components → labs}/VPicker/_variables.scss +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","names":["VDateInput","VDateRangeInput"],"sources":["../../../src/labs/VDateInput/index.ts"],"sourcesContent":["export { VDateInput } from './VDateInput'\nexport { VDateRangeInput } from './VDateRangeInput'\n"],"mappings":"SAASA,UAAU;AAAA,SACVC,eAAe"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
.v-date-card {
|
|
2
|
+
padding-bottom: 8px;
|
|
3
|
+
}
|
|
4
|
+
.v-date-card .v-card-actions {
|
|
5
|
+
justify-content: flex-end;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
.v-date-card .v-date-picker-month {
|
|
9
|
+
padding-left: 12px;
|
|
10
|
+
padding-right: 12px;
|
|
11
|
+
}
|
|
12
|
+
.v-date-card .v-date-picker-month .v-date-picker-month__day {
|
|
13
|
+
height: 32px;
|
|
14
|
+
width: 32px;
|
|
15
|
+
}
|
|
16
|
+
.v-date-card .v-date-picker-month .v-date-picker-month__day .v-btn {
|
|
17
|
+
--v-btn-height: 16px;
|
|
18
|
+
--v-btn-size: 0.75rem;
|
|
19
|
+
}
|
|
20
|
+
.v-date-card .v-date-picker-years {
|
|
21
|
+
height: 248px;
|
|
22
|
+
}
|
|
23
|
+
.v-date-card .v-date-picker-years .v-date-picker-years__content {
|
|
24
|
+
grid-template-columns: repeat(4, 56px);
|
|
25
|
+
grid-gap: 0px;
|
|
26
|
+
grid-row-gap: 2px;
|
|
27
|
+
padding-right: 3px;
|
|
28
|
+
}
|
|
29
|
+
.v-date-card .v-date-picker-years .v-date-picker-years__content .v-btn {
|
|
30
|
+
--v-btn-height: 28px;
|
|
31
|
+
--v-btn-size: 0.75rem;
|
|
32
|
+
min-width: unset;
|
|
33
|
+
}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import { createVNode as _createVNode, mergeProps as _mergeProps, Fragment as _Fragment } from "vue";
|
|
2
|
+
// Styles
|
|
3
|
+
import "./VDateCard.css";
|
|
4
|
+
|
|
5
|
+
// Components
|
|
6
|
+
import { makeVDatePickerControlsProps, VDatePickerControls } from "./VDatePickerControls.mjs";
|
|
7
|
+
import { makeVDatePickerMonthProps, VDatePickerMonth } from "./VDatePickerMonth.mjs";
|
|
8
|
+
import { makeVDatePickerYearsProps, VDatePickerYears } from "./VDatePickerYears.mjs";
|
|
9
|
+
import { VFadeTransition } from "../../components/transitions/index.mjs";
|
|
10
|
+
import { VBtn } from "../../components/VBtn/index.mjs";
|
|
11
|
+
import { VCard } from "../../components/VCard/VCard.mjs"; // Composables
|
|
12
|
+
import { createDatePicker } from "./composables.mjs";
|
|
13
|
+
import { useLocale } from "../../composables/locale.mjs";
|
|
14
|
+
import { useProxiedModel } from "../../composables/proxiedModel.mjs";
|
|
15
|
+
import { makeTransitionProps, MaybeTransition } from "../../composables/transition.mjs"; // Utilities
|
|
16
|
+
import { genericComponent, propsFactory, useRender } from "../../util/index.mjs"; // Types
|
|
17
|
+
export const makeVDateCardProps = propsFactory({
|
|
18
|
+
cancelText: {
|
|
19
|
+
type: String,
|
|
20
|
+
default: '$vuetify.datePicker.cancel'
|
|
21
|
+
},
|
|
22
|
+
okText: {
|
|
23
|
+
type: String,
|
|
24
|
+
default: '$vuetify.datePicker.ok'
|
|
25
|
+
},
|
|
26
|
+
inputMode: {
|
|
27
|
+
type: String,
|
|
28
|
+
default: 'calendar'
|
|
29
|
+
},
|
|
30
|
+
hideActions: Boolean,
|
|
31
|
+
...makeVDatePickerControlsProps(),
|
|
32
|
+
...makeVDatePickerMonthProps(),
|
|
33
|
+
...makeVDatePickerYearsProps(),
|
|
34
|
+
...makeTransitionProps({
|
|
35
|
+
transition: {
|
|
36
|
+
component: VFadeTransition,
|
|
37
|
+
leaveAbsolute: true
|
|
38
|
+
}
|
|
39
|
+
})
|
|
40
|
+
}, 'VDateCard');
|
|
41
|
+
export const VDateCard = genericComponent()({
|
|
42
|
+
name: 'VDateCard',
|
|
43
|
+
props: makeVDateCardProps(),
|
|
44
|
+
emits: {
|
|
45
|
+
save: () => true,
|
|
46
|
+
cancel: () => true,
|
|
47
|
+
'update:displayDate': value => true,
|
|
48
|
+
'update:inputMode': value => true,
|
|
49
|
+
'update:modelValue': value => true,
|
|
50
|
+
'update:viewMode': mode => true
|
|
51
|
+
},
|
|
52
|
+
setup(props, _ref) {
|
|
53
|
+
let {
|
|
54
|
+
emit,
|
|
55
|
+
slots
|
|
56
|
+
} = _ref;
|
|
57
|
+
const model = useProxiedModel(props, 'modelValue');
|
|
58
|
+
const {
|
|
59
|
+
t
|
|
60
|
+
} = useLocale();
|
|
61
|
+
createDatePicker(props);
|
|
62
|
+
function onDisplayUpdate(val) {
|
|
63
|
+
emit('update:displayDate', val);
|
|
64
|
+
}
|
|
65
|
+
function onViewModeUpdate(val) {
|
|
66
|
+
emit('update:viewMode', val);
|
|
67
|
+
}
|
|
68
|
+
function onSave() {
|
|
69
|
+
emit('update:modelValue', model.value);
|
|
70
|
+
emit('save');
|
|
71
|
+
}
|
|
72
|
+
function onCancel() {
|
|
73
|
+
emit('cancel');
|
|
74
|
+
}
|
|
75
|
+
useRender(() => {
|
|
76
|
+
const [cardProps] = VCard.filterProps(props);
|
|
77
|
+
const [datePickerControlsProps] = VDatePickerControls.filterProps(props);
|
|
78
|
+
const [datePickerMonthProps] = VDatePickerMonth.filterProps(props);
|
|
79
|
+
const [datePickerYearsProps] = VDatePickerYears.filterProps(props);
|
|
80
|
+
const hasActions = !props.hideActions || !!slots.actions;
|
|
81
|
+
return _createVNode(VCard, _mergeProps(cardProps, {
|
|
82
|
+
"class": "v-date-card"
|
|
83
|
+
}), {
|
|
84
|
+
...slots,
|
|
85
|
+
default: () => _createVNode(_Fragment, null, [_createVNode(VDatePickerControls, _mergeProps(datePickerControlsProps, {
|
|
86
|
+
"onUpdate:displayDate": onDisplayUpdate,
|
|
87
|
+
"onUpdate:viewMode": onViewModeUpdate
|
|
88
|
+
}), null), _createVNode(MaybeTransition, {
|
|
89
|
+
"transition": props.transition
|
|
90
|
+
}, {
|
|
91
|
+
default: () => [props.viewMode === 'month' ? _createVNode(VDatePickerMonth, _mergeProps(datePickerMonthProps, {
|
|
92
|
+
"modelValue": model.value,
|
|
93
|
+
"onUpdate:modelValue": $event => model.value = $event,
|
|
94
|
+
"onUpdate:displayDate": onDisplayUpdate
|
|
95
|
+
}), null) : _createVNode(VDatePickerYears, _mergeProps(datePickerYearsProps, {
|
|
96
|
+
"onUpdate:displayDate": onDisplayUpdate,
|
|
97
|
+
"onUpdate:viewMode": onViewModeUpdate
|
|
98
|
+
}), null)]
|
|
99
|
+
})]),
|
|
100
|
+
actions: !hasActions ? undefined : () => _createVNode(_Fragment, null, [slots.actions?.() ?? _createVNode(_Fragment, null, [_createVNode(VBtn, {
|
|
101
|
+
"onClick": onCancel,
|
|
102
|
+
"text": t(props.cancelText)
|
|
103
|
+
}, null), _createVNode(VBtn, {
|
|
104
|
+
"onClick": onSave,
|
|
105
|
+
"text": t(props.okText)
|
|
106
|
+
}, null)])])
|
|
107
|
+
});
|
|
108
|
+
});
|
|
109
|
+
return {};
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
//# sourceMappingURL=VDateCard.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VDateCard.mjs","names":["makeVDatePickerControlsProps","VDatePickerControls","makeVDatePickerMonthProps","VDatePickerMonth","makeVDatePickerYearsProps","VDatePickerYears","VFadeTransition","VBtn","VCard","createDatePicker","useLocale","useProxiedModel","makeTransitionProps","MaybeTransition","genericComponent","propsFactory","useRender","makeVDateCardProps","cancelText","type","String","default","okText","inputMode","hideActions","Boolean","transition","component","leaveAbsolute","VDateCard","name","props","emits","save","cancel","value","mode","setup","_ref","emit","slots","model","t","onDisplayUpdate","val","onViewModeUpdate","onSave","onCancel","cardProps","filterProps","datePickerControlsProps","datePickerMonthProps","datePickerYearsProps","hasActions","actions","_createVNode","_mergeProps","_Fragment","viewMode","$event","undefined"],"sources":["../../../src/labs/VDatePicker/VDateCard.tsx"],"sourcesContent":["// Styles\nimport './VDateCard.sass'\n\n// Components\nimport { makeVDatePickerControlsProps, VDatePickerControls } from './VDatePickerControls'\nimport { makeVDatePickerMonthProps, VDatePickerMonth } from './VDatePickerMonth'\nimport { makeVDatePickerYearsProps, VDatePickerYears } from './VDatePickerYears'\nimport { VFadeTransition } from '@/components/transitions'\nimport { VBtn } from '@/components/VBtn'\nimport { VCard } from '@/components/VCard/VCard'\n\n// Composables\nimport { createDatePicker } from './composables'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { makeTransitionProps, MaybeTransition } from '@/composables/transition'\n\n// Utilities\nimport { genericComponent, propsFactory, useRender } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { VCardSlots } from '@/components/VCard/VCard'\n\nexport const makeVDateCardProps = propsFactory({\n cancelText: {\n type: String,\n default: '$vuetify.datePicker.cancel',\n },\n okText: {\n type: String,\n default: '$vuetify.datePicker.ok',\n },\n inputMode: {\n type: String as PropType<'keyboard' | 'calendar'>,\n default: 'calendar',\n },\n hideActions: Boolean,\n\n ...makeVDatePickerControlsProps(),\n ...makeVDatePickerMonthProps(),\n ...makeVDatePickerYearsProps(),\n ...makeTransitionProps({ transition: { component: VFadeTransition, leaveAbsolute: true } }),\n}, 'VDateCard')\n\nexport const VDateCard = genericComponent<VCardSlots>()({\n name: 'VDateCard',\n\n props: makeVDateCardProps(),\n\n emits: {\n save: () => true,\n cancel: () => true,\n 'update:displayDate': (value: any) => true,\n 'update:inputMode': (value: any) => true,\n 'update:modelValue': (value: any) => true,\n 'update:viewMode': (mode: 'month' | 'year') => true,\n },\n\n setup (props, { emit, slots }) {\n const model = useProxiedModel(props, 'modelValue')\n const { t } = useLocale()\n\n createDatePicker(props)\n\n function onDisplayUpdate (val: any) {\n emit('update:displayDate', val)\n }\n\n function onViewModeUpdate (val: any) {\n emit('update:viewMode', val)\n }\n\n function onSave () {\n emit('update:modelValue', model.value)\n emit('save')\n }\n\n function onCancel () {\n emit('cancel')\n }\n\n useRender(() => {\n const [cardProps] = VCard.filterProps(props)\n const [datePickerControlsProps] = VDatePickerControls.filterProps(props)\n const [datePickerMonthProps] = VDatePickerMonth.filterProps(props)\n const [datePickerYearsProps] = VDatePickerYears.filterProps(props)\n const hasActions = !props.hideActions || !!slots.actions\n\n return (\n <VCard\n { ...cardProps }\n class=\"v-date-card\"\n >\n {{\n ...slots,\n default: () => (\n <>\n <VDatePickerControls\n { ...datePickerControlsProps }\n onUpdate:displayDate={ onDisplayUpdate }\n onUpdate:viewMode={ onViewModeUpdate }\n />\n\n <MaybeTransition transition={ props.transition }>\n { props.viewMode === 'month' ? (\n <VDatePickerMonth\n { ...datePickerMonthProps }\n v-model={ model.value }\n onUpdate:displayDate={ onDisplayUpdate }\n />\n ) : (\n <VDatePickerYears\n { ...datePickerYearsProps }\n onUpdate:displayDate={ onDisplayUpdate }\n onUpdate:viewMode={ onViewModeUpdate }\n />\n )}\n </MaybeTransition>\n </>\n ),\n actions: !hasActions ? undefined : () => (\n <>\n { slots.actions?.() ?? (\n <>\n <VBtn onClick={ onCancel } text={ t(props.cancelText) } />\n <VBtn onClick={ onSave } text={ t(props.okText) } />\n </>\n )}\n </>\n ),\n }}\n </VCard>\n )\n })\n\n return {}\n },\n})\n\nexport type VDateCard = InstanceType<typeof VDateCard>\n"],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
.v-date-card
|
|
2
|
+
padding-bottom: 8px
|
|
3
|
+
|
|
4
|
+
.v-card-actions
|
|
5
|
+
justify-content: flex-end
|
|
6
|
+
|
|
7
|
+
.v-date-card
|
|
8
|
+
.v-date-picker-month
|
|
9
|
+
padding-left: 12px
|
|
10
|
+
padding-right: 12px
|
|
11
|
+
|
|
12
|
+
.v-date-picker-month__day
|
|
13
|
+
height: 32px
|
|
14
|
+
width: 32px
|
|
15
|
+
|
|
16
|
+
.v-btn
|
|
17
|
+
--v-btn-height: 16px
|
|
18
|
+
--v-btn-size: 0.75rem
|
|
19
|
+
|
|
20
|
+
.v-date-picker-years
|
|
21
|
+
height: 248px
|
|
22
|
+
|
|
23
|
+
.v-date-picker-years__content
|
|
24
|
+
grid-template-columns: repeat(4, 56px)
|
|
25
|
+
grid-gap: 0px
|
|
26
|
+
grid-row-gap: 2px
|
|
27
|
+
padding-right: 3px
|
|
28
|
+
|
|
29
|
+
.v-btn
|
|
30
|
+
--v-btn-height: 28px
|
|
31
|
+
--v-btn-size: 0.75rem
|
|
32
|
+
min-width: unset
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
.v-date-picker__input {
|
|
2
|
+
padding-top: 16px;
|
|
3
|
+
padding-left: 24px;
|
|
4
|
+
padding-right: 24px;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
.v-date-picker {
|
|
8
|
+
overflow: hidden;
|
|
9
|
+
width: 358px;
|
|
10
|
+
}
|
|
11
|
+
.v-date-picker .v-date-picker-month {
|
|
12
|
+
padding-bottom: 8px;
|
|
13
|
+
padding-inline-start: 12px;
|
|
14
|
+
padding-inline-end: 12px;
|
|
15
|
+
}
|
|
16
|
+
.v-date-picker .v-date-picker-month .v-date-picker-month__day {
|
|
17
|
+
height: 40px;
|
|
18
|
+
width: 40px;
|
|
19
|
+
}
|
|
20
|
+
.v-date-picker .v-date-picker-month .v-date-picker-month__day .v-btn {
|
|
21
|
+
--v-btn-height: 24px;
|
|
22
|
+
--v-btn-size: 0.85rem;
|
|
23
|
+
}
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import { resolveDirective as _resolveDirective, Fragment as _Fragment, createVNode as _createVNode, mergeProps as _mergeProps } from "vue";
|
|
2
|
+
// Styles
|
|
3
|
+
import "./VDatePicker.css";
|
|
4
|
+
|
|
5
|
+
// Components
|
|
6
|
+
import { makeVDatePickerControlsProps, VDatePickerControls } from "./VDatePickerControls.mjs";
|
|
7
|
+
import { VDatePickerHeader } from "./VDatePickerHeader.mjs";
|
|
8
|
+
import { makeVDatePickerMonthProps, VDatePickerMonth } from "./VDatePickerMonth.mjs";
|
|
9
|
+
import { makeVDatePickerYearsProps, VDatePickerYears } from "./VDatePickerYears.mjs";
|
|
10
|
+
import { VBtn } from "../../components/VBtn/index.mjs";
|
|
11
|
+
import { VTextField } from "../../components/VTextField/index.mjs";
|
|
12
|
+
import { dateEmits, makeDateProps } from "../VDateInput/composables.mjs";
|
|
13
|
+
import { makeVPickerProps, VPicker } from "../VPicker/VPicker.mjs"; // Composables
|
|
14
|
+
import { createDatePicker } from "./composables.mjs";
|
|
15
|
+
import { useLocale } from "../../composables/locale.mjs";
|
|
16
|
+
import { useProxiedModel } from "../../composables/proxiedModel.mjs";
|
|
17
|
+
import { makeTransitionProps, MaybeTransition } from "../../composables/transition.mjs";
|
|
18
|
+
import { useDate } from "../date/index.mjs"; // Utilities
|
|
19
|
+
import { computed, ref, watch } from 'vue';
|
|
20
|
+
import { genericComponent, propsFactory, useRender } from "../../util/index.mjs"; // Types
|
|
21
|
+
export const makeVDatePickerProps = propsFactory({
|
|
22
|
+
calendarIcon: {
|
|
23
|
+
type: String,
|
|
24
|
+
default: '$calendar'
|
|
25
|
+
},
|
|
26
|
+
keyboardIcon: {
|
|
27
|
+
type: String,
|
|
28
|
+
default: '$edit'
|
|
29
|
+
},
|
|
30
|
+
cancelText: {
|
|
31
|
+
type: String,
|
|
32
|
+
default: '$vuetify.datePicker.cancel'
|
|
33
|
+
},
|
|
34
|
+
okText: {
|
|
35
|
+
type: String,
|
|
36
|
+
default: '$vuetify.datePicker.ok'
|
|
37
|
+
},
|
|
38
|
+
inputText: {
|
|
39
|
+
type: String,
|
|
40
|
+
default: '$vuetify.datePicker.input.placeholder'
|
|
41
|
+
},
|
|
42
|
+
header: {
|
|
43
|
+
type: String,
|
|
44
|
+
default: '$vuetify.datePicker.header'
|
|
45
|
+
},
|
|
46
|
+
hideActions: Boolean,
|
|
47
|
+
...makeDateProps(),
|
|
48
|
+
...makeTransitionProps({
|
|
49
|
+
transition: 'fade'
|
|
50
|
+
}),
|
|
51
|
+
...makeVDatePickerControlsProps(),
|
|
52
|
+
...makeVDatePickerMonthProps(),
|
|
53
|
+
...makeVDatePickerYearsProps(),
|
|
54
|
+
...makeVPickerProps({
|
|
55
|
+
title: '$vuetify.datePicker.title'
|
|
56
|
+
})
|
|
57
|
+
}, 'VDatePicker');
|
|
58
|
+
export const VDatePicker = genericComponent()({
|
|
59
|
+
name: 'VDatePicker',
|
|
60
|
+
props: makeVDatePickerProps(),
|
|
61
|
+
emits: {
|
|
62
|
+
'click:cancel': () => true,
|
|
63
|
+
'click:save': () => true,
|
|
64
|
+
...dateEmits
|
|
65
|
+
},
|
|
66
|
+
setup(props, _ref) {
|
|
67
|
+
let {
|
|
68
|
+
emit,
|
|
69
|
+
slots
|
|
70
|
+
} = _ref;
|
|
71
|
+
const adapter = useDate();
|
|
72
|
+
const {
|
|
73
|
+
t
|
|
74
|
+
} = useLocale();
|
|
75
|
+
createDatePicker(props);
|
|
76
|
+
const model = ref(props.modelValue ?? []);
|
|
77
|
+
const isReversing = ref(false);
|
|
78
|
+
const displayDate = useProxiedModel(props, 'displayDate', props.displayDate);
|
|
79
|
+
const inputMode = useProxiedModel(props, 'inputMode', props.inputMode);
|
|
80
|
+
const viewMode = useProxiedModel(props, 'viewMode', props.viewMode);
|
|
81
|
+
const inputModel = computed(() => model.value.length ? adapter.format(model.value[0], 'keyboardDate') : '');
|
|
82
|
+
const title = computed(() => t(props.title));
|
|
83
|
+
const header = computed(() => model.value.length ? adapter.format(model.value[0], 'normalDateWithWeekday') : t(props.header));
|
|
84
|
+
const headerIcon = computed(() => inputMode.value === 'calendar' ? props.keyboardIcon : props.calendarIcon);
|
|
85
|
+
const headerTransition = computed(() => `date-picker-header${isReversing.value ? '-reverse' : ''}-transition`);
|
|
86
|
+
watch(inputModel, () => {
|
|
87
|
+
const {
|
|
88
|
+
isValid,
|
|
89
|
+
date
|
|
90
|
+
} = adapter;
|
|
91
|
+
model.value = isValid(inputModel.value) ? [date(inputModel.value)] : [];
|
|
92
|
+
});
|
|
93
|
+
watch(model, (val, oldVal) => {
|
|
94
|
+
if (props.hideActions) {
|
|
95
|
+
emit('update:modelValue', val);
|
|
96
|
+
}
|
|
97
|
+
isReversing.value = adapter.isBefore(val[0], oldVal[0]);
|
|
98
|
+
});
|
|
99
|
+
function onClickCancel() {
|
|
100
|
+
emit('click:cancel');
|
|
101
|
+
}
|
|
102
|
+
function onClickSave() {
|
|
103
|
+
emit('click:save');
|
|
104
|
+
emit('update:modelValue', model.value);
|
|
105
|
+
}
|
|
106
|
+
function onClickAppend() {
|
|
107
|
+
inputMode.value = inputMode.value === 'calendar' ? 'keyboard' : 'calendar';
|
|
108
|
+
}
|
|
109
|
+
const headerSlotProps = computed(() => ({
|
|
110
|
+
header: header.value,
|
|
111
|
+
appendIcon: headerIcon.value,
|
|
112
|
+
transition: headerTransition.value,
|
|
113
|
+
'onClick:append': onClickAppend
|
|
114
|
+
}));
|
|
115
|
+
useRender(() => {
|
|
116
|
+
const [pickerProps] = VPicker.filterProps(props);
|
|
117
|
+
const [datePickerControlsProps] = VDatePickerControls.filterProps(props);
|
|
118
|
+
const [datePickerMonthProps] = VDatePickerMonth.filterProps(props);
|
|
119
|
+
const [datePickerYearsProps] = VDatePickerYears.filterProps(props);
|
|
120
|
+
return _createVNode(VPicker, _mergeProps(pickerProps, {
|
|
121
|
+
"class": ['v-date-picker', props.class],
|
|
122
|
+
"style": props.style,
|
|
123
|
+
"title": title.value
|
|
124
|
+
}), {
|
|
125
|
+
header: () => slots.header?.(headerSlotProps.value) ?? _createVNode(VDatePickerHeader, _mergeProps({
|
|
126
|
+
"key": "header"
|
|
127
|
+
}, headerSlotProps.value), null),
|
|
128
|
+
default: () => inputMode.value === 'calendar' ? _createVNode(_Fragment, null, [_createVNode(VDatePickerControls, _mergeProps(datePickerControlsProps, {
|
|
129
|
+
"displayDate": displayDate.value,
|
|
130
|
+
"onUpdate:displayDate": $event => displayDate.value = $event,
|
|
131
|
+
"viewMode": viewMode.value,
|
|
132
|
+
"onUpdate:viewMode": $event => viewMode.value = $event
|
|
133
|
+
}), null), _createVNode(MaybeTransition, {
|
|
134
|
+
"transition": props.transition,
|
|
135
|
+
"mode": "out-in"
|
|
136
|
+
}, {
|
|
137
|
+
default: () => [viewMode.value === 'month' ? _createVNode(VDatePickerMonth, _mergeProps(datePickerMonthProps, {
|
|
138
|
+
"modelValue": model.value,
|
|
139
|
+
"onUpdate:modelValue": $event => model.value = $event,
|
|
140
|
+
"displayDate": displayDate.value,
|
|
141
|
+
"onUpdate:displayDate": $event => displayDate.value = $event
|
|
142
|
+
}), null) : _createVNode(VDatePickerYears, _mergeProps(datePickerYearsProps, {
|
|
143
|
+
"displayDate": displayDate.value,
|
|
144
|
+
"onUpdate:displayDate": $event => displayDate.value = $event,
|
|
145
|
+
"viewMode": viewMode.value,
|
|
146
|
+
"onUpdate:viewMode": $event => viewMode.value = $event
|
|
147
|
+
}), null)]
|
|
148
|
+
})]) : _createVNode("div", {
|
|
149
|
+
"class": "v-date-picker__input"
|
|
150
|
+
}, [_createVNode(VTextField, {
|
|
151
|
+
"modelValue": inputModel.value,
|
|
152
|
+
"onUpdate:modelValue": $event => inputModel.value = $event,
|
|
153
|
+
"label": t(props.inputText),
|
|
154
|
+
"placeholder": "dd/mm/yyyy"
|
|
155
|
+
}, null)]),
|
|
156
|
+
actions: !props.hideActions ? () => _createVNode("div", null, [_createVNode(VBtn, {
|
|
157
|
+
"variant": "text",
|
|
158
|
+
"color": props.color,
|
|
159
|
+
"onClick": onClickCancel,
|
|
160
|
+
"text": t(props.cancelText)
|
|
161
|
+
}, null), _createVNode(VBtn, {
|
|
162
|
+
"variant": "text",
|
|
163
|
+
"color": props.color,
|
|
164
|
+
"onClick": onClickSave,
|
|
165
|
+
"text": t(props.okText)
|
|
166
|
+
}, null)]) : undefined
|
|
167
|
+
});
|
|
168
|
+
});
|
|
169
|
+
return {};
|
|
170
|
+
}
|
|
171
|
+
});
|
|
172
|
+
//# sourceMappingURL=VDatePicker.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VDatePicker.mjs","names":["makeVDatePickerControlsProps","VDatePickerControls","VDatePickerHeader","makeVDatePickerMonthProps","VDatePickerMonth","makeVDatePickerYearsProps","VDatePickerYears","VBtn","VTextField","dateEmits","makeDateProps","makeVPickerProps","VPicker","createDatePicker","useLocale","useProxiedModel","makeTransitionProps","MaybeTransition","useDate","computed","ref","watch","genericComponent","propsFactory","useRender","makeVDatePickerProps","calendarIcon","type","String","default","keyboardIcon","cancelText","okText","inputText","header","hideActions","Boolean","transition","title","VDatePicker","name","props","emits","click:cancel","click:save","setup","_ref","emit","slots","adapter","t","model","modelValue","isReversing","displayDate","inputMode","viewMode","inputModel","value","length","format","headerIcon","headerTransition","isValid","date","val","oldVal","isBefore","onClickCancel","onClickSave","onClickAppend","headerSlotProps","appendIcon","pickerProps","filterProps","datePickerControlsProps","datePickerMonthProps","datePickerYearsProps","_createVNode","_mergeProps","class","style","_Fragment","$event","actions","color","undefined"],"sources":["../../../src/labs/VDatePicker/VDatePicker.tsx"],"sourcesContent":["// Styles\nimport './VDatePicker.sass'\n\n// Components\nimport { makeVDatePickerControlsProps, VDatePickerControls } from './VDatePickerControls'\nimport { VDatePickerHeader } from './VDatePickerHeader'\nimport { makeVDatePickerMonthProps, VDatePickerMonth } from './VDatePickerMonth'\nimport { makeVDatePickerYearsProps, VDatePickerYears } from './VDatePickerYears'\nimport { VBtn } from '@/components/VBtn'\nimport { VTextField } from '@/components/VTextField'\nimport { dateEmits, makeDateProps } from '@/labs/VDateInput/composables'\nimport { makeVPickerProps, VPicker } from '@/labs/VPicker/VPicker'\n\n// Composables\nimport { createDatePicker } from './composables'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { makeTransitionProps, MaybeTransition } from '@/composables/transition'\nimport { useDate } from '@/labs/date'\n\n// Utilities\nimport { computed, ref, watch } from 'vue'\nimport { genericComponent, propsFactory, useRender } from '@/util'\n\n// Types\nexport type VDatePickerSlots = {\n header: {\n header: string\n appendIcon: string\n 'onClick:append': () => void\n }\n}\n\nexport const makeVDatePickerProps = propsFactory({\n calendarIcon: {\n type: String,\n default: '$calendar',\n },\n keyboardIcon: {\n type: String,\n default: '$edit',\n },\n cancelText: {\n type: String,\n default: '$vuetify.datePicker.cancel',\n },\n okText: {\n type: String,\n default: '$vuetify.datePicker.ok',\n },\n inputText: {\n type: String,\n default: '$vuetify.datePicker.input.placeholder',\n },\n header: {\n type: String,\n default: '$vuetify.datePicker.header',\n },\n hideActions: Boolean,\n\n ...makeDateProps(),\n ...makeTransitionProps({ transition: 'fade' }),\n ...makeVDatePickerControlsProps(),\n ...makeVDatePickerMonthProps(),\n ...makeVDatePickerYearsProps(),\n ...makeVPickerProps({ title: '$vuetify.datePicker.title' }),\n}, 'VDatePicker')\n\nexport const VDatePicker = genericComponent<VDatePickerSlots>()({\n name: 'VDatePicker',\n\n props: makeVDatePickerProps(),\n\n emits: {\n 'click:cancel': () => true,\n 'click:save': () => true,\n ...dateEmits,\n },\n\n setup (props, { emit, slots }) {\n const adapter = useDate()\n const { t } = useLocale()\n\n createDatePicker(props)\n\n const model = ref<any[]>(props.modelValue ?? [])\n const isReversing = ref(false)\n\n const displayDate = useProxiedModel(props, 'displayDate', props.displayDate)\n const inputMode = useProxiedModel(props, 'inputMode', props.inputMode)\n const viewMode = useProxiedModel(props, 'viewMode', props.viewMode)\n\n const inputModel = computed(() => model.value.length ? adapter.format(model.value[0], 'keyboardDate') : '')\n const title = computed(() => t(props.title))\n const header = computed(() => model.value.length ? adapter.format(model.value[0], 'normalDateWithWeekday') : t(props.header))\n const headerIcon = computed(() => inputMode.value === 'calendar' ? props.keyboardIcon : props.calendarIcon)\n const headerTransition = computed(() => `date-picker-header${isReversing.value ? '-reverse' : ''}-transition`)\n\n watch(inputModel, () => {\n const { isValid, date } = adapter\n\n model.value = isValid(inputModel.value) ? [date(inputModel.value)] : []\n })\n\n watch(model, (val, oldVal) => {\n if (props.hideActions) {\n emit('update:modelValue', val)\n }\n\n isReversing.value = adapter.isBefore(val[0], oldVal[0])\n })\n\n function onClickCancel () {\n emit('click:cancel')\n }\n function onClickSave () {\n emit('click:save')\n emit('update:modelValue', model.value)\n }\n function onClickAppend () {\n inputMode.value = inputMode.value === 'calendar' ? 'keyboard' : 'calendar'\n }\n\n const headerSlotProps = computed(() => ({\n header: header.value,\n appendIcon: headerIcon.value,\n transition: headerTransition.value,\n 'onClick:append': onClickAppend,\n }))\n\n useRender(() => {\n const [pickerProps] = VPicker.filterProps(props)\n const [datePickerControlsProps] = VDatePickerControls.filterProps(props)\n const [datePickerMonthProps] = VDatePickerMonth.filterProps(props)\n const [datePickerYearsProps] = VDatePickerYears.filterProps(props)\n\n return (\n <VPicker\n { ...pickerProps }\n class={[\n 'v-date-picker',\n props.class,\n ]}\n style={ props.style }\n title={ title.value }\n v-slots={{\n header: () => slots.header?.(headerSlotProps.value) ?? (\n <VDatePickerHeader\n key=\"header\"\n { ...headerSlotProps.value }\n />\n ),\n default: () => inputMode.value === 'calendar' ? (\n <>\n <VDatePickerControls\n { ...datePickerControlsProps }\n v-model:displayDate={ displayDate.value }\n v-model:viewMode={ viewMode.value }\n />\n\n <MaybeTransition transition={ props.transition } mode=\"out-in\">\n { viewMode.value === 'month' ? (\n <VDatePickerMonth\n { ...datePickerMonthProps }\n v-model={ model.value }\n v-model:displayDate={ displayDate.value }\n />\n ) : (\n <VDatePickerYears\n { ...datePickerYearsProps }\n v-model:displayDate={ displayDate.value }\n v-model:viewMode={ viewMode.value }\n />\n )}\n </MaybeTransition>\n </>\n ) : (\n <div class=\"v-date-picker__input\">\n <VTextField\n v-model={ inputModel.value }\n label={ t(props.inputText) }\n placeholder=\"dd/mm/yyyy\"\n />\n </div>\n ),\n actions: !props.hideActions ? () => (\n <div>\n <VBtn\n variant=\"text\"\n color={ props.color }\n onClick={ onClickCancel }\n text={ t(props.cancelText) }\n />\n\n <VBtn\n variant=\"text\"\n color={ props.color }\n onClick={ onClickSave }\n text={ t(props.okText) }\n />\n </div>\n ) : undefined,\n }}\n />\n )\n })\n\n return {}\n },\n})\n\nexport type VDatePicker = InstanceType<typeof VDatePicker>\n"],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
@use '../../styles/tools'
|
|
2
|
+
|
|
3
|
+
.v-date-picker__input
|
|
4
|
+
padding-top: 16px
|
|
5
|
+
padding-left: 24px
|
|
6
|
+
padding-right: 24px
|
|
7
|
+
|
|
8
|
+
.v-date-picker
|
|
9
|
+
overflow: hidden
|
|
10
|
+
width: 358px
|
|
11
|
+
|
|
12
|
+
.v-date-picker-month
|
|
13
|
+
padding-bottom: 8px
|
|
14
|
+
padding-inline-start: 12px
|
|
15
|
+
padding-inline-end: 12px
|
|
16
|
+
|
|
17
|
+
.v-date-picker-month__day
|
|
18
|
+
height: 40px
|
|
19
|
+
width: 40px
|
|
20
|
+
|
|
21
|
+
.v-btn
|
|
22
|
+
--v-btn-height: 24px
|
|
23
|
+
--v-btn-size: 0.85rem
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
.v-date-picker-controls {
|
|
2
|
+
display: flex;
|
|
3
|
+
align-items: center;
|
|
4
|
+
justify-content: space-between;
|
|
5
|
+
font-size: 0.875rem;
|
|
6
|
+
padding-inline-start: 24px;
|
|
7
|
+
padding-inline-end: 12px;
|
|
8
|
+
}
|
|
9
|
+
.v-date-picker-controls .v-btn:last-child {
|
|
10
|
+
margin-left: 24px;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
.v-date-picker-controls__date {
|
|
14
|
+
margin-right: 4px;
|
|
15
|
+
}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { createVNode as _createVNode } from "vue";
|
|
2
|
+
// Styles
|
|
3
|
+
import "./VDatePickerControls.css";
|
|
4
|
+
|
|
5
|
+
// Components
|
|
6
|
+
import { VBtn } from "../../components/VBtn/index.mjs";
|
|
7
|
+
import { VSpacer } from "../../components/VGrid/index.mjs"; // Composables
|
|
8
|
+
import { useDate } from "../date/index.mjs"; // Utilities
|
|
9
|
+
import { computed } from 'vue';
|
|
10
|
+
import { dateEmits, makeDateProps } from "../VDateInput/composables.mjs";
|
|
11
|
+
import { genericComponent, omit, propsFactory, useRender } from "../../util/index.mjs";
|
|
12
|
+
export const makeVDatePickerControlsProps = propsFactory({
|
|
13
|
+
nextIcon: {
|
|
14
|
+
type: [String],
|
|
15
|
+
default: '$next'
|
|
16
|
+
},
|
|
17
|
+
prevIcon: {
|
|
18
|
+
type: [String],
|
|
19
|
+
default: '$prev'
|
|
20
|
+
},
|
|
21
|
+
expandIcon: {
|
|
22
|
+
type: [String],
|
|
23
|
+
default: '$expand'
|
|
24
|
+
},
|
|
25
|
+
collapseIcon: {
|
|
26
|
+
type: [String],
|
|
27
|
+
default: '$collapse'
|
|
28
|
+
},
|
|
29
|
+
range: {
|
|
30
|
+
default: false,
|
|
31
|
+
type: [String, Boolean],
|
|
32
|
+
validator: v => v === false || ['start', 'end'].includes(v)
|
|
33
|
+
},
|
|
34
|
+
...omit(makeDateProps(), ['modelValue', 'inputMode'])
|
|
35
|
+
}, 'VDatePickerControls');
|
|
36
|
+
export const VDatePickerControls = genericComponent()({
|
|
37
|
+
name: 'VDatePickerControls',
|
|
38
|
+
props: makeVDatePickerControlsProps(),
|
|
39
|
+
emits: {
|
|
40
|
+
...omit(dateEmits, ['update:modelValue', 'update:inputMode'])
|
|
41
|
+
},
|
|
42
|
+
setup(props, _ref) {
|
|
43
|
+
let {
|
|
44
|
+
emit
|
|
45
|
+
} = _ref;
|
|
46
|
+
const adapter = useDate();
|
|
47
|
+
const monthAndYear = computed(() => {
|
|
48
|
+
const month = props.range === 'end' ? adapter.addMonths(props.displayDate, 1) : props.displayDate;
|
|
49
|
+
return adapter.format(month, 'monthAndYear');
|
|
50
|
+
});
|
|
51
|
+
useRender(() => {
|
|
52
|
+
const prevBtn = _createVNode(VBtn, {
|
|
53
|
+
"variant": "text",
|
|
54
|
+
"icon": props.prevIcon,
|
|
55
|
+
"onClick": () => emit('update:displayDate', adapter.addMonths(props.displayDate, -1))
|
|
56
|
+
}, null);
|
|
57
|
+
const nextBtn = _createVNode(VBtn, {
|
|
58
|
+
"variant": "text",
|
|
59
|
+
"icon": props.nextIcon,
|
|
60
|
+
"onClick": () => emit('update:displayDate', adapter.addMonths(props.displayDate, 1))
|
|
61
|
+
}, null);
|
|
62
|
+
return _createVNode("div", {
|
|
63
|
+
"class": "v-date-picker-controls"
|
|
64
|
+
}, [props.viewMode === 'month' && props.range === 'start' && prevBtn, !!props.range && _createVNode(VSpacer, {
|
|
65
|
+
"key": "range-spacer"
|
|
66
|
+
}, null), _createVNode("div", {
|
|
67
|
+
"class": "v-date-picker-controls__date"
|
|
68
|
+
}, [monthAndYear.value]), _createVNode(VBtn, {
|
|
69
|
+
"key": "expand-btn",
|
|
70
|
+
"variant": "text",
|
|
71
|
+
"icon": props.viewMode === 'month' ? props.expandIcon : props.collapseIcon,
|
|
72
|
+
"onClick": () => emit('update:viewMode', props.viewMode === 'month' ? 'year' : 'month')
|
|
73
|
+
}, null), _createVNode(VSpacer, null, null), props.viewMode === 'month' && !props.range && _createVNode("div", {
|
|
74
|
+
"key": "month-buttons"
|
|
75
|
+
}, [prevBtn, nextBtn]), props.viewMode === 'month' && props.range === 'end' && nextBtn]);
|
|
76
|
+
});
|
|
77
|
+
return {};
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
//# sourceMappingURL=VDatePickerControls.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VDatePickerControls.mjs","names":["VBtn","VSpacer","useDate","computed","dateEmits","makeDateProps","genericComponent","omit","propsFactory","useRender","makeVDatePickerControlsProps","nextIcon","type","String","default","prevIcon","expandIcon","collapseIcon","range","Boolean","validator","v","includes","VDatePickerControls","name","props","emits","setup","_ref","emit","adapter","monthAndYear","month","addMonths","displayDate","format","prevBtn","_createVNode","onClick","nextBtn","viewMode","value"],"sources":["../../../src/labs/VDatePicker/VDatePickerControls.tsx"],"sourcesContent":["// Styles\nimport './VDatePickerControls.sass'\n\n// Components\nimport { VBtn } from '@/components/VBtn'\nimport { VSpacer } from '@/components/VGrid'\n\n// Composables\nimport { useDate } from '@/labs/date'\n\n// Utilities\nimport { computed } from 'vue'\nimport { dateEmits, makeDateProps } from '../VDateInput/composables'\nimport { genericComponent, omit, propsFactory, useRender } from '@/util'\n\nexport const makeVDatePickerControlsProps = propsFactory({\n nextIcon: {\n type: [String],\n default: '$next',\n },\n prevIcon: {\n type: [String],\n default: '$prev',\n },\n expandIcon: {\n type: [String],\n default: '$expand',\n },\n collapseIcon: {\n type: [String],\n default: '$collapse',\n },\n range: {\n default: false,\n type: [String, Boolean],\n validator: (v: any) => v === false || ['start', 'end'].includes(v),\n },\n ...omit(makeDateProps(), ['modelValue', 'inputMode']),\n}, 'VDatePickerControls')\n\nexport const VDatePickerControls = genericComponent()({\n name: 'VDatePickerControls',\n\n props: makeVDatePickerControlsProps(),\n\n emits: {\n ...omit(dateEmits, ['update:modelValue', 'update:inputMode']),\n },\n\n setup (props, { emit }) {\n const adapter = useDate()\n const monthAndYear = computed(() => {\n const month = props.range === 'end' ? adapter.addMonths(props.displayDate, 1) : props.displayDate\n return adapter.format(month, 'monthAndYear')\n })\n\n useRender(() => {\n const prevBtn = (\n <VBtn\n variant=\"text\"\n icon={ props.prevIcon }\n onClick={ () => emit('update:displayDate', adapter.addMonths(props.displayDate, -1)) }\n />\n )\n\n const nextBtn = (\n <VBtn\n variant=\"text\"\n icon={ props.nextIcon }\n onClick={ () => emit('update:displayDate', adapter.addMonths(props.displayDate, 1)) }\n />\n )\n\n return (\n <div class=\"v-date-picker-controls\">\n { props.viewMode === 'month' && props.range === 'start' && prevBtn }\n { !!props.range && <VSpacer key=\"range-spacer\" /> }\n <div class=\"v-date-picker-controls__date\">{ monthAndYear.value }</div>\n <VBtn\n key=\"expand-btn\"\n variant=\"text\"\n icon={ props.viewMode === 'month' ? props.expandIcon : props.collapseIcon }\n onClick={ () => emit('update:viewMode', props.viewMode === 'month' ? 'year' : 'month') }\n />\n <VSpacer />\n { (props.viewMode === 'month' && !props.range) && (\n <div key=\"month-buttons\">\n { prevBtn }\n { nextBtn }\n </div>\n )}\n { props.viewMode === 'month' && props.range === 'end' && nextBtn }\n </div>\n )\n })\n\n return {}\n },\n})\n\nexport type VDatePickerControls = InstanceType<typeof VDatePickerControls>\n"],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
.v-date-picker-controls
|
|
2
|
+
display: flex
|
|
3
|
+
align-items: center
|
|
4
|
+
justify-content: space-between
|
|
5
|
+
font-size: .875rem
|
|
6
|
+
padding-inline-start: 24px
|
|
7
|
+
// padding-top: 4px
|
|
8
|
+
// padding-bottom: 4px
|
|
9
|
+
padding-inline-end: 12px
|
|
10
|
+
|
|
11
|
+
.v-btn:last-child
|
|
12
|
+
margin-left: 24px
|
|
13
|
+
|
|
14
|
+
.v-date-picker-controls__date
|
|
15
|
+
margin-right: 4px
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
.v-date-picker-header {
|
|
2
|
+
display: grid;
|
|
3
|
+
grid-template-areas: "prepend content append";
|
|
4
|
+
grid-template-columns: min-content minmax(0, 1fr) min-content;
|
|
5
|
+
overflow: hidden;
|
|
6
|
+
padding-inline-start: 24px;
|
|
7
|
+
padding-inline-end: 12px;
|
|
8
|
+
padding-bottom: 12px;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
.v-date-picker-header__append {
|
|
12
|
+
grid-area: append;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
.v-date-picker-header__prepend {
|
|
16
|
+
grid-area: prepend;
|
|
17
|
+
padding-inline-start: 8px;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
.v-date-picker-header__content {
|
|
21
|
+
align-items: center;
|
|
22
|
+
display: flex;
|
|
23
|
+
font-size: 32px;
|
|
24
|
+
line-height: 40px;
|
|
25
|
+
grid-area: content;
|
|
26
|
+
justify-content: space-between;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
.date-picker-header-transition-enter-active,
|
|
30
|
+
.date-picker-header-reverse-transition-enter-active {
|
|
31
|
+
transition-duration: 0.3s;
|
|
32
|
+
transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
|
|
33
|
+
}
|
|
34
|
+
.date-picker-header-transition-leave-active,
|
|
35
|
+
.date-picker-header-reverse-transition-leave-active {
|
|
36
|
+
transition-duration: 0.3s;
|
|
37
|
+
transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
.date-picker-header-transition-enter-from {
|
|
41
|
+
transform: translate(0, 100%);
|
|
42
|
+
}
|
|
43
|
+
.date-picker-header-transition-leave-to {
|
|
44
|
+
opacity: 0;
|
|
45
|
+
transform: translate(0, -100%);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
.date-picker-header-reverse-transition-enter-from {
|
|
49
|
+
transform: translate(0, -100%);
|
|
50
|
+
}
|
|
51
|
+
.date-picker-header-reverse-transition-leave-to {
|
|
52
|
+
opacity: 0;
|
|
53
|
+
transform: translate(0, 100%);
|
|
54
|
+
}
|