fix(DatePicker): format value when exceed max date (#11122)

This commit is contained in:
neverland 2022-10-07 23:04:56 +08:00 committed by GitHub
parent 137a1b9cb7
commit baa9c33dd4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 147 additions and 118 deletions

View File

@ -14,6 +14,7 @@ import {
sharedProps,
getMonthEndDay,
pickerInheritKeys,
formatValueRange,
} from './utils';
// Components
@ -143,9 +144,13 @@ export default defineComponent({
watch(
() => props.modelValue,
(newValues) => {
newValues = formatValueRange(newValues, columns.value);
if (!isSameValue(newValues, currentValues.value)) {
currentValues.value = newValues;
}
},
{
immediate: true,
}
);

View File

@ -143,55 +143,6 @@
// expect(wrapper.emitted<[Date]>('confirm')![1][0].getHours()).toEqual(23);
// });
// test('cancel event', () => {
// const wrapper = mount(DatePicker);
// wrapper.find('.van-picker__cancel').trigger('click');
// expect(wrapper.emitted('cancel')).toBeTruthy();
// });
// test('max-date prop', () => {
// const maxDate = new Date(2010, 5, 0, 0, 0);
// const wrapper = mount(DatePicker, {
// props: {
// modelValue: new Date(2020, 10, 30, 30, 30),
// maxDate,
// },
// });
// wrapper.find('.van-picker__confirm').trigger('click');
// expect(wrapper.emitted<[Date]>('confirm')![0][0]).toEqual(maxDate);
// });
// test('min-date prop', () => {
// const minDate = new Date(2030, 0, 0, 0, 0);
// const wrapper = mount(DatePicker, {
// props: {
// modelValue: new Date(2020, 0, 0, 0, 0),
// minDate,
// },
// });
// wrapper.find('.van-picker__confirm').trigger('click');
// expect(wrapper.emitted<[Date]>('confirm')![0][0]).toEqual(minDate);
// });
// test('dynamic set value', async () => {
// const wrapper = mount(DatePicker, {
// props: {
// modelValue: new Date(2019, 1, 1),
// },
// });
// await wrapper.setProps({ modelValue: new Date(2019, 1, 1) });
// wrapper.find('.van-picker__confirm').trigger('click');
// await wrapper.setProps({ modelValue: new Date(2025, 1, 1) });
// wrapper.find('.van-picker__confirm').trigger('click');
// expect(wrapper.emitted<[Date]>('confirm')![0][0].getFullYear()).toEqual(2019);
// expect(wrapper.emitted<[Date]>('confirm')![1][0].getFullYear()).toEqual(2025);
// });
// test('use min-date with filter', async () => {
// const minDate = new Date(2030, 0, 0, 0, 3);
// const maxDate = new Date(2040, 0, 0, 0, 0);

View File

@ -1,59 +0,0 @@
// import { later, mount, triggerDrag } from '../../../test';
// import DatePicker from '../../datetime-picker/DatePicker';
// test('month-day type', async () => {
// const date = new Date(2020, 10, 1, 0, 0);
// const wrapper = mount(DatePicker, {
// props: {
// type: 'month-day',
// modelValue: date,
// minDate: new Date(2020, 0, 1),
// maxDate: new Date(2025, 10, 1),
// },
// });
// await later();
// wrapper.find('.van-picker__confirm').trigger('click');
// expect(wrapper.emitted<[Date]>('confirm')![0][0].getMonth()).toEqual(10);
// expect(wrapper.emitted<[Date]>('confirm')![0][0].getDate()).toEqual(1);
// await later();
// triggerDrag(wrapper.find('.van-picker-column'), 0, -300);
// wrapper.find('.van-picker__confirm').trigger('click');
// expect(wrapper.emitted<[Date]>('confirm')![1][0].getMonth()).toEqual(11);
// expect(wrapper.emitted<[Date]>('confirm')![1][0].getDate()).toEqual(1);
// await later();
// triggerDrag(wrapper.findAll('.van-picker-column')[1], 0, -300);
// wrapper.find('.van-picker__confirm').trigger('click');
// expect(wrapper.emitted<[Date]>('confirm')![2][0].getMonth()).toEqual(11);
// expect(wrapper.emitted<[Date]>('confirm')![2][0].getDate()).toEqual(31);
// });
// test('v-model', async () => {
// const minDate = new Date(2030, 0, 0, 0, 3);
// const wrapper = mount(DatePicker, {
// props: {
// minDate,
// },
// });
// await later();
// wrapper.find('.van-picker__confirm').trigger('click');
// expect(wrapper.emitted<[Date]>('confirm')![0][0]).toEqual(minDate);
// });
// test('value has an initial value', async () => {
// const defaultValue = new Date(2020, 0, 0, 0, 0);
// const wrapper = mount(DatePicker, {
// propsData: {
// modelValue: defaultValue,
// },
// });
// await later();
// wrapper.find('.van-picker__confirm').trigger('click');
// expect(wrapper.emitted<[Date]>('confirm')![0][0]).toEqual(defaultValue);
// });

View File

@ -0,0 +1,121 @@
import { nextTick } from 'vue';
import { later, mount } from '../../../test';
import DatePicker from '..';
import type {
PickerCancelEventParams,
PickerConfirmEventParams,
} from '../../picker';
test('should emit confirm event correctly', async () => {
const minDate = new Date(2030, 0, 1);
const wrapper = mount(DatePicker, {
props: {
minDate,
},
});
await later();
wrapper.find('.van-picker__confirm').trigger('click');
expect(wrapper.emitted<[PickerConfirmEventParams]>('confirm')![0][0]).toEqual(
{
selectedOptions: [
{ text: '2030', value: '2030' },
{ text: '01', value: '01' },
{ text: '01', value: '01' },
],
selectedValues: ['2030', '01', '01'],
}
);
});
test('should emit cancel event correctly', async () => {
const minDate = new Date(2030, 0, 1);
const wrapper = mount(DatePicker, {
props: {
minDate,
},
});
await later();
wrapper.find('.van-picker__cancel').trigger('click');
expect(wrapper.emitted<[PickerCancelEventParams]>('cancel')![0][0]).toEqual({
selectedOptions: [
{ text: '2030', value: '2030' },
{ text: '01', value: '01' },
{ text: '01', value: '01' },
],
selectedValues: ['2030', '01', '01'],
});
});
test('should allow to dynamically set value', async () => {
const wrapper = mount(DatePicker, {
props: {
modelValue: ['2020', '01', '01'],
minDate: new Date(2019, 0, 1),
},
});
await wrapper.setProps({ modelValue: ['2020', '02', '02'] });
await wrapper.find('.van-picker__confirm').trigger('click');
await wrapper.setProps({ modelValue: ['2020', '03', '03'] });
await wrapper.find('.van-picker__confirm').trigger('click');
expect(
wrapper.emitted<[PickerConfirmEventParams]>('confirm')![0][0].selectedValues
).toEqual(['2020', '02', '02']);
expect(
wrapper.emitted<[PickerConfirmEventParams]>('confirm')![1][0].selectedValues
).toEqual(['2020', '03', '03']);
});
test('should render with max-date correctly', async () => {
const maxDate = new Date(2010, 1, 1);
const minDate = new Date(2000, 1, 1);
const wrapper = mount(DatePicker, {
props: {
modelValue: ['2020', '10', '10'],
minDate,
maxDate,
'onUpdate:modelValue': (newVal: string[]) => {
nextTick(() => {
wrapper.setProps({
modelValue: newVal,
});
});
},
},
});
await later();
wrapper.find('.van-picker__confirm').trigger('click');
expect(
wrapper.emitted<[PickerConfirmEventParams]>('confirm')![0][0].selectedValues
).toEqual(['2010', '01', '10']);
});
test('should render with min-date correctly', async () => {
const maxDate = new Date(2010, 1, 1);
const minDate = new Date(2000, 1, 1);
const wrapper = mount(DatePicker, {
props: {
modelValue: ['1990', '10', '10'],
minDate,
maxDate,
'onUpdate:modelValue': (newVal: string[]) => {
nextTick(() => {
wrapper.setProps({
modelValue: newVal,
});
});
},
},
});
await later();
wrapper.find('.van-picker__confirm').trigger('click');
expect(
wrapper.emitted<[PickerConfirmEventParams]>('confirm')![0][0].selectedValues
).toEqual(['2000', '10', '10']);
});

View File

@ -53,3 +53,15 @@ export const genOptions = <T extends string>(
});
return filter ? filter(type, options) : options;
};
export const formatValueRange = (values: string[], columns: PickerOption[]) =>
values.map((value, index) => {
const column = columns[index];
if (column.length) {
const maxValue = +column[column.length - 1].value!;
if (+value > maxValue) {
return String(maxValue);
}
}
return value;
});

View File

@ -19,6 +19,7 @@ import {
genOptions,
sharedProps,
pickerInheritKeys,
formatValueRange,
} from '../date-picker/utils';
// Components
@ -89,23 +90,21 @@ export default defineComponent({
})
);
watch(
currentValues,
(newValues) => {
if (!isSameValue(newValues, props.modelValue)) {
emit('update:modelValue', newValues);
}
},
{ immediate: true }
);
watch(currentValues, (newValues) => {
if (!isSameValue(newValues, props.modelValue)) {
emit('update:modelValue', newValues);
}
});
watch(
() => props.modelValue,
(newValues) => {
newValues = formatValueRange(newValues, columns.value);
if (!isSameValue(newValues, currentValues.value)) {
currentValues.value = newValues;
}
}
},
{ immediate: true }
);
const onChange = (...args: unknown[]) => emit('change', ...args);