You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
38 lines
1.4 KiB
38 lines
1.4 KiB
import type { App } from 'vue';
|
|
import dataFnsGenerateConfig from '../vc-picker/generate/dateFns';
|
|
import type {
|
|
PickerProps,
|
|
PickerDateProps,
|
|
RangePickerProps as BaseRangePickerProps,
|
|
} from './generatePicker';
|
|
import generatePicker from './generatePicker';
|
|
import type { ExtraDatePickerProps, ExtraRangePickerProps } from './generatePicker/props';
|
|
|
|
export type DatePickerProps = PickerProps<Date> & ExtraDatePickerProps<Date>;
|
|
export type MonthPickerProps = Omit<PickerDateProps<Date>, 'picker'> & ExtraDatePickerProps<Date>;
|
|
export type WeekPickerProps = Omit<PickerDateProps<Date>, 'picker'> & ExtraDatePickerProps<Date>;
|
|
export type RangePickerProps = BaseRangePickerProps<Date> & ExtraRangePickerProps<Date>;
|
|
|
|
const { DatePicker, WeekPicker, MonthPicker, YearPicker, TimePicker, QuarterPicker, RangePicker } =
|
|
generatePicker<Date>(dataFnsGenerateConfig);
|
|
|
|
/* 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;
|
|
},
|
|
});
|