From f5ffb5ce487e825969262fa84a59e41b1f6cdc92 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Fri, 12 Sep 2025 13:20:31 +0000 Subject: [PATCH] Version Packages --- .../config-override-and-improvements.md | 12 -- mcp-pointer-chrome-extension.zip | Bin 0 -> 35117 bytes packages/chrome-extension/CHANGELOG.md | 12 ++ packages/chrome-extension/package.json | 2 +- packages/server/CHANGELOG.md | 12 ++ packages/server/README.md | 156 ++++++++++++++++++ packages/server/package.json | 2 +- 7 files changed, 182 insertions(+), 14 deletions(-) delete mode 100644 .changeset/config-override-and-improvements.md create mode 100644 mcp-pointer-chrome-extension.zip create mode 100644 packages/server/README.md diff --git a/.changeset/config-override-and-improvements.md b/.changeset/config-override-and-improvements.md deleted file mode 100644 index 3569714..0000000 --- a/.changeset/config-override-and-improvements.md +++ /dev/null @@ -1,12 +0,0 @@ ---- -"@mcp-pointer/server": patch -"@mcp-pointer/chrome-extension": patch ---- - -Fix config override and improve UI - -- Fix MCP server configuration to override existing configurations by removing before adding -- Add comprehensive tests for config override scenarios -- Update border color to use CSS custom property for better theming -- Fix GitHub Actions badge URLs in README -- Add README copying to npm package in release workflow \ No newline at end of file diff --git a/mcp-pointer-chrome-extension.zip b/mcp-pointer-chrome-extension.zip new file mode 100644 index 0000000000000000000000000000000000000000..708295e7279cce01fd54430fe0a837cba66b13d1 GIT binary patch literal 35117 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 literal 0 HcmV?d00001 diff --git a/packages/chrome-extension/CHANGELOG.md b/packages/chrome-extension/CHANGELOG.md index 228644f..2670503 100644 --- a/packages/chrome-extension/CHANGELOG.md +++ b/packages/chrome-extension/CHANGELOG.md @@ -1,5 +1,17 @@ # @mcp-pointer/chrome-extension +## 0.4.1 + +### Patch Changes + +- e232269: Fix config override and improve UI + + - Fix MCP server configuration to override existing configurations by removing before adding + - Add comprehensive tests for config override scenarios + - Update border color to use CSS custom property for better theming + - Fix GitHub Actions badge URLs in README + - Add README copying to npm package in release workflow + ## 0.4.0 ### Minor Changes diff --git a/packages/chrome-extension/package.json b/packages/chrome-extension/package.json index 7b27c10..9653d35 100644 --- a/packages/chrome-extension/package.json +++ b/packages/chrome-extension/package.json @@ -1,6 +1,6 @@ { "name": "@mcp-pointer/chrome-extension", - "version": "0.4.0", + "version": "0.4.1", "repository": { "type": "git", "url": "https://github.com/etsd-tech/mcp-pointer.git", diff --git a/packages/server/CHANGELOG.md b/packages/server/CHANGELOG.md index c0e1e7a..b403ff4 100644 --- a/packages/server/CHANGELOG.md +++ b/packages/server/CHANGELOG.md @@ -1,5 +1,17 @@ # @mcp-pointer/server +## 0.4.1 + +### Patch Changes + +- e232269: Fix config override and improve UI + + - Fix MCP server configuration to override existing configurations by removing before adding + - Add comprehensive tests for config override scenarios + - Update border color to use CSS custom property for better theming + - Fix GitHub Actions badge URLs in README + - Add README copying to npm package in release workflow + ## 0.4.0 ### Minor Changes diff --git a/packages/server/README.md b/packages/server/README.md new file mode 100644 index 0000000..890469e --- /dev/null +++ b/packages/server/README.md @@ -0,0 +1,156 @@ +![MCP Pointer banner](/docs/banner.png) + +[![CI](https://github.com/etsd-tech/mcp-pointer/actions/workflows/ci.yml/badge.svg?branch=main)](https://github.com/etsd-tech/mcp-pointer/actions/workflows/ci.yml) +[![Release](https://github.com/etsd-tech/mcp-pointer/actions/workflows/release.yml/badge.svg?branch=main)](https://github.com/etsd-tech/mcp-pointer/actions/workflows/release.yml) + +# 👆 MCP Pointer + +**Point to browser DOM elements for agentic coding tools via MCP!** + +MCP Pointer is a *local* tool combining an MCP Server with a Chrome Extension: + +1. **🖥️ MCP Server** (Node.js package) - Bridges between the browser and AI tools via the Model Context Protocol +2. **🌐 Chrome Extension** - Captures DOM element selections in the browser using Option+Click + +The extension lets you visually select DOM elements in the browser, and the MCP server makes this **textual context** available to agentic coding tools like Claude Code, Cursor, and Windsurf through standardized MCP tools. + +## ✨ Features + +- 🎯 **Option+Click Selection** - Simply hold Option (Alt on Windows) and click any element +- 📋 **Complete Element Data** - Text content, CSS classes, HTML attributes, positioning, and styling +- ⚛️ **React Component Detection** - Component names and source files via Fiber (experimental) +- 🔗 **WebSocket Connection** - Real-time communication between browser and AI tools +- 🤖 **MCP Compatible** - Works with Claude Code and other MCP-enabled AI tools + +## 🎬 Usage example (video) + +https://github.com/user-attachments/assets/98c4adf6-1f05-4c9b-be41-0416ab784e2c + +See MCP Pointer in action: Option+Click any element in your browser, then ask your agentic coding tool about it (in this example, Claude Code). The AI gets complete textual context about the selected DOM element including CSS properties, url, selector, and more. + +## 🚀 Getting Started + +> **Note:** Chrome extension is not yet published on Chrome Web Store. You'll need to build and install it manually for now. + +### 1. Configure the MCP Server + +Use npx to automatically configure the MCP server with your AI tool: + +```bash +# Configure MCP Pointer for your AI tool +npx -y @mcp-pointer/server config claude # Automatically configures Claude Code +npx -y @mcp-pointer/server config cursor # Opens Cursor deeplink for automatic installation +npx -y @mcp-pointer/server config windsurf # Automatically updates Windsurf config file +npx -y @mcp-pointer/server config manual # Shows manual configuration for other tools +``` + +> **Optional:** You can install globally with `npm install -g @mcp-pointer/server` to use `mcp-pointer` instead of `npx -y @mcp-pointer/server` + +### 2. Install Chrome Extension + +**Option A: Download from Releases (Recommended)** + +1. Go to [GitHub Releases](https://github.com/etsd-tech/mcp-pointer/releases) +2. Download `mcp-pointer-chrome-extension.zip` from the latest release +3. Extract the zip file to a folder on your computer +4. Open Chrome → Settings → Extensions → Developer mode (toggle ON) +5. Click "Load unpacked" and select the extracted folder +6. The MCP Pointer extension should appear in your extensions list + +**Option B: Build from Source** + +1. Clone this repository +2. Follow the build instructions in [CONTRIBUTING.md](./CONTRIBUTING.md) +3. Open Chrome → Settings → Extensions → Developer mode (toggle ON) +4. Click "Load unpacked" and select the `packages/chrome-extension/dist/` folder + +### 3. Start Using + +1. **Navigate to any webpage** +2. **Option+Click** any element to select it +3. **Ask your AI** to analyze the targeted element! + +Your AI tool will automatically start the MCP server when needed using the `npx -y @mcp-pointer/server start` command. + +**Available AI Tools:** +- `getTargetedElement` - Get comprehensive info about the selected element +- `clearTargetedElement` - Clear the current selection +- `getPointerStatus` - Check system status and statistics + +## 🎯 How It Works + +1. **Element Selection**: Content script captures Option+Click events +2. **Data Extraction**: Analyzes element structure, CSS, and framework info +3. **WebSocket Transport**: Sends data to MCP server on port 7007 +4. **MCP Protocol**: Makes data available to AI tools via MCP tools +5. **AI Analysis**: Your assistant can now see and analyze the element! + +## 🎨 Element Data Extracted + +- **Basic Info**: Tag name, ID, classes, text content +- **CSS Properties**: Display, position, colors, dimensions +- **Component Info**: React component names and source files (experimental) +- **Attributes**: All HTML attributes +- **Position**: Exact coordinates and dimensions +- **Source Hints**: File paths and component origins + +## 🔍 Framework Support + +- ⚛️ **React** - Component names and source files via Fiber (experimental) +- 📦 **Generic HTML/CSS/JS** - Full support for any web content +- 🔮 **Planned** - Vue component detection (PRs appreciated) + +## 🌐 Browser Support + +- ✅ **Chrome** - Full support (tested) +- 🟡 **Chromium-based browsers** - Should work (Edge, Brave, Arc - load built extension manually) + +## 🐛 Troubleshooting + +### Extension Not Connecting + +1. Make sure MCP server is running: `npx -y @mcp-pointer/server start` +2. Check browser console for WebSocket errors +3. Verify port 7007 is not blocked by firewall + +### MCP Tools Not Available + +1. Restart your AI assistant after installing +2. Check MCP configuration: `mcp-pointer config ` +3. Verify server is running: `npx -y @mcp-pointer/server start` + +### Elements Not Highlighting + +1. Some pages block content scripts (chrome://, etc.) +2. Try refreshing the page +3. Check if targeting is enabled (click extension icon) + +## 🚀 Roadmap + +### 1. **Dynamic Context Control** + - LLM-configurable detail levels (visible text only, all text, CSS levels) + - Progressive refinement options + - Token-conscious data fetching + +### 2. **Enhanced Framework Support** + - Vue.js component detection + - Better React support (React 19 removed `_debugSource`, affecting source mapping in dev builds) + +### 3. **Visual Content Support** (for multimodal LLMs) + - Base64 encoding for images (img tags) + - Screenshot capture of selected elements + - Separate MCP tool for direct visual content retrieval + +## 📝 License + +MIT License - see LICENSE file for details + +## 🤝 Contributing + +We welcome contributions! Please see our [CONTRIBUTING.md](./CONTRIBUTING.md) guide for development setup and guidelines. + +--- + +**Made with ❤️ for AI-powered web development** + +*Now your AI can analyze any element you point at! 👆* diff --git a/packages/server/package.json b/packages/server/package.json index 420ce1a..e2e8c5e 100644 --- a/packages/server/package.json +++ b/packages/server/package.json @@ -1,6 +1,6 @@ { "name": "@mcp-pointer/server", - "version": "0.4.0", + "version": "0.4.1", "description": "MCP Server for DOM element pointing - WebSocket bridge for element targeting", "repository": { "type": "git",