2024-11-26 20:30:52 -05:00
|
|
|
import { render } from "@react-email/render";
|
2024-10-03 20:55:54 -04:00
|
|
|
import { ReactElement } from "react";
|
|
|
|
import emailClient from "@server/emails";
|
|
|
|
import logger from "@server/logger";
|
|
|
|
|
|
|
|
export async function sendEmail(
|
|
|
|
template: ReactElement,
|
|
|
|
opts: {
|
2025-01-01 16:40:01 -05:00
|
|
|
name?: string;
|
2024-10-12 18:21:31 -04:00
|
|
|
from: string | undefined;
|
|
|
|
to: string | undefined;
|
2024-10-03 20:55:54 -04:00
|
|
|
subject: string;
|
|
|
|
},
|
|
|
|
) {
|
|
|
|
if (!emailClient) {
|
|
|
|
logger.warn("Email client not configured, skipping email send");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-10-04 21:16:01 -04:00
|
|
|
if (!opts.from || !opts.to || !opts.subject) {
|
|
|
|
logger.error("Email missing required fields", opts);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-10-03 20:55:54 -04:00
|
|
|
const emailHtml = await render(template);
|
|
|
|
|
2024-12-31 18:25:11 -05:00
|
|
|
await emailClient.sendMail({
|
|
|
|
from: {
|
2025-01-04 20:22:01 -05:00
|
|
|
name: opts.name || "Pangolin",
|
2024-12-31 18:25:11 -05:00
|
|
|
address: opts.from,
|
|
|
|
},
|
2024-10-03 20:55:54 -04:00
|
|
|
to: opts.to,
|
|
|
|
subject: opts.subject,
|
|
|
|
html: emailHtml,
|
2024-12-31 18:25:11 -05:00
|
|
|
});
|
2024-10-03 20:55:54 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
export default sendEmail;
|