mirror of
https://github.com/documenso/documenso.git
synced 2025-11-14 16:51:38 +10:00
This commit is contained in:
@ -0,0 +1,35 @@
|
|||||||
|
import React from 'react';
|
||||||
|
|
||||||
|
export type TemplateCustomMessageBodyProps = {
|
||||||
|
text?: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
export const TemplateCustomMessageBody = ({ text }: TemplateCustomMessageBodyProps) => {
|
||||||
|
if (!text) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
const normalized = text
|
||||||
|
.trim()
|
||||||
|
.replace(/\r\n?/g, '\n')
|
||||||
|
.replace(/\n\s*\n+/g, '\n\n')
|
||||||
|
.replace(/\n{2,}/g, '\n\n');
|
||||||
|
|
||||||
|
const paragraphs = normalized.split('\n\n');
|
||||||
|
|
||||||
|
return paragraphs.map((paragraph, i) => (
|
||||||
|
<p
|
||||||
|
key={`p-${i}`}
|
||||||
|
className="whitespace-pre-line break-words font-sans text-base text-slate-400"
|
||||||
|
>
|
||||||
|
{paragraph.split('\n').map((line, j) => (
|
||||||
|
<React.Fragment key={`line-${i}-${j}`}>
|
||||||
|
{j > 0 && <br />}
|
||||||
|
{line}
|
||||||
|
</React.Fragment>
|
||||||
|
))}
|
||||||
|
</p>
|
||||||
|
));
|
||||||
|
};
|
||||||
|
|
||||||
|
export default TemplateCustomMessageBody;
|
||||||
@ -8,6 +8,7 @@ import { RECIPIENT_ROLES_DESCRIPTION } from '@documenso/lib/constants/recipient-
|
|||||||
|
|
||||||
import { Body, Container, Head, Hr, Html, Img, Link, Preview, Section, Text } from '../components';
|
import { Body, Container, Head, Hr, Html, Img, Link, Preview, Section, Text } from '../components';
|
||||||
import { useBranding } from '../providers/branding';
|
import { useBranding } from '../providers/branding';
|
||||||
|
import { TemplateCustomMessageBody } from '../template-components/template-custom-message-body';
|
||||||
import type { TemplateDocumentInviteProps } from '../template-components/template-document-invite';
|
import type { TemplateDocumentInviteProps } from '../template-components/template-document-invite';
|
||||||
import { TemplateDocumentInvite } from '../template-components/template-document-invite';
|
import { TemplateDocumentInvite } from '../template-components/template-document-invite';
|
||||||
import { TemplateFooter } from '../template-components/template-footer';
|
import { TemplateFooter } from '../template-components/template-footer';
|
||||||
@ -105,7 +106,7 @@ export const DocumentInviteEmailTemplate = ({
|
|||||||
|
|
||||||
<Text className="mt-2 text-base text-slate-400">
|
<Text className="mt-2 text-base text-slate-400">
|
||||||
{customBody ? (
|
{customBody ? (
|
||||||
<pre className="font-sans text-base text-slate-400">{customBody}</pre>
|
<TemplateCustomMessageBody text={customBody} />
|
||||||
) : (
|
) : (
|
||||||
<Trans>
|
<Trans>
|
||||||
{inviterName} has invited you to {action} the document "{documentName}".
|
{inviterName} has invited you to {action} the document "{documentName}".
|
||||||
|
|||||||
Reference in New Issue
Block a user