2023-02-27 20:45:40 +00:00
|
|
|
import type { TFunction } from "next-i18next";
|
2022-06-25 05:16:20 +00:00
|
|
|
|
|
|
|
import { getRichDescription } from "@calcom/lib/CalEventParser";
|
2022-11-30 21:52:56 +00:00
|
|
|
import { APP_NAME } from "@calcom/lib/constants";
|
2023-07-28 14:22:19 +00:00
|
|
|
import { TimeFormat } from "@calcom/lib/timeFormat";
|
2022-06-25 05:16:20 +00:00
|
|
|
import type { CalendarEvent } from "@calcom/types/Calendar";
|
|
|
|
|
|
|
|
import { renderEmail } from "..";
|
|
|
|
import BaseEmail from "./_base-email";
|
|
|
|
|
|
|
|
export default class BrokenIntegrationEmail extends BaseEmail {
|
|
|
|
type: "calendar" | "video";
|
|
|
|
calEvent: CalendarEvent;
|
|
|
|
t: TFunction;
|
|
|
|
|
|
|
|
constructor(calEvent: CalendarEvent, type: "calendar" | "video") {
|
|
|
|
super();
|
|
|
|
this.name = "SEND_BROKEN_INTEGRATION";
|
|
|
|
this.calEvent = calEvent;
|
|
|
|
this.t = this.calEvent.organizer.language.translate;
|
|
|
|
this.type = type;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected getNodeMailerPayload(): Record<string, unknown> {
|
|
|
|
const toAddresses = [this.calEvent.organizer.email];
|
|
|
|
|
|
|
|
return {
|
2022-11-30 21:52:56 +00:00
|
|
|
from: `${APP_NAME} <${this.getMailerOptions().from}>`,
|
2022-06-25 05:16:20 +00:00
|
|
|
to: toAddresses.join(","),
|
|
|
|
subject: `[Action Required] ${this.t("confirmed_event_type_subject", {
|
|
|
|
eventType: this.calEvent.type,
|
|
|
|
name: this.calEvent.attendees[0].name,
|
|
|
|
date: this.getFormattedDate(),
|
|
|
|
})}`,
|
|
|
|
html: renderEmail("BrokenIntegrationEmail", {
|
|
|
|
calEvent: this.calEvent,
|
|
|
|
attendee: this.calEvent.organizer,
|
|
|
|
type: this.type,
|
|
|
|
}),
|
|
|
|
text: this.getTextBody(),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
protected getTextBody(
|
|
|
|
title = "",
|
|
|
|
subtitle = "emailed_you_and_any_other_attendees",
|
|
|
|
extraInfo = "",
|
|
|
|
callToAction = ""
|
|
|
|
): string {
|
|
|
|
return `
|
|
|
|
${this.t(
|
|
|
|
title || this.calEvent.recurringEvent?.count ? "new_event_scheduled_recurring" : "new_event_scheduled"
|
|
|
|
)}
|
|
|
|
${this.t(subtitle)}
|
|
|
|
${extraInfo}
|
|
|
|
${getRichDescription(this.calEvent)}
|
|
|
|
${callToAction}
|
|
|
|
`.trim();
|
|
|
|
}
|
|
|
|
|
|
|
|
protected getTimezone(): string {
|
|
|
|
return this.calEvent.organizer.timeZone;
|
|
|
|
}
|
|
|
|
|
2023-07-28 14:22:19 +00:00
|
|
|
protected getLocale(): string {
|
|
|
|
return this.calEvent.organizer.language.locale;
|
|
|
|
}
|
|
|
|
|
2022-06-25 05:16:20 +00:00
|
|
|
protected getOrganizerStart(format: string) {
|
2023-07-28 14:22:19 +00:00
|
|
|
return this.getFormattedRecipientTime({
|
|
|
|
time: this.calEvent.startTime,
|
|
|
|
format,
|
|
|
|
});
|
2022-06-25 05:16:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
protected getOrganizerEnd(format: string) {
|
2023-07-28 14:22:19 +00:00
|
|
|
return this.getFormattedRecipientTime({
|
|
|
|
time: this.calEvent.endTime,
|
|
|
|
format,
|
|
|
|
});
|
2022-06-25 05:16:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
protected getFormattedDate() {
|
2023-07-28 14:22:19 +00:00
|
|
|
const organizerTimeFormat = this.calEvent.organizer.timeFormat || TimeFormat.TWELVE_HOUR;
|
|
|
|
return `${this.getOrganizerStart(organizerTimeFormat)} - ${this.getOrganizerEnd(
|
|
|
|
organizerTimeFormat
|
|
|
|
)}, ${this.t(this.getOrganizerStart("dddd").toLowerCase())}, ${this.t(
|
|
|
|
this.getOrganizerStart("MMMM").toLowerCase()
|
|
|
|
)} ${this.getOrganizerStart("D, YYYY")}`;
|
2022-06-25 05:16:20 +00:00
|
|
|
}
|
|
|
|
}
|