MCP Frontend Tools Server
Generates CSS modules for React components and provides responsive CSS patterns, including container queries and Tailwind patterns for styling.
Generates typed React components with tests, stories, and CSS modules, providing scaffolding capabilities for React component development.
Creates Storybook stories for generated React components, enabling component documentation and visual testing.
Generates Testing Library test files for React components, providing testing capabilities for component behavior and interactions.
Creates typed React components with TypeScript support, ensuring type safety in generated frontend code.
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., "@MCP Frontend Tools Serverscaffold a login form component with email and password fields"
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.
mcp-frontend-tools
The reference Model Context Protocol server for frontend work. One install gives any coding agent — Claude Desktop, Cursor, VS Code, Zed, Continue — real eyes and hands on your UI:
axe_audit— run the realaxe-corerule engine against raw HTML (via jsdom) or a live URL (via Playwright). Returns violations grouped by WCAG impact with fix links.page_screenshot— headless-Chromium PNGs of any URL or CSS selector, with viewport / DPR / color-scheme /waitForSelectorcontrols.bundle_budget_check— walk adist/directory, compute gzip (+ optional brotli) sizes, enforce a global or per-entry KB budget. CI-ready pass/fail JSON.design_token_diff— structural diff of two W3C DTCG / Style Dictionary token files. Reports added / removed / changed tokens with$type-aware notes.storybook_story_run— load a single Storybook story in headless Chromium viaiframe.html?id=…, screenshot it, and run an axe audit against just the rendered component.scaffold_react_component— emit a typed React component (functional /forwardRef/ polymorphicas) plus optional Vitest test and Storybook story.
All tools return structured JSON the model can reason over. No bespoke wrappers per editor.
Install
npm i -g @ashios15/mcp-frontend-tools
# Optional — enables page_screenshot, storybook_story_run, and URL-mode axe_audit
npm i -g playwright
npx playwright install chromiumNode ≥ 20 is required. Without Playwright the server still starts; those three tools will return a clear "install playwright" error if called.
Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (or the Windows equivalent):
{
"mcpServers": {
"frontend-tools": {
"command": "mcp-frontend-tools"
}
}
}Cursor
Settings → MCP → Add new server:
{
"frontend-tools": { "command": "mcp-frontend-tools" }
}VS Code (GitHub Copilot agent mode)
Add to .vscode/mcp.json:
{
"servers": {
"frontend-tools": { "command": "mcp-frontend-tools" }
}
}MCP Inspector
npx @modelcontextprotocol/inspector mcp-frontend-toolsTool reference
axe_audit
{
url?: string; // require playwright
html?: string; // jsdom
tags?: string[]; // default: wcag2a/aa + wcag21aa + wcag22aa + best-practice
selector?: string; // URL mode only
timeoutMs?: number; // default 15000
}Returns violations and incomplete rules with impact, help, helpUrl, and up to 5 example failing nodes per rule.
page_screenshot
{
url: string;
outPath: string; // absolute; parent dirs auto-created
selector?: string;
fullPage?: boolean;
width?: number; // default 1280
height?: number; // default 800
deviceScaleFactor?: number;// default 2
colorScheme?: "light" | "dark" | "no-preference";
waitForSelector?: string;
timeoutMs?: number;
}bundle_budget_check
{
buildDir: string;
budgetKb?: number; // default 250 (gzipped)
perEntryBudgetKb?: Record<string, number>;// key = path substring, longest match wins
ext?: string[]; // default [".js",".mjs",".cjs",".css"]
includeBrotli?: boolean;
}Returns every file with raw / gzip / brotli sizes, its applied budget, and status: "pass" | "fail".
design_token_diff
{
beforePath: string;
afterPath: string;
ignoreKeys?: string[];
}Understands the W3C DTCG shape ($value, $type). Group metadata keys starting with $ are ignored. Color / dimension changes get annotated notes.
storybook_story_run
{
storybookUrl: string; // e.g. http://localhost:6006
storyId: string; // e.g. components-button--primary
screenshotPath?: string;
runAxe?: boolean; // default true
viewport?: { width: number; height: number };
colorScheme?: "light" | "dark" | "no-preference";
timeoutMs?: number;
}Loads ${storybookUrl}/iframe.html?viewMode=story&id=${storyId}, waits for #storybook-root, and reports any page errors + axe violations scoped to the story.
scaffold_react_component
{
name: string; // PascalCase
outDir: string; // absolute
variant?: "functional" | "forwardRef" | "polymorphic";
withTests?: boolean; // default true
withStory?: boolean; // default true
props?: Array<{ name: string; type: string; required?: boolean; defaultValue?: string }>;
}Why this over ad-hoc scripts?
Agents get typed contracts. Every tool is a Zod-validated JSON Schema the model can introspect.
No local hallucination. Axe violations come from the real axe-core engine, not a regex. Bundle sizes come from actual
zlibcompression, not estimates.Composable.
bundle_budget_checkfailure → ask the agent to pull the largest file intopage_screenshot→ feed the image into a visual-regression step. All through MCP.Stable surface. Tools change behind a version bump; your
.vscode/mcp.jsondoesn't.
Development
git clone https://github.com/ashios15/mcp-frontend-tools.git
cd mcp-frontend-tools
npm install
npm run test # 3 unit tests (bundle + tokens + scaffold)
npm run build
npm run inspector # opens MCP Inspector against the built server
node scripts/smoke.mjs # quick stdio tools/list checkLicense
MIT © ashios15
mcp-frontend-tools
The reference Model Context Protocol server for frontend work. One install gives any coding agent — Claude Desktop, Cursor, VS Code, Zed, Continue — real eyes and hands on your UI:
axe_audit— run the realaxe-corerule engine against raw HTML (via jsdom) or a live URL (via Playwright). Returns violations grouped by WCAG impact with fix links.page_screenshot— headless-Chromium PNGs of any URL or CSS selector, with viewport / DPR / color-scheme /waitForSelectorcontrols.bundle_budget_check— walk adist/directory, compute gzip (+ optional brotli) sizes, enforce a global or per-entry KB budget. CI-ready pass/fail JSON.design_token_diff— structural diff of two W3C DTCG / Style Dictionary token files. Reports added / removed / changed tokens with$type-aware notes.storybook_story_run— load a single Storybook story in headless Chromium viaiframe.html?id=…, screenshot it, and run an axe audit against just the rendered component.scaffold_react_component— emit a typed React component (functional /forwardRef/ polymorphicas) plus optional Vitest test and Storybook story.
All tools return structured JSON the model can reason over. No bespoke wrappers per editor.
Install
npm i -g @ashishjoshi/mcp-frontend-tools
# Optional — enables page_screenshot, storybook_story_run, and URL-mode axe_audit
npm i -g playwright
npx playwright install chromiumNode ≥ 20 is required. Without Playwright the server still starts; those three tools will return a clear "install playwright" error if called.
Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (or the Windows equivalent):
{
"mcpServers": {
"frontend-tools": {
"command": "mcp-frontend-tools"
}
}
}Cursor
Settings → MCP → Add new server:
{
"frontend-tools": { "command": "mcp-frontend-tools" }
}VS Code (GitHub Copilot agent mode)
Add to .vscode/mcp.json:
{
"servers": {
"frontend-tools": { "command": "mcp-frontend-tools" }
}
}MCP Inspector
npx @modelcontextprotocol/inspector mcp-frontend-toolsTool reference
axe_audit
{
url?: string; // require playwright
html?: string; // jsdom
tags?: string[]; // default: wcag2a/aa + wcag21aa + wcag22aa + best-practice
selector?: string; // URL mode only
timeoutMs?: number; // default 15000
}Returns violations and incomplete rules with impact, help, helpUrl, and up to 5 example failing nodes per rule.
page_screenshot
{
url: string;
outPath: string; // absolute; parent dirs auto-created
selector?: string;
fullPage?: boolean;
width?: number; // default 1280
height?: number; // default 800
deviceScaleFactor?: number;// default 2
colorScheme?: "light" | "dark" | "no-preference";
waitForSelector?: string;
timeoutMs?: number;
}bundle_budget_check
{
buildDir: string;
budgetKb?: number; // default 250 (gzipped)
perEntryBudgetKb?: Record<string, number>;// key = path substring, longest match wins
ext?: string[]; // default [".js",".mjs",".cjs",".css"]
includeBrotli?: boolean;
}Returns every file with raw / gzip / brotli sizes, its applied budget, and status: "pass" | "fail".
design_token_diff
{
beforePath: string;
afterPath: string;
ignoreKeys?: string[];
}Understands the W3C DTCG shape ($value, $type). Group metadata keys starting with $ are ignored. Color / dimension changes get annotated notes.
storybook_story_run
{
storybookUrl: string; // e.g. http://localhost:6006
storyId: string; // e.g. components-button--primary
screenshotPath?: string;
runAxe?: boolean; // default true
viewport?: { width: number; height: number };
colorScheme?: "light" | "dark" | "no-preference";
timeoutMs?: number;
}Loads ${storybookUrl}/iframe.html?viewMode=story&id=${storyId}, waits for #storybook-root, and reports any page errors + axe violations scoped to the story.
scaffold_react_component
{
name: string; // PascalCase
outDir: string; // absolute
variant?: "functional" | "forwardRef" | "polymorphic";
withTests?: boolean; // default true
withStory?: boolean; // default true
props?: Array<{ name: string; type: string; required?: boolean; defaultValue?: string }>;
}Why this over ad-hoc scripts?
Agents get typed contracts. Every tool is a Zod-validated JSON-Schema the model can introspect.
No local hallucination. Axe violations come from the real axe-core engine, not a regex. Bundle sizes come from actual
zlibcompression, not estimates.Composable.
bundle_budget_checkfailure → ask the agent to pull the largest file intopage_screenshot→ feed the image into a visual-regression step. All through MCP.Stable surface. Tools change behind a version bump; your
.vscode/mcp.jsondoesn't.
Development
npm install
npm run test # 3 unit tests (bundle + tokens + scaffold)
npm run build
npm run inspector # opens MCP Inspector against the built server
node scripts/smoke.mjs # quick stdio tools/list checkLicense
MIT © Ashish Joshi
MCP Frontend Tools Server
A Model Context Protocol (MCP) server that gives AI assistants (Claude, Copilot, Cursor) access to frontend development tools — component scaffolding, bundle analysis, accessibility checks, and responsive design guides.
Available Tools
Tool | Description |
| Generate a typed React component with tests, stories, and CSS module |
| Scan a build directory for oversized JS/CSS, report findings |
| Static WCAG 2.2 checks on HTML with fix suggestions |
| Generate responsive CSS, container query, and Tailwind patterns |
Setup
Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"frontend-tools": {
"command": "node",
"args": ["/path/to/mcp-frontend-tools/dist/index.js"]
}
}
}VS Code with Copilot
Add to .vscode/settings.json:
{
"github.copilot.chat.mcpServers": {
"frontend-tools": {
"command": "node",
"args": ["${workspaceFolder}/mcp-frontend-tools/dist/index.js"]
}
}
}Example Usage (in AI Chat)
"Scaffold a UserProfileCard component with avatar, name, and bio props"
The AI calls scaffold_react_component and gets back:
UserProfileCard.tsx— Typed component with forwardRefUserProfileCard.test.tsx— Testing Library testsUserProfileCard.stories.tsx— Storybook storyUserProfileCard.module.css— CSS moduleindex.ts— Barrel export
"Analyze my dist/ folder for bundle size issues"
The AI calls analyze_bundle and returns a markdown report with oversized files, recommendations, and a summary table.
Architecture
src/
├── index.ts # MCP server setup (stdio transport)
└── tools/
├── index.ts # Tool definitions + router
├── scaffold-component.ts # React component generator
├── bundle-analyzer.ts # Build output analyzer
├── a11y-checker.ts # Static WCAG checks
└── responsive-guide.ts # Responsive CSS pattern generatorDevelopment
npm install
npm run build
npm run inspector # Test with MCP InspectorLicense
MIT
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/ashios15/mcp-frontend-tools'
If you have feedback or need assistance with the MCP directory API, please join our Discord server