DesignDiff MCP
Verifies that AI-generated interfaces match Figma design system designs by comparing computed CSS output against Figma specs and returning patch-ready fixes.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@DesignDiff MCPVerify Button component at localhost:6006 matches Figma file abc123 node 123:456"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
DesignDiff MCP
AI implementation verification engine for Figma and MCP-compatible coding agents.
DesignDiff verifies that AI-generated interfaces match your Figma design system before they ship. It reads the Figma spec, renders your component in a real browser, compares computed CSS output, and returns patch-ready fixes — all inside your existing coding agent session.
Claude Code / Cursor / Windsurf
↓
DesignDiff MCP
↓
Figma REST API + Playwright renderer
↓
Scored diff + Patch-ready fix
↓
Agent applies → Re-checks: 94/100Why
AI agents generate UI code from Figma specs and get it mostly right — but not exactly. The typical failure pattern:
Token violations — hardcoded
#2563EBinstead ofvar(--brand-blue-600). Works today, breaks on the next brand refresh.Spacing drift — padding is 12px not 16px because the agent approximated instead of reading the exact value.
Missing states — hover, focus, and disabled were defined in Figma variants the agent didn't parse.
The component looks correct visually. That's what makes this dangerous. DesignDiff catches these errors before they land in a PR.
Related MCP server: Mimic AI
Quick start
1. Get your Figma API key Settings → Account → Personal access tokens
2. Add to your agent config
Claude Code (~/.config/claude/mcp.json):
{
"mcpServers": {
"designdiff": {
"command": "npx",
"args": ["-y", "designdiff-mcp"],
"env": { "FIGMA_API_KEY": "your-token-here" }
}
}
}Same format for Cursor (.cursor/mcp.json), Windsurf, VS Code Copilot, and Zed.
3. Say to your agent
"Build the Button component from Figma file abc123, node 123:456,
running at localhost:6006 — and verify it matches the spec"DesignDiff is called automatically when the agent generates or modifies a component.
Works best with Storybook, local preview routes, or any stable component URL your agent can render.
Tools
check_component_parity — ships now
Diffs the Figma design spec against computed browser CSS. Returns a scored parity report with ranked mismatches and a patch-ready fix when score drops below threshold.
check_component_parity({
file_id: "abc123", // Figma file ID from URL
node_id: "123:456", // Component node ID
component_url: "http://localhost:6006/story/button--primary",
code_path: "src/components/Button.tsx",
threshold: 80, // Score below which fix is generated (default: 80)
})What it checks: spacing, color tokens, typography, borders, border-radius, interactive states.
What it returns: 0–100 parity score, ranked mismatches with consequences, pattern detection (e.g. "AI-generated code signature"), and a patch-ready git diff.
flag_stale_mappings — ships now
Cross-references Code Connect mappings in your repo against Figma version history and git blame. Surfaces components that have drifted silently, ranked by blast radius and days since divergence.
flag_stale_mappings({
file_id: "abc123",
repo_root: ".", // Path to your repo root
})Reads from .figma/code-connect.json in your repo root.
generate_sync_patch — ships now
Generates a surgical patch for a specific component — token substitutions, prop corrections, missing state stubs. Output as git diff, JSX corrections, or CSS delta.
generate_sync_patch({
file_id: "abc123",
node_id: "123:456",
code_path: "src/components/Button.tsx",
format: "diff", // "diff" | "jsx" | "css"
})audit_state_coverage — v0.2
Checks whether every interactive state defined in a Figma component set (hover, focus, disabled, error, loading) exists in code. Flags WCAG 2.4.7 risk for missing focus rings.
check_responsive_parity — v0.2
Renders at 375/768/1280/1920px and catches overflow, collapsed containers, and flex direction errors.
check_theme_parity — v0.2
Runs parity across Figma variable modes — light/dark, brand variants, high-contrast. Catches hardcoded colors that are invisible in light mode but break in dark.
Finding your Figma IDs
File ID: From the URL — figma.com/file/{FILE_ID}/...
Node ID: Right-click a component in Figma → Copy link → extract the node-id parameter. Format: 123:456. Note: the URL uses 123-456 (hyphen) but the API uses 123:456 (colon) — DesignDiff handles the encoding automatically.
How it works
Fetch — Calls the Figma REST API and extracts the full design spec: exact pixel values, token references, and every variant state from the component set.
Render — Launches a headless Playwright browser and renders your component at its real URL. Captures computed CSS — what the browser actually produces after cascade and runtime overrides resolve.
Score — Compares the two. Token violations score highest (they break the entire design system contract). Missing focus states are flagged with WCAG reference. Every mismatch includes the real-world consequence of not fixing it.
Fix — When score is below threshold, generates a patch-ready diff the agent applies in the same response, then re-verifies the score improved.
Configuration
Environment variable | Required | Default | Description |
| ✓ | — | Figma personal access token |
| — |
|
|
| — |
| HTTP port (when |
HTTP transport
For use with non-stdio MCP clients:
FIGMA_API_KEY=xxx TRANSPORT=http npx designdiff-mcp
# → DesignDiff MCP v0.2 running at http://localhost:3847/mcpHealth check: GET /health
Development
git clone https://github.com/designdiff/designdiff-mcp
cd designdiff-mcp
npm install
npx playwright install chromium
npm run build
FIGMA_API_KEY=xxx npm startInspect tools interactively:
npm run inspectorThis opens the MCP Inspector UI where you can call tools directly.
Roadmap
Stage | What ships |
v0.1 — Now | Rendered parity check · token compliance · patch-ready diffs |
v0.2 | State coverage · responsive parity · theme parity · Storybook adapter |
v1.0 | Unified quality score · CI gate · score history · Slack alerts |
Contributing
See CONTRIBUTING.md.
License
MIT — see LICENSE.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Valkyrie2048/DesignDiff'
If you have feedback or need assistance with the MCP directory API, please join our Discord server