import React from 'react'; import Calendar from 'rc-calendar'; import MonthCalendar from 'rc-calendar/lib/MonthCalendar'; import Datepicker from 'rc-calendar/lib/Picker'; import GregorianCalendar from 'gregorian-calendar'; import defaultLocale from './locale/zh_CN'; import pickerEnUsLocale from './locale/en_US'; import CalendarLocale from 'rc-calendar/lib/locale/zh_CN'; import DateTimeFormat from 'gregorian-calendar-format'; import objectAssign from 'object-assign'; function createPicker(TheCalendar) { return React.createClass({ getDefaultProps() { return { format: 'yyyy-MM-dd', placeholder: '请选择日期', transitionName: 'slide-up', popupStyle: {}, onSelect: null, // 向前兼容 onChange() { }, // onChange 可用于 Validator locale: {}, align: { offset: [0, -10], }, open: false }; }, getInitialState() { return { value: this.parseDateFromValue(this.props.value || this.props.defaultValue) }; }, componentWillReceiveProps(nextProps) { if ('value' in nextProps) { this.setState({ value: this.parseDateFromValue(nextProps.value) }); } }, getLocale() { // 统一合并为完整的 Locale let locale = objectAssign({}, defaultLocale, this.props.locale); locale.lang = objectAssign({}, defaultLocale.lang, this.props.locale.lang); return locale; }, getFormatter() { const formats = this.formats = this.formats || {}; const format = this.props.format; if (formats[format]) { return formats[format]; } formats[format] = new DateTimeFormat(format, this.getLocale().lang.format); return formats[format]; }, parseDateFromValue(value) { if (value) { if (typeof value === 'string') { return this.getFormatter().parse(value, {locale: this.getLocale()}); } else if (value instanceof Date) { let date = new GregorianCalendar(this.getLocale()); date.setTime(value); return date; } } else if (value === null) { return value; } return undefined; }, // remove input readonly warning handleInputChange() { }, toggleOpen(e) { this.setState({ open: e.open }); }, handleChange(value) { this.setState({value}); const timeValue = value ? new Date(value.getTime()) : null; // onSelect 为向前兼容. if (this.props.onSelect) { require('util-deprecate')(this.props.onSelect, 'onSelect property of Datepicker is deprecated, use onChange instead')(timeValue); } this.props.onChange(timeValue); }, render() { // 以下两行代码 // 给没有初始值的日期选择框提供本地化信息 // 否则会以周日开始排 let defaultCalendarValue = new GregorianCalendar(this.getLocale()); defaultCalendarValue.setTime(Date.now()); const calendar = ( ); let sizeClass = ''; if (this.props.size === 'large') { sizeClass = ' ant-input-lg'; } else if (this.props.size === 'small') { sizeClass = ' ant-input-sm'; } let pickerClass = 'ant-calendar-picker'; if (this.state.open) { pickerClass += ' ant-calendar-picker-open'; } return { ({value}) => { return ( ); } } ; } }); } const AntDatePicker = createPicker(Calendar); const AntMonthPicker = createPicker(MonthCalendar); const AntCalendar = React.createClass({ getDefaultProps() { return { locale: CalendarLocale, prefixCls: 'ant-calendar', }; }, render() { return ; } }); AntDatePicker.Calendar = AntCalendar; AntDatePicker.MonthPicker = AntMonthPicker; // TODO. remove after https://github.com/ant-design/ant-design/issues/487 AntDatePicker.locale = { en_US: pickerEnUsLocale, zh_CN: defaultLocale, }; export default AntDatePicker;