35 lines
1.3 KiB
TypeScript
35 lines
1.3 KiB
TypeScript
import { APP_NAME } from "@calcom/lib/constants";
|
|
|
|
import { renderEmail } from "../";
|
|
import OrganizerScheduledEmail from "./organizer-scheduled-email";
|
|
|
|
export default class OrganizerRequestEmail extends OrganizerScheduledEmail {
|
|
protected getNodeMailerPayload(): Record<string, unknown> {
|
|
const toAddresses = [this.teamMember?.email || this.calEvent.organizer.email];
|
|
|
|
return {
|
|
from: `${APP_NAME} <${this.getMailerOptions().from}>`,
|
|
to: toAddresses.join(","),
|
|
replyTo: [this.calEvent.organizer.email, ...this.calEvent.attendees.map(({ email }) => email)],
|
|
subject: `${this.t("awaiting_approval")}: ${this.calEvent.title}`,
|
|
html: renderEmail("OrganizerRequestEmail", {
|
|
calEvent: this.calEvent,
|
|
attendee: this.calEvent.organizer,
|
|
}),
|
|
text: this.getTextBody("event_awaiting_approval"),
|
|
};
|
|
}
|
|
|
|
protected getTextBody(title = "event_awaiting_approval"): string {
|
|
return super.getTextBody(
|
|
title,
|
|
`${this.calEvent.organizer.language.translate("someone_requested_an_event")}`,
|
|
"",
|
|
`${this.calEvent.organizer.language.translate("confirm_or_reject_request")}
|
|
${process.env.NEXT_PUBLIC_WEBAPP_URL} + ${
|
|
this.calEvent.recurringEvent?.count ? "/bookings/recurring" : "/bookings/upcoming"
|
|
}`
|
|
);
|
|
}
|
|
}
|