🎯

og-images

🎯Skill

from richtabor/agent-skills

VibeIndex|
What it does

Generates dynamic, customizable OpenGraph and Twitter share images for Next.js using ImageResponse with flexible layout and styling options.

πŸ“¦

Part of

richtabor/agent-skills(14 items)

og-images

Installation

Quick InstallInstall with npx
npx skills add richtabor/agent-skills
Add MarketplaceAdd marketplace to Claude Code
/plugin marketplace add https://github.com/richtabor/agent-skills
Install PluginInstall plugin from marketplace
/plugin install rt
πŸ“– Extracted from docs: richtabor/agent-skills
4Installs
-
AddedFeb 4, 2026

Skill Details

SKILL.md

Guides creation of OpenGraph and Twitter share images using next/og ImageResponse. Covers layout patterns, custom fonts, avatars, title case, and Satori rules. Use when building OG images, Twitter cards, or social previews.

Overview

# Creating Share Images for Next.js

Generate dynamic OpenGraph (1200x630) and Twitter (1200x600) images using next/og ImageResponse.

Choosing an Approach

  • File-based route (app/opengraph-image.tsx): Best for static pages with known titles at build time. Export runtime, alt, size, contentType, and a default Image function.
  • API route (app/api/og/route.tsx): Best for dynamic content (blog posts, CMS). Accept slug and/or title as query params. Reference in metadata via generateMetadata().

Use export const runtime = "edge" for both approaches.

File Naming Convention

| File | Purpose | Dimensions |

|------|---------|------------|

| opengraph-image.tsx | Facebook, LinkedIn, iMessage | 1200x630 |

| twitter-image.tsx | Twitter/X cards | 1200x600 |

| app/api/og/route.tsx | Dynamic API route | 1200x630 |

Place file-based routes in the relevant route directory (e.g., app/about/opengraph-image.tsx for /about).

Layout Pattern

  • Use flexDirection: "column" with justifyContent: "space-between" to separate content from branding
  • Title and subtitle (e.g., author name) go top-left in a stacked flex column
  • Title: large, bold/medium weight, dark color
  • Subtitle: same size or smaller, lighter weight, muted color (e.g., #888)
  • Keep text left-aligned with textWrap: "balance" and constrain width with maxWidth
  • Use letterSpacing: "-0.02em" for tight, editorial feel at large sizes
  • Padding: 48px on all sides works well at 1200x630

Avatar / Logo (Optional)

If the project has an avatar or logo, place it in the bottom-right corner using a flex container with justifyContent: "flex-end". Load images via fetch + arrayBuffer, convert to base64 data URI for the src. Use borderRadius: "50%" for circular avatars. Cache loaded assets in a Map to avoid refetching.

Custom Fonts

Load .ttf files from public/fonts/ using new URL("../../../public/fonts/YourFont.ttf", import.meta.url). Pass the ArrayBuffer to ImageResponse via the fonts option. Cache the font buffer after first load. Match the weight in the fonts config to the actual font file weight.

Title Case

If titles come from a CMS, apply smart title case:

  • Lowercase small words (a, an, the, and, but, for, in, of, etc.) unless first or last
  • Always capitalize brand names correctly (WordPress, JavaScript, GitHub, macOS, etc.)
  • Uppercase known acronyms (AI, API, CSS, HTML, UI, UX)
  • Handle hyphenated words by capitalizing each part independently

Metadata Integration

Reference the OG route in generateMetadata():

```tsx

export function generateMetadata({ params }) {

return {

openGraph: {

images: [/api/og?slug=${params.slug}],

},

};

}

```

For static pages, pass the title directly: /api/og?title=About.

Satori Rules

These are hard requirements of the next/og rendering engine (Satori):

  1. Every element needs display: "flex" β€” this is the only layout mode
  2. Inline styles only β€” no CSS classes, no external stylesheets, no CSS variables
  3. All text must be in elements with explicit style props
  4. Use hex colors β€” no rgb(), hsl(), or CSS variables
  5. No gap on older versions β€” test before relying on it; fallback to margin

Common Issues

| Issue | Solution |

|-------|----------|

| Text not rendering | Add display: "flex" to the text wrapper |

| Layout broken | Ensure all containers have display: "flex" |

| Colors wrong | Use hex colors, not CSS variables |

| Font not loading | Check the relative path from route file to public/fonts/ |

| Image not showing | Convert to base64 data URI, don't use relative paths |

Testing

Preview during development by visiting the route directly in the browser:

```

http://localhost:3000/api/og?title=Hello+World

```

After building, verify routes register as dynamic (f prefix) in the build output.

More from this repository10

πŸͺ
richtabor-agent-skillsπŸͺMarketplace

Provides Claude with specialized plugins for technical writing, accessibility reviews, motion design, and social media content creation across different platforms.

🎯
technical-writing🎯Skill

Generates technical blog posts by analyzing code implementations, crafting clear and engaging content that avoids AI-sounding language.

🎯
create-prd🎯Skill

Interactively plan and generate a comprehensive Product Requirements Document (PRD) by asking clarifying questions and structuring detailed feature specifications.

🎯
x-writing🎯Skill

Transforms notes and ideas into engaging X (Twitter) posts by analyzing content, applying strategic writing principles, and crafting authentic social media content.

🎯
fresh-eyes🎯Skill

Performs a detailed, critical re-read of recently modified code to catch bugs, errors, and potential issues from a fresh perspective.

🎯
humanize🎯Skill

Humanizes AI-generated text by removing robotic patterns, preserving meaning, and making writing sound more natural and authentic.

🎯
ralph-json-create-issues🎯Skill

Converts markdown PRD or plan files into structured JSON stories, ensuring right-sized, dependency-aware tasks for autonomous Ralph execution.

🎯
ralph-github-create-issues🎯Skill

Here's a concise, practical description for the "ralph-github-create-issues" skill: Converts PRD markdown files into structured GitHub Issues, enabling seamless product requirement tracking and im...

🎯
ralph-github-start-loop🎯Skill

Autonomously fetches, implements, and closes GitHub issues across multiple iterations, guiding development through PRD-labeled issues.

🎯
review-pr🎯Skill

Reviews GitHub PR comments, evaluates against current code, and automatically addresses reviewer feedback with precise reasoning.