v-event-calendar
Version:
Lightweight, Vue 3 Event Calendar With Event Scheduling, Multiple Views, Drag-&-Drop, Resizing and Customizable Styling
74 lines (72 loc) • 2.79 kB
TypeScript
import { CalendarCell, CalendarEvent } from '../types';
interface CalendarDayProps {
cell: CalendarCell;
view: 'month' | 'week' | 'date';
maxEventsDisplay?: number;
allowEventCreation?: boolean;
multiDayTrackCount?: number;
timeFormat?: '12h' | '24h';
}
declare function __VLS_template(): {
event?(_: {
event: CalendarEvent;
displayTime: string;
view: "month" | "date" | "week";
isMultiDay: boolean;
isContained: boolean;
}): any;
};
declare const __VLS_component: import('vue').DefineComponent<import('vue').ExtractPropTypes<__VLS_WithDefaults<__VLS_TypePropsToRuntimeProps<CalendarDayProps>, {
view: string;
timeFormat: string;
maxEventsDisplay: number;
allowEventCreation: boolean;
}>>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {
dayClick: (date: Date) => void;
eventClick: (event: CalendarEvent) => void;
dragStart: () => void;
dragEnd: () => void;
createEvent: (date: Date, startTime: string, endTime: string, duration: number) => void;
eventUpdate: (eventId: string, newStartTime?: string, newEndTime?: string, duration?: number) => void;
}, string, import('vue').PublicProps, Readonly<import('vue').ExtractPropTypes<__VLS_WithDefaults<__VLS_TypePropsToRuntimeProps<CalendarDayProps>, {
view: string;
timeFormat: string;
maxEventsDisplay: number;
allowEventCreation: boolean;
}>>> & Readonly<{
onCreateEvent?: (date: Date, startTime: string, endTime: string, duration: number) => any;
onEventUpdate?: (eventId: string, newStartTime?: string, newEndTime?: string, duration?: number) => any;
onDayClick?: (date: Date) => any;
onEventClick?: (event: CalendarEvent) => any;
onDragStart?: () => any;
onDragEnd?: () => any;
}>, {
view: "month" | "week" | "date";
timeFormat: "12h" | "24h";
allowEventCreation: boolean;
maxEventsDisplay: number;
}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
export default _default;
type __VLS_NonUndefinedable<T> = T extends undefined ? never : T;
type __VLS_TypePropsToRuntimeProps<T> = {
[K in keyof T]-?: {} extends Pick<T, K> ? {
type: import('vue').PropType<__VLS_NonUndefinedable<T[K]>>;
} : {
type: import('vue').PropType<T[K]>;
required: true;
};
};
type __VLS_WithDefaults<P, D> = {
[K in keyof Pick<P, keyof P>]: K extends keyof D ? __VLS_Prettify<P[K] & {
default: D[K];
}> : P[K];
};
type __VLS_Prettify<T> = {
[K in keyof T]: T[K];
} & {};
type __VLS_WithTemplateSlots<T, S> = T & {
new (): {
$slots: S;
};
};