### Description 1. This PR is a continuation of a previous PR: https://github.com/twentyhq/twenty/pull/6201#pullrequestreview-2175601222 2. One test case was removed here: `packages/twenty-front/src/utils/image/__tests__/getImageAbsoluteURI.test.ts` because since we are not handling base64 images anymore, the result is the same of the last test case. Would you rather we update the test instead? ### Refs - #3514 - https://github.com/twentyhq/twenty/pull/6201 ### Demo https://www.loom.com/share/4f32b535c77a4d418e319b095d09452c?sid=df34adf8-b013-44ef-b794-d54846f52d2d Fixes #3514 --------- Co-authored-by: gitstart-twenty <gitstart-twenty@users.noreply.github.com>
49 lines
1.6 KiB
TypeScript
49 lines
1.6 KiB
TypeScript
import { Img } from '@react-email/components';
|
|
|
|
import { BaseEmail } from 'src/components/BaseEmail';
|
|
import { CallToAction } from 'src/components/CallToAction';
|
|
import { HighlightedContainer } from 'src/components/HighlightedContainer';
|
|
import { HighlightedText } from 'src/components/HighlightedText';
|
|
import { Link } from 'src/components/Link';
|
|
import { MainText } from 'src/components/MainText';
|
|
import { Title } from 'src/components/Title';
|
|
import { WhatIsTwenty } from 'src/components/WhatIsTwenty';
|
|
import { capitalize } from 'src/utils/capitalize';
|
|
import { getImageAbsoluteURI } from 'src/utils/getImageAbsoluteURI';
|
|
|
|
type SendInviteLinkEmailProps = {
|
|
link: string;
|
|
workspace: { name: string | undefined; logo: string | undefined };
|
|
sender: {
|
|
email: string;
|
|
firstName: string;
|
|
};
|
|
serverUrl?: string;
|
|
};
|
|
|
|
export const SendInviteLinkEmail = ({
|
|
link,
|
|
workspace,
|
|
sender,
|
|
serverUrl,
|
|
}: SendInviteLinkEmailProps) => {
|
|
const workspaceLogo = getImageAbsoluteURI(workspace.logo, serverUrl);
|
|
return (
|
|
<BaseEmail width={333}>
|
|
<Title value="Join your team on Twenty" />
|
|
<MainText>
|
|
{capitalize(sender.firstName)} (
|
|
<Link href={sender.email} value={sender.email} />) has invited you to
|
|
join a workspace called <b>{workspace.name}</b>
|
|
<br />
|
|
</MainText>
|
|
<HighlightedContainer>
|
|
{workspaceLogo && <Img src={workspaceLogo} width={40} height={40} />}
|
|
{workspace.name && <HighlightedText value={workspace.name} />}
|
|
<CallToAction href={link} value="Accept invite" />
|
|
</HighlightedContainer>
|
|
<WhatIsTwenty />
|
|
</BaseEmail>
|
|
);
|
|
};
|