mirror of
https://github.com/ant-design/ant-design.git
synced 2024-11-25 03:29:59 +08:00
287 lines
10 KiB
TypeScript
287 lines
10 KiB
TypeScript
import dayjs from 'dayjs';
|
||
import 'dayjs/locale/mk'; // to test local in 'prop locale should works' test case
|
||
import customParseFormat from 'dayjs/plugin/customParseFormat';
|
||
import MockDate from 'mockdate';
|
||
import React from 'react';
|
||
import type { TriggerProps } from 'rc-trigger';
|
||
import { fireEvent, render } from '../../../tests/utils';
|
||
import DatePicker from '..';
|
||
import focusTest from '../../../tests/shared/focusTest';
|
||
import type { PickerLocale } from '../generatePicker';
|
||
|
||
dayjs.extend(customParseFormat);
|
||
|
||
let triggerProps: TriggerProps;
|
||
|
||
jest.mock('rc-trigger', () => {
|
||
let Trigger = jest.requireActual('rc-trigger/lib/mock');
|
||
Trigger = Trigger.default || Trigger;
|
||
const h: typeof React = jest.requireActual('react');
|
||
|
||
return {
|
||
default: h.forwardRef<unknown, TriggerProps>((props, ref) => {
|
||
triggerProps = props;
|
||
return h.createElement(Trigger, { ref, ...props });
|
||
}),
|
||
__esModule: true,
|
||
};
|
||
});
|
||
|
||
describe('DatePicker', () => {
|
||
const errorSpy = jest.spyOn(console, 'error').mockImplementation(() => {});
|
||
|
||
focusTest(DatePicker, { refFocus: true });
|
||
|
||
beforeEach(() => {
|
||
MockDate.set(dayjs('2016-11-22').valueOf());
|
||
});
|
||
|
||
afterEach(() => {
|
||
MockDate.reset();
|
||
errorSpy.mockReset();
|
||
});
|
||
|
||
afterAll(() => {
|
||
errorSpy.mockRestore();
|
||
});
|
||
|
||
it('prop locale should works', () => {
|
||
const locale = {
|
||
lang: {
|
||
locale: 'mk',
|
||
placeholder: 'Избери дата',
|
||
rangePlaceholder: ['Начална дата', 'Крайна дата'],
|
||
today: 'Днес',
|
||
now: 'Сега',
|
||
backToToday: 'Към днес',
|
||
ok: 'Добре',
|
||
clear: 'Изчистване',
|
||
month: 'Месец',
|
||
year: 'Година',
|
||
timeSelect: 'Избор на час',
|
||
dateSelect: 'Избор на дата',
|
||
monthSelect: 'Избор на месец',
|
||
yearSelect: 'Избор на година',
|
||
decadeSelect: 'Десетилетие',
|
||
previousMonth: 'Предишен месец (PageUp)',
|
||
nextMonth: 'Следващ месец (PageDown)',
|
||
previousYear: 'Последна година (Control + left)',
|
||
nextYear: 'Следваща година (Control + right)',
|
||
previousDecade: 'Предишно десетилетие',
|
||
nextDecade: 'Следващо десетилетие',
|
||
previousCentury: 'Последен век',
|
||
nextCentury: 'Следващ век',
|
||
yearFormat: 'YYYY',
|
||
dateFormat: 'D M YYYY',
|
||
dayFormat: 'D',
|
||
dateTimeFormat: 'D M YYYY HH:mm:ss',
|
||
monthBeforeYear: true,
|
||
},
|
||
timePickerLocale: {
|
||
placeholder: 'Избор на час',
|
||
},
|
||
};
|
||
const birthday = dayjs('2000-01-01', 'YYYY-MM-DD');
|
||
const wrapper = render(<DatePicker open locale={locale as PickerLocale} value={birthday} />);
|
||
expect(Array.from(wrapper.container.children)).toMatchSnapshot();
|
||
});
|
||
|
||
it('disabled date', () => {
|
||
const disabledDate = (current: any) => current && current < dayjs().endOf('day');
|
||
const wrapper = render(<DatePicker disabledDate={disabledDate} open />);
|
||
expect(Array.from(wrapper.container.children)).toMatchSnapshot();
|
||
});
|
||
|
||
it('placeholder', () => {
|
||
const wrapper = render(<DatePicker placeholder={undefined} />);
|
||
expect(wrapper.container.querySelector('input')?.placeholder).toEqual('Select date');
|
||
});
|
||
|
||
it('showTime={{ showHour: true, showMinute: true }}', () => {
|
||
const { container } = render(
|
||
<DatePicker
|
||
defaultValue={dayjs()}
|
||
showTime={{ showHour: true, showMinute: true }}
|
||
format="YYYY-MM-DD"
|
||
open
|
||
/>,
|
||
);
|
||
expect(container.querySelectorAll('.ant-picker-time-panel-column').length).toBe(2);
|
||
expect(
|
||
container
|
||
.querySelectorAll('.ant-picker-time-panel-column')?.[0]
|
||
.querySelectorAll('.ant-picker-time-panel-cell').length,
|
||
).toBe(24);
|
||
expect(
|
||
container
|
||
.querySelectorAll('.ant-picker-time-panel-column')?.[1]
|
||
.querySelectorAll('.ant-picker-time-panel-cell').length,
|
||
).toBe(60);
|
||
});
|
||
|
||
it('showTime={{ showHour: true, showSecond: true }}', () => {
|
||
const { container } = render(
|
||
<DatePicker
|
||
defaultValue={dayjs()}
|
||
showTime={{ showHour: true, showSecond: true }}
|
||
format="YYYY-MM-DD"
|
||
open
|
||
/>,
|
||
);
|
||
expect(container.querySelectorAll('.ant-picker-time-panel-column').length).toBe(2);
|
||
expect(
|
||
container
|
||
.querySelectorAll('.ant-picker-time-panel-column')?.[0]
|
||
.querySelectorAll('.ant-picker-time-panel-cell').length,
|
||
).toBe(24);
|
||
expect(
|
||
container
|
||
.querySelectorAll('.ant-picker-time-panel-column')?.[1]
|
||
.querySelectorAll('.ant-picker-time-panel-cell').length,
|
||
).toBe(60);
|
||
});
|
||
|
||
it('showTime={{ showMinute: true, showSecond: true }}', () => {
|
||
const { container } = render(
|
||
<DatePicker
|
||
defaultValue={dayjs()}
|
||
showTime={{ showMinute: true, showSecond: true }}
|
||
format="YYYY-MM-DD"
|
||
open
|
||
/>,
|
||
);
|
||
expect(container.querySelectorAll('.ant-picker-time-panel-column').length).toBe(2);
|
||
expect(
|
||
container
|
||
.querySelectorAll('.ant-picker-time-panel-column')?.[0]
|
||
.querySelectorAll('.ant-picker-time-panel-cell').length,
|
||
).toBe(60);
|
||
expect(
|
||
container
|
||
.querySelectorAll('.ant-picker-time-panel-column')?.[1]
|
||
.querySelectorAll('.ant-picker-time-panel-cell').length,
|
||
).toBe(60);
|
||
});
|
||
it('showTime should work correctly when format is custom function', () => {
|
||
const { container } = render(
|
||
<DatePicker defaultValue={dayjs()} showTime format={val => val.format('YYYY-MM-DD')} open />,
|
||
);
|
||
const fuousEvent = () => {
|
||
fireEvent.focus(container.querySelector('input')!);
|
||
};
|
||
const mouseDownEvent = () => {
|
||
fireEvent.mouseDown(container.querySelector('input')!);
|
||
};
|
||
expect(fuousEvent).not.toThrowError();
|
||
expect(mouseDownEvent).not.toThrowError();
|
||
});
|
||
|
||
it('12 hours', () => {
|
||
const { container } = render(
|
||
<DatePicker defaultValue={dayjs()} showTime format="YYYY-MM-DD HH:mm:ss A" open />,
|
||
);
|
||
expect(container.querySelectorAll('.ant-picker-time-panel-column').length).toBe(4);
|
||
expect(
|
||
container
|
||
.querySelectorAll('.ant-picker-time-panel-column')?.[0]
|
||
.querySelectorAll('.ant-picker-time-panel-cell').length,
|
||
).toBe(12);
|
||
expect(
|
||
container
|
||
.querySelectorAll('.ant-picker-time-panel-column')?.[1]
|
||
.querySelectorAll('.ant-picker-time-panel-cell').length,
|
||
).toBe(60);
|
||
expect(
|
||
container
|
||
.querySelectorAll('.ant-picker-time-panel-column')?.[2]
|
||
.querySelectorAll('.ant-picker-time-panel-cell').length,
|
||
).toBe(60);
|
||
expect(
|
||
container
|
||
.querySelectorAll('.ant-picker-time-panel-column')?.[3]
|
||
.querySelectorAll('.ant-picker-time-panel-cell').length,
|
||
).toBe(2);
|
||
});
|
||
|
||
it('24 hours', () => {
|
||
const { container } = render(
|
||
<DatePicker defaultValue={dayjs()} showTime format="YYYY-MM-DD HH:mm:ss" open />,
|
||
);
|
||
expect(container.querySelectorAll('.ant-picker-time-panel-column').length).toBe(3);
|
||
expect(
|
||
container
|
||
.querySelectorAll('.ant-picker-time-panel-column')?.[0]
|
||
.querySelectorAll('.ant-picker-time-panel-cell').length,
|
||
).toBe(24);
|
||
expect(
|
||
container
|
||
.querySelectorAll('.ant-picker-time-panel-column')?.[1]
|
||
.querySelectorAll('.ant-picker-time-panel-cell').length,
|
||
).toBe(60);
|
||
expect(
|
||
container
|
||
.querySelectorAll('.ant-picker-time-panel-column')?.[2]
|
||
.querySelectorAll('.ant-picker-time-panel-cell').length,
|
||
).toBe(60);
|
||
});
|
||
|
||
it('DatePicker should show warning when use dropdownClassName', () => {
|
||
render(<DatePicker dropdownClassName="myCustomClassName" />);
|
||
expect(errorSpy).toHaveBeenCalledWith(
|
||
'Warning: [antd: DatePicker] `dropdownClassName` is deprecated which will be removed in next major version. Please use `popupClassName` instead.',
|
||
);
|
||
});
|
||
|
||
it('RangePicker should show warning when use dropdownClassName', () => {
|
||
render(<DatePicker.RangePicker dropdownClassName="myCustomClassName" />);
|
||
expect(errorSpy).toHaveBeenCalledWith(
|
||
'Warning: [antd: RangePicker] `dropdownClassName` is deprecated which will be removed in next major version. Please use `popupClassName` instead.',
|
||
);
|
||
});
|
||
|
||
it('DatePicker.RangePicker with defaultPickerValue and showTime', () => {
|
||
const startDate = dayjs('1982-02-12');
|
||
const endDate = dayjs('1982-02-22');
|
||
|
||
const { container } = render(
|
||
<DatePicker.RangePicker defaultPickerValue={[startDate, endDate]} showTime open />,
|
||
);
|
||
|
||
const m = container.querySelector('.ant-picker-header-view .ant-picker-month-btn')?.innerHTML;
|
||
const y = container.querySelector('.ant-picker-header-view .ant-picker-year-btn')?.innerHTML;
|
||
expect(m).toBe(startDate.format('MMM'));
|
||
expect(y).toBe(startDate.format('YYYY'));
|
||
expect(container.querySelectorAll('.ant-picker-time-panel').length).toBe(1);
|
||
});
|
||
|
||
it('placement api work correctly', () => {
|
||
const { rerender } = render(<DatePicker.RangePicker open placement="topLeft" />);
|
||
expect(triggerProps?.builtinPlacements).toEqual(
|
||
expect.objectContaining({
|
||
topLeft: expect.objectContaining({ offset: [0, -4], points: ['bl', 'tl'] }),
|
||
}),
|
||
);
|
||
|
||
rerender(<DatePicker.RangePicker open placement="topRight" />);
|
||
expect(triggerProps?.builtinPlacements).toEqual(
|
||
expect.objectContaining({
|
||
topRight: expect.objectContaining({ offset: [0, -4], points: ['br', 'tr'] }),
|
||
}),
|
||
);
|
||
|
||
rerender(<DatePicker.RangePicker open placement="bottomLeft" />);
|
||
expect(triggerProps?.builtinPlacements).toEqual(
|
||
expect.objectContaining({
|
||
bottomLeft: expect.objectContaining({ offset: [0, 4], points: ['tl', 'bl'] }),
|
||
}),
|
||
);
|
||
|
||
rerender(<DatePicker.RangePicker open placement="bottomRight" />);
|
||
expect(triggerProps?.builtinPlacements).toEqual(
|
||
expect.objectContaining({
|
||
bottomRight: expect.objectContaining({ offset: [0, 4], points: ['tr', 'br'] }),
|
||
}),
|
||
);
|
||
});
|
||
});
|