Files
outline/server/emails/templates/InviteEmail.tsx
2023-10-17 22:34:01 -04:00

76 lines
2.0 KiB
TypeScript
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
import * as React from "react";
import env from "@server/env";
import BaseEmail, { EmailProps } from "./BaseEmail";
import Body from "./components/Body";
import Button from "./components/Button";
import EmailTemplate from "./components/EmailLayout";
import EmptySpace from "./components/EmptySpace";
import Footer from "./components/Footer";
import Header from "./components/Header";
import Heading from "./components/Heading";
type Props = EmailProps & {
name: string;
actorName: string;
actorEmail: string | null;
teamName: string;
teamUrl: string;
};
/**
* Email sent to an external user when an admin sends them an invite.
*/
export default class InviteEmail extends BaseEmail<Props, Record<string, any>> {
protected subject({ actorName, teamName }: Props) {
return `${actorName} invited you to join ${teamName}s workspace`;
}
protected preview() {
return `${env.APP_NAME} is a place for your team to build and share knowledge.`;
}
protected renderAsText({
teamName,
actorName,
actorEmail,
teamUrl,
}: Props): string {
return `
Join ${teamName} on ${env.APP_NAME}
${actorName} ${actorEmail ? `(${actorEmail})` : ""} has invited you to join ${
env.APP_NAME
}, a place for your team to build and share knowledge.
Join now: ${teamUrl}
`;
}
protected render({ teamName, actorName, actorEmail, teamUrl }: Props) {
const inviteLink = `${teamUrl}?ref=invite-email`;
return (
<EmailTemplate previewText={this.preview()}>
<Header />
<Body>
<Heading>
Join {teamName} on {env.APP_NAME}
</Heading>
<p>
{actorName} {actorEmail ? `(${actorEmail})` : ""} has invited you to
join {env.APP_NAME}, a place for your team to build and share
knowledge.
</p>
<EmptySpace height={10} />
<p>
<Button href={inviteLink}>Join now</Button>
</p>
</Body>
<Footer />
</EmailTemplate>
);
}
}