import dayjs from 'dayjs'; import customParseFormat from 'dayjs/plugin/customParseFormat'; import React from 'react'; import { resetWarned } from '../../_util/warning'; import DatePicker from '..'; import focusTest from '../../../tests/shared/focusTest'; import { render, resetMockDate, setMockDate } from '../../../tests/utils'; import enUS from '../locale/en_US'; import { closePicker, openPicker, selectCell } from './utils'; dayjs.extend(customParseFormat); const { RangePicker } = DatePicker; describe('RangePicker', () => { focusTest(RangePicker, { refFocus: true, blurDelay: 110 }); beforeEach(() => { setMockDate(); }); afterEach(() => { resetMockDate(); }); // issue: https://github.com/ant-design/ant-design/issues/5872 it('should not throw error when value is reset to `[]`', () => { const birthday = dayjs('2000-01-01', 'YYYY-MM-DD'); const wrapper1 = render(); const wrapper2 = render(); expect(() => { openPicker(wrapper1); selectCell(wrapper1, 3); closePicker(wrapper1); openPicker(wrapper1, 1); selectCell(wrapper1, 5, 1); closePicker(wrapper1, 1); openPicker(wrapper2); selectCell(wrapper2, 3); closePicker(wrapper2); openPicker(wrapper2, 1); selectCell(wrapper2, 5, 1); closePicker(wrapper2, 1); }).not.toThrow(); }); it('customize separator', () => { const { container } = render(); expect(container.firstChild).toMatchSnapshot(); }); // https://github.com/ant-design/ant-design/issues/13302 describe('in "month" mode, when the left and right panels select the same month', () => { it('the cell status is correct', () => { let rangePickerValue: dayjs.Dayjs[] = [] as any; class Test extends React.Component { state = { value: null }; render() { return ( { this.setState({ value }); rangePickerValue = value as any; }} /> ); } } const wrapper = render(); openPicker(wrapper); selectCell(wrapper, 'Feb'); openPicker(wrapper, 1); selectCell(wrapper, 'Feb'); closePicker(wrapper, 1); const [start, end] = rangePickerValue; expect(start.isSame(end, 'date')).toBeTruthy(); }); }); describe('ranges', () => { it('RangePicker support presetted ranges with Tags', () => { const { container } = render( , ); expect(Array.from(container.children)).toMatchSnapshot(); }); }); it('placeholder', () => { const { container } = render(); const inputLists = container.querySelectorAll('input'); expect(inputLists[0]?.placeholder).toEqual('Start date'); expect(inputLists[inputLists.length - 1].placeholder).toEqual('End date'); }); it('RangePicker picker quarter placeholder', () => { const { container } = render(); expect(container.querySelectorAll('input')[0]?.placeholder).toEqual('Start quarter'); expect(container.querySelectorAll('input')[1]?.placeholder).toEqual('End quarter'); }); it('legacy dropdownClassName', () => { resetWarned(); const errSpy = jest.spyOn(console, 'error').mockImplementation(() => {}); const { container } = render(); expect(errSpy).toHaveBeenCalledWith( 'Warning: [antd: DatePicker.RangePicker] `dropdownClassName` is deprecated. Please use `popupClassName` instead.', ); expect(container.querySelector('.legacy')).toBeTruthy(); errSpy.mockRestore(); }); });