cal.pub0.org/lib/CalEventParser.ts

104 lines
2.6 KiB
TypeScript
Raw Normal View History

import { CalendarEvent } from "./calendarClient";
import { v5 as uuidv5 } from "uuid";
import short from "short-uuid";
import { stripHtml } from "./emails/helpers";
const translator = short();
export default class CalEventParser {
calEvent: CalendarEvent;
constructor(calEvent: CalendarEvent) {
this.calEvent = calEvent;
}
/**
* Returns a link to reschedule the given booking.
*/
public getRescheduleLink(): string {
return process.env.BASE_URL + "/reschedule/" + this.getUid();
}
/**
* Returns a link to cancel the given booking.
*/
public getCancelLink(): string {
return process.env.BASE_URL + "/cancel/" + this.getUid();
}
/**
* Returns a unique identifier for the given calendar event.
*/
public getUid(): string {
return translator.fromUUID(uuidv5(JSON.stringify(this.calEvent), uuidv5.URL));
}
/**
* Returns a footer section with links to change the event (as HTML).
*/
public getChangeEventFooterHtml(): string {
return `
2021-06-29 22:31:30 +00:00
<strong>Need to change this event?</strong>
Cancel: <a href="${this.getCancelLink()}">${this.getCancelLink()}</a>
Reschedule: <a href="${this.getRescheduleLink()}">${this.getRescheduleLink()}</a>
`;
}
/**
* Returns a footer section with links to change the event (as plain text).
*/
public getChangeEventFooter(): string {
return stripHtml(this.getChangeEventFooterHtml());
}
/**
* Returns an extended description with all important information (as HTML).
*
* @protected
*/
public getRichDescriptionHtml(): string {
2021-06-29 22:31:30 +00:00
// This odd indentation is necessary because otherwise the leading tabs will be applied into the event description.
return (
`
2021-06-29 22:31:30 +00:00
<strong>Event Type:</strong>
${this.calEvent.type}
<strong>Invitee Email:</strong>
<a href="mailto:${this.calEvent.attendees[0].email}">${this.calEvent.attendees[0].email}</a>
` +
(this.calEvent.location
2021-06-29 22:31:30 +00:00
? `<strong>Location:</strong>
${this.calEvent.location}
`
: "") +
2021-06-29 22:31:30 +00:00
`<strong>Invitee Time Zone:</strong>
${this.calEvent.attendees[0].timeZone}
<strong>Additional notes:</strong>
${this.calEvent.description}` +
2021-06-29 22:11:16 +00:00
this.getChangeEventFooterHtml()
);
}
/**
* Returns an extended description with all important information (as plain text).
*
* @protected
*/
public getRichDescription(): string {
return stripHtml(this.getRichDescriptionHtml());
}
/**
* Returns a calendar event with rich description.
*/
public asRichEvent(): CalendarEvent {
const eventCopy: CalendarEvent = { ...this.calEvent };
eventCopy.description = this.getRichDescriptionHtml();
return eventCopy;
}
}