element-inspector

element-inspector

Enables interactive element inspection on any website, allowing users to click elements and send detailed information (tag, classes, styles, attributes) to Claude for analysis.

Category
Visit Server

README

Web Element Inspector MCP Server

A general-purpose MCP server that provides an interactive element inspector for ANY website. Perfect for analyzing web pages, debugging UI issues, examining competitors' designs, or understanding how any website is built. Click on elements and instantly send detailed information about them to Claude.

Features

  • šŸ” Interactive Element Inspection: Click on any element on any website
  • 🌐 Universal Support: Works with local dev servers, production sites, and external websites
  • šŸ“Š Detailed Element Data: Captures tag name, ID, classes, attributes, styles, position, and text content
  • šŸ’¬ Direct Claude Integration: Send element information directly to Claude via app.sendMessage()
  • šŸŽÆ Real-time Feedback: Visual highlighting and instant status updates
  • šŸ“ Inspection History: Keep track of all inspected elements during a session
  • šŸ”„ Batch Operations: Send individual elements or entire history to Claude
  • šŸ›”ļø Smart Attribute Detection: Highlights important attributes like href, src, aria-label, etc.

How It Works

  1. Launch the Inspector: Call the inspect-web-elements tool with any website URL
  2. Enable Inspection: Click the "Enable Element Inspection" button
  3. Click Elements: Click on any element in the loaded page
  4. Send to Claude: Use "Send to Claude" to instantly share element data

Installation

1. Install Dependencies

cd ~/ai-agent/element-inspector-mcp
npm install

2. Build the Project

npm run build

3. Configure Claude Desktop

Add this to your Claude Desktop config file:

macOS: ~/Library/Application Support/Claude/claude_desktop_config.json Windows: %APPDATA%\Claude\claude_desktop_config.json

{
  "mcpServers": {
    "element-inspector": {
      "command": "node",
      "args": [
        "/data/data/com.termux/files/home/ai-agent/element-inspector-mcp/dist/index.js",
        "--stdio"
      ]
    }
  }
}

Usage

Basic Usage

  1. Start your development server (e.g., npm run dev on port 3000) or navigate to any website
  2. In Claude Desktop, ask: "Launch the element inspector for https://example.com"
  3. The inspector UI will appear in the chat
  4. Click "Enable Element Inspection"
  5. Click on any element in the loaded page
  6. Click "Send to Claude" to share the element information

Example Prompts

  • "Launch the element inspector for my dev server at http://localhost:3000"
  • "Inspect the navigation bar on https://github.com"
  • "Analyze the header structure of https://example.com"
  • "Click on the main CTA button on https://www.producthunt.com and tell me about its styling"
  • "Examine the pricing table on https://stripe.com and send the details to me"

Advanced Usage

The inspector captures comprehensive element data:

{
  "tagName": "button",
  "id": "submit-btn",
  "classes": ["btn", "btn-primary"],
  "text": "Submit",
  "attributes": {
    "type": "submit",
    "disabled": "false"
  },
  "styles": {
    "display": "inline-block",
    "padding": "10px 20px",
    "backgroundColor": "rgb(33, 150, 243)"
  },
  "position": {
    "x": 100,
    "y": 200,
    "width": 150,
    "height": 40
  }
}

Development

Project Structure

element-inspector-mcp/
ā”œā”€ā”€ src/
│   ā”œā”€ā”€ mcp-app.ts      # Client-side application
│   ā”œā”€ā”€ index.html       # HTML template
│   └── styles.css       # Application styles
ā”œā”€ā”€ server.ts            # MCP server with tool registration
ā”œā”€ā”€ index.ts             # Entry point
ā”œā”€ā”€ vite.config.ts       # Vite configuration
└── package.json

Building

npm run build

Running Locally (for testing)

npm run build
node dist/index.js --stdio

Technical Details

  • Uses MCP Apps SDK for interactive UI
  • Built with TypeScript and Vite
  • Single-file bundle for easy distribution
  • Safe iframe sandboxing
  • CORS-aware element inspection

Use Cases

  • Development: Debug UI issues in your local development environment
  • Competitor Analysis: Examine how competitors structure their websites
  • Learning: Study the HTML/CSS of well-designed websites
  • Accessibility Testing: Check ARIA labels and semantic structure
  • SEO Analysis: Examine meta tags, headings, and semantic HTML
  • Design Inspiration: Capture styling details from impressive websites
  • Content Strategy: Analyze how successful sites structure their content

Limitations

  • CORS Restrictions: Some websites may block iframe embedding (X-Frame-Options)
  • Same-Origin Policy: Cross-origin access may be limited on some sites
  • Dynamic Content: Very dynamic content (SPAs) may require re-enabling inspection
  • Authentication: Logged-in pages may not work in iframes
  • Complex CSP Sites: Sites with strict Content Security Policies may block interaction

Troubleshooting

"Cannot access iframe content" error

This occurs when websites block iframe embedding. Solutions:

  1. For local development: Add CORS headers to your dev server
  2. For external sites: The site may have X-Frame-Options or CSP restrictions
  3. Workaround: Try using a CORS proxy or browser extension
  4. Alternative: Use browser DevTools with MCP for problematic sites

Elements not highlighting

  • Ensure inspection mode is enabled (button should be green and pulsing)
  • Check that the page has fully loaded
  • For SPAs, try toggling inspection mode off and on
  • Some sites with complex event handling may interfere

"Site may block iframe embedding" warning

This is normal for external websites. Many sites have security policies that prevent iframe embedding. This doesn't affect the inspector's functionality - it's just a warning that some sites may not load in iframes.

Tips for Best Results

  1. Local Development: Always use http://localhost:3000 or similar for best results
  2. Simple Pages: Static sites work better than complex SPAs
  3. Public URLs: Use public URLs rather than authenticated pages
  4. Stable Content: Choose pages with stable content for reliable inspection
  5. Large Elements: Click on larger elements for more accurate selection

Future Enhancements

  • [ ] CSS selector generation and copying
  • [ ] Screenshot capture integration
  • [ ] Network request monitoring
  • [ ] Console log inspection
  • [ ] Multiple element selection
  • [ ] Element tree visualization
  • [ ] Export inspection data as JSON
  • [ ] Integration with browser DevTools protocol

License

MIT

Contributing

Contributions welcome! Feel free to open issues or pull requests.

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