LoginSignup
14
1

More than 1 year has passed since last update.

この記事の概要

HTMLメールを手動で作成したことはありますか?
WYSISYGなエディタで作るならともかく、1からHTMLを書いて作るのは大変ですよね。
考えた通りのスタイリングを施そうと思うと結局外部サービスでは上手くいかず手書きした経験が何度かありますが、結構本当にしんどいです。

そんな中、react-emailというReactでHTMLメールを作れるライブラリを見つけたので試しに触ってみました。

使い方

セットアップをします。
マニュアルとオートがありますが、今回はオートを選びます。

私は普段Yarnを使っているのでYarnで実行します。
npxでもセットアップできます(その場合はnpx create-email@latest)。

yarn create email
success Installed "create-email@0.0.4" with binaries:
      - create-email
⠋ Preparing files...
qiita-react-email
├── emails
│   ├── notion-magic-link.tsx
│   ├── plaid-verify-identity.tsx
│   ├── stripe-welcome.tsx
│   └── vercel-invite-user.tsx
├── package.json
✔ React Email Starter files ready
✨  Done in 4.38s.

依存関係をインストール。

yarn

立ち上げ。

yarn dev

localhost:3000で確認できるようになりました。

$ email dev
✔ React Email files ready
✔ React email is up-to-date
✔ Emails preview generated
✔ Dependencies installed
$ next dev
ready - started server on 0.0.0.0:3000, url: http://localhost:3000

表示される通り、emailsフォルダの中にメールを作成します。

サンプルファイルを真似てコードを書いてみました。

my-first-email.tsx
import * as React from "react";
import { Button } from "@react-email/button";
import { Container } from "@react-email/container";
import { Head } from "@react-email/head";
import { Hr } from '@react-email/hr';
import { Html } from "@react-email/html";
import { Img } from "@react-email/img";
import { Link } from "@react-email/link";
import { Preview } from "@react-email/preview";
import { Section } from "@react-email/section";
import { Text } from "@react-email/text";

export default function Email() {
  return (
    <Html>
      <Head />
      <Preview>My first email</Preview>
      <Section style={section}>
        <Container style={container}>
          <Img
            src="https://picsum.photos/id/0/300/200"
            alt=""
            width="300"
            height="200"
            style={image}
          />
          <Text style={heading}>This is my first email</Text>
          <Text style={paragraph}>
            <Link href="https://example.com">Lorem ipsum</Link> dolor sit amet,
            consectetur adipiscing elit, sed do eiusmod tempor incididunt ut
            labore et dolore magna aliqua.
          </Text>
          <Hr />
          <Text>
            Ut enim ad minim veniam, quis nostrud
            exercitation ullamco laboris nisi ut aliquip ex ea commodo
            consequat. Duis aute irure dolor in reprehenderit in voluptate velit
            esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat
            cupidatat non proident, sunt in culpa qui officia deserunt mollit
            anim id est laborum.
          </Text>
          <Section style={buttonWrapper}>
            <Button style={button}>Check it out!</Button>
          </Section>
        </Container>
      </Section>
    </Html>
  );
}

// スタイルの定義は省略

出力結果は次のようになりました。

たかがこれだけですが、HTMLメールを手で書いたことのある身としてはあまりにも簡単で涙が出るかと思いました。

ドキュメントに載っていないけど存在するコンポーネント

基本的にはdocs/componentに呼び出し方やPropsが載っているのですが、ColumnHeadingHrSectionは載っていなかったので列挙だけしておきます。

使い方は他のコンポーネントとなんら変わりません。

最後に

私がデザイナーなのもあり、普段HTMLメールを作成する際は実際の送信まで行っていません。
そのため今回も一旦メールの見た目を作成するまでの記事です。

しかし、送信までして初めてHTMLメールなので(?)どこかで触ってみたいと思います。


最後まで読んでくださってありがとうございます!
Twitterでも情報を発信しているので、良かったらフォローお願いします!

Devトークでのお話してくださる方も募集中です!

14
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
14
1