import * as React from 'react'; import * as moment from 'moment'; import { TimePickerProps } from '../time-picker'; export interface PickerProps { id?: number | string; prefixCls?: string; inputPrefixCls?: string; format?: string | string[]; disabled?: boolean; allowClear?: boolean; className?: string; suffixIcon?: React.ReactNode; style?: React.CSSProperties; popupStyle?: React.CSSProperties; dropdownClassName?: string; locale?: any; size?: 'large' | 'small' | 'default'; getCalendarContainer?: (triggerNode: Element) => HTMLElement; open?: boolean; onOpenChange?: (status: boolean) => void; disabledDate?: (current: moment.Moment | undefined) => boolean; renderExtraFooter?: () => React.ReactNode; dateRender?: (current: moment.Moment, today: moment.Moment) => React.ReactNode; } export interface SinglePickerProps { value?: moment.Moment; defaultValue?: moment.Moment; defaultPickerValue?: moment.Moment; onChange?: (date: moment.Moment, dateString: string) => void; } export interface DatePickerProps extends PickerProps, SinglePickerProps { className?: string; showTime?: TimePickerProps | boolean; showToday?: boolean; open?: boolean; disabledTime?: ( current: moment.Moment | undefined, ) => { disabledHours?: () => number[]; disabledMinutes?: () => number[]; disabledSeconds?: () => number[]; }; onOpenChange?: (status: boolean) => void; onOk?: (selectedTime: moment.Moment) => void; placeholder?: string; } export interface MonthPickerProps extends PickerProps, SinglePickerProps { className?: string; placeholder?: string; } export type RangePickerValue = | undefined[] | [moment.Moment] | [undefined, moment.Moment] | [moment.Moment, moment.Moment]; export type RangePickerPresetRange = RangePickerValue | (() => RangePickerValue); export interface RangePickerProps extends PickerProps { className?: string; value?: RangePickerValue; defaultValue?: RangePickerValue; defaultPickerValue?: RangePickerValue; onChange?: (dates: RangePickerValue, dateStrings: [string, string]) => void; onCalendarChange?: (dates: RangePickerValue, dateStrings: [string, string]) => void; onOk?: (selectedTime: RangePickerPresetRange) => void; showTime?: TimePickerProps | boolean; ranges?: { [range: string]: RangePickerPresetRange; }; placeholder?: [string, string]; mode?: string | string[]; disabledTime?: ( current: moment.Moment | undefined, type: string, ) => { disabledHours?: () => number[]; disabledMinutes?: () => number[]; disabledSeconds?: () => number[]; }; onPanelChange?: (value?: RangePickerValue, mode?: string | string[]) => void; } export interface WeekPickerProps extends PickerProps, SinglePickerProps { className?: string; placeholder?: string; } export interface DatePickerDecorator extends React.ClassicComponentClass { RangePicker: React.ClassicComponentClass; MonthPicker: React.ClassicComponentClass; WeekPicker: React.ClassicComponentClass; }