import type { GenerateConfig } from '../vc-picker/generate'; import type { PickerPanelBaseProps as RCPickerPanelBaseProps, PickerPanelDateProps as RCPickerPanelDateProps, PickerPanelTimeProps as RCPickerPanelTimeProps } from '../vc-picker/PickerPanel'; import enUS from './locale/en_US'; import type { VueNode } from '../_util/type'; declare type InjectDefaultProps = Omit & { locale?: typeof enUS; size?: 'large' | 'default' | 'small'; }; export declare type PickerPanelBaseProps = InjectDefaultProps>; export declare type PickerPanelDateProps = InjectDefaultProps>; export declare type PickerPanelTimeProps = InjectDefaultProps>; export declare type PickerProps = PickerPanelBaseProps | PickerPanelDateProps | PickerPanelTimeProps; export declare type CalendarMode = 'year' | 'month'; export declare type HeaderRender = (config: { value: DateType; type: CalendarMode; onChange: (date: DateType) => void; onTypeChange: (type: CalendarMode) => void; }) => VueNode; declare type CustomRenderType = (config: { current: DateType; }) => VueNode; export interface CalendarProps { prefixCls?: string; locale?: typeof enUS; validRange?: [DateType, DateType]; disabledDate?: (date: DateType) => boolean; dateFullCellRender?: CustomRenderType; dateCellRender?: CustomRenderType; monthFullCellRender?: CustomRenderType; monthCellRender?: CustomRenderType; headerRender?: HeaderRender; value?: DateType | string; defaultValue?: DateType | string; mode?: CalendarMode; fullscreen?: boolean; onChange?: (date: DateType | string) => void; 'onUpdate:value'?: (date: DateType | string) => void; onPanelChange?: (date: DateType | string, mode: CalendarMode) => void; onSelect?: (date: DateType | string) => void; valueFormat?: string; } declare function generateCalendar = CalendarProps>(generateConfig: GenerateConfig): import("vue").DefineComponent ? import("vue").ExtractPropTypes : Props>, import("vue").ExtractDefaultPropTypes>; export default generateCalendar;