apps/docs/integrations/scaleway.mdx
Get the @react-email/components package and the Scaleway Node.js SDK.
<CodeGroup>npm install @scaleway/sdk @react-email/components
yarn add @scaleway/sdk @react-email/components
pnpm add @scaleway/sdk @react-email/components
Start by building your email template in a .jsx or .tsx file.
import * as React from "react";
import { Html, Button } from "@react-email/components";
export function Email(props) {
const { url } = props;
return (
<Html lang="en">
<Button href={url}>Click me</Button>
</Html>
);
}
Import the email template you just built, convert into an HTML string, and use the Scaleway SDK to send it.
import { render } from "@react-email/components";
import { TransactionalEmail, createClient } from "@scaleway/sdk";
import { Email } from "./email";
const client = createClient({
accessKey: process.env.ACCESS_KEY,
secretKey: process.env.SECRET_KEY,
defaultProjectId: process.env.PROJECT_ID,
defaultRegion: "fr-par",
defaultZone: "fr-par-1",
});
const transactionalEmailClient = new TransactionalEmail.v1alpha1.API(client);
const emailHtml = await render(<Email url="https://example.com" />);
const sender = {
email: "[email protected]",
subject: "TEST",
name: "Team",
};
const userInvited = {
email: "[email protected]",
name: "TEST",
teamName: "Team",
};
const userInvitedBy = {
email: "[email protected]",
name: "TEST",
teamName: "Team",
};
transactionalEmailClient.createEmail({
from: {
email: sender.email,
name: sender.name,
},
to: [
{
email: userInvited.email,
name: userInvited.name,
},
],
subject: sender.subject,
text: null,
html: emailHtml,
});
<Card title="Scaleway Transactional Email" icon="arrow-up-right-from-square" iconType="duotone" href="https://github.com/resend/react-email/tree/main/examples/scaleway"
See the full source code. </Card>