// import { TimePickerProps } from '../time-picker' import PropTypes from '../_util/vue-types'; import { TimesType, TimeType } from '../_util/moment-util'; export const PickerProps = () => ({ name: PropTypes.string, transitionName: PropTypes.string, prefixCls: PropTypes.string, inputPrefixCls: PropTypes.string, format: PropTypes.oneOfType([PropTypes.string, PropTypes.array]), disabled: PropTypes.bool, allowClear: PropTypes.bool, suffixIcon: PropTypes.any, popupStyle: PropTypes.object, dropdownClassName: PropTypes.string, locale: PropTypes.any, localeCode: PropTypes.string, size: PropTypes.oneOf(['large', 'small', 'default']), getCalendarContainer: PropTypes.func, open: PropTypes.bool, // onOpenChange: PropTypes.(status: bool) => void, disabledDate: PropTypes.func, showToday: PropTypes.bool, dateRender: PropTypes.any, // (current: moment.Moment, today: moment.Moment) => React.ReactNode, pickerClass: PropTypes.string, pickerInputClass: PropTypes.string, timePicker: PropTypes.any, autoFocus: PropTypes.bool, tagPrefixCls: PropTypes.string, tabIndex: PropTypes.oneOfType([PropTypes.string, PropTypes.number]), align: PropTypes.object.def(() => ({})), inputReadOnly: PropTypes.bool, valueFormat: PropTypes.string, }); export const SinglePickerProps = () => ({ value: TimeType, defaultValue: TimeType, defaultPickerValue: TimeType, renderExtraFooter: PropTypes.any, placeholder: PropTypes.string, // onChange?: (date: moment.Moment, dateString: string) => void; }); export const DatePickerProps = () => ({ ...PickerProps(), ...SinglePickerProps(), showTime: PropTypes.oneOfType([PropTypes.object, PropTypes.bool]), open: PropTypes.bool, disabledTime: PropTypes.func, // onOpenChange?: (status: bool) => void; // onOk?: (selectedTime: moment.Moment) => void; mode: PropTypes.oneOf(['time', 'date', 'month', 'year']), }); export const MonthPickerProps = () => ({ ...PickerProps(), ...SinglePickerProps(), placeholder: PropTypes.string, monthCellContentRender: PropTypes.func, }); // export const RangePickerPresetRange = PropTypes.oneOfType([TimesType, PropTypes.func]) export const RangePickerProps = () => ({ ...PickerProps(), tagPrefixCls: PropTypes.string, value: TimesType, defaultValue: TimesType, defaultPickerValue: TimesType, timePicker: PropTypes.any, // onChange?: (dates: TimesType, dateStrings: [string, string]) => void; // onCalendarChange?: (dates: TimesType, dateStrings: [string, string]) => void; // onOk?: (selectedTime: moment.Moment) => void; showTime: PropTypes.oneOfType([PropTypes.object, PropTypes.bool]), ranges: PropTypes.object, placeholder: PropTypes.arrayOf(String), mode: PropTypes.oneOfType([PropTypes.string, PropTypes.arrayOf(String)]), separator: PropTypes.any, disabledTime: PropTypes.func, showToday: PropTypes.bool, renderExtraFooter: PropTypes.any, // onPanelChange?: (value?: TimesType, mode?: string | string[]) => void; }); export const WeekPickerProps = () => ({ ...PickerProps(), ...SinglePickerProps(), placeholder: PropTypes.string, }); // export interface DatePickerDecorator extends React.ClassicComponentClass { // RangePicker: React.ClassicComponentClass; // MonthPicker: React.ClassicComponentClass; // WeekPicker: React.ClassicComponentClass; // }