vuetify 3.4.0 → 3.4.2
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/json/attributes.json +1860 -1856
- package/dist/json/importMap.json +140 -140
- package/dist/json/tags.json +1 -0
- package/dist/json/web-types.json +3641 -3631
- package/dist/vuetify-labs.css +1393 -1386
- package/dist/vuetify-labs.d.ts +1936 -9147
- package/dist/vuetify-labs.esm.js +91 -79
- package/dist/vuetify-labs.esm.js.map +1 -1
- package/dist/vuetify-labs.js +91 -79
- package/dist/vuetify-labs.min.css +2 -2
- package/dist/vuetify.css +940 -933
- package/dist/vuetify.d.ts +2081 -9282
- package/dist/vuetify.esm.js +91 -79
- package/dist/vuetify.esm.js.map +1 -1
- package/dist/vuetify.js +91 -79
- package/dist/vuetify.js.map +1 -1
- package/dist/vuetify.min.css +2 -2
- package/dist/vuetify.min.js +67 -66
- package/dist/vuetify.min.js.map +1 -1
- package/lib/blueprints/index.d.mts +0 -2
- package/lib/blueprints/md1.d.mts +0 -2
- package/lib/blueprints/md2.d.mts +0 -2
- package/lib/blueprints/md3.d.mts +0 -2
- package/lib/components/VAutocomplete/VAutocomplete.mjs +3 -3
- package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
- package/lib/components/VAutocomplete/index.d.mts +74 -98
- package/lib/components/VBottomNavigation/VBottomNavigation.mjs +1 -1
- package/lib/components/VBottomNavigation/VBottomNavigation.mjs.map +1 -1
- package/lib/components/VBottomNavigation/index.d.mts +44 -69
- package/lib/components/VBtn/VBtn.mjs +1 -1
- package/lib/components/VBtn/VBtn.mjs.map +1 -1
- package/lib/components/VBtn/index.d.mts +11 -11
- package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
- package/lib/components/VBtnToggle/index.d.mts +45 -71
- package/lib/components/VCarousel/VCarousel.mjs +1 -1
- package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
- package/lib/components/VCarousel/index.d.mts +73 -513
- package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
- package/lib/components/VCheckbox/VCheckboxBtn.mjs +1 -1
- package/lib/components/VCheckbox/VCheckboxBtn.mjs.map +1 -1
- package/lib/components/VCheckbox/index.d.mts +100 -482
- package/lib/components/VChip/index.d.mts +15 -18
- package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
- package/lib/components/VChipGroup/index.d.mts +49 -189
- package/lib/components/VCombobox/VCombobox.mjs +3 -3
- package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
- package/lib/components/VCombobox/index.d.mts +74 -98
- package/lib/components/VDataIterator/index.d.mts +8 -6
- package/lib/components/VDataTable/VDataTable.mjs.map +1 -1
- package/lib/components/VDataTable/VDataTableRow.mjs.map +1 -1
- package/lib/components/VDataTable/VDataTableRows.mjs.map +1 -1
- package/lib/components/VDataTable/VDataTableServer.mjs.map +1 -1
- package/lib/components/VDataTable/VDataTableVirtual.mjs +2 -1
- package/lib/components/VDataTable/VDataTableVirtual.mjs.map +1 -1
- package/lib/components/VDataTable/composables/items.mjs.map +1 -1
- package/lib/components/VDataTable/composables/paginate.mjs.map +1 -1
- package/lib/components/VDataTable/composables/select.mjs.map +1 -1
- package/lib/components/VDataTable/index.d.mts +411 -4142
- package/lib/components/VDataTable/types.mjs.map +1 -1
- package/lib/components/VDatePicker/VDatePicker.css +4 -0
- package/lib/components/VDatePicker/VDatePicker.mjs +29 -22
- package/lib/components/VDatePicker/VDatePicker.mjs.map +1 -1
- package/lib/components/VDatePicker/VDatePicker.sass +4 -0
- package/lib/components/VDatePicker/VDatePickerMonth.mjs +3 -1
- package/lib/components/VDatePicker/VDatePickerMonth.mjs.map +1 -1
- package/lib/components/VDatePicker/VDatePickerYears.mjs +1 -1
- package/lib/components/VDatePicker/VDatePickerYears.mjs.map +1 -1
- package/lib/components/VDatePicker/index.d.mts +32 -36
- package/lib/components/VDialog/VDialog.css +4 -1
- package/lib/components/VDialog/VDialog.sass +4 -3
- package/lib/components/VField/VField.mjs +1 -1
- package/lib/components/VField/VField.mjs.map +1 -1
- package/lib/components/VField/index.d.mts +33 -41
- package/lib/components/VFileInput/index.d.mts +144 -385
- package/lib/components/VImg/VImg.mjs +10 -2
- package/lib/components/VImg/VImg.mjs.map +1 -1
- package/lib/components/VInput/VInput.mjs +1 -1
- package/lib/components/VInput/VInput.mjs.map +1 -1
- package/lib/components/VInput/index.d.mts +72 -154
- package/lib/components/VItemGroup/VItemGroup.mjs +1 -1
- package/lib/components/VItemGroup/VItemGroup.mjs.map +1 -1
- package/lib/components/VItemGroup/index.d.mts +49 -189
- package/lib/components/VList/VList.mjs +2 -2
- package/lib/components/VList/VList.mjs.map +1 -1
- package/lib/components/VList/index.d.mts +58 -95
- package/lib/components/VOtpInput/index.d.mts +8 -11
- package/lib/components/VRadio/index.d.mts +1 -1
- package/lib/components/VRadioGroup/VRadioGroup.mjs +1 -1
- package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
- package/lib/components/VRadioGroup/index.d.mts +77 -211
- package/lib/components/VRangeSlider/index.d.mts +22 -25
- package/lib/components/VSelect/VSelect.mjs +2 -2
- package/lib/components/VSelect/VSelect.mjs.map +1 -1
- package/lib/components/VSelect/index.d.mts +67 -91
- package/lib/components/VSelectionControl/VSelectionControl.mjs +2 -2
- package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
- package/lib/components/VSelectionControl/index.d.mts +9 -18
- package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +1 -1
- package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -1
- package/lib/components/VSelectionControlGroup/index.d.mts +46 -68
- package/lib/components/VSlideGroup/VSlideGroup.mjs.map +1 -1
- package/lib/components/VSlideGroup/index.d.mts +47 -101
- package/lib/components/VSlider/index.d.mts +22 -25
- package/lib/components/VSwitch/VSwitch.mjs +7 -5
- package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
- package/lib/components/VSwitch/index.d.mts +90 -303
- package/lib/components/VTextField/index.d.mts +173 -451
- package/lib/components/VTextarea/index.d.mts +144 -385
- package/lib/components/VValidation/VValidation.mjs +2 -2
- package/lib/components/VValidation/VValidation.mjs.map +1 -1
- package/lib/components/VValidation/index.d.mts +88 -359
- package/lib/components/VWindow/VWindow.mjs +1 -1
- package/lib/components/VWindow/VWindow.mjs.map +1 -1
- package/lib/components/VWindow/index.d.mts +58 -245
- package/lib/components/index.d.mts +1933 -9130
- package/lib/composables/date/DateAdapter.mjs.map +1 -1
- package/lib/composables/date/adapters/vuetify.mjs +1 -13
- package/lib/composables/date/adapters/vuetify.mjs.map +1 -1
- package/lib/composables/date/date.mjs +1 -1
- package/lib/composables/date/date.mjs.map +1 -1
- package/lib/composables/form.mjs.map +1 -1
- package/lib/composables/group.mjs.map +1 -1
- package/lib/composables/nested/nested.mjs.map +1 -1
- package/lib/composables/proxiedModel.mjs.map +1 -1
- package/lib/composables/validation.mjs.map +1 -1
- package/lib/composables/virtual.mjs +11 -13
- package/lib/composables/virtual.mjs.map +1 -1
- package/lib/entry-bundler.mjs +1 -1
- package/lib/framework.mjs +1 -1
- package/lib/index.d.mts +40 -44
- package/lib/labs/VConfirmEdit/index.d.mts +0 -10
- package/lib/labs/components.d.mts +0 -10
- package/lib/util/defineComponent.mjs.map +1 -1
- package/lib/util/helpers.mjs.map +1 -1
- package/package.json +2 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.mjs","names":[],"sources":["../../../src/components/VDataTable/types.ts"],"sourcesContent":["// Types\nimport type { provideExpanded } from './composables/expand'\nimport type { Group, GroupableItem, provideGroupBy } from './composables/group'\nimport type { provideSelection, SelectableItem } from './composables/select'\nimport type { FilterFunction, InternalItem } from '@/composables/filter'\nimport type { SelectItemKey } from '@/util'\n\nexport type DataTableCompareFunction<T = any> = (a: T, b: T) => number\n\nexport type DataTableHeader = {\n key?: 'data-table-group' | 'data-table-select' | 'data-table-expand' | (string & {})\n value?: SelectItemKey\n title?: string\n\n fixed?: boolean\n align?: 'start' | 'end' | 'center'\n\n width?: number | string\n minWidth?: string\n maxWidth?: string\n\n headerProps?: Record<string, any>\n cellProps?: HeaderCellProps\n\n sortable?: boolean\n sort?: DataTableCompareFunction\n filter?: FilterFunction\n\n children?: DataTableHeader[]\n}\n\nexport type InternalDataTableHeader = Omit<DataTableHeader, 'key' | 'value' | 'children'> & {\n key: string | null\n value: SelectItemKey | null\n sortable: boolean\n fixedOffset?: number\n lastFixed?: boolean\n colspan?: number\n rowspan?: number\n children?: InternalDataTableHeader[]\n}\n\nexport interface DataTableItem<T = any> extends InternalItem<T>, GroupableItem<T>, SelectableItem {\n key: any\n index: number\n columns: {\n [key: string]: any\n }\n}\n\nexport type GroupHeaderSlot = {\n index: number\n item: Group\n columns: InternalDataTableHeader[]\n isExpanded: ReturnType<typeof provideExpanded>['isExpanded']\n toggleExpand: ReturnType<typeof provideExpanded>['toggleExpand']\n isSelected: ReturnType<typeof provideSelection>['isSelected']\n toggleSelect: ReturnType<typeof provideSelection>['toggleSelect']\n toggleGroup: ReturnType<typeof provideGroupBy>['toggleGroup']\n isGroupOpen: ReturnType<typeof provideGroupBy>['isGroupOpen']\n}\n\ntype ItemSlotBase<T
|
|
1
|
+
{"version":3,"file":"types.mjs","names":[],"sources":["../../../src/components/VDataTable/types.ts"],"sourcesContent":["// Types\nimport type { provideExpanded } from './composables/expand'\nimport type { Group, GroupableItem, provideGroupBy } from './composables/group'\nimport type { provideSelection, SelectableItem } from './composables/select'\nimport type { FilterFunction, InternalItem } from '@/composables/filter'\nimport type { SelectItemKey } from '@/util'\n\nexport type DataTableCompareFunction<T = any> = (a: T, b: T) => number\n\nexport type DataTableHeader = {\n key?: 'data-table-group' | 'data-table-select' | 'data-table-expand' | (string & {})\n value?: SelectItemKey\n title?: string\n\n fixed?: boolean\n align?: 'start' | 'end' | 'center'\n\n width?: number | string\n minWidth?: string\n maxWidth?: string\n\n headerProps?: Record<string, any>\n cellProps?: HeaderCellProps\n\n sortable?: boolean\n sort?: DataTableCompareFunction\n filter?: FilterFunction\n\n children?: DataTableHeader[]\n}\n\nexport type InternalDataTableHeader = Omit<DataTableHeader, 'key' | 'value' | 'children'> & {\n key: string | null\n value: SelectItemKey | null\n sortable: boolean\n fixedOffset?: number\n lastFixed?: boolean\n colspan?: number\n rowspan?: number\n children?: InternalDataTableHeader[]\n}\n\nexport interface DataTableItem<T = any> extends InternalItem<T>, GroupableItem<T>, SelectableItem {\n key: any\n index: number\n columns: {\n [key: string]: any\n }\n}\n\nexport type GroupHeaderSlot = {\n index: number\n item: Group\n columns: InternalDataTableHeader[]\n isExpanded: ReturnType<typeof provideExpanded>['isExpanded']\n toggleExpand: ReturnType<typeof provideExpanded>['toggleExpand']\n isSelected: ReturnType<typeof provideSelection>['isSelected']\n toggleSelect: ReturnType<typeof provideSelection>['toggleSelect']\n toggleGroup: ReturnType<typeof provideGroupBy>['toggleGroup']\n isGroupOpen: ReturnType<typeof provideGroupBy>['isGroupOpen']\n}\n\ntype ItemSlotBase<T> = {\n index: number\n item: T\n internalItem: DataTableItem<T>\n isExpanded: ReturnType<typeof provideExpanded>['isExpanded']\n toggleExpand: ReturnType<typeof provideExpanded>['toggleExpand']\n isSelected: ReturnType<typeof provideSelection>['isSelected']\n toggleSelect: ReturnType<typeof provideSelection>['toggleSelect']\n}\n\nexport type ItemSlot<T> = ItemSlotBase<T> & {\n columns: InternalDataTableHeader[]\n}\n\nexport type ItemKeySlot<T> = ItemSlotBase<T> & {\n value: any\n column: InternalDataTableHeader\n}\n\nexport type RowProps<T> =\n | Record<string, any>\n | ((data: Pick<ItemKeySlot<T>, 'index' | 'item' | 'internalItem'>) => Record<string, any>)\n\nexport type CellProps<T> =\n | Record<string, any>\n | ((data: Pick<ItemKeySlot<T>, 'index' | 'item' | 'internalItem' | 'value' | 'column'>) => Record<string, any>)\n\nexport type HeaderCellProps =\n | Record<string, any>\n | ((data: Pick<ItemKeySlot<any>, 'index' | 'item' | 'internalItem' | 'value'>) => Record<string, any>)\n"],"mappings":""}
|
|
@@ -9,12 +9,13 @@ import { makeVDatePickerMonthProps, VDatePickerMonth } from "./VDatePickerMonth.
|
|
|
9
9
|
import { makeVDatePickerMonthsProps, VDatePickerMonths } from "./VDatePickerMonths.mjs";
|
|
10
10
|
import { makeVDatePickerYearsProps, VDatePickerYears } from "./VDatePickerYears.mjs";
|
|
11
11
|
import { VFadeTransition } from "../transitions/index.mjs";
|
|
12
|
+
import { VDefaultsProvider } from "../VDefaultsProvider/index.mjs";
|
|
12
13
|
import { VTextField } from "../VTextField/index.mjs";
|
|
13
14
|
import { makeVPickerProps, VPicker } from "../../labs/VPicker/VPicker.mjs"; // Composables
|
|
14
15
|
import { useDate } from "../../composables/date/index.mjs";
|
|
15
16
|
import { useLocale } from "../../composables/locale.mjs";
|
|
16
17
|
import { useProxiedModel } from "../../composables/proxiedModel.mjs"; // Utilities
|
|
17
|
-
import { computed, ref, shallowRef, watch
|
|
18
|
+
import { computed, ref, shallowRef, watch } from 'vue';
|
|
18
19
|
import { genericComponent, omit, propsFactory, useRender, wrapInArray } from "../../util/index.mjs"; // Types
|
|
19
20
|
export const makeVDatePickerProps = propsFactory({
|
|
20
21
|
calendarIcon: {
|
|
@@ -70,18 +71,14 @@ export const VDatePicker = genericComponent()({
|
|
|
70
71
|
t
|
|
71
72
|
} = useLocale();
|
|
72
73
|
const model = useProxiedModel(props, 'modelValue', undefined, v => wrapInArray(v), v => props.multiple ? v : v[0]);
|
|
73
|
-
const internal = ref(model.value);
|
|
74
|
-
watchEffect(() => {
|
|
75
|
-
internal.value = model.value;
|
|
76
|
-
});
|
|
77
74
|
const viewMode = useProxiedModel(props, 'viewMode');
|
|
78
75
|
const inputMode = useProxiedModel(props, 'inputMode');
|
|
79
|
-
const
|
|
80
|
-
const value = adapter.date(
|
|
76
|
+
const internal = computed(() => {
|
|
77
|
+
const value = adapter.date(model.value?.[0]);
|
|
81
78
|
return value && adapter.isValid(value) ? value : adapter.date();
|
|
82
79
|
});
|
|
83
|
-
const month = ref(Number(props.month ?? adapter.getMonth(adapter.startOfMonth(
|
|
84
|
-
const year = ref(Number(props.year ?? adapter.getYear(adapter.startOfYear(adapter.setMonth(
|
|
80
|
+
const month = ref(Number(props.month ?? adapter.getMonth(adapter.startOfMonth(internal.value))));
|
|
81
|
+
const year = ref(Number(props.year ?? adapter.getYear(adapter.startOfYear(adapter.setMonth(internal.value, month.value)))));
|
|
85
82
|
const isReversing = shallowRef(false);
|
|
86
83
|
const header = computed(() => {
|
|
87
84
|
return props.multiple && model.value.length > 1 ? t('$vuetify.datePicker.itemsSelected', model.value.length) : model.value[0] && adapter.isValid(model.value[0]) ? adapter.format(model.value[0], 'normalDateWithWeekday') : t(props.header);
|
|
@@ -101,6 +98,7 @@ export const VDatePicker = genericComponent()({
|
|
|
101
98
|
return props.max && adapter.isValid(date) ? date : null;
|
|
102
99
|
});
|
|
103
100
|
const disabled = computed(() => {
|
|
101
|
+
if (props.disabled) return true;
|
|
104
102
|
const targets = [];
|
|
105
103
|
if (viewMode.value !== 'month') {
|
|
106
104
|
targets.push(...['prev', 'next']);
|
|
@@ -154,11 +152,10 @@ export const VDatePicker = genericComponent()({
|
|
|
154
152
|
watch(year, () => {
|
|
155
153
|
if (viewMode.value === 'year') onClickYear();
|
|
156
154
|
});
|
|
157
|
-
watch(
|
|
155
|
+
watch(model, (val, oldVal) => {
|
|
158
156
|
const before = adapter.date(wrapInArray(val)[0]);
|
|
159
157
|
const after = adapter.date(wrapInArray(oldVal)[0]);
|
|
160
158
|
isReversing.value = adapter.isBefore(before, after);
|
|
161
|
-
model.value = val;
|
|
162
159
|
});
|
|
163
160
|
useRender(() => {
|
|
164
161
|
const pickerProps = VPicker.filterProps(props);
|
|
@@ -167,21 +164,31 @@ export const VDatePicker = genericComponent()({
|
|
|
167
164
|
const datePickerMonthProps = VDatePickerMonth.filterProps(props);
|
|
168
165
|
const datePickerMonthsProps = omit(VDatePickerMonths.filterProps(props), ['modelValue']);
|
|
169
166
|
const datePickerYearsProps = omit(VDatePickerYears.filterProps(props), ['modelValue']);
|
|
167
|
+
const headerProps = {
|
|
168
|
+
header: header.value,
|
|
169
|
+
transition: headerTransition.value,
|
|
170
|
+
'onClick:append': onClickAppend
|
|
171
|
+
};
|
|
170
172
|
return _createVNode(VPicker, _mergeProps(pickerProps, {
|
|
171
|
-
"class": ['v-date-picker', `v-date-picker--${viewMode.value}`,
|
|
172
|
-
|
|
173
|
-
|
|
173
|
+
"class": ['v-date-picker', `v-date-picker--${viewMode.value}`, {
|
|
174
|
+
'v-date-picker--show-week': props.showWeek
|
|
175
|
+
}, props.class],
|
|
176
|
+
"style": props.style
|
|
174
177
|
}), {
|
|
175
178
|
title: () => slots.title?.() ?? _createVNode("div", {
|
|
176
179
|
"class": "v-date-picker__title"
|
|
177
180
|
}, [t(props.title)]),
|
|
178
|
-
header: () => _createVNode(
|
|
181
|
+
header: () => slots.header ? _createVNode(VDefaultsProvider, {
|
|
182
|
+
"defaults": {
|
|
183
|
+
VDatePickerHeader: {
|
|
184
|
+
...headerProps
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
}, {
|
|
188
|
+
default: () => [slots.header?.(headerProps)]
|
|
189
|
+
}) : _createVNode(VDatePickerHeader, _mergeProps({
|
|
179
190
|
"key": "header"
|
|
180
|
-
}, datePickerHeaderProps,
|
|
181
|
-
"header": header.value,
|
|
182
|
-
"transition": headerTransition.value,
|
|
183
|
-
"onClick:append": onClickAppend
|
|
184
|
-
}), slots),
|
|
191
|
+
}, datePickerHeaderProps, headerProps), slots),
|
|
185
192
|
default: () => props.inputMode === 'calendar' ? _createVNode(_Fragment, null, [_createVNode(VDatePickerControls, _mergeProps(datePickerControlsProps, {
|
|
186
193
|
"disabled": disabled.value,
|
|
187
194
|
"text": text.value,
|
|
@@ -209,8 +216,8 @@ export const VDatePicker = genericComponent()({
|
|
|
209
216
|
}), null) : _createVNode(VDatePickerMonth, _mergeProps({
|
|
210
217
|
"key": "date-picker-month"
|
|
211
218
|
}, datePickerMonthProps, {
|
|
212
|
-
"modelValue":
|
|
213
|
-
"onUpdate:modelValue": $event =>
|
|
219
|
+
"modelValue": model.value,
|
|
220
|
+
"onUpdate:modelValue": $event => model.value = $event,
|
|
214
221
|
"month": month.value,
|
|
215
222
|
"onUpdate:month": $event => month.value = $event,
|
|
216
223
|
"year": year.value,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VDatePicker.mjs","names":["makeVDatePickerControlsProps","VDatePickerControls","VDatePickerHeader","makeVDatePickerMonthProps","VDatePickerMonth","makeVDatePickerMonthsProps","VDatePickerMonths","makeVDatePickerYearsProps","VDatePickerYears","VFadeTransition","VTextField","makeVPickerProps","VPicker","useDate","useLocale","useProxiedModel","computed","ref","shallowRef","watch","watchEffect","genericComponent","omit","propsFactory","useRender","wrapInArray","makeVDatePickerProps","calendarIcon","type","String","default","keyboardIcon","inputMode","inputText","inputPlaceholder","header","title","modelValue","VDatePicker","name","props","emits","date","setup","_ref","emit","slots","adapter","t","model","undefined","v","multiple","internal","value","viewMode","_model","isValid","month","Number","getMonth","startOfMonth","year","getYear","startOfYear","setMonth","isReversing","length","format","text","setYear","headerTransition","minDate","min","maxDate","max","disabled","targets","push","_date","addDays","isAfter","endOfMonth","onClickAppend","onClickNext","onClickPrev","onClickMonth","onClickYear","val","oldVal","before","after","isBefore","pickerProps","filterProps","datePickerControlsProps","datePickerHeaderProps","datePickerMonthProps","datePickerMonthsProps","datePickerYearsProps","_createVNode","_mergeProps","class","style","showWeek","_Fragment","$event","actions"],"sources":["../../../src/components/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 { makeVDatePickerMonthsProps, VDatePickerMonths } from './VDatePickerMonths'\nimport { makeVDatePickerYearsProps, VDatePickerYears } from './VDatePickerYears'\nimport { VFadeTransition } from '@/components/transitions'\nimport { VTextField } from '@/components/VTextField'\nimport { makeVPickerProps, VPicker } from '@/labs/VPicker/VPicker'\n\n// Composables\nimport { useDate } from '@/composables/date'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { computed, ref, shallowRef, watch, watchEffect } from 'vue'\nimport { genericComponent, omit, propsFactory, useRender, wrapInArray } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { VPickerSlots } from '@/labs/VPicker/VPicker'\nimport type { GenericProps } from '@/util'\n\n// Types\nexport type VDatePickerSlots = Omit<VPickerSlots, 'header'> & {\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 inputMode: {\n type: String as PropType<'calendar' | 'keyboard'>,\n default: 'calendar',\n },\n inputText: {\n type: String,\n default: '$vuetify.datePicker.input.placeholder',\n },\n inputPlaceholder: {\n type: String,\n default: 'dd/mm/yyyy',\n },\n header: {\n type: String,\n default: '$vuetify.datePicker.header',\n },\n\n ...makeVDatePickerControlsProps(),\n ...makeVDatePickerMonthProps(),\n ...omit(makeVDatePickerMonthsProps(), ['modelValue']),\n ...omit(makeVDatePickerYearsProps(), ['modelValue']),\n ...makeVPickerProps({ title: '$vuetify.datePicker.title' }),\n\n modelValue: null,\n}, 'VDatePicker')\n\nexport const VDatePicker = genericComponent<new <T, Multiple extends boolean = false> (\n props: {\n modelValue?: Multiple extends true ? T[] : T\n 'onUpdate:modelValue'?: (value: Multiple extends true ? T[] : T) => void\n multiple?: Multiple\n },\n slots: VDatePickerSlots\n) => GenericProps<typeof props, typeof slots>>()({\n name: 'VDatePicker',\n\n props: makeVDatePickerProps(),\n\n emits: {\n 'update:modelValue': (date: any) => true,\n 'update:month': (date: any) => true,\n 'update:year': (date: any) => true,\n 'update:inputMode': (date: any) => true,\n 'update:viewMode': (date: any) => true,\n },\n\n setup (props, { emit, slots }) {\n const adapter = useDate()\n const { t } = useLocale()\n\n const model = useProxiedModel(\n props,\n 'modelValue',\n undefined,\n v => wrapInArray(v),\n v => props.multiple ? v : v[0],\n )\n const internal = ref(model.value)\n watchEffect(() => {\n internal.value = model.value\n })\n\n const viewMode = useProxiedModel(props, 'viewMode')\n const inputMode = useProxiedModel(props, 'inputMode')\n const _model = computed(() => {\n const value = adapter.date(internal.value?.[0])\n\n return value && adapter.isValid(value) ? value : adapter.date()\n })\n\n const month = ref(Number(props.month ?? adapter.getMonth(adapter.startOfMonth(_model.value))))\n const year = ref(Number(props.year ?? adapter.getYear(adapter.startOfYear(adapter.setMonth(_model.value, month.value)))))\n\n const isReversing = shallowRef(false)\n const header = computed(() => {\n return props.multiple && model.value.length > 1\n ? t('$vuetify.datePicker.itemsSelected', model.value.length)\n : model.value[0] && adapter.isValid(model.value[0])\n ? adapter.format(model.value[0], 'normalDateWithWeekday')\n : t(props.header)\n })\n const text = computed(() => {\n return adapter.format(\n adapter.setYear(adapter.setMonth(adapter.date(), month.value), year.value),\n 'monthAndYear',\n )\n })\n // TODO: implement in v3.5\n // const headerIcon = computed(() => props.inputMode === 'calendar' ? props.keyboardIcon : props.calendarIcon)\n const headerTransition = computed(() => `date-picker-header${isReversing.value ? '-reverse' : ''}-transition`)\n const minDate = computed(() => {\n const date = adapter.date(props.min)\n\n return props.min && adapter.isValid(date) ? date : null\n })\n const maxDate = computed(() => {\n const date = adapter.date(props.max)\n\n return props.max && adapter.isValid(date) ? date : null\n })\n const disabled = computed(() => {\n const targets = []\n\n if (viewMode.value !== 'month') {\n targets.push(...['prev', 'next'])\n } else {\n let _date = adapter.date()\n\n _date = adapter.setYear(_date, year.value)\n _date = adapter.setMonth(_date, month.value)\n\n if (minDate.value) {\n const date = adapter.addDays(adapter.startOfMonth(_date), -1)\n\n adapter.isAfter(minDate.value, date) && targets.push('prev')\n }\n\n if (maxDate.value) {\n const date = adapter.addDays(adapter.endOfMonth(_date), 1)\n\n adapter.isAfter(date, maxDate.value) && targets.push('next')\n }\n }\n\n return targets\n })\n\n function onClickAppend () {\n inputMode.value = inputMode.value === 'calendar' ? 'keyboard' : 'calendar'\n }\n\n function onClickNext () {\n if (month.value < 11) {\n month.value++\n\n emit('update:month', month.value)\n } else {\n year.value++\n month.value = 0\n\n emit('update:year', year.value)\n }\n }\n\n function onClickPrev () {\n if (month.value > 0) {\n month.value--\n\n emit('update:month', month.value)\n } else {\n year.value--\n month.value = 11\n\n emit('update:year', month.value)\n }\n }\n\n function onClickMonth () {\n viewMode.value = viewMode.value === 'months' ? 'month' : 'months'\n }\n\n function onClickYear () {\n viewMode.value = viewMode.value === 'year' ? 'month' : 'year'\n }\n\n watch(month, () => {\n if (viewMode.value === 'months') onClickMonth()\n })\n\n watch(year, () => {\n if (viewMode.value === 'year') onClickYear()\n })\n\n watch(internal, (val, oldVal) => {\n const before = adapter.date(wrapInArray(val)[0])\n const after = adapter.date(wrapInArray(oldVal)[0])\n\n isReversing.value = adapter.isBefore(before, after)\n\n model.value = val\n })\n\n useRender(() => {\n const pickerProps = VPicker.filterProps(props)\n const datePickerControlsProps = VDatePickerControls.filterProps(props)\n const datePickerHeaderProps = VDatePickerHeader.filterProps(props)\n const datePickerMonthProps = VDatePickerMonth.filterProps(props)\n const datePickerMonthsProps = omit(VDatePickerMonths.filterProps(props), ['modelValue'])\n const datePickerYearsProps = omit(VDatePickerYears.filterProps(props), ['modelValue'])\n\n return (\n <VPicker\n { ...pickerProps }\n class={[\n 'v-date-picker',\n `v-date-picker--${viewMode.value}`,\n props.class,\n ]}\n style={ props.style }\n width={ props.showWeek ? 408 : 360 }\n v-slots={{\n title: () => slots.title?.() ?? (\n <div class=\"v-date-picker__title\">\n { t(props.title) }\n </div>\n ),\n header: () => (\n <VDatePickerHeader\n key=\"header\"\n { ...datePickerHeaderProps }\n header={ header.value }\n transition={ headerTransition.value }\n onClick:append={ onClickAppend }\n v-slots={ slots }\n />\n ),\n default: () => props.inputMode === 'calendar' ? (\n <>\n <VDatePickerControls\n { ...datePickerControlsProps }\n disabled={ disabled.value }\n text={ text.value }\n onClick:next={ onClickNext }\n onClick:prev={ onClickPrev }\n onClick:month={ onClickMonth }\n onClick:year={ onClickYear }\n />\n\n <VFadeTransition hideOnLeave>\n { viewMode.value === 'months' ? (\n <VDatePickerMonths\n key=\"date-picker-months\"\n { ...datePickerMonthsProps }\n v-model={ month.value }\n min={ minDate.value }\n max={ maxDate.value }\n />\n ) : viewMode.value === 'year' ? (\n <VDatePickerYears\n key=\"date-picker-years\"\n { ...datePickerYearsProps }\n v-model={ year.value }\n min={ minDate.value }\n max={ maxDate.value }\n />\n ) : (\n <VDatePickerMonth\n key=\"date-picker-month\"\n { ...datePickerMonthProps }\n v-model={ internal.value }\n v-model:month={ month.value }\n v-model:year={ year.value }\n min={ minDate.value }\n max={ maxDate.value }\n />\n )}\n </VFadeTransition>\n </>\n ) : (\n <div class=\"v-date-picker__input\">\n <VTextField\n label={ t(props.inputText) }\n placeholder={ props.inputPlaceholder }\n />\n </div>\n ),\n actions: slots.actions,\n }}\n />\n )\n })\n\n return {}\n },\n})\n\nexport type VDatePicker = InstanceType<typeof VDatePicker>\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"VDatePicker.mjs","names":["makeVDatePickerControlsProps","VDatePickerControls","VDatePickerHeader","makeVDatePickerMonthProps","VDatePickerMonth","makeVDatePickerMonthsProps","VDatePickerMonths","makeVDatePickerYearsProps","VDatePickerYears","VFadeTransition","VDefaultsProvider","VTextField","makeVPickerProps","VPicker","useDate","useLocale","useProxiedModel","computed","ref","shallowRef","watch","genericComponent","omit","propsFactory","useRender","wrapInArray","makeVDatePickerProps","calendarIcon","type","String","default","keyboardIcon","inputMode","inputText","inputPlaceholder","header","title","modelValue","VDatePicker","name","props","emits","date","setup","_ref","emit","slots","adapter","t","model","undefined","v","multiple","viewMode","internal","value","isValid","month","Number","getMonth","startOfMonth","year","getYear","startOfYear","setMonth","isReversing","length","format","text","setYear","headerTransition","minDate","min","maxDate","max","disabled","targets","push","_date","addDays","isAfter","endOfMonth","onClickAppend","onClickNext","onClickPrev","onClickMonth","onClickYear","val","oldVal","before","after","isBefore","pickerProps","filterProps","datePickerControlsProps","datePickerHeaderProps","datePickerMonthProps","datePickerMonthsProps","datePickerYearsProps","headerProps","transition","_createVNode","_mergeProps","showWeek","class","style","_Fragment","$event","actions"],"sources":["../../../src/components/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 { makeVDatePickerMonthsProps, VDatePickerMonths } from './VDatePickerMonths'\nimport { makeVDatePickerYearsProps, VDatePickerYears } from './VDatePickerYears'\nimport { VFadeTransition } from '@/components/transitions'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VTextField } from '@/components/VTextField'\nimport { makeVPickerProps, VPicker } from '@/labs/VPicker/VPicker'\n\n// Composables\nimport { useDate } from '@/composables/date'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { computed, ref, shallowRef, watch } from 'vue'\nimport { genericComponent, omit, propsFactory, useRender, wrapInArray } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { VPickerSlots } from '@/labs/VPicker/VPicker'\nimport type { GenericProps } from '@/util'\n\n// Types\nexport type VDatePickerSlots = Omit<VPickerSlots, 'header'> & {\n header: {\n header: string\n transition: 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 inputMode: {\n type: String as PropType<'calendar' | 'keyboard'>,\n default: 'calendar',\n },\n inputText: {\n type: String,\n default: '$vuetify.datePicker.input.placeholder',\n },\n inputPlaceholder: {\n type: String,\n default: 'dd/mm/yyyy',\n },\n header: {\n type: String,\n default: '$vuetify.datePicker.header',\n },\n\n ...makeVDatePickerControlsProps(),\n ...makeVDatePickerMonthProps(),\n ...omit(makeVDatePickerMonthsProps(), ['modelValue']),\n ...omit(makeVDatePickerYearsProps(), ['modelValue']),\n ...makeVPickerProps({ title: '$vuetify.datePicker.title' }),\n\n modelValue: null,\n}, 'VDatePicker')\n\nexport const VDatePicker = genericComponent<new <T, Multiple extends boolean = false> (\n props: {\n modelValue?: Multiple extends true ? T[] : T\n 'onUpdate:modelValue'?: (value: Multiple extends true ? T[] : T) => void\n multiple?: Multiple\n },\n slots: VDatePickerSlots\n) => GenericProps<typeof props, typeof slots>>()({\n name: 'VDatePicker',\n\n props: makeVDatePickerProps(),\n\n emits: {\n 'update:modelValue': (date: any) => true,\n 'update:month': (date: any) => true,\n 'update:year': (date: any) => true,\n 'update:inputMode': (date: any) => true,\n 'update:viewMode': (date: any) => true,\n },\n\n setup (props, { emit, slots }) {\n const adapter = useDate()\n const { t } = useLocale()\n\n const model = useProxiedModel(\n props,\n 'modelValue',\n undefined,\n v => wrapInArray(v),\n v => props.multiple ? v : v[0],\n )\n\n const viewMode = useProxiedModel(props, 'viewMode')\n const inputMode = useProxiedModel(props, 'inputMode')\n const internal = computed(() => {\n const value = adapter.date(model.value?.[0])\n\n return value && adapter.isValid(value) ? value : adapter.date()\n })\n\n const month = ref(Number(props.month ?? adapter.getMonth(adapter.startOfMonth(internal.value))))\n const year = ref(Number(props.year ?? adapter.getYear(adapter.startOfYear(adapter.setMonth(internal.value, month.value)))))\n\n const isReversing = shallowRef(false)\n const header = computed(() => {\n return props.multiple && model.value.length > 1\n ? t('$vuetify.datePicker.itemsSelected', model.value.length)\n : model.value[0] && adapter.isValid(model.value[0])\n ? adapter.format(model.value[0], 'normalDateWithWeekday')\n : t(props.header)\n })\n const text = computed(() => {\n return adapter.format(\n adapter.setYear(adapter.setMonth(adapter.date(), month.value), year.value),\n 'monthAndYear',\n )\n })\n // TODO: implement in v3.5\n // const headerIcon = computed(() => props.inputMode === 'calendar' ? props.keyboardIcon : props.calendarIcon)\n const headerTransition = computed(() => `date-picker-header${isReversing.value ? '-reverse' : ''}-transition`)\n const minDate = computed(() => {\n const date = adapter.date(props.min)\n\n return props.min && adapter.isValid(date) ? date : null\n })\n const maxDate = computed(() => {\n const date = adapter.date(props.max)\n\n return props.max && adapter.isValid(date) ? date : null\n })\n const disabled = computed(() => {\n if (props.disabled) return true\n\n const targets = []\n\n if (viewMode.value !== 'month') {\n targets.push(...['prev', 'next'])\n } else {\n let _date = adapter.date()\n\n _date = adapter.setYear(_date, year.value)\n _date = adapter.setMonth(_date, month.value)\n\n if (minDate.value) {\n const date = adapter.addDays(adapter.startOfMonth(_date), -1)\n\n adapter.isAfter(minDate.value, date) && targets.push('prev')\n }\n\n if (maxDate.value) {\n const date = adapter.addDays(adapter.endOfMonth(_date), 1)\n\n adapter.isAfter(date, maxDate.value) && targets.push('next')\n }\n }\n\n return targets\n })\n\n function onClickAppend () {\n inputMode.value = inputMode.value === 'calendar' ? 'keyboard' : 'calendar'\n }\n\n function onClickNext () {\n if (month.value < 11) {\n month.value++\n\n emit('update:month', month.value)\n } else {\n year.value++\n month.value = 0\n\n emit('update:year', year.value)\n }\n }\n\n function onClickPrev () {\n if (month.value > 0) {\n month.value--\n\n emit('update:month', month.value)\n } else {\n year.value--\n month.value = 11\n\n emit('update:year', month.value)\n }\n }\n\n function onClickMonth () {\n viewMode.value = viewMode.value === 'months' ? 'month' : 'months'\n }\n\n function onClickYear () {\n viewMode.value = viewMode.value === 'year' ? 'month' : 'year'\n }\n\n watch(month, () => {\n if (viewMode.value === 'months') onClickMonth()\n })\n\n watch(year, () => {\n if (viewMode.value === 'year') onClickYear()\n })\n\n watch(model, (val, oldVal) => {\n const before = adapter.date(wrapInArray(val)[0])\n const after = adapter.date(wrapInArray(oldVal)[0])\n\n isReversing.value = adapter.isBefore(before, after)\n })\n\n useRender(() => {\n const pickerProps = VPicker.filterProps(props)\n const datePickerControlsProps = VDatePickerControls.filterProps(props)\n const datePickerHeaderProps = VDatePickerHeader.filterProps(props)\n const datePickerMonthProps = VDatePickerMonth.filterProps(props)\n const datePickerMonthsProps = omit(VDatePickerMonths.filterProps(props), ['modelValue'])\n const datePickerYearsProps = omit(VDatePickerYears.filterProps(props), ['modelValue'])\n\n const headerProps = {\n header: header.value,\n transition: headerTransition.value,\n 'onClick:append': onClickAppend,\n }\n\n return (\n <VPicker\n { ...pickerProps }\n class={[\n 'v-date-picker',\n `v-date-picker--${viewMode.value}`,\n {\n 'v-date-picker--show-week': props.showWeek,\n },\n props.class,\n ]}\n style={ props.style }\n v-slots={{\n title: () => slots.title?.() ?? (\n <div class=\"v-date-picker__title\">\n { t(props.title) }\n </div>\n ),\n header: () => slots.header ? (\n <VDefaultsProvider\n defaults={{\n VDatePickerHeader: { ...headerProps },\n }}\n >\n { slots.header?.(headerProps) }\n </VDefaultsProvider>\n ) : (\n <VDatePickerHeader\n key=\"header\"\n { ...datePickerHeaderProps }\n { ...headerProps }\n v-slots={ slots }\n />\n ),\n default: () => props.inputMode === 'calendar' ? (\n <>\n <VDatePickerControls\n { ...datePickerControlsProps }\n disabled={ disabled.value }\n text={ text.value }\n onClick:next={ onClickNext }\n onClick:prev={ onClickPrev }\n onClick:month={ onClickMonth }\n onClick:year={ onClickYear }\n />\n\n <VFadeTransition hideOnLeave>\n { viewMode.value === 'months' ? (\n <VDatePickerMonths\n key=\"date-picker-months\"\n { ...datePickerMonthsProps }\n v-model={ month.value }\n min={ minDate.value }\n max={ maxDate.value }\n />\n ) : viewMode.value === 'year' ? (\n <VDatePickerYears\n key=\"date-picker-years\"\n { ...datePickerYearsProps }\n v-model={ year.value }\n min={ minDate.value }\n max={ maxDate.value }\n />\n ) : (\n <VDatePickerMonth\n key=\"date-picker-month\"\n { ...datePickerMonthProps }\n v-model={ model.value }\n v-model:month={ month.value }\n v-model:year={ year.value }\n min={ minDate.value }\n max={ maxDate.value }\n />\n )}\n </VFadeTransition>\n </>\n ) : (\n <div class=\"v-date-picker__input\">\n <VTextField\n label={ t(props.inputText) }\n placeholder={ props.inputPlaceholder }\n />\n </div>\n ),\n actions: slots.actions,\n }}\n />\n )\n })\n\n return {}\n },\n})\n\nexport type VDatePicker = InstanceType<typeof VDatePicker>\n"],"mappings":"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"}
|
|
@@ -11,6 +11,7 @@ import { computed, ref } from 'vue';
|
|
|
11
11
|
import { genericComponent, propsFactory, wrapInArray } from "../../util/index.mjs"; // Types
|
|
12
12
|
export const makeVDatePickerMonthProps = propsFactory({
|
|
13
13
|
allowedDates: [Array, Function],
|
|
14
|
+
disabled: Boolean,
|
|
14
15
|
color: String,
|
|
15
16
|
month: [Number, String],
|
|
16
17
|
hideWeekdays: Boolean,
|
|
@@ -63,7 +64,7 @@ export const VDatePickerMonth = genericComponent()({
|
|
|
63
64
|
// Make sure there's always 6 weeks in month (6 * 7 days)
|
|
64
65
|
// But only do it if we're not hiding adjacent months?
|
|
65
66
|
const daysInMonth = 6 * 7;
|
|
66
|
-
if (days.length < daysInMonth
|
|
67
|
+
if (days.length < daysInMonth) {
|
|
67
68
|
const lastDay = days[days.length - 1];
|
|
68
69
|
let week = [];
|
|
69
70
|
for (let day = 1; day <= daysInMonth - days.length; day++) {
|
|
@@ -106,6 +107,7 @@ export const VDatePickerMonth = genericComponent()({
|
|
|
106
107
|
});
|
|
107
108
|
});
|
|
108
109
|
function isDisabled(value) {
|
|
110
|
+
if (props.disabled) return true;
|
|
109
111
|
const date = adapter.date(value);
|
|
110
112
|
if (props.min && adapter.isAfter(props.min, date)) return true;
|
|
111
113
|
if (props.max && adapter.isAfter(date, props.max)) return true;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VDatePickerMonth.mjs","names":["VBtn","VDefaultsProvider","getWeek","useDate","useProxiedModel","computed","ref","genericComponent","propsFactory","wrapInArray","makeVDatePickerMonthProps","allowedDates","Array","Function","color","String","month","Number","hideWeekdays","Boolean","max","min","modelValue","multiple","showAdjacentMonths","showWeek","year","VDatePickerMonth","name","props","emits","date","setup","_ref","emit","slots","daysRef","adapter","model","v","_model","value","isValid","undefined","setYear","startOfYear","getYear","setMonth","getMonth","weeksInMonth","weeks","getWeekArray","days","flat","daysInMonth","length","lastDay","week","day","push","addDays","today","map","index","isoDate","toISO","isAdjacent","isSameMonth","formatted","format","isDisabled","isWeekStart","isWeekEnd","isSelected","some","isSameDay","isToday","isHidden","isHovered","localized","isAfter","isArray","d","onClick","findIndex","selection","splice","_createVNode","_createTextVNode","getWeekdays","weekDay","item","i","slotProps","disabled","icon","ripple","text","variant","default"],"sources":["../../../src/components/VDatePicker/VDatePickerMonth.tsx"],"sourcesContent":["// Styles\nimport './VDatePickerMonth.sass'\n\n// Components\nimport { VBtn } from '@/components/VBtn'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\n\n// Composables\nimport { getWeek, useDate } from '@/composables/date/date'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { computed, ref } from 'vue'\nimport { genericComponent, propsFactory, wrapInArray } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\nexport type VDatePickerMonthSlots = {\n day: {\n props: {\n onClick: () => void\n }\n item: any\n i: number\n }\n}\n\nexport const makeVDatePickerMonthProps = propsFactory({\n allowedDates: [Array, Function],\n color: String,\n month: [Number, String],\n hideWeekdays: Boolean,\n max: null as any as PropType<unknown>,\n min: null as any as PropType<unknown>,\n modelValue: Array as PropType<unknown[]>,\n multiple: Boolean,\n showAdjacentMonths: Boolean,\n showWeek: Boolean,\n year: [Number, String],\n}, 'VDatePickerMonth')\n\nexport const VDatePickerMonth = genericComponent<VDatePickerMonthSlots>()({\n name: 'VDatePickerMonth',\n\n props: makeVDatePickerMonthProps(),\n\n emits: {\n 'update:modelValue': (date: any) => true,\n 'update:month': (date: any) => true,\n 'update:year': (date: any) => true,\n },\n\n setup (props, { emit, slots }) {\n const daysRef = ref()\n\n const adapter = useDate()\n // model comes in always as array\n // leaves as array if multiple\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => wrapInArray(v),\n )\n // shorthand to access the first value in the model or a fresh date\n const _model = computed(() => {\n const value = model.value?.[0]\n\n return value && adapter.isValid(value) ? value : adapter.date()\n })\n const year = useProxiedModel(\n props,\n 'year',\n undefined,\n v => {\n let date = adapter.date(_model.value)\n\n if (v != null) date = adapter.setYear(date, Number(v))\n\n return adapter.startOfYear(date)\n },\n v => adapter.getYear(v)\n )\n const month = useProxiedModel(\n props,\n 'month',\n undefined,\n v => {\n let date = adapter.date(_model.value)\n\n if (v != null) date = adapter.setMonth(date, Number(v))\n\n date = adapter.setYear(date, adapter.getYear(year.value))\n\n return date\n },\n v => adapter.getMonth(v)\n )\n\n const weeksInMonth = computed(() => {\n const weeks = adapter.getWeekArray(month.value)\n\n const days = weeks.flat()\n\n // Make sure there's always 6 weeks in month (6 * 7 days)\n // But only do it if we're not hiding adjacent months?\n const daysInMonth = 6 * 7\n if (days.length < daysInMonth && props.showAdjacentMonths) {\n const lastDay = days[days.length - 1]\n\n let week = []\n for (let day = 1; day <= daysInMonth - days.length; day++) {\n week.push(adapter.addDays(lastDay, day))\n\n if (day % 7 === 0) {\n weeks.push(week)\n week = []\n }\n }\n }\n\n return weeks\n })\n\n const daysInMonth = computed(() => {\n const days = weeksInMonth.value.flat()\n const today = adapter.date()\n\n return days.map((date, index) => {\n const isoDate = adapter.toISO(date)\n const isAdjacent = !adapter.isSameMonth(date, month.value)\n\n return {\n date,\n isoDate,\n formatted: adapter.format(date, 'keyboardDate'),\n year: adapter.getYear(date),\n month: adapter.getMonth(date),\n isDisabled: isDisabled(date),\n isWeekStart: index % 7 === 0,\n isWeekEnd: index % 7 === 6,\n isSelected: model.value.some(value => adapter.isSameDay(date, value)),\n isToday: adapter.isSameDay(date, today),\n isAdjacent,\n isHidden: isAdjacent && !props.showAdjacentMonths,\n isHovered: false,\n localized: adapter.format(date, 'dayOfMonth'),\n }\n })\n })\n\n const weeks = computed(() => {\n return weeksInMonth.value.map(week => {\n return getWeek(adapter, week[0])\n })\n })\n\n function isDisabled (value: unknown) {\n const date = adapter.date(value)\n\n if (props.min && adapter.isAfter(props.min, date)) return true\n if (props.max && adapter.isAfter(date, props.max)) return true\n\n if (Array.isArray(props.allowedDates)) {\n return !props.allowedDates.some(d => adapter.isSameDay(adapter.date(d), date))\n }\n\n if (typeof props.allowedDates === 'function') {\n return !props.allowedDates(date)\n }\n\n return false\n }\n\n function onClick (value: unknown) {\n if (props.multiple) {\n const index = model.value.findIndex(selection => adapter.isSameDay(selection, value))\n\n if (index === -1) {\n model.value = [...model.value, value]\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n } else {\n model.value = [value]\n }\n }\n\n return () => (\n <div class=\"v-date-picker-month\">\n { props.showWeek && (\n <div key=\"weeks\" class=\"v-date-picker-month__weeks\">\n { !props.hideWeekdays && (\n <div key=\"hide-week-days\" class=\"v-date-picker-month__day\"> </div>\n )}\n { weeks.value.map(week => (\n <div\n class={[\n 'v-date-picker-month__day',\n 'v-date-picker-month__day--adjacent',\n ]}\n >{ week }</div>\n ))}\n </div>\n )}\n\n <div\n ref={ daysRef }\n class=\"v-date-picker-month__days\"\n >\n { !props.hideWeekdays && adapter.getWeekdays().map(weekDay => (\n <div\n class={[\n 'v-date-picker-month__day',\n 'v-date-picker-month__weekday',\n ]}\n >{ weekDay }</div>\n ))}\n\n { daysInMonth.value.map((item, i) => {\n const slotProps = {\n props: {\n onClick: () => onClick(item.date),\n },\n item,\n i,\n } as const\n\n return (\n <div\n class={[\n 'v-date-picker-month__day',\n {\n 'v-date-picker-month__day--adjacent': item.isAdjacent,\n 'v-date-picker-month__day--hide-adjacent': item.isHidden,\n 'v-date-picker-month__day--hovered': item.isHovered,\n 'v-date-picker-month__day--selected': item.isSelected,\n 'v-date-picker-month__day--week-end': item.isWeekEnd,\n 'v-date-picker-month__day--week-start': item.isWeekStart,\n },\n ]}\n data-v-date={ !item.isDisabled ? item.isoDate : undefined }\n >\n\n { (props.showAdjacentMonths || !item.isAdjacent) && (\n <VDefaultsProvider\n defaults={{\n VBtn: {\n color: (item.isSelected || item.isToday) && !item.isDisabled\n ? props.color\n : undefined,\n disabled: item.isDisabled,\n icon: true,\n ripple: false,\n text: item.localized,\n variant: item.isDisabled\n ? 'text'\n : item.isToday && !item.isSelected ? 'outlined' : 'flat',\n onClick: () => onClick(item.date),\n },\n }}\n >\n { slots.day?.(slotProps) ?? (\n <VBtn { ...slotProps.props } />\n )}\n </VDefaultsProvider>\n )}\n </div>\n )\n })}\n </div>\n </div>\n )\n },\n})\n\nexport type VDatePickerMonth = InstanceType<typeof VDatePickerMonth>\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"VDatePickerMonth.mjs","names":["VBtn","VDefaultsProvider","getWeek","useDate","useProxiedModel","computed","ref","genericComponent","propsFactory","wrapInArray","makeVDatePickerMonthProps","allowedDates","Array","Function","disabled","Boolean","color","String","month","Number","hideWeekdays","max","min","modelValue","multiple","showAdjacentMonths","showWeek","year","VDatePickerMonth","name","props","emits","date","setup","_ref","emit","slots","daysRef","adapter","model","v","_model","value","isValid","undefined","setYear","startOfYear","getYear","setMonth","getMonth","weeksInMonth","weeks","getWeekArray","days","flat","daysInMonth","length","lastDay","week","day","push","addDays","today","map","index","isoDate","toISO","isAdjacent","isSameMonth","formatted","format","isDisabled","isWeekStart","isWeekEnd","isSelected","some","isSameDay","isToday","isHidden","isHovered","localized","isAfter","isArray","d","onClick","findIndex","selection","splice","_createVNode","_createTextVNode","getWeekdays","weekDay","item","i","slotProps","icon","ripple","text","variant","default"],"sources":["../../../src/components/VDatePicker/VDatePickerMonth.tsx"],"sourcesContent":["// Styles\nimport './VDatePickerMonth.sass'\n\n// Components\nimport { VBtn } from '@/components/VBtn'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\n\n// Composables\nimport { getWeek, useDate } from '@/composables/date/date'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { computed, ref } from 'vue'\nimport { genericComponent, propsFactory, wrapInArray } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\nexport type VDatePickerMonthSlots = {\n day: {\n props: {\n onClick: () => void\n }\n item: any\n i: number\n }\n}\n\nexport const makeVDatePickerMonthProps = propsFactory({\n allowedDates: [Array, Function],\n disabled: Boolean,\n color: String,\n month: [Number, String],\n hideWeekdays: Boolean,\n max: null as any as PropType<unknown>,\n min: null as any as PropType<unknown>,\n modelValue: Array as PropType<unknown[]>,\n multiple: Boolean,\n showAdjacentMonths: Boolean,\n showWeek: Boolean,\n year: [Number, String],\n}, 'VDatePickerMonth')\n\nexport const VDatePickerMonth = genericComponent<VDatePickerMonthSlots>()({\n name: 'VDatePickerMonth',\n\n props: makeVDatePickerMonthProps(),\n\n emits: {\n 'update:modelValue': (date: any) => true,\n 'update:month': (date: any) => true,\n 'update:year': (date: any) => true,\n },\n\n setup (props, { emit, slots }) {\n const daysRef = ref()\n\n const adapter = useDate()\n // model comes in always as array\n // leaves as array if multiple\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => wrapInArray(v),\n )\n // shorthand to access the first value in the model or a fresh date\n const _model = computed(() => {\n const value = model.value?.[0]\n\n return value && adapter.isValid(value) ? value : adapter.date()\n })\n const year = useProxiedModel(\n props,\n 'year',\n undefined,\n v => {\n let date = adapter.date(_model.value)\n\n if (v != null) date = adapter.setYear(date, Number(v))\n\n return adapter.startOfYear(date)\n },\n v => adapter.getYear(v)\n )\n const month = useProxiedModel(\n props,\n 'month',\n undefined,\n v => {\n let date = adapter.date(_model.value)\n\n if (v != null) date = adapter.setMonth(date, Number(v))\n\n date = adapter.setYear(date, adapter.getYear(year.value))\n\n return date\n },\n v => adapter.getMonth(v)\n )\n\n const weeksInMonth = computed(() => {\n const weeks = adapter.getWeekArray(month.value)\n\n const days = weeks.flat()\n\n // Make sure there's always 6 weeks in month (6 * 7 days)\n // But only do it if we're not hiding adjacent months?\n const daysInMonth = 6 * 7\n if (days.length < daysInMonth) {\n const lastDay = days[days.length - 1]\n\n let week = []\n for (let day = 1; day <= daysInMonth - days.length; day++) {\n week.push(adapter.addDays(lastDay, day))\n\n if (day % 7 === 0) {\n weeks.push(week)\n week = []\n }\n }\n }\n\n return weeks\n })\n\n const daysInMonth = computed(() => {\n const days = weeksInMonth.value.flat()\n const today = adapter.date()\n\n return days.map((date, index) => {\n const isoDate = adapter.toISO(date)\n const isAdjacent = !adapter.isSameMonth(date, month.value)\n\n return {\n date,\n isoDate,\n formatted: adapter.format(date, 'keyboardDate'),\n year: adapter.getYear(date),\n month: adapter.getMonth(date),\n isDisabled: isDisabled(date),\n isWeekStart: index % 7 === 0,\n isWeekEnd: index % 7 === 6,\n isSelected: model.value.some(value => adapter.isSameDay(date, value)),\n isToday: adapter.isSameDay(date, today),\n isAdjacent,\n isHidden: isAdjacent && !props.showAdjacentMonths,\n isHovered: false,\n localized: adapter.format(date, 'dayOfMonth'),\n }\n })\n })\n\n const weeks = computed(() => {\n return weeksInMonth.value.map(week => {\n return getWeek(adapter, week[0])\n })\n })\n\n function isDisabled (value: unknown) {\n if (props.disabled) return true\n\n const date = adapter.date(value)\n\n if (props.min && adapter.isAfter(props.min, date)) return true\n if (props.max && adapter.isAfter(date, props.max)) return true\n\n if (Array.isArray(props.allowedDates)) {\n return !props.allowedDates.some(d => adapter.isSameDay(adapter.date(d), date))\n }\n\n if (typeof props.allowedDates === 'function') {\n return !props.allowedDates(date)\n }\n\n return false\n }\n\n function onClick (value: unknown) {\n if (props.multiple) {\n const index = model.value.findIndex(selection => adapter.isSameDay(selection, value))\n\n if (index === -1) {\n model.value = [...model.value, value]\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n } else {\n model.value = [value]\n }\n }\n\n return () => (\n <div class=\"v-date-picker-month\">\n { props.showWeek && (\n <div key=\"weeks\" class=\"v-date-picker-month__weeks\">\n { !props.hideWeekdays && (\n <div key=\"hide-week-days\" class=\"v-date-picker-month__day\"> </div>\n )}\n { weeks.value.map(week => (\n <div\n class={[\n 'v-date-picker-month__day',\n 'v-date-picker-month__day--adjacent',\n ]}\n >{ week }</div>\n ))}\n </div>\n )}\n\n <div\n ref={ daysRef }\n class=\"v-date-picker-month__days\"\n >\n { !props.hideWeekdays && adapter.getWeekdays().map(weekDay => (\n <div\n class={[\n 'v-date-picker-month__day',\n 'v-date-picker-month__weekday',\n ]}\n >{ weekDay }</div>\n ))}\n\n { daysInMonth.value.map((item, i) => {\n const slotProps = {\n props: {\n onClick: () => onClick(item.date),\n },\n item,\n i,\n } as const\n\n return (\n <div\n class={[\n 'v-date-picker-month__day',\n {\n 'v-date-picker-month__day--adjacent': item.isAdjacent,\n 'v-date-picker-month__day--hide-adjacent': item.isHidden,\n 'v-date-picker-month__day--hovered': item.isHovered,\n 'v-date-picker-month__day--selected': item.isSelected,\n 'v-date-picker-month__day--week-end': item.isWeekEnd,\n 'v-date-picker-month__day--week-start': item.isWeekStart,\n },\n ]}\n data-v-date={ !item.isDisabled ? item.isoDate : undefined }\n >\n\n { (props.showAdjacentMonths || !item.isAdjacent) && (\n <VDefaultsProvider\n defaults={{\n VBtn: {\n color: (item.isSelected || item.isToday) && !item.isDisabled\n ? props.color\n : undefined,\n disabled: item.isDisabled,\n icon: true,\n ripple: false,\n text: item.localized,\n variant: item.isDisabled\n ? 'text'\n : item.isToday && !item.isSelected ? 'outlined' : 'flat',\n onClick: () => onClick(item.date),\n },\n }}\n >\n { slots.day?.(slotProps) ?? (\n <VBtn { ...slotProps.props } />\n )}\n </VDefaultsProvider>\n )}\n </div>\n )\n })}\n </div>\n </div>\n )\n },\n})\n\nexport type VDatePickerMonth = InstanceType<typeof VDatePickerMonth>\n"],"mappings":"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"}
|
|
@@ -41,7 +41,7 @@ export const VDatePickerYears = genericComponent()({
|
|
|
41
41
|
date = adapter.setYear(date, min);
|
|
42
42
|
return createRange(max - min + 1, min).map(i => {
|
|
43
43
|
const text = adapter.format(date, 'year');
|
|
44
|
-
date = adapter.
|
|
44
|
+
date = adapter.setYear(date, adapter.getYear(date) + 1);
|
|
45
45
|
return {
|
|
46
46
|
text,
|
|
47
47
|
value: i
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VDatePickerYears.mjs","names":["VBtn","useDate","useProxiedModel","computed","nextTick","onMounted","ref","watchEffect","convertToUnit","createRange","genericComponent","propsFactory","useRender","makeVDatePickerYearsProps","color","String","height","Number","min","max","modelValue","VDatePickerYears","name","props","emits","year","setup","_ref","slots","adapter","model","years","getYear","date","startOfYear","setYear","map","i","text","format","
|
|
1
|
+
{"version":3,"file":"VDatePickerYears.mjs","names":["VBtn","useDate","useProxiedModel","computed","nextTick","onMounted","ref","watchEffect","convertToUnit","createRange","genericComponent","propsFactory","useRender","makeVDatePickerYearsProps","color","String","height","Number","min","max","modelValue","VDatePickerYears","name","props","emits","year","setup","_ref","slots","adapter","model","years","getYear","date","startOfYear","setYear","map","i","text","format","value","yearRef","$el","scrollIntoView","block","_createVNode","btnProps","undefined","active","rounded","variant","onClick","_mergeProps"],"sources":["../../../src/components/VDatePicker/VDatePickerYears.tsx"],"sourcesContent":["// Styles\nimport './VDatePickerYears.sass'\n\n// Components\nimport { VBtn } from '@/components/VBtn'\n\n// Composables\nimport { useDate } from '@/composables/date'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { computed, nextTick, onMounted, ref, watchEffect } from 'vue'\nimport { convertToUnit, createRange, genericComponent, propsFactory, useRender } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\n// Types\nexport type VDatePickerYearsSlots = {\n year: {\n year: {\n text: string\n value: number\n }\n i: number\n props: {\n active: boolean\n color?: string\n rounded: boolean\n text: string\n variant: 'flat' | 'text'\n onClick: () => void\n }\n }\n}\n\nexport const makeVDatePickerYearsProps = propsFactory({\n color: String,\n height: [String, Number],\n min: null as any as PropType<unknown>,\n max: null as any as PropType<unknown>,\n modelValue: Number,\n}, 'VDatePickerYears')\n\nexport const VDatePickerYears = genericComponent<VDatePickerYearsSlots>()({\n name: 'VDatePickerYears',\n\n props: makeVDatePickerYearsProps(),\n\n emits: {\n 'update:modelValue': (year: number) => true,\n },\n\n setup (props, { slots }) {\n const adapter = useDate()\n const model = useProxiedModel(props, 'modelValue')\n const years = computed(() => {\n const year = adapter.getYear(adapter.date())\n\n let min = year - 100\n let max = year + 52\n\n if (props.min) {\n min = adapter.getYear(adapter.date(props.min))\n }\n\n if (props.max) {\n max = adapter.getYear(adapter.date(props.max))\n }\n\n let date = adapter.startOfYear(adapter.date())\n\n date = adapter.setYear(date, min)\n\n return createRange(max - min + 1, min).map(i => {\n const text = adapter.format(date, 'year')\n date = adapter.setYear(date, adapter.getYear(date) + 1)\n\n return {\n text,\n value: i,\n }\n })\n })\n\n watchEffect(() => {\n model.value = model.value ?? adapter.getYear(adapter.date())\n })\n\n const yearRef = ref<VBtn>()\n onMounted(async () => {\n await nextTick()\n yearRef.value?.$el.scrollIntoView({ block: 'center' })\n })\n\n useRender(() => (\n <div\n class=\"v-date-picker-years\"\n style={{\n height: convertToUnit(props.height),\n }}\n >\n <div class=\"v-date-picker-years__content\">\n { years.value.map((year, i) => {\n const btnProps = {\n ref: model.value === year.value ? yearRef : undefined,\n active: model.value === year.value,\n color: model.value === year.value ? props.color : undefined,\n rounded: true,\n text: year.text,\n variant: model.value === year.value ? 'flat' : 'text',\n onClick: () => model.value = year.value,\n } as const\n\n return slots.year?.({\n year,\n i,\n props: btnProps,\n }) ?? (\n <VBtn\n key=\"month\"\n { ...btnProps }\n />\n )\n })}\n </div>\n </div>\n ))\n\n return {}\n },\n})\n\nexport type VDatePickerYears = InstanceType<typeof VDatePickerYears>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,IAAI,6BAEb;AAAA,SACSC,OAAO;AAAA,SACPC,eAAe,8CAExB;AACA,SAASC,QAAQ,EAAEC,QAAQ,EAAEC,SAAS,EAAEC,GAAG,EAAEC,WAAW,QAAQ,KAAK;AAAA,SAC5DC,aAAa,EAAEC,WAAW,EAAEC,gBAAgB,EAAEC,YAAY,EAAEC,SAAS,gCAE9E;AAsBA,OAAO,MAAMC,yBAAyB,GAAGF,YAAY,CAAC;EACpDG,KAAK,EAAEC,MAAM;EACbC,MAAM,EAAE,CAACD,MAAM,EAAEE,MAAM,CAAC;EACxBC,GAAG,EAAE,IAAgC;EACrCC,GAAG,EAAE,IAAgC;EACrCC,UAAU,EAAEH;AACd,CAAC,EAAE,kBAAkB,CAAC;AAEtB,OAAO,MAAMI,gBAAgB,GAAGX,gBAAgB,EAAyB,CAAC;EACxEY,IAAI,EAAE,kBAAkB;EAExBC,KAAK,EAAEV,yBAAyB,EAAE;EAElCW,KAAK,EAAE;IACL,mBAAmB,EAAGC,IAAY,IAAK;EACzC,CAAC;EAEDC,KAAKA,CAAEH,KAAK,EAAAI,IAAA,EAAa;IAAA,IAAX;MAAEC;IAAM,CAAC,GAAAD,IAAA;IACrB,MAAME,OAAO,GAAG5B,OAAO,EAAE;IACzB,MAAM6B,KAAK,GAAG5B,eAAe,CAACqB,KAAK,EAAE,YAAY,CAAC;IAClD,MAAMQ,KAAK,GAAG5B,QAAQ,CAAC,MAAM;MAC3B,MAAMsB,IAAI,GAAGI,OAAO,CAACG,OAAO,CAACH,OAAO,CAACI,IAAI,EAAE,CAAC;MAE5C,IAAIf,GAAG,GAAGO,IAAI,GAAG,GAAG;MACpB,IAAIN,GAAG,GAAGM,IAAI,GAAG,EAAE;MAEnB,IAAIF,KAAK,CAACL,GAAG,EAAE;QACbA,GAAG,GAAGW,OAAO,CAACG,OAAO,CAACH,OAAO,CAACI,IAAI,CAACV,KAAK,CAACL,GAAG,CAAC,CAAC;MAChD;MAEA,IAAIK,KAAK,CAACJ,GAAG,EAAE;QACbA,GAAG,GAAGU,OAAO,CAACG,OAAO,CAACH,OAAO,CAACI,IAAI,CAACV,KAAK,CAACJ,GAAG,CAAC,CAAC;MAChD;MAEA,IAAIc,IAAI,GAAGJ,OAAO,CAACK,WAAW,CAACL,OAAO,CAACI,IAAI,EAAE,CAAC;MAE9CA,IAAI,GAAGJ,OAAO,CAACM,OAAO,CAACF,IAAI,EAAEf,GAAG,CAAC;MAEjC,OAAOT,WAAW,CAACU,GAAG,GAAGD,GAAG,GAAG,CAAC,EAAEA,GAAG,CAAC,CAACkB,GAAG,CAACC,CAAC,IAAI;QAC9C,MAAMC,IAAI,GAAGT,OAAO,CAACU,MAAM,CAACN,IAAI,EAAE,MAAM,CAAC;QACzCA,IAAI,GAAGJ,OAAO,CAACM,OAAO,CAACF,IAAI,EAAEJ,OAAO,CAACG,OAAO,CAACC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEvD,OAAO;UACLK,IAAI;UACJE,KAAK,EAAEH;QACT,CAAC;MACH,CAAC,CAAC;IACJ,CAAC,CAAC;IAEF9B,WAAW,CAAC,MAAM;MAChBuB,KAAK,CAACU,KAAK,GAAGV,KAAK,CAACU,KAAK,IAAIX,OAAO,CAACG,OAAO,CAACH,OAAO,CAACI,IAAI,EAAE,CAAC;IAC9D,CAAC,CAAC;IAEF,MAAMQ,OAAO,GAAGnC,GAAG,EAAQ;IAC3BD,SAAS,CAAC,YAAY;MACpB,MAAMD,QAAQ,EAAE;MAChBqC,OAAO,CAACD,KAAK,EAAEE,GAAG,CAACC,cAAc,CAAC;QAAEC,KAAK,EAAE;MAAS,CAAC,CAAC;IACxD,CAAC,CAAC;IAEFhC,SAAS,CAAC,MAAAiC,YAAA;MAAA,SAEA,qBAAqB;MAAA,SACpB;QACL7B,MAAM,EAAER,aAAa,CAACe,KAAK,CAACP,MAAM;MACpC;IAAC,IAAA6B,YAAA;MAAA,SAEU;IAA8B,IACrCd,KAAK,CAACS,KAAK,CAACJ,GAAG,CAAC,CAACX,IAAI,EAAEY,CAAC,KAAK;MAC7B,MAAMS,QAAQ,GAAG;QACfxC,GAAG,EAAEwB,KAAK,CAACU,KAAK,KAAKf,IAAI,CAACe,KAAK,GAAGC,OAAO,GAAGM,SAAS;QACrDC,MAAM,EAAElB,KAAK,CAACU,KAAK,KAAKf,IAAI,CAACe,KAAK;QAClC1B,KAAK,EAAEgB,KAAK,CAACU,KAAK,KAAKf,IAAI,CAACe,KAAK,GAAGjB,KAAK,CAACT,KAAK,GAAGiC,SAAS;QAC3DE,OAAO,EAAE,IAAI;QACbX,IAAI,EAAEb,IAAI,CAACa,IAAI;QACfY,OAAO,EAAEpB,KAAK,CAACU,KAAK,KAAKf,IAAI,CAACe,KAAK,GAAG,MAAM,GAAG,MAAM;QACrDW,OAAO,EAAEA,CAAA,KAAMrB,KAAK,CAACU,KAAK,GAAGf,IAAI,CAACe;MACpC,CAAU;MAEV,OAAOZ,KAAK,CAACH,IAAI,GAAG;QAClBA,IAAI;QACJY,CAAC;QACDd,KAAK,EAAEuB;MACT,CAAC,CAAC,IAAAD,YAAA,CAAA7C,IAAA,EAAAoD,WAAA;QAAA,OAEM;MAAO,GACNN,QAAQ,QAEhB;IACH,CAAC,CAAC,IAGP,CAAC;IAEF,OAAO,CAAC,CAAC;EACX;AACF,CAAC,CAAC"}
|