import * as moment from 'moment' // import { TimePickerProps } from '../time-picker' import PropTypes from '../_util/vue-types' export const MomentType = { type: Object, validator: function (value) { return value === undefined || moment.isMoment(value) }, } export const PickerProps = () => ({ transitionName: PropTypes.string, prefixCls: PropTypes.string, inputPrefixCls: PropTypes.string, format: PropTypes.string, disabled: PropTypes.bool, allowClear: PropTypes.bool, 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, renderExtraFooter: PropTypes.any, 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, }) export const SinglePickerProps = () => ({ value: MomentType, defaultValue: MomentType, defaultPickerValue: MomentType, // 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; placeholder: PropTypes.string, }) export const MonthPickerProps = () => ({ ...PickerProps(), ...SinglePickerProps(), placeholder: PropTypes.string, monthCellContentRender: PropTypes.func, }) function isMomentArray (value) { if (Array.isArray(value)) { return value.length === 0 || value.findIndex((val) => val === undefined || moment.isMoment(val)) !== -1 } return false } export const RangePickerValue = PropTypes.custom(isMomentArray) // export const RangePickerPresetRange = PropTypes.oneOfType([RangePickerValue, PropTypes.func]) export const RangePickerProps = () => ({ ...PickerProps(), value: RangePickerValue, defaultValue: RangePickerValue, defaultPickerValue: RangePickerValue, // onChange?: (dates: RangePickerValue, dateStrings: [string, string]) => void; // onCalendarChange?: (dates: RangePickerValue, 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)]), disabledTime: PropTypes.func, showToday: PropTypes.bool, // onPanelChange?: (value?: RangePickerValue, 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; // }