An MCP (Model Context Protocol) server that analyzes website UIs and provides precise fix instructions for AI coding assistants. Designed to solve the problem of "messy UI updates" when using agentic code IDEs like GitHub Copilot or Cursor.
- Live UI Analysis - Renders and inspects actual websites using Playwright
- Smart Query Interpretation - Understands vague complaints like "navbar is broken"
- Precise Fix Instructions - Generates specific CSS selectors and property changes
- Technology Detection - Identifies React, Vue, Angular, Next.js, Tailwind, Bootstrap, and more
- Responsive Testing - Compare UIs across mobile, tablet, and desktop viewports
- Accessibility Analysis - Extracts accessibility tree for semantic understanding
When using AI coding assistants to build or update website UIs, the results can sometimes be messy:
- Layout breaks unexpectedly
- Elements overlap or misalign
- Spacing becomes inconsistent
- Responsive design breaks
Users often struggle to describe exactly what's wrong, saying things like "the navbar is broken" or "the hero section looks weird" - vague descriptions that don't help the AI understand what specific CSS or HTML changes are needed.
This MCP server bridges that gap by:
- Analyzing the live website - Using Playwright to render and inspect the actual UI
- Detecting technology stack - Identifying frameworks (React, Next.js, Vue) and CSS libraries (Tailwind, Bootstrap)
- Identifying UI elements - Finding navbars, headers, footers, heroes, buttons, forms, etc.
- Detecting issues - Spotting layout problems, overflow, z-index conflicts, accessibility issues
- Interpreting vague queries - Understanding what "the header is messed up" actually means
- Generating framework-aware fix instructions - Providing specific CSS selectors, property changes, and code snippets tailored to the detected tech stack
- Python 3.13 or higher
- uv package manager
# Clone the repository
git clone https://github.com/0x-Professor/UIAnalyzerMCP.git
cd UIAnalyzerMCP
# Install dependencies
uv sync
# Install Playwright browsers
uv run playwright install chromium# Run directly
uv run python server.py
# Or use the MCP CLI
uv run mcp run server.py
# For development with inspector
uv run mcp dev server.pyAdd to your VS Code settings.json or MCP configuration:
{
"mcpServers": {
"ui-analyzer": {
"command": "uv",
"args": ["run", "python", "server.py"],
"cwd": "/path/to/UIAnalyzerMCP"
}
}
}Add to your Cursor MCP settings (~/.cursor/mcp.json or project .cursor/mcp.json):
{
"mcpServers": {
"ui-analyzer": {
"command": "uv",
"args": ["run", "python", "server.py"],
"cwd": "/path/to/UIAnalyzerMCP"
}
}
}Add to your Claude Desktop config file:
Windows: %APPDATA%\Claude\claude_desktop_config.json
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
{
"mcpServers": {
"ui-analyzer": {
"command": "uv",
"args": ["run", "python", "server.py"],
"cwd": "C:\\path\\to\\UIAnalyzerMCP"
}
}
}| Tool | Description |
|---|---|
analyze_page |
Full UI analysis with elements, issues, and screenshot |
get_fix_instructions |
Generate precise fix instructions from vague complaints |
get_screenshot |
Capture screenshots with optional element highlighting |
get_element_details |
Get detailed info about specific element types |
get_accessibility_snapshot |
Extract accessibility tree in YAML format |
get_dom_overview |
Get simplified DOM structure overview |
compare_viewports |
Compare UI at mobile, tablet, and desktop sizes |
get_tech_stack |
Detect frameworks, libraries, and CSS approach |
Full UI analysis of a webpage. Returns elements, issues, accessibility tree, DOM structure, and screenshot.
analyze_page(url="http://localhost:3000", query="the navbar is broken")
The main tool for fixing messy UIs. Interprets vague user complaints and generates precise fix instructions.
get_fix_instructions(
url="http://localhost:3000",
user_complaint="the hero section looks weird and buttons are not aligned"
)
Returns:
- Interpreted problem description
- Affected elements with CSS selectors
- Ordered fix instructions with property changes
- Complete CSS changes to apply
- Additional recommendations
Capture a screenshot with optional element highlighting.
get_screenshot(url="http://localhost:3000", element_type="navbar")
get_screenshot(url="http://localhost:3000", highlight_selector=".hero-section")
Get detailed information about specific UI element types.
get_element_details(url="http://localhost:3000", element_type="button")
Get the accessibility tree in YAML format for understanding semantic structure.
get_accessibility_snapshot(url="http://localhost:3000")
Get a simplified DOM structure overview.
get_dom_overview(url="http://localhost:3000", max_depth=5)
Compare the UI at different screen sizes to identify responsive issues.
compare_viewports(url="http://localhost:3000")
Detect the technology stack (frameworks, libraries, CSS approach) used on a webpage. Returns framework-specific fix guidance.
get_tech_stack(url="http://localhost:3000")
Returns:
- Primary framework (React, Vue, Angular, Svelte, etc.)
- Meta framework (Next.js, Nuxt, Remix, Gatsby, Astro)
- CSS approach (Tailwind, Bootstrap, CSS Modules, styled-components)
- UI libraries (shadcn/ui, Material UI, Chakra UI, Ant Design)
- Framework-specific fix recommendations
- React, Vue, Angular, Svelte, Solid, Preact
- jQuery, Alpine.js, HTMX
- Next.js, Nuxt, Remix, Gatsby, Astro, SvelteKit, Vite
- Tailwind CSS, Bootstrap, Bulma, Foundation
- shadcn/ui, Material UI, Chakra UI, Ant Design, Radix UI
- CSS Modules, styled-components, Emotion
- Inline styles, CSS variables, Sass/SCSS
-
User runs their dev server:
npm run dev -
User tells the AI: "The navbar is messed up and the hero section has weird spacing"
-
AI uses
get_fix_instructions:
get_fix_instructions(
url="http://localhost:3000",
user_complaint="The navbar is messed up and the hero section has weird spacing"
)
- Server returns precise instructions:
Interpreted Problem: User is reporting alignment, spacing issues with the navbar, hero
Affected Elements:
- nav.navbar (selector: nav.navbar)
- section.hero (selector: .hero-section)
Fix Instructions:
1. Fix spacing on navbar
Selector: nav.navbar
CSS Changes:
- padding: 1rem 2rem
- gap: 1rem
- align-items: center
2. Fix spacing on hero
Selector: .hero-section
CSS Changes:
- padding: 4rem 2rem
- margin: 0 auto
- max-width: 1200px
- AI applies the exact CSS changes to the codebase
The analyzer can identify and analyze:
- navbar - Navigation bars, menus
- header - Page headers, banners
- footer - Page footers
- hero - Hero sections, splash areas
- button - Buttons, CTAs
- link - Anchor links
- heading - H1-H6 headings
- form - Forms and form containers
- input - Input fields, textareas, selects
- card - Card components, panels
- sidebar - Side navigation, asides
- modal - Dialogs, popups
- dropdown - Dropdown menus, selects
- image - Images, SVGs
- section - Content sections
- container - Main containers, wrappers
- layout_broken
- overflow_hidden
- z_index_conflict
- spacing_inconsistent
- alignment_off
- responsive_issue
- accessibility_missing
- contrast_low
- element_overlap
- invisible_element
- empty_container
- broken_flexbox
- broken_grid
# Run with MCP inspector for debugging
uv run mcp dev server.py
# Run the test suite
uv run python test_mcp_server.pyTest Coverage:
- Query interpretation (vague user queries to element types)
- Page loading across multiple test sites
- Screenshot capture (full page, viewport, highlighted elements)
- Accessibility tree extraction
- DOM structure extraction
- Element identification by type
- Issue detection
- Full page analysis
- Fix instruction generation
- Viewport comparison (mobile, tablet, desktop)
- Technology stack detection
Test artifacts are saved to test_output/ directory:
- Screenshots at different viewports
- Accessibility tree YAML
- DOM structure text
- Detected elements JSON
- Analysis results JSON
- Tech stack detection results
MIT License - see LICENSE file for details.
Contributions are welcome! Please open an issue or submit a pull request.
- Built with MCP Python SDK
- Uses Playwright for browser automation
- Designed to work with GitHub Copilot, Cursor, and Claude