Claude-seo seo-image-gen
AI image generation for SEO assets: OG/social preview images, blog hero images, schema images, product photography, infographics. Powered by Gemini via nanobanana-mcp. Requires banana extension installed. Use when user says \"generate image\", \"OG image\", \"social preview\", \"hero image\", \"blog image\", \"product photo\", \"infographic\", \"seo image\", \"create visual\", \"image-gen\", \"favicon\", \"schema image\", \"pinterest pin\", \"generate visual\", \"banner\", or \"thumbnail\".
git clone https://github.com/AgriciDaniel/claude-seo
T=$(mktemp -d) && git clone --depth=1 https://github.com/AgriciDaniel/claude-seo "$T" && mkdir -p ~/.claude/skills && cp -r "$T/extensions/banana/skills/seo-image-gen" ~/.claude/skills/agricidaniel-claude-seo-seo-image-gen && rm -rf "$T"
extensions/banana/skills/seo-image-gen/SKILL.mdSEO Image Gen: AI Image Generation for SEO Assets (Extension)
Generate production-ready images for SEO use cases using Gemini's image generation via the banana Creative Director pipeline. Maps SEO needs to optimized domain modes, aspect ratios, and resolution defaults.
Architecture Note
This extension is built on Claude Banana, the standalone AI image generation skill for Claude Code.
This skill has two components with distinct roles:
- SKILL.md (this file): Handles interactive
commands for generating images/seo image-gen - Agent (
): Audit-only analyst spawned duringagents/seo-image-gen.md
to assess existing OG/social images and produce a generation plan (never auto-generates)/seo audit
Prerequisites
This skill requires the banana extension to be installed:
./extensions/banana/install.sh
Check availability: Before using any image generation tool, verify the MCP server is connected by checking if
gemini_generate_image or set_aspect_ratio tools are
available. If tools are not available, inform the user the extension is not installed
and provide install instructions.
Quick Reference
| Command | What it does |
|---|---|
| Generate OG/social preview image (1200x630 feel) |
| Blog hero image (widescreen, dramatic) |
| Product photography (clean, white BG) |
| Infographic visual (vertical, data-heavy) |
| Custom image with full Creative Director pipeline |
| Generate N variations (default: 3) |
SEO Image Use Cases
Each use case maps to pre-configured banana parameters:
| Use Case | Aspect Ratio | Resolution | Domain Mode | Notes |
|---|---|---|---|---|
| OG/Social Preview | | | Product or UI/Web | Clean, professional, text-friendly |
| Blog Hero | | | Cinema or Editorial | Dramatic, atmospheric, editorial quality |
| Schema Image | | | Product | Clean, descriptive, schema ImageObject |
| Social Square | | | UI/Web | Platform-optimized square |
| Product Photo | | | Product | White background, studio lighting |
| Infographic | | | Infographic | Data-heavy, vertical layout |
| Favicon/Icon | | | Logo | Minimal, scalable, recognizable |
| Pinterest Pin | | | Editorial | Tall vertical card |
Generation Pipeline
For every generation request:
- Identify use case from command or context (og, hero, product, etc.)
- Apply SEO defaults from the use cases table above
- Set aspect ratio via
MCP toolset_aspect_ratio - Construct Reasoning Brief using the banana Creative Director pipeline:
- Load
for the 6-component systemreferences/prompt-engineering.md - Apply domain mode emphasis (Subject 30%, Style 25%, Context 15%, etc.)
- Be SPECIFIC and VISCERAL: describe what the camera sees
- Load
- Generate via
MCP toolgemini_generate_image - Post-generation SEO checklist (see below)
Check for Presets
If the user mentions a brand or has SEO presets configured:
python3 scripts/presets.py list
Load matching preset and apply as defaults. Also check
references/seo-image-presets.md
for SEO-specific preset templates.
Post-Generation SEO Checklist
After every successful generation, guide the user on:
- Alt text:Write descriptive, keyword-rich alt text for the generated image
- File naming:Rename to SEO-friendly format:
keyword-description-widthxheight.webp - WebP conversion:Convert to WebP for optimal page speed:
magick output.png -quality 85 output.webp - File size:Target under 200KB for hero images, under 100KB for thumbnails
- Schema markup:Suggest
schema for the generated image:ImageObject{ "@type": "ImageObject", "url": "https://example.com/images/keyword-description.webp", "width": 1200, "height": 630, "caption": "Descriptive caption with target keyword" } - OG meta tags:For social preview images, remind about:
<meta property="og:image" content="https://example.com/images/og-image.webp" /> <meta property="og:image:width" content="1200" /> <meta property="og:image:height" content="630" /> <meta property="og:image:alt" content="Descriptive alt text" />
Cost Awareness
Image generation costs money. Be transparent:
- Show estimated cost before generating (especially for batch)
- Log every generation:
python3 scripts/cost_tracker.py log --model MODEL --resolution RES --prompt "brief" - Run
if user asks about usagecost_tracker.py summary
Approximate costs (gemini-3.1-flash):
- 512: ~$0.02/image
- 1K resolution: ~$0.04/image
- 2K resolution: ~$0.08/image
- 4K resolution: ~$0.16/image
Model Routing
| Scenario | Model | Why |
|---|---|---|
| OG images, social previews | @ 1K | Fast, cost-effective |
| Hero images, product photos | @ 2K | Quality + detail |
| Infographics with text | @ 2K, thinking: high | Better text rendering |
| Quick drafts | @ 512 | Rapid iteration |
Error Handling
| Error | Resolution |
|---|---|
| MCP not configured | Run |
| API key invalid | New key at https://aistudio.google.com/apikey |
| Rate limited (429) | Wait 60s, retry. Free tier: ~10 RPM / ~500 RPD |
| Rephrase prompt - see Safety section |
| MCP unavailable | Fall back: |
| Extension not installed | Show install instructions: |
Cross-Skill Integration
- seo-images (analysis) feeds into seo-image-gen (generation): audit results from
identify missing or low-quality images; use those findings to drive/seo images
commands/seo image-gen - seo-audit spawns the seo-image-gen agent (not this skill) to analyze OG/social images across the site and produce a prioritized generation plan
- seo-schema can consume generated images: after generation, suggest
schema markup pointing to the new assetsImageObject
Reference Documentation
Load on-demand. Do NOT load all at startup:
:6-component system, domain modes, templatesreferences/prompt-engineering.md
:Model specs, rate limits, capabilitiesreferences/gemini-models.md
:MCP tool parameters and responsesreferences/mcp-tools.md
:ImageMagick/FFmpeg pipeline recipesreferences/post-processing.md
:Pricing, usage trackingreferences/cost-tracking.md
:Brand preset managementreferences/presets.md
:SEO-specific preset templatesreferences/seo-image-presets.md
Response Format
After generating, always provide:
- Image path:where it was saved
- Crafted prompt:show what was sent to the API (educational)
- Settings:model, aspect ratio, resolution
- SEO checklist:alt text suggestion, file naming, WebP conversion
- Schema snippet:ImageObject or og:image markup if applicable