mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-26 11:26:35 +08:00
153 lines
3.5 KiB
JavaScript
153 lines
3.5 KiB
JavaScript
import TimePicker from '../TimePicker';
|
|
import { mount, later, triggerDrag } from '../../../test';
|
|
|
|
function filter(type, options) {
|
|
const mod = type === 'minute' ? 10 : 5;
|
|
return options.filter((option) => option % mod === 0);
|
|
}
|
|
|
|
function formatter(type, value) {
|
|
return `${value} ${type}`;
|
|
}
|
|
|
|
test('format initial value', () => {
|
|
const wrapper = mount(TimePicker, {
|
|
props: {
|
|
minHour: 22,
|
|
minMinute: 58,
|
|
},
|
|
});
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|
|
|
|
test('max-hour & max-minute', () => {
|
|
const wrapper = mount(TimePicker, {
|
|
props: {
|
|
value: '23:59',
|
|
maxHour: 2,
|
|
maxMinute: 2,
|
|
},
|
|
});
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|
|
|
|
test('filter prop', () => {
|
|
const wrapper = mount(TimePicker, {
|
|
props: {
|
|
filter,
|
|
value: '12:00',
|
|
},
|
|
});
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|
|
|
|
test('formatter prop', async () => {
|
|
const wrapper = mount(TimePicker, {
|
|
props: {
|
|
filter,
|
|
formatter,
|
|
value: '12:00',
|
|
},
|
|
});
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
|
|
triggerDrag(wrapper.find('.van-picker-column'), 0, -100);
|
|
wrapper.find('.van-picker-column ul').trigger('transitionend');
|
|
await later();
|
|
|
|
expect(wrapper.emitted('change')[0][0].getValues()).toEqual([
|
|
'20 hour',
|
|
'00 minute',
|
|
]);
|
|
});
|
|
|
|
test('confirm event', () => {
|
|
const wrapper = mount(TimePicker, {
|
|
props: {
|
|
value: '12:00',
|
|
},
|
|
});
|
|
|
|
triggerDrag(wrapper.find('.van-picker-column'), 0, -100);
|
|
wrapper.find('.van-picker__confirm').trigger('click');
|
|
expect(wrapper.emitted('confirm')[0][0]).toEqual('23:00');
|
|
});
|
|
|
|
test('cancel event', () => {
|
|
const wrapper = mount(TimePicker);
|
|
|
|
wrapper.find('.van-picker__cancel').trigger('click');
|
|
expect(wrapper.emitted('cancel')).toBeTruthy();
|
|
});
|
|
|
|
test('dynamic set value', () => {
|
|
const wrapper = mount(TimePicker);
|
|
|
|
wrapper.setProps({ value: '00:00' });
|
|
wrapper.find('.van-picker__confirm').trigger('click');
|
|
wrapper.setProps({ value: '22:30' });
|
|
wrapper.find('.van-picker__confirm').trigger('click');
|
|
|
|
expect(wrapper.emitted('confirm')[0][0]).toEqual('00:00');
|
|
expect(wrapper.emitted('confirm')[1][0]).toEqual('22:30');
|
|
});
|
|
|
|
test('change min-minute and emit correct value', async () => {
|
|
const wrapper = mount(TimePicker, {
|
|
props: {
|
|
value: '12:00',
|
|
minMinute: 0,
|
|
},
|
|
});
|
|
|
|
await later();
|
|
|
|
wrapper.setProps({ minMinute: 30 });
|
|
wrapper.find('.van-picker__confirm').trigger('click');
|
|
expect(wrapper.emitted('confirm')[0][0]).toEqual('12:30');
|
|
});
|
|
|
|
test('set max-hour & max-minute smaller than current then emit correct value', async () => {
|
|
const wrapper = mount(TimePicker, {
|
|
props: {
|
|
value: '23:59',
|
|
},
|
|
});
|
|
await later();
|
|
wrapper.setProps({
|
|
maxHour: 2,
|
|
maxMinute: 2,
|
|
});
|
|
|
|
wrapper.find('.van-picker__confirm').trigger('click');
|
|
expect(wrapper.emitted('confirm')[0][0]).toEqual('00:00');
|
|
});
|
|
|
|
test('set min-minute dynamically', async () => {
|
|
const wrapper = mount({
|
|
template: `
|
|
<van-datetime-picker
|
|
v-model="currentTime"
|
|
type="time"
|
|
:min-minute="currentTime.split(':')[0] > 12 ? 0 : 30"
|
|
min-hour="12"
|
|
max-hour="13"
|
|
@confirm="$emit('confirm', $event)"
|
|
/>
|
|
`,
|
|
data() {
|
|
return {
|
|
currentTime: '12:30',
|
|
};
|
|
},
|
|
});
|
|
|
|
triggerDrag(wrapper.find('.van-picker-column'), 0, -100);
|
|
wrapper.find('.van-picker__confirm').trigger('click');
|
|
expect(wrapper.emitted('confirm')[0][0]).toEqual('13:00');
|
|
});
|