An MCP server for reviewing React component changes.
MCP Component Review
An MCP (Model Context Protocol) server for reviewing React component changes. Analyzes structural differences, generates visual diffs, and validates implementations against Figma designs.
Features
- Structural Analysis: Parse React components (TSX/JSX) and extract props, children, and styles
- Style Detection: Support for Tailwind CSS, styled-components, and CSS Modules
- Visual Diff: Screenshot components and generate pixel-level diff images
- Figma Integration: Extract design specs and validate implementation compliance
- Branch Review: Analyze all changed components in a git branch
Installation
git clone https://github.com/yourusername/mcp-component-review.git
cd mcp-component-review
npm install
npm run build
Usage
With Claude Desktop
Add to your claude_desktop_config.json:
{
"mcpServers": {
"component-review": {
"command": "node",
"args": ["/path/to/mcp-component-review/dist/index.js"]
}
}
}
With Claude Code
claude mcp add component-review node /path/to/mcp-component-review/dist/index.js
Available Tools
`analyze_component`
Analyze a single React component file.
analyze_component({
file: "/path/to/Button.tsx"
})
Output:
- Component name and props
- Component tree structure
- Extracted styles (colors, spacing, typography)
`compare_components`
Compare two component files and get a structured diff.
compare_components({
oldFile: "/path/to/Button.old.tsx",
newFile: "/path/to/Button.new.tsx"
})
Output:
- Text content changes
- Child component additions/removals
- Prop changes
- Style changes (colors, spacing, typography)
`visual_diff_components`
Generate visual diff screenshots.
visual_diff_components({
oldFile: "/path/to/Button.old.tsx",
newFile: "/path/to/Button.new.tsx",
outputDir: "/path/to/output"
})
Output:
- Screenshots of old and new components
- Diff image highlighting changes
- Combined side-by-side view
`get_figma_specs`
Extract design specifications from Figma.
get_figma_specs({
figmaUrl: "https://www.figma.com/file/ABC123/Design?node-id=1:2",
figmaToken: "figd_xxxxx"
})
Output:
- Dimensions (width, height)
- Spacing (padding, margin, gap)
- Colors (background, text, border)
- Typography (font-size, font-weight, line-height)
- Border (radius, width)
`validate_design_implementation`
Compare Figma specs with implementation.
validate_design_implementation({
figmaUrl: "https://www.figma.com/file/ABC123/Design?node-id=1:2",
figmaToken: "figd_xxxxx",
componentFile: "/path/to/Button.tsx",
tolerance: 2
})
Output:
# Design Validation Report: Button
## Summary ⚠️
- **Score**: 75%
- **Matches**: 6/8
- **Mismatches**: 2
## Validation Details
| Property | Figma | Implementation | Status |
|---------------|-----------|----------------------|------------|
| padding-top | 8px | 8px (p-2) | ✅ match |
| background | #22C55E | #16A34A (bg-green-600)| ❌ mismatch|
| font-size | 16px | 18px (text-lg) | ❌ mismatch|
`review_branch`
Review all changed components in a git branch.
review_branch({
repoPath: "/path/to/repo",
baseBranch: "main",
targetBranch: "feature/new-button",
figmaToken: "figd_xxxxx",
figmaFileKey: "ABC123",
figmaMapping: {
"src/components/Button.tsx": "1:234",
"src/components/Card.tsx": "1:567"
},
outputDir: "/path/to/visual-diffs"
})
Output:
- Summary of all changed components
- Structural analysis for each component
- Visual diffs for modified components
- Figma validation scores
`validate_and_fix`
Validate a component and get auto-fix instructions. If the component doesn't match Figma, returns exact Tailwind/CSS changes needed.
validate_and_fix({
figmaUrl: "https://www.figma.com/file/ABC123/Design?node-id=1:2",
figmaToken: "figd_xxxxx",
componentFile: "/path/to/Button.tsx"
})
Output (when fixes needed):
🔧 **AUTO-FIX REQUIRED** for `src/Button.tsx`
Current design compliance: **62%**
## Required Changes
### 🔴 Missing (High Priority)
- **gap**: Add `gap-2`
- Expected: `8px`
### 🟡 Mismatches (Medium Priority)
- **background**: Change to `bg-green-500`
- Current: `bg-green-600`
- Expected: `#22C55E`
- **font-size**: Change to `text-base`
- Current: `text-lg`
- Expected: `16px`
## Instructions
1. Open `src/Button.tsx`
2. Find the className or styled-components styles
3. Apply the following Tailwind class changes:
Add/Replace: gap-2 bg-green-500 text-base
4. Save the file
5. Run validation again to confirm compliance
This output is designed to be directly actionable by an AI agent to automatically fix the issues.
Getting a Figma Token
- Go to Figma → Settings → Account
- Scroll to "Pers
Tools (7)
analyze_componentAnalyze a single React component file.compare_componentsCompare two component files and get a structured diff.visual_diff_componentsGenerate visual diff screenshots.get_figma_specsExtract design specifications from Figma.validate_design_implementationCompare Figma specs with implementation.review_branchReview all changed components in a git branch.validate_and_fixValidate a component and get auto-fix instructions.Environment Variables
figmaTokenrequiredPersonal access token for Figma API accessConfiguration
{"mcpServers": {"component-review": {"command": "node", "args": ["/path/to/mcp-component-review/dist/index.js"]}}}