v-event-calendar
Version:
Lightweight, Vue 3 Event Calendar With Event Scheduling, Multiple Views, Drag-&-Drop, Resizing and Customizable Styling
75 lines (73 loc) • 2.79 kB
TypeScript
import { CalendarCell, CalendarEvent } from '../types';
interface CalendarDateGridProps {
endHour?: number;
startHour?: number;
hourHeight?: number;
calendarCells: CalendarCell[];
timeFormat?: '12h' | '24h';
allowEventCreation?: boolean;
}
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<CalendarDateGridProps>, {
allowEventCreation: boolean;
hourHeight: number;
startHour: number;
endHour: number;
timeFormat: string;
}>>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {
dayClick: (date: Date) => void;
eventClick: (event: CalendarEvent) => void;
createEvent: (date: Date, start: string, end?: string, duration?: number) => void;
timeSlotClick: (date: Date, time: string) => void;
eventUpdate: (eventId: string, start: string, end?: string, duration?: number) => void;
}, string, import('vue').PublicProps, Readonly<import('vue').ExtractPropTypes<__VLS_WithDefaults<__VLS_TypePropsToRuntimeProps<CalendarDateGridProps>, {
allowEventCreation: boolean;
hourHeight: number;
startHour: number;
endHour: number;
timeFormat: string;
}>>> & Readonly<{
onCreateEvent?: (date: Date, start: string, end?: string, duration?: number) => any;
onTimeSlotClick?: (date: Date, time: string) => any;
onEventUpdate?: (eventId: string, start: string, end?: string, duration?: number) => any;
onDayClick?: (date: Date) => any;
onEventClick?: (event: CalendarEvent) => any;
}>, {
hourHeight: number;
timeFormat: "12h" | "24h";
startHour: number;
endHour: number;
allowEventCreation: boolean;
}, {}, {}, {}, 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;
};
};