import type { Dayjs } from 'dayjs'; import type { App } from 'vue'; import dayjsGenerateConfig from '../vc-picker/generate/dayjs'; import type { PickerProps, PickerDateProps, RangePickerProps as BaseRangePickerProps, } from './generatePicker'; import generatePicker from './generatePicker'; import type { ExtraDatePickerProps, ExtraRangePickerProps } from './generatePicker/props'; export type DatePickerProps = PickerProps & ExtraDatePickerProps; export type MonthPickerProps = Omit, 'picker'> & ExtraDatePickerProps; export type WeekPickerProps = Omit, 'picker'> & ExtraDatePickerProps; export type RangePickerProps = BaseRangePickerProps & ExtraRangePickerProps; const { DatePicker, WeekPicker, MonthPicker, YearPicker, TimePicker, QuarterPicker, RangePicker } = generatePicker(dayjsGenerateConfig); /* istanbul ignore next */ export { RangePicker, WeekPicker, MonthPicker, QuarterPicker }; export default Object.assign(DatePicker, { WeekPicker, MonthPicker, YearPicker, RangePicker, TimePicker, QuarterPicker, install: (app: App) => { app.component(DatePicker.name, DatePicker); app.component(RangePicker.name, RangePicker); app.component(MonthPicker.name, MonthPicker); app.component(WeekPicker.name, WeekPicker); app.component(QuarterPicker.name, QuarterPicker); return app; }, });