
* WIP bookings page ui changes, created api endpoint * Ui changes mobile/desktop * Added translations * Fix lib import and common names * WIP reschedule * WIP * Save wip * [WIP] builder and class for CalendarEvent, email for attende * update rescheduled emails, booking view and availability page view * Working version reschedule * Fix for req.user as array * Added missing translation and refactor dialog to self component * Test for reschedule * update on types * Update lib no required * Update type on createBooking * fix types * remove preview stripe sub * remove unused file * remove unused import * Fix reschedule test * Refactor and cleaning up code * Email reschedule title fixes * Adding calendar delete and recreate placeholder of cancelled * Add translation * Removed logs, notes, fixed types * Fixes process.env types * Use strict compare * Fixes type inference * Type fixing is my middle name * Update apps/web/components/booking/BookingListItem.tsx * Update apps/web/components/dialog/RescheduleDialog.tsx * Update packages/core/builders/CalendarEvent/director.ts * Update apps/web/pages/success.tsx * Updates rescheduling labels * Update packages/core/builders/CalendarEvent/builder.ts * Type fixes * Update packages/core/builders/CalendarEvent/builder.ts * Only validating input blocked once * E2E fixes * Stripe tests fixes * Wipe my cal init commit * Fixes circular dependencies * Added conditional display for wipe my cal button * Added placeholder image for app category * Fix type string for conditional validation Co-authored-by: Peer Richelsen <peer@cal.com> Co-authored-by: zomars <zomars@me.com>
77 lines
2.1 KiB
TypeScript
77 lines
2.1 KiB
TypeScript
import { Credential } from "@prisma/client";
|
|
import _ from "lodash";
|
|
|
|
import { getUid } from "@calcom/lib/CalEventParser";
|
|
import logger from "@calcom/lib/logger";
|
|
import type { CalendarEvent } from "@calcom/types/Calendar";
|
|
import type { EventResult } from "@calcom/types/EventManager";
|
|
|
|
import { getCalendar } from "../../_utils/getCalendar";
|
|
|
|
const log = logger.getChildLogger({ prefix: ["CalendarManager"] });
|
|
|
|
/** TODO: Remove once all references are updated to app-store */
|
|
export { getCalendar };
|
|
|
|
export const createEvent = async (credential: Credential, calEvent: CalendarEvent): Promise<EventResult> => {
|
|
const uid: string = getUid(calEvent);
|
|
const calendar = getCalendar(credential);
|
|
let success = true;
|
|
|
|
// Check if the disabledNotes flag is set to true
|
|
if (calEvent.hideCalendarNotes) {
|
|
calEvent.additionalNotes = "Notes have been hidden by the organizer"; // TODO: i18n this string?
|
|
}
|
|
|
|
const creationResult = calendar
|
|
? await calendar.createEvent(calEvent).catch((e) => {
|
|
log.error("createEvent failed", e, calEvent);
|
|
success = false;
|
|
return undefined;
|
|
})
|
|
: undefined;
|
|
|
|
return {
|
|
type: credential.type,
|
|
success,
|
|
uid,
|
|
createdEvent: creationResult,
|
|
originalEvent: calEvent,
|
|
};
|
|
};
|
|
|
|
export const updateEvent = async (
|
|
credential: Credential,
|
|
calEvent: CalendarEvent,
|
|
bookingRefUid: string | null
|
|
): Promise<EventResult> => {
|
|
const uid = getUid(calEvent);
|
|
const calendar = getCalendar(credential);
|
|
let success = true;
|
|
|
|
const updatedResult =
|
|
calendar && bookingRefUid
|
|
? await calendar.updateEvent(bookingRefUid, calEvent).catch((e) => {
|
|
log.error("updateEvent failed", e, calEvent);
|
|
success = false;
|
|
return undefined;
|
|
})
|
|
: undefined;
|
|
|
|
return {
|
|
type: credential.type,
|
|
success,
|
|
uid,
|
|
updatedEvent: updatedResult,
|
|
originalEvent: calEvent,
|
|
};
|
|
};
|
|
|
|
export const deleteEvent = (credential: Credential, uid: string, event: CalendarEvent): Promise<unknown> => {
|
|
const calendar = getCalendar(credential);
|
|
if (calendar) {
|
|
return calendar.deleteEvent(uid, event);
|
|
}
|
|
|
|
return Promise.resolve({});
|
|
};
|