canva-creator
Takes an approved content brief and executes a campaign end-to-end: builds the posting calendar, generates Canva designs for social posts, drafts caption and email copy, and stages social sends in HubSpot. Canva is used for social posts only (Instagram, Facebook, X, LinkedIn) — email content is drafted as plain text and surfaced inline for the owner to send from their own tool. Every step requires explicit owner approval. Use when the user says "make the content," "generate the posts," "create the assets," "turn this into a campaign," or hands off an approved brief for execution.
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o canva-creator.zip https://jpskill.com/download/22752.zip && unzip -o canva-creator.zip && rm canva-creator.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/22752.zip -OutFile "$d\canva-creator.zip"; Expand-Archive "$d\canva-creator.zip" -DestinationPath $d -Force; ri "$d\canva-creator.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
canva-creator.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
canva-creatorフォルダができる - 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
📖 Skill本文(日本語訳)
※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。
Canva Creator
範囲
このスキルは、所有者の承認によってゲートされる5つの連続した段階でキャンペーンを処理します。
brief → calendar → asset inventory → Canva designs → copy → HubSpot staging
| パス | チャネル | このスキルが生成するもの |
|---|---|---|
| Canva (ソーシャル) | Instagram, Facebook, X/Twitter, LinkedIn | Canvaデザイン + キャプション + スケジュールされたHubSpot投稿 |
| テキストのみ | メール (ニュースレター、マーケティング、ドリップ) | 件名 + プリヘッダー + 本文、所有者が送信できるようにインラインで表示 |
Canvaは、いかなる状況においてもメール行には使用されません — テンプレート、自動入力、デザインコピー、アセットアップロード、エクスポートは一切行いません。所有者は、メールパスからCanvaを明示的に除外しました。これは、メールテンプレートの自動入力が、画像スロットが利用可能な写真を超えた場合にプレースホルダーグラフィックを生成し、バリエーションのサムネイルがチャットプレビューでレンダリングされないためです。所有者がCanvaのメールデザインを要求した場合は、リダイレクトの文言についてreference/gotchas.mdを参照してください。
事前準備
ステージ1の前に、以下を確認してください。
-
ブリーフ。 ユーザーが承認済みのブリーフを参照または貼り付けていること。そうでない場合: 「キャンペーンを作成する前にコンテンツブリーフが必要です。コンテンツ戦略スキルから入手したものがありますか、それとも今すぐ作成しますか?」
-
Canvaティア。 Pro/Teamsは、ユーザーのライブラリからの手動テンプレート選択が必要です(自動入力APIなし)。Enterpriseは、ブランドテンプレートから自動入力できます。
-
HubSpotティア。 ソーシャルステージングにはMarketing Hub Professionalが必要です。 StarterまたはFreeの場合 → ステージ5をスキップし、代わりにCSVをエクスポートします (reference/hubspot-staging.mdを参照)。
-
ブランドアセット。 ディスク上の製品写真へのパス、またはブランドキットがCanvaでライブであることを確認します。
-
生成予算。 キャンペーンのCanvaボリュームを見積もり、ステージ1が始まる前に提示します。デフォルトはCanvaにバインドされた行ごとに3つの候補です。各デザインには約5回のAPI呼び出し(自動入力 + エクスポート + ポーリング)がかかります。
このキャンペーンの生成予算: Canva (ソーシャル) 行: 8 行あたりの候補数: 3 (デフォルト — 1を使用するには「単一候補」と言ってください) 合計デザイン数: 24 API呼び出し (概算): ~120 (自動入力 + エクスポート + ポーリング) Canva制限: 1分あたり100リクエスト。これは約2〜3分の生成時間を要し、ティア制限内に十分に収まります。続行しますか?予測される合計デザイン数が30を超える場合は、事前に単一候補モードを推奨します — 大規模なキャンペーンはすぐにヘッドルームがなくなります。所有者は、ステージ1が始まる前に、行あたりの候補数を1、2、または3にデフォルトを上書きできます。選択された値はセッション全体でロックされます。
ワークフロー
ステージ1 — 投稿カレンダー
ブリーフから、コンテンツのテーマ、チャネル、頻度、確定日(ローンチ、セール、休日)を抽出します。
すべての行をCanvaまたはテキストのみのドラフトにルーティングするPath列を含むカレンダーテーブルを作成します。
| 日付 | チャネル | パス | テーマ | アセットタイプ | キャプション/件名の角度 |
|---|---|---|---|---|---|
| 6月2日 | Instagramフィード | Canva (ソーシャル) | リネンローンチ | スクエア投稿 | 「ついに、ドレスが…」 |
| 6月5日 | メール | テキストのみ | リネンローンチ | メール本文 | 「実際に呼吸するリネン」 |
提示する前に、すべてのメールチャネル行をText-onlyとしてタグ付けします。ブリーフで特に指定がない限り、30日で上限を設定します。スケジュールの競合(同じ日に同じ製品の2つの投稿)は事前にフラグを立てます。
チェックポイント1。 カレンダーを提示します。「これは計画と一致していますか?日付の変更、チャネルの追加、テーマの交換はありますか?」承認されるまで繰り返し、その後、「N行はCanvaを通過し、M行はテキストのみのドラフトを通過します」と分割を声に出して述べ、次に進みます。ここでの誤分類の発見は無料です。デザインを生成した後に発見するのは無料ではありません。
ステージ2 — アセットインベントリ (Canva行のみ)
メール行はこのステージを完全にスキップします。各Canva (social)行について、テンプレートが必要とするものとすでに利用可能なものを示すマニフェストを作成します。
-
すべての画像スロットを名前で列挙します。 正方形のInstagram投稿には通常1〜2つの画像スロットがあります。カルーセルや製品グリッドには5つ以上ある場合があります。それらを個別にリストアップします(
Header_Image、Product1_Image、Product2_Image、…)—「製品画像」としてまとめることは決してありません。- Enterprise: ブランドテンプレートの
dataset[].labelからフィールド名を読み取ります(GET /v1/brand-templates/{id})。 - Pro/Teams: テンプレート内のすべての異なる画像長方形を数えます。
- Enterprise: ブランドテンプレートの
-
利用可能なアセットをインベントリします。 ブリーフからのテキストコンテンツ(製品名、オファーコピー、タグライン、価格設定)、Canvaにすでにアップロードされている製品写真(
GET /v1/assets)または所有者のディスク上にあるもの、ブランドキットの色とフォント(Enterprise)。 -
スロットごとのギャップテーブルを作成します。 デザインごとではなく、デザインごとのスロットごとに1行です。
日付 スロット名 スロットの種類 利用可能なアセット ステータス 6月2日 Hero_Image image bloom_summer.jpg → asset_id pending アップロード 6月2日 Headline text 「夏の麻、ついに」 準備完了 6月9日 Product1_Image image — 不足 -
所有者とスロット/アセットの不一致を解決します。 テンプレートにブリーフが提供する写真よりも多くの画像スロットがある場合は、一時停止して尋ねます。
「Summer Carousel」テンプレートには5つの画像スロットがあります。ブリーフには1枚の写真(bloom_summer.jpg)しかありませんでした。残りの4つをどのように埋めますか? 1. 同じ写真を5つのスロットすべてで再利用する 2. 追加の4枚の写真(ファイルパス)を送る 3. スロットの少ないシンプルなテンプレートを選択する所有者が選択するまで生成呼び出しは行いません。空のスロットで生成すると、Canvaのデフォルトの風景プレースホルダーでいっぱいのデザインが生成されます。
-
不足している写真をアップロードし、検証済みのアセットIDをキャプチャします。
POST /v1/asset-uploadsを介してアップロードし、status == "success"になるまでGET /v1/asset-uploads/{job_id}をポーリングします。応答からasset.idを記録します — これが自動入力画像フィールドで機能する唯一の値です。空の文字列、URL、ファイルパス、または古いIDを渡すと、Canvaのストック画像がサイレントにレンダリングされます。
(原文がここで切り詰められています)
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開
Canva Creator
Scope
This skill handles a campaign in five sequential stages, each gated by owner approval:
brief → calendar → asset inventory → Canva designs → copy → HubSpot staging
| Path | Channels | What this skill produces |
|---|---|---|
| Canva (social) | Instagram, Facebook, X/Twitter, LinkedIn | Canva design + caption + scheduled HubSpot post |
| Text-only | Email (newsletter, marketing, drip) | Subject + preheader + body, surfaced inline for the owner to send |
Canva is not used for email rows under any circumstance — no templates,
no autofill, no design copies, no asset uploads, no exports. The owner
explicitly descoped Canva from the email path because email-template
autofill produces placeholder graphics when image slots exceed available
photos, and variation thumbnails fail to render in chat previews. If the
owner asks for a Canva email design, see reference/gotchas.md for the
redirect language.
Pre-flight
Before Stage 1, confirm:
-
Brief. The user has referenced or pasted an approved brief. If not: "I'll need the content brief before I can build the campaign. Do you have one from the content-strategy skill, or would you like to write one now?"
-
Canva tier. Pro/Teams require manual template selection from the user's library (no autofill API). Enterprise can autofill from brand templates.
-
HubSpot tier. Social staging requires Marketing Hub Professional. Starter or Free → skip Stage 5 and export a CSV instead (see reference/hubspot-staging.md).
-
Brand assets. Confirm the path to product photos on disk or that the brand kit is live in Canva.
-
Generation budget. Estimate the campaign's Canva volume and surface it before Stage 1 begins. Default is 3 candidates per Canva-bound row; each design costs ~5 API calls (autofill + export + polling).
Generation budget for this campaign: Canva (social) rows: 8 Candidates per row: 3 (default — say "single candidate" to use 1) Total designs: 24 API calls (approx): ~120 (autofill + export + polling) Canva limit: 100 requests/minute. This will take ~2-3 minutes of generation, well within your tier limits. Proceed?If the projected total designs exceeds 30, recommend single-candidate mode upfront — large campaigns run out of headroom fast. The owner can override the default to 1, 2, or 3 candidates per row before Stage 1 starts. Lock the chosen value for the entire session.
Workflow
Stage 1 — Posting calendar
Pull from the brief: content themes, channels, cadence, hard dates (launches, sales, holidays).
Build a calendar table with a Path column that routes every row to either
Canva or text-only drafting:
| Date | Channel | Path | Theme | Asset type | Caption/Subject angle |
|---|---|---|---|---|---|
| Jun 2 | Instagram feed | Canva (social) | Linen launch | Square post | "finally, a dress…" |
| Jun 5 | Text-only | Linen launch | Email body | "Linen that actually breathes" |
Tag every email-channel row as Text-only before presenting. Cap at 30
days unless the brief specifies otherwise. Flag scheduling conflicts (two
posts same day for the same product) up front.
Checkpoint 1. Present the calendar. Ask: "Does this match the plan? Any dates to shift, channels to add, or themes to swap?" Iterate until approved, then restate the split out loud — "N rows go through Canva, M rows go through text-only drafting" — before moving on. Catching a miscategorization here is free; catching it after generating designs isn't.
Stage 2 — Asset inventory (Canva rows only)
Email rows skip this stage entirely. For each Canva (social) row, build
a manifest of what the template needs and what's already available.
-
Enumerate every image slot by name. Square Instagram posts usually have 1-2 image slots; carousels and product grids can have 5+. List them individually (
Header_Image,Product1_Image,Product2_Image, …) — never roll them up as "product images."- Enterprise: read field names from
dataset[].labelon the brand template (GET /v1/brand-templates/{id}). - Pro/Teams: count every distinct image rectangle in the template.
- Enterprise: read field names from
-
Inventory available assets. Text content from the brief (product names, offer copy, taglines, pricing), product photos already uploaded to Canva (
GET /v1/assets) or on the owner's disk, brand kit colors and fonts (Enterprise). -
Build the slot-by-slot gap table. One row per slot per design — not per design.
Date Slot name Slot kind Available asset Status Jun 2 Hero_Image image bloom_summer.jpg → asset_id pending upload Jun 2 Headline text "Summer linen, finally" ready Jun 9 Product1_Image image — MISSING -
Resolve slot/asset mismatches with the owner. If the template has more image slots than the brief provides photos, pause and ask:
The "Summer Carousel" template has 5 image slots. The brief gave me 1 photo (bloom_summer.jpg). How should I fill the other 4? 1. Reuse the same photo across all 5 slots 2. You send me 4 more photos (file paths) 3. Pick a simpler template with fewer slotsNo generation calls until the owner picks. Generating with empty slots produces designs full of Canva's default landscape placeholders.
-
Upload missing photos and capture verified asset IDs. Upload via
POST /v1/asset-uploads, then pollGET /v1/asset-uploads/{job_id}untilstatus == "success". Recordasset.idfrom the response — this is the only value that works in an autofill image field. Passing an empty string, a URL, a file path, or a stale ID silently renders Canva's stock landscape graphic instead of the photo. -
Confirm the manifest. Show the owner the completed slot-by-slot table with every slot resolved and every image
asset.idconfirmed. This is the last stop before Canva API calls.
Stage 3 — Canva design generation
Before any Canva API call, re-read the calendar and drop any row whose
Path is not Canva (social). Email rows do not pass through this
stage.
Generate designs one calendar row at a time, with 3 candidates per row (or the value chosen at pre-flight). Each row follows the same loop: generate candidates → verify → export → visually check → retry failures → present → wait for owner pick → next row. Pause 30 seconds between rows. This caps the burst at 3 generations + 3 exports per ~30s — well under Canva's 100 req/min rate limit. Do not parallelize multiple rows; one row at a time is the protection that keeps the owner from hitting quota mid-campaign.
Polling cadence. Poll job status every 3-5 seconds, not faster. Tighter intervals burn quota without speeding up completion.
Preview URLs — only one type is safe to embed. Autofill responses
return design.canva.ai thumbnails that expire within minutes; embedding
them as markdown images produces broken "Show Image" placeholders.
Permanent export URLs (export-download.canva.com or the export-design
MCP tool) do not expire. Native Cowork carousels render the autofill
result directly using the connector's authenticated session — let them
render on their own, don't re-embed.
Row loop
-
Resolve template. (Once per session — same template across rows unless the calendar mixes asset types.)
- Enterprise:
GET /v1/brand-templatesfiltered by asset type. - Pro/Teams:
GET /v1/designs?ownership=any&query={template name}, surface top 3 to the owner, confirm one before generating.
- Enterprise:
-
Generate the row's candidates in parallel. Fire the row's 3 candidates simultaneously (or N from pre-flight).
- Enterprise:
POST /v1/autofillsper candidate with the template ID and field values. Poll all jobs concurrently. - Pro/Teams:
POST /v1/designsto create copies. Describe the text and image edits the owner applies in Canva; collect design IDs back.
- Enterprise:
-
Verify job status. For each candidate, confirm
GET /autofills/{job_id}returnedstatus == "success"andresult.design.idis present. Handle errors per-design:-
JOB_FAILED→ readjob.error.message, fix the field values or asset IDs, retry once. -
RATE_LIMIT_EXCEEDED(first hit this session) → wait 60s, retry that one candidate once. This handles transient spikes. -
RATE_LIMIT_EXCEEDED(second hit this session) or anyquota_exceeded/ daily-cap error → stop generation immediately. Do not retry. Surface progress and ask:Canva is rate-limiting the campaign. Status so far: ✓ Generated: Posts 1-4 (12 designs) ⏸ Remaining: Posts 5-8 (12 designs not yet generated) How should I proceed? 1. Switch to 1 candidate per remaining row (4 designs total) — finishes now 2. Pause campaign — resume in 60 minutes when quota refills 3. Stop generation — work with what we have, move to captionsWait for the owner's choice. Do not loop on retry.
-
-
Export each successful candidate to a permanent PNG. Fire the row's exports in parallel.
- REST:
POST /v1/exportswithformat.type: "png", pollGET /v1/exports/{job_id}until success, captureurls[0]. - Canva MCP:
export-designwith the design ID.
These permanent URLs are what get embedded in previews and attached to the HubSpot post later. The autofill response thumbnail is never used downstream.
- REST:
-
Visually verify each export. Look at the image and reject any of these — they all indicate an unfilled slot or wrong asset:
- Generic landscape with clouds and green hills (Canva's default placeholder)
- Solid gray rectangles where a photo should be
- Lorem-ipsum or template-default text
- Subject that doesn't match the brief (wrong product, wrong brand)
If a candidate fails verification: re-check the manifest for the affected slot, fix the
asset.id, regenerate that single candidate, re-export, re-verify. -
Retry per-candidate on partial failure. If 1 of N candidates in the row failed at Step 3 or 5, regenerate just that one — don't redo the whole row and don't present a partial broken carousel. If the second attempt also fails:
The third candidate for the Jun 9 post keeps failing — Canva returned [error / rendered placeholder]. How should I proceed? 1. Skip it — present the other 2 and move on 2. Swap to a simpler template for just this candidate 3. Try once more with a different photo -
Present the row's candidates. Let the native Cowork carousel render the autofill tool result. Below it, add a text prompt:
Jun 9 candidates are ready — scroll through the carousel above. Which one should I use for the Jun 9 post?If the carousel doesn't render or one position is broken, embed the permanent export PNG URLs from Step 4 instead. Final fallback: link to the design's Canva edit URL (
https://www.canva.com/d/{design_id}). Never re-embeddesign.canva.aiURLs. -
Pause 30 seconds, then move to the next row.
Checkpoint 2. Satisfied once the owner has picked one design per calendar row. If they want a regenerate, regenerate only that one candidate.
Stage 4 — Copy drafting
For each calendar row, draft the copy. Social rows get a caption; email rows get a full email.
Social captions — Instagram, Facebook, X, LinkedIn:
- Length: channel-appropriate (Instagram ≤ 2,200 chars; Facebook ≤ 500 recommended; X ≤ 280).
- Structure: hook → one product benefit → CTA → 3-5 hashtags (not 30).
- Voice: match the brief's tone markers. If the brief says "casual and friendly," don't write corporate copy.
- No filler. No "Exciting news!" or "We're thrilled to announce." Open with the value.
Email content — Claude writes the entire email; no Canva:
- Subject: ≤ 50 chars, specific, no clickbait. "Spring projects are booking up" beats "Don't miss out!"
- Preheader: ≤ 90 chars, complements the subject without repeating it.
- Body: plain prose, 100-250 words. Opening line that earns the read → 1-2 paragraphs of substance → single clear CTA → sign-off.
- Voice: same tone markers as social. Owners want their emails to sound like them, not like a templated newsletter.
- No image references. Don't write "see image above." If the owner wants visuals, they add them in their email tool.
- One CTA per email. Pick the most important action and lead with it.
Present captions inline below each social row. Present full emails inline below each email row:
Subject: <subject line>
Preheader: <preheader text>
<body text>
For worked examples, see reference/examples/boutique-brief-campaign.md.
Checkpoint 3. "Any captions or emails to rewrite? Flag the date and what to change." Iterate until approved.
Stage 5 — HubSpot staging + email handoff
Stage social posts in HubSpot. Email content is not staged — it's surfaced inline for the owner to copy into their email tool. For API field reference, see reference/hubspot-staging.md.
-
Create the campaign.
POST /marketing/v3/campaignswith the campaign name and start/end dates from the calendar. -
Stage each social post.
POSTto the HubSpot Social API perCanva (social)row:channel: map calendar channel to HubSpot account IDscheduledAt: ISO 8601 datetime — confirm it's in the future before callingcontent.body: approved captionattachments: permanent Canva export PNG URL from Stage 3status:SCHEDULED(neverPUBLISHED)
-
Confirm the queue. Call
GET /marketing/v3/social/posts?status=SCHEDULED, surface the list, provide a direct link to the HubSpot campaign view. -
Surface email content for handoff. For each email row, present the approved subject + preheader + body inline, grouped by send date. The owner copies these into their email tool (HubSpot Marketing Email, Mailchimp, Gmail).
Final checkpoint.
Your social posts are scheduled in HubSpot: [link]
They'll go out as scheduled — you can cancel or edit any post in HubSpot.
Email content is drafted below — copy each into your email tool when
you're ready to send:
Jun 5 — "Spring projects are booking up"
Jul 15 — "Summer maintenance windows are filling"
Anything to change before we're done?
Approval gates
- No Canva calls for email rows. Re-check the
Pathcolumn before every API call. - No publishing. Every HubSpot post is staged as
SCHEDULED; the owner controls go-live. - Always surface the generation budget at pre-flight. Owner sees the total design count and approves before Stage 1 begins.
- One row at a time in Stage 3. Candidates within a row fire in parallel, but rows are sequential with a 30s gap — this is the quota protection.
- On the second quota error, pause and ask. Never loop on retry.
- Always export to a permanent PNG before presenting. Job success doesn't mean the design rendered correctly.
- Never embed
design.canva.aiURLs in messages. They expire. - Never regenerate the whole row when one candidate fails. Per-candidate retry only.
- Never auto-select a template for Pro/Teams users. Always confirm.
- Never skip slot-by-slot inventory. Multi-slot templates render placeholder landscapes when any slot is empty.
- Never skip Checkpoint 1. Generating before the calendar is approved is the largest source of wasted work in this skill.
Reference
- reference/canva-api.md — Canva Connect API endpoints, asset upload, export formats, MCP equivalents
- reference/hubspot-staging.md — HubSpot Social API and CSV fallback for non-Pro tiers
- reference/gotchas.md — Good / Bad patterns for every failure mode this skill has hit in production
- reference/examples/boutique-brief-campaign.md — full worked examples (single-slot social, multi-slot template)