figma-slides-mcp

figma-slides-mcp

Enables AI agents to create and edit Figma Slides in real-time, with built-in renderers for D3 charts, Rough.js sketches, and Satori layouts.

Category
Visit Server

README

figma-slides-mcp

MCP server that lets AI create and edit Figma Slides — with built-in D3, Rough.js, and Satori renderers for charts, diagrams, and custom graphics.

architecture license enjoy

What this is

An MCP server that gives AI agents (Claude, Cursor, etc.) direct control over Figma Slides. The AI can create slides, add text, draw shapes, render D3 charts, place images, and screenshot its work — all in real-time, in your actual Figma file.

This is not a design-to-code tool. It goes the other direction: AI → Figma. Your agent designs slides for you.

How it works

Your AI Agent ←—stdio—→ MCP Server ←—WebSocket—→ Figma Plugin ←—API—→ Slides Canvas

Three pieces:

  1. MCP Server — Node.js process that exposes tools over stdio. Your AI client spawns it.
  2. Figma Plugin — Runs inside Figma, executes commands on the canvas. Connects via WebSocket.
  3. Design Skill (optional) — Teaches the AI how to design well: layout, typography, color, D3 patterns.

Quick start

Claude Code (recommended)

Step 1 — Add the marketplace and install:

/plugin marketplace add luan007/figma-slides-mcp
/plugin install figma-slides-mcp@figma-slides-mcp

This clones the repo, loads the MCP server and design skill automatically.

Step 2 — Load the Figma plugin:

  1. Open a Figma Slides file
  2. Plugins → Development → Import plugin from manifest...
  3. Navigate to the cloned plugin directory — check the plugin cache:
    ~/.claude/plugins/cache/figma-slides-mcp/
    
    Find plugin/manifest.json inside and select it.
  4. Run the plugin — green dot = connected

You only import the manifest once. After that it's in your recent plugins.

Step 3 — Go:

Tell Claude: "Start a Figma Slides session"

Other MCP clients (Cursor, Windsurf, etc.)

git clone https://github.com/luan007/figma-slides-mcp.git
cd figma-slides-mcp && npm install

Add to your MCP config:

{
  "mcpServers": {
    "figma-slides": {
      "command": "npx",
      "args": ["-y", "figma-slides-mcp"]
    }
  }
}

Then import plugin/manifest.json into Figma (same as Step 2 above, but from your clone directory).

Graphics renderers

The Figma plugin bundles full graphics libraries. Your AI can use them to render complex visuals directly onto slides.

Renderer What it does Text stays editable?
D3 v7 Charts, data viz, diagrams, tables Yes
Rough.js Hand-drawn / sketchy style graphics Yes
Satori HTML/CSS → SVG (flexbox layouts) No (becomes paths)
SVG import Icons, logos, custom vectors Depends

The AI writes a D3 script, the plugin runs it in a sandboxed iframe, extracts the SVG, and converts it to editable Figma nodes. Text elements become real Figma text — you can edit them after.

What the AI can do

  • Create, duplicate, delete, reorder slides
  • Add any shape: rectangles, ellipses, lines, frames, text
  • Style anything: fills, strokes, effects, opacity, corner radius
  • Set text with per-character styling (font, size, color, spacing)
  • Render D3 charts, Rough.js sketches, Satori layouts
  • Place images from URL
  • Screenshot slides to verify its own work
  • Batch multiple operations in one call
  • Search nodes, export to PNG/SVG/PDF

Design skill

The bundled skill at skills/figma-slides-mcp/SKILL.md teaches the AI:

  • Layout planning (coordinate grids, column systems)
  • Typography hierarchy (font sizes, spacing, weight)
  • Visual design theory (when to use charts vs text, color systems)
  • D3 patterns (tables, flows, comparisons, Gantt charts, donuts)
  • The screenshot-verify-fix loop
  • API gotchas (gradient transforms, fill opacity, batch limits)

It's optional but makes a big difference. Without it, the AI tends to dump text on slides. With it, the AI thinks in layers and designs visually.

Claude Code plugin install includes the skill automatically. For manual setup, copy it to ~/.claude/skills/figma-slides-mcp/.

Limitations & quirks

This is an early-stage project. It works, but has edges.

  • Single session only. One MCP server → one Figma file at a time. No multi-document support yet.
  • Port conflict. If another instance is running on port 3055, it fails. Set FIGMA_WS_PORT to use a different port.
  • Plugin must be running. The Figma plugin needs to be open and connected. If you close it, the MCP server can't reach Figma.
  • Figma Slides only. Doesn't work with regular Figma Design files. Must be a Slides file.
  • Tables are limited. createTable works but is Slides-only and can be finicky.
  • Video is broken. createVideoAsync returns empty. Figma's API limitation.
  • Satori text is paths. Text rendered through Satori becomes vector paths — not editable as text in Figma. Use D3 instead when text editability matters.
  • No undo across sessions. The AI's changes are real Figma operations. You can Cmd+Z in Figma, but only within the current session.
  • Dev plugin, not published. The Figma plugin is loaded from local manifest, not the Figma Community. You need to import it manually once.

Under construction

  • [ ] Multi-session support (multiple Figma files)
  • [ ] Published Figma Community plugin (no manual manifest import)
  • [ ] Slide templates / presets
  • [ ] Better image search integration
  • [ ] Animation / transition authoring

Environment variables

Variable Default Description
FIGMA_WS_PORT 3055 WebSocket port for plugin connection

Project structure

figma-slides-mcp/
├── server/           # MCP server (Node.js, no build)
│   ├── index.js      # Entry point (stdio transport)
│   ├── bridge.js     # WebSocket bridge to plugin
│   ├── tools.js      # All MCP tool definitions
│   └── utils.js      # Helpers
├── plugin/           # Figma plugin (no build)
│   ├── manifest.json # Import this in Figma
│   ├── code.js       # Plugin logic
│   └── ui.html       # UI panel + D3/Rough.js/Satori loaders
├── skills/           # AI design skill
│   └── figma-slides-mcp/
│       └── SKILL.md
├── .claude-plugin/   # Claude Code plugin manifest
│   └── plugin.json
├── .mcp.json         # MCP server config (auto-loaded by plugin system)
└── test/

Zero TypeScript, zero bundlers, zero build steps. Plain JS all the way down.

For AI agents

See AGENT-INSTALL.md for detailed setup instructions, troubleshooting, and the full tool reference.

License

MIT

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured