import { mount } from 'enzyme'; import MockDate from 'mockdate'; import Moment from 'moment'; import momentGenerateConfig from 'rc-picker/lib/generate/moment'; import type { Locale } from 'rc-picker/lib/interface'; import React from 'react'; import Calendar from '..'; import mountTest from '../../../tests/shared/mountTest'; import rtlTest from '../../../tests/shared/rtlTest'; import { fireEvent, render } from '../../../tests/utils'; import Group from '../../radio/group'; import Button from '../../radio/radioButton'; import Select from '../../select'; import Header from '../Header'; describe('Calendar', () => { mountTest(Calendar); rtlTest(Calendar, { mockDate: true }); function openSelect(wrapper: HTMLElement, className: string) { fireEvent.mouseDown(wrapper.querySelector(className)!.querySelector('.ant-select-selector')!); } function findSelectItem(wrapper: HTMLElement) { return wrapper.querySelectorAll('.ant-select-item-option')!; } function clickSelectItem(wrapper: HTMLElement, index = 0) { fireEvent.click(findSelectItem(wrapper)[index]); } // https://github.com/ant-design/ant-design/issues/30392 it('should be able to set undefined or null', () => { expect(() => { const wrapper = mount(); wrapper.setProps({ value: null }); }).not.toThrow(); expect(() => { const wrapper = mount(); wrapper.setProps({ value: undefined }); }).not.toThrow(); }); it('Calendar should be selectable', () => { MockDate.set(Moment('2000-01-01').valueOf()); const onSelect = jest.fn(); const onChange = jest.fn(); const { container } = render(); fireEvent.click(container.querySelector('.ant-picker-cell')!); expect(onSelect).toHaveBeenCalledWith(expect.anything()); const value = onSelect.mock.calls[0][0]; expect(Moment.isMoment(value)).toBe(true); expect(onChange).toHaveBeenCalled(); MockDate.reset(); }); it('only Valid range should be selectable', () => { const onSelect = jest.fn(); const validRange: [Moment.Moment, Moment.Moment] = [Moment('2018-02-02'), Moment('2018-02-18')]; const wrapper = mount( , ); wrapper.find('[title="2018-02-01"]').at(0).simulate('click'); wrapper.find('[title="2018-02-02"]').at(0).simulate('click'); expect(onSelect.mock.calls.length).toBe(1); }); it('dates other than in valid range should be disabled', () => { const onSelect = jest.fn(); const validRange: [Moment.Moment, Moment.Moment] = [Moment('2018-02-02'), Moment('2018-02-18')]; const { container } = render( , ); fireEvent.click(container.querySelector('[title="2018-02-20"]')!); const elem = container .querySelector('[title="2018-02-20"]')! .className.includes('ant-picker-cell-disabled'); expect(elem).toEqual(true); expect(onSelect.mock.calls.length).toBe(0); }); it('months other than in valid range should be disabled', () => { const onSelect = jest.fn(); const validRange: [Moment.Moment, Moment.Moment] = [Moment('2018-02-02'), Moment('2018-05-18')]; const { container } = render( , ); expect( container.querySelector('[title="2018-01"]')?.className.includes('ant-picker-cell-disabled'), ).toBe(true); expect( container.querySelector('[title="2018-02"]')?.className.includes('ant-picker-cell-disabled'), ).toBe(false); expect( container.querySelector('[title="2018-06"]')?.className.includes('ant-picker-cell-disabled'), ).toBe(true); fireEvent.click(container.querySelector('[title="2018-01"]')!); fireEvent.click(container.querySelector('[title="2018-03"]')!); expect(onSelect.mock.calls.length).toBe(1); }); it('months other than in valid range should not be shown in header', () => { const validRange: [Moment.Moment, Moment.Moment] = [Moment('2017-02-02'), Moment('2018-05-18')]; const { container } = render(); openSelect(container, '.ant-picker-calendar-year-select'); clickSelectItem(container); openSelect(container, '.ant-picker-calendar-month-select'); // 2 years and 11 months expect(container.querySelectorAll('.ant-select-item-option').length).toBe(13); }); it('getDateRange should returns a disabledDate function', () => { const validRange: [Moment.Moment, Moment.Moment] = [Moment('2018-02-02'), Moment('2018-05-18')]; const wrapper = mount(); const { disabledDate } = wrapper.find('PickerPanel').props() as any; expect(disabledDate(Moment('2018-06-02'))).toBe(true); expect(disabledDate(Moment('2018-04-02'))).toBe(false); }); it('validRange should work with disabledDate function', () => { const validRange: [Moment.Moment, Moment.Moment] = [Moment('2018-02-02'), Moment('2018-05-18')]; const wrapper = mount( data.isSame(Moment('2018-02-03'))} />, ); const { disabledDate } = wrapper.find('PickerPanel').props() as any; expect(disabledDate(Moment('2018-02-01'))).toBe(true); expect(disabledDate(Moment('2018-02-02'))).toBe(false); expect(disabledDate(Moment('2018-02-03'))).toBe(true); expect(disabledDate(Moment('2018-02-04'))).toBe(false); expect(disabledDate(Moment('2018-06-01'))).toBe(true); }); it('Calendar MonthSelect should display correct label', () => { const validRange: [Moment.Moment, Moment.Moment] = [Moment('2018-02-02'), Moment('2019-06-1')]; const wrapper = mount(); expect(wrapper.render()).toMatchSnapshot(); }); it('Calendar should change mode by prop', () => { const monthMode = 'month'; const yearMode = 'year'; const wrapper = mount(); expect(wrapper.find('CalendarHeader').props().mode).toEqual(monthMode); wrapper.setProps({ mode: yearMode }); expect(wrapper.find('CalendarHeader').props().mode).toEqual(yearMode); }); it('Calendar should switch mode', () => { const monthMode = 'month'; const yearMode = 'year'; const onPanelChangeStub = jest.fn(); const wrapper = mount(); expect(wrapper.find('CalendarHeader').props().mode).toEqual(yearMode); wrapper.setProps({ mode: monthMode }); expect(wrapper.find('CalendarHeader').props().mode).toEqual(monthMode); expect(onPanelChangeStub).toHaveBeenCalledTimes(0); }); it('Calendar should support locale', () => { MockDate.set(Moment('2018-10-19').valueOf()); // eslint-disable-next-line global-require const zhCN = require('../locale/zh_CN').default; const wrapper = mount(); expect(wrapper.render()).toMatchSnapshot(); MockDate.reset(); }); describe('onPanelChange', () => { it('trigger when click last month of date', () => { const onPanelChange = jest.fn(); const date = Moment('1990-09-03'); const wrapper = mount(); wrapper.find('.ant-picker-cell').at(0).simulate('click'); expect(onPanelChange).toHaveBeenCalled(); expect(onPanelChange.mock.calls[0][0].month()).toEqual(date.month() - 1); }); it('not trigger when in same month', () => { const onPanelChange = jest.fn(); const date = Moment('1990-09-03'); const wrapper = mount(); wrapper.find('.ant-picker-cell').at(10).simulate('click'); expect(onPanelChange).not.toHaveBeenCalled(); }); }); it('switch should work correctly without prop mode', async () => { const onPanelChange = jest.fn(); const date = Moment(new Date(Date.UTC(2017, 7, 9, 8))); const wrapper = mount(); expect(wrapper.find('CalendarHeader').props().mode).toBe('month'); expect(wrapper.find('.ant-picker-date-panel').length).toBe(1); expect(wrapper.find('.ant-picker-month-panel').length).toBe(0); wrapper.find('.ant-radio-button-input[value="year"]').simulate('change'); expect(wrapper.find('.ant-picker-date-panel').length).toBe(0); expect(wrapper.find('.ant-picker-month-panel').length).toBe(1); expect(onPanelChange).toHaveBeenCalled(); expect(onPanelChange.mock.calls[0][1]).toEqual('year'); }); const createWrapper = ( start: Moment.Moment, end: Moment.Moment, value: Moment.Moment, onValueChange: (v: Moment.Moment) => void, ) => { const wrapper = render( // @ts-ignore
, ); openSelect(wrapper.container, '.ant-picker-calendar-year-select'); clickSelectItem(wrapper.container); }; it('if value.month > end.month, set value.month to end.month', () => { const value = Moment('1990-01-03'); const start = Moment('2019-04-01'); const end = Moment('2019-11-01'); const onValueChange = jest.fn(); createWrapper(start, end, value, onValueChange); expect(onValueChange).toHaveBeenCalledWith(value.year(2019).month('3')); }); it('if start.month > value.month, set value.month to start.month', () => { const value = Moment('1990-01-03'); const start = Moment('2019-11-01'); const end = Moment('2019-03-01'); const onValueChange = jest.fn(); createWrapper(start, end, value, onValueChange); expect(onValueChange).toHaveBeenCalledWith(value.year(2019).month('10')); }); it('if change year and month > end month, set value.month to end.month', () => { const value = Moment('2018-11-03'); const start = Moment('2000-01-01'); const end = Moment('2019-03-01'); const onValueChange = jest.fn(); const wrapper = render(
, ); openSelect(wrapper.container, '.ant-picker-calendar-year-select'); fireEvent.click( Array.from(wrapper.container.querySelectorAll('.ant-select-item-option')).at(-1)!, ); expect(onValueChange).toHaveBeenCalledWith(value.year(2019).month('2')); }); it('onMonthChange should work correctly', () => { const start = Moment('2018-11-01'); const end = Moment('2019-03-01'); const value = Moment('2018-12-03'); const onValueChange = jest.fn(); const wrapper = render(
, ); openSelect(wrapper.container, '.ant-picker-calendar-month-select'); clickSelectItem(wrapper.container); expect(onValueChange).toHaveBeenCalledWith(value.month(10)); }); it('onTypeChange should work correctly', () => { const onTypeChange = jest.fn(); const value = Moment('2018-12-03'); const wrapper = render(
, ); fireEvent.click( Array.from(wrapper.container.querySelectorAll(`.ant-radio-button-input`)).at(1)!, ); expect(onTypeChange).toHaveBeenCalledWith('year'); }); it('headerRender should work correctly', () => { const onMonthChange = jest.fn(); const onYearChange = jest.fn(); const onTypeChange = jest.fn(); // Year const headerRender = jest.fn(({ value }) => { const year = value.year(); const options = []; for (let i = year - 100; i < year + 100; i += 1) { options.push( {i} , ); } return ( ); }); const uiWithYear = ; const wrapperWithYear = render(uiWithYear); openSelect(wrapperWithYear.container, '.ant-select'); wrapperWithYear.rerender(uiWithYear); fireEvent.click(Array.from(findSelectItem(wrapperWithYear.container)).at(-1)!); expect(onYearChange).toHaveBeenCalled(); // Month const headerRenderWithMonth = jest.fn(({ value }) => { const start = 0; const end = 12; const monthOptions = []; const current = value.clone(); const localeData = value.localeData(); const months = []; for (let i = 0; i < 12; i += 1) { current.month(i); months.push(localeData.monthsShort(current)); } for (let index = start; index < end; index += 1) { monthOptions.push( {months[index]} , ); } const month = value.month(); return ( ); }); const uiWithMonth = ; const wrapperWithMonth = render(uiWithMonth); openSelect(wrapperWithMonth.container, '.ant-select'); wrapperWithMonth.rerender(uiWithMonth); fireEvent.click(Array.from(findSelectItem(wrapperWithMonth.container)).at(-1)!); expect(onMonthChange).toHaveBeenCalled(); // Type const headerRenderWithTypeChange = jest.fn(({ type }) => ( )); const wrapperWithTypeChange = render( , ); fireEvent.click( Array.from(wrapperWithTypeChange.container.querySelectorAll('.ant-radio-button-input')).at( -1, )!, ); expect(onTypeChange).toHaveBeenCalled(); }); it('dateFullCellRender', () => { const { container } = render(
Bamboo
} />, ); expect(container.querySelectorAll('.light')[0].innerHTML).toEqual('Bamboo'); }); it('monthFullCellRender', () => { const { container } = render(
Light
} />, ); expect(container.querySelectorAll('.bamboo')[0].innerHTML).toEqual('Light'); }); it('when fullscreen is false, the element returned by dateFullCellRender should be interactive', () => { const onClick = jest.fn(); const { container } = render( (
Light
)} />, ); fireEvent.click(container.querySelectorAll('.bamboo')[0]); expect(onClick).toHaveBeenCalled(); }); });