mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-19 06:43:16 +08:00
2cdf586291
* chore: fix lint * chore: fix lint * test: fix 16 * fix: lint
41 lines
1.5 KiB
TypeScript
41 lines
1.5 KiB
TypeScript
import React from 'react';
|
|
import dayjs from 'dayjs';
|
|
import customParseFormat from 'dayjs/plugin/customParseFormat';
|
|
import type { DatePickerProps } from 'antd';
|
|
import { DatePicker, Space } from 'antd';
|
|
|
|
dayjs.extend(customParseFormat);
|
|
|
|
const { RangePicker } = DatePicker;
|
|
|
|
const dateFormat = 'YYYY/MM/DD';
|
|
const weekFormat = 'MM/DD';
|
|
const monthFormat = 'YYYY/MM';
|
|
|
|
/** Manually entering any of the following formats will perform date parsing */
|
|
const dateFormatList = ['DD/MM/YYYY', 'DD/MM/YY', 'DD-MM-YYYY', 'DD-MM-YY'];
|
|
|
|
const customFormat: DatePickerProps['format'] = (value) =>
|
|
`custom format: ${value.format(dateFormat)}`;
|
|
|
|
const customWeekStartEndFormat: DatePickerProps['format'] = (value) =>
|
|
`${dayjs(value).startOf('week').format(weekFormat)} ~ ${dayjs(value)
|
|
.endOf('week')
|
|
.format(weekFormat)}`;
|
|
|
|
const App: React.FC = () => (
|
|
<Space direction="vertical" size={12}>
|
|
<DatePicker defaultValue={dayjs('2015/01/01', dateFormat)} format={dateFormat} />
|
|
<DatePicker defaultValue={dayjs('01/01/2015', dateFormatList[0])} format={dateFormatList} />
|
|
<DatePicker defaultValue={dayjs('2015/01', monthFormat)} format={monthFormat} picker="month" />
|
|
<DatePicker defaultValue={dayjs()} format={customWeekStartEndFormat} picker="week" />
|
|
<RangePicker
|
|
defaultValue={[dayjs('2015/01/01', dateFormat), dayjs('2015/01/01', dateFormat)]}
|
|
format={dateFormat}
|
|
/>
|
|
<DatePicker defaultValue={dayjs('2015/01/01', dateFormat)} format={customFormat} />
|
|
</Space>
|
|
);
|
|
|
|
export default App;
|