24 lines
733 B
TypeScript
24 lines
733 B
TypeScript
|
import * as ReactDOMServer from "react-dom/server";
|
||
|
|
||
|
import * as templates from "./templates";
|
||
|
|
||
|
function renderEmail<K extends keyof typeof templates>(
|
||
|
template: K,
|
||
|
props: React.ComponentProps<typeof templates[K]>
|
||
|
) {
|
||
|
const Component = templates[template];
|
||
|
return (
|
||
|
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
||
|
// @ts-expect-error
|
||
|
ReactDOMServer.renderToStaticMarkup(Component(props))
|
||
|
// Remove `<RawHtml />` injected scripts
|
||
|
.replace(/<script><\/script>/g, "")
|
||
|
.replace(
|
||
|
"<html>",
|
||
|
`<html xmlns="http://www.w3.org/1999/xhtml" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office">`
|
||
|
)
|
||
|
);
|
||
|
}
|
||
|
|
||
|
export default renderEmail;
|