import * as React from 'react'; import * as moment from 'moment'; import { polyfill } from 'react-lifecycles-compat'; import Calendar from 'rc-calendar'; import RcDatePicker from 'rc-calendar/lib/Picker'; import classNames from 'classnames'; import Icon from '../icon'; import { ConfigConsumer, ConfigConsumerProps } from '../config-provider'; import interopDefault from '../_util/interopDefault'; function formatValue(value: moment.Moment | null, format: string): string { return (value && value.format(format)) || ''; } interface WeekPickerState { open: boolean; value: moment.Moment | null; } class WeekPicker extends React.Component { static defaultProps = { format: 'gggg-wo', allowClear: true, }; static getDerivedStateFromProps(nextProps: any) { if ('value' in nextProps || 'open' in nextProps) { const state = {} as WeekPickerState; if ('value' in nextProps) { state.value = nextProps.value; } if ('open' in nextProps) { state.open = nextProps.open; } return state; } return null; } private input: any; private prefixCls?: string; constructor(props: any) { super(props); const value = props.value || props.defaultValue; if (value && !interopDefault(moment).isMoment(value)) { throw new Error( 'The value/defaultValue of DatePicker or MonthPicker must be ' + 'a moment object after `antd@2.0`, see: https://u.ant.design/date-picker-value', ); } this.state = { value, open: props.open, }; } weekDateRender = (current: any) => { const selectedValue = this.state.value; const { prefixCls } = this; const { dateRender } = this.props; const dateNode = dateRender ? dateRender(current) : current.date(); if ( selectedValue && current.year() === selectedValue.year() && current.week() === selectedValue.week() ) { return (
{dateNode}
); } return
{dateNode}
; }; handleChange = (value: moment.Moment | null) => { if (!('value' in this.props)) { this.setState({ value }); } this.props.onChange(value, formatValue(value, this.props.format)); }; handleOpenChange = (open: boolean) => { const { onOpenChange } = this.props; if (!('open' in this.props)) { this.setState({ open }); } if (onOpenChange) { onOpenChange(open); } if (!open) { this.focus(); } }; clearSelection = (e: React.MouseEvent) => { e.preventDefault(); e.stopPropagation(); this.handleChange(null); }; renderFooter = (...args: any[]) => { const { prefixCls, renderExtraFooter } = this.props; return renderExtraFooter ? (
{renderExtraFooter(...args)}
) : null; }; focus() { this.input.focus(); } blur() { this.input.blur(); } saveInput = (node: any) => { this.input = node; }; renderWeekPicker = ({ getPrefixCls }: ConfigConsumerProps) => { const { prefixCls: customizePrefixCls, className, disabled, pickerClass, popupStyle, pickerInputClass, format, allowClear, locale, localeCode, disabledDate, style, onFocus, onBlur, id, suffixIcon, } = this.props; const prefixCls = getPrefixCls('calendar', customizePrefixCls); // To support old version react. // Have to add prefixCls on the instance. // https://github.com/facebook/react/issues/12397 this.prefixCls = prefixCls; const { open, value: pickerValue } = this.state; if (pickerValue && localeCode) { pickerValue.locale(localeCode); } const placeholder = 'placeholder' in this.props ? this.props.placeholder : locale.lang.placeholder; const calendar = ( ); const clearIcon = !disabled && allowClear && this.state.value ? ( ) : null; const inputIcon = (suffixIcon && (React.isValidElement<{ className?: string }>(suffixIcon) ? ( React.cloneElement(suffixIcon, { className: classNames({ [suffixIcon.props.className!]: suffixIcon.props.className, [`${prefixCls}-picker-icon`]: true, }), }) ) : ( {suffixIcon} ))) || ; const input = ({ value }: { value: moment.Moment | undefined }) => ( {clearIcon} {inputIcon} ); return ( {input} ); }; render() { return {this.renderWeekPicker}; } } polyfill(WeekPicker); export default WeekPicker;