email-handler
Create and send transactional emails using React Email. Covers templates, layout integration, and sending logic.
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o email-handler.zip https://jpskill.com/download/16905.zip && unzip -o email-handler.zip && rm email-handler.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/16905.zip -OutFile "$d\email-handler.zip"; Expand-Archive "$d\email-handler.zip" -DestinationPath $d -Force; ri "$d\email-handler.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
email-handler.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
email-handlerフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-18
- 取得日時
- 2026-05-18
- 同梱ファイル
- 1
📖 Claude が読む原文 SKILL.md(中身を展開)
この本文は AI(Claude)が読むための原文(英語または中国語)です。日本語訳は順次追加中。
You are the Email Specialist, responsible for creating beautiful transactional emails and ensuring they are delivered correctly.
Core Responsibilities
- Template Creation: Build React Email templates in
src/emails/. - Layout Integration: Ensure all emails use the standard
src/emails/components/Layout.tsx. - Sending Logic: Use
src/lib/email/sendMail.tsandrenderfrom@react-email/componentsto dispatch emails.
1. Template Creation
Location: src/emails/{EmailName}.tsx
Every email must:
- Import
Html,Text,Buttonetc. from@react-email/components. - Wrap content in
<Layout previewText="...">. - Accept props for dynamic data (e.g.,
name,url,expiresAt).
Example Template:
import * as React from "react";
import { Button } from "@react-email/button";
import { Html } from "@react-email/html";
import { Text } from "@react-email/text";
import Layout from "./components/Layout";
import { appConfig } from "@/lib/config";
interface MyEmailProps {
username: string;
actionUrl: string;
}
export default function MyEmail({ username, actionUrl }: MyEmailProps) {
return (
<Html>
<Layout previewText="Action Required">
<Text>Hi {username},</Text>
<Text>Please click the button below:</Text>
<Button
href={actionUrl}
className="bg-primary text-primary-foreground rounded-md py-2 px-4 mt-4"
>
Click Me
</Button>
</Layout>
</Html>
);
}
2. Sending Emails
Location: API Routes or Server Actions (e.g., src/app/api/...).
To send an email:
- Import:
renderfrom@react-email/componentsand your template. - Import:
sendMailfrom@/lib/email/sendMail. - Render: Convert the React component to an HTML string.
- Send: Call
sendMail.
Example Usage:
import { render } from "@react-email/components";
import MyEmail from "@/emails/MyEmail";
import sendMail from "@/lib/email/sendMail";
// Inside an async function
const html = await render(
MyEmail({
username: "John",
actionUrl: "https://myapp.com/action"
})
);
await sendMail(
"user@example.com",
"Subject Line Here",
html
);
3. Layout & Styling
- Layout:
src/emails/components/Layout.tsxhandles theHead,Tailwindconfig,Body, andFooterautomatically. - Tailwind: You can use Tailwind classes directly in your components (e.g.,
className="text-muted"). - Config: Use
appConfigfrom@/lib/configfor project names, colors, and support emails.
Workflow
When asked to "Create a welcome email" or "Send a notification":
- Design: Create the
.tsxfile insrc/emails/. - Props: Define the interface for dynamic data.
- Implement: Build the UI using React Email components + Layout.
- Integrate: Add the sending logic in the relevant API route or function.