import React from 'react'; import moment from 'moment'; import RangeCalendar from 'rc-calendar/lib/RangeCalendar'; import RcDatePicker from 'rc-calendar/lib/Picker'; import classNames from 'classnames'; import assign from 'object-assign'; import Icon from '../icon'; import { getLocaleCode } from '../_util/getLocale'; import warning from '../_util/warning'; export default class RangePicker extends React.Component { static contextTypes = { antLocale: React.PropTypes.object, }; static defaultProps = { prefixCls: 'ant-calendar', allowClear: true, showToday: false, }; constructor(props) { super(props); const value = props.value || props.defaultValue || []; if ( value[0] && !moment.isMoment(value[0]) || value[1] && !moment.isMoment(value[1]) ) { throw new Error( 'The value/defaultValue of RangePicker must be a moment object array after `antd@2.0`, ' + 'see: http://u.ant.design/date-picker-value' ); } this.state = { value, open: props.open, }; } componentWillReceiveProps(nextProps) { if ('value' in nextProps) { const value = nextProps.value || []; const showDate = value[0]; this.setState({ value, showDate }); } if ('open' in nextProps) { this.setState({ open: nextProps.open, }); } } clearSelection = (e) => { e.preventDefault(); e.stopPropagation(); this.setState({ value: [] }); this.handleChange([]); } handleChange = (value) => { const props = this.props; if (!('value' in props)) { this.setState({ value, showDate: value[0] }); } props.onChange(value, [ (value[0] && value[0].format(props.format)) || '', (value[1] && value[1].format(props.format)) || '', ]); } handleOpenChange = (open) => { this.setState({ open }); const { onOpenChange } = this.props; if (onOpenChange) { onOpenChange(open); } } handleShowDateChange = showDate => this.setState({ showDate }) setValue(value) { this.handleChange(value); if (!this.props.showTime) { this.setState({ open: false }); } } renderFooter = () => { const { prefixCls, ranges } = this.props; if (!ranges) { return null; } const operations = Object.keys(ranges).map((range) => { const value = ranges[range]; return this.setValue(value)}>{range}; }); return (
{operations}
); } render() { const { state, props, context } = this; const { value, showDate, open } = state; const localeCode = getLocaleCode(context); if (value && localeCode) { if (value[0]) { value[0].locale(localeCode); } if (value[1]) { value[1].locale(localeCode); } } const { disabledDate, disabledTime, showTime, showToday, ranges, prefixCls, popupStyle, style, onOk, locale, format, } = props; warning(!('onOK' in props), 'It should be `RangePicker[onOk]`, instead of `onOK`!'); const calendarClassName = classNames({ [`${prefixCls}-time`]: showTime, [`${prefixCls}-range-with-ranges`]: ranges, }); // 需要选择时间时,点击 ok 时才触发 onChange let pickerChangeHandler = { onChange: this.handleChange, }; let calendarHandler: Object = { onOk: this.handleChange, }; if (props.timePicker) { pickerChangeHandler.onChange = changedValue => this.handleChange(changedValue); } else { calendarHandler = {}; } const startPlaceholder = ('placeholder' in props) ? props.placeholder[0] : locale.lang.rangePlaceholder[0]; const endPlaceholder = ('placeholder' in props) ? props.placeholder[1] : locale.lang.rangePlaceholder[1]; const calendar = ( ); // default width for showTime const pickerStyle = {} as any; if (props.showTime) { pickerStyle.width = (style && style.width) || 300; } const clearIcon = (!props.disabled && props.allowClear && value && (value[0] || value[1])) ? : null; const input = ({ value: inputValue }) => { const start = inputValue[0]; const end = inputValue[1]; return ( ~ {clearIcon} ); }; return ( {input} ); } }