document-mcp

document-mcp

Enables AI agents to efficiently manage and update component documentation with precise partial updates, saving up to 75% tokens compared to full rewrites.

Category
Visit Server

README

Document MCP Server

A Model Context Protocol (MCP) server designed to efficiently manage component documentation with AI-powered updates and token optimization.

Features

  • šŸš€ Component Scanning: Automatically scan project components folder and generate structured information
  • šŸ” MD5 Hashing: Generate MD5 hashes for files to track changes
  • šŸ“‹ Component Queries: Quickly retrieve specific component details
  • āœļø Precision Updates: Update only description or props sections, saving significant tokens
  • šŸ¤– AI-Friendly: Structured updates prevent AI hallucinations and unnecessary modifications
  • šŸ“Š Token Optimization: Save ~75% tokens compared to traditional full-file regeneration

Installation

NPM Package

# Install globally
npm install -g @tianyi-li/document-mcp

# Install as project dependency
npm install @tianyi-li/document-mcp

Development Setup

# Clone and setup
git clone https://github.com/TianyiLi/document-mcp.git
cd document-mcp
pnpm install
pnpm run build

Quick Start

1. Basic Usage

# Run the MCP server
document-mcp

# Or use npx/pnpx
npx @tianyi-li/document-mcp

2. IDE Integration

Claude Desktop

Add to your claude_desktop_config.json:

{
  "mcpServers": {
    "document-mcp": {
      "command": "npx",
      "args": ["@tianyi-li/document-mcp"]
    }
  }
}

Claude Code

Option 1: Through Claude Desktop (Automatic)

Claude Code automatically detects MCP servers configured in Claude Desktop - no additional setup required.

Option 2: Direct CLI Configuration

Configure directly via Claude Code CLI:

# Using npx (recommended)
claude mcp add document-mcp -- npx @tianyi-li/document-mcp

# Using global installation
claude mcp add document-mcp -- document-mcp

# List configured servers
claude mcp list

# Remove if needed
claude mcp remove document-mcp
Project Documentation (CLAUDE.md)

Add to your project's CLAUDE.md for team reference:

# Document MCP Server

This project uses Document MCP Server for efficient component documentation management.

## Setup
```bash
# Quick setup
npm install -g @tianyi-li/document-mcp
claude mcp add document-mcp -- document-mcp

Available Tools

  • init_components - Scan all project components
  • get_component_info - Get specific component details
  • update_component_description - Update description only (saves ~75% tokens)
  • update_component_props - Update props only (saves ~75% tokens)
  • update_component_content - Batch update multiple sections
  • compare_md5 - Verify file changes

Workflow

  1. init_components → Understand project structure
  2. update_component_* → Make targeted updates
  3. compare_md5 → Verify changes

## API Reference

### Reading Tools

#### `init_components`
Scan components folder and generate structured JSON data.

**Parameters:**
- `projectRoot` (optional): Project root path, defaults to current directory

**Returns:**
```json
[
  {
    "name": "Button",
    "path": "components/Button", 
    "description": "A reusable button component",
    "props": "Props information",
    "md5": "a1b2c3d4e5f6..."
  }
]

get_component_info

Get detailed information for a specific component.

Parameters:

  • componentName (required): Component name
  • projectRoot (optional): Project root path

Returns: Single component JSON object

Update Tools ⭐ Core Value

update_component_description

Precisely update component description section - best choice for token saving.

Parameters:

  • componentName (required): Component name
  • description (required): New component description
  • projectRoot (optional): Project root path

Usage: AI agents can update only the description section without regenerating entire files

update_component_props

Precisely update component Props section with Markdown table support.

Parameters:

  • componentName (required): Component name
  • props (required): New Props content (supports Markdown format)
  • projectRoot (optional): Project root path

Example Props Format:

| Property | Type | Required | Default | Description |
|----------|------|----------|---------|-------------|
| variant | "primary" \| "secondary" | No | "primary" | Button style |
| size | "small" \| "medium" \| "large" | No | "medium" | Button size |
| disabled | boolean | No | false | Whether disabled |

update_component_content

Batch update component description and/or Props with partial update support.

Parameters:

  • componentName (required): Component name
  • description (optional): New component description
  • props (optional): New Props content
  • projectRoot (optional): Project root path

Usage: Can update multiple sections simultaneously or individually

Validation Tools

calculate_md5

Calculate MD5 hash for specified file.

Parameters:

  • filePath (required): File path for MD5 calculation

Returns: MD5 hash string

compare_md5

Compare current file MD5 with expected value.

Parameters:

  • filePath (required): File path to check
  • expectedMd5 (required): Expected MD5 hash value

Returns:

{
  "currentMd5": "current file MD5",
  "expectedMd5": "expected MD5", 
  "isMatch": true/false,
  "hasChanged": true/false
}

Use Cases

Reading Phase

  1. Automated Documentation Management: AI agents quickly understand project component structure
  2. Component Information Queries: Avoid scanning entire project structure, saving tokens
  3. File Change Tracking: Ensure document content consistency through MD5 comparison

Update Phase ⭐ Core Value

  1. Precision Document Updates: Update only necessary parts (description or Props), dramatically saving tokens
  2. Prevent AI Hallucinations: Structured updates avoid AI adding/removing unnecessary items
  3. Incremental Maintenance: Modify based on existing content rather than complete rewrites
  4. Consistency Guarantee: Use standard templates and formats for unified document style

Workflow Example

1. init_components          → Understand all components
2. get_component_info       → Get specific component current state
3. update_component_description → Update only description section
4. compare_md5              → Verify update success

Token Savings

  • Traditional Method: AI reads full file + regenerates complete file = ~2000 tokens
  • Using This Tool: Get existing info + precise partial updates = ~500 tokens
  • Savings Rate: ~75% token reduction

Project Structure

This tool assumes your project has the following structure:

project-root/
ā”œā”€ā”€ components/
│   ā”œā”€ā”€ Button/
│   │   └── README.md
│   ā”œā”€ā”€ Input/
│   │   └── README.md
│   └── ...
└── ...

Each component folder should contain a README.md file with component description and props information.

Configuration Examples

Using pnpx/npx (Recommended)

{
  "mcpServers": {
    "document-mcp": {
      "command": "pnpx",
      "args": ["@tianyi-li/document-mcp"],
      "cwd": "/path/to/your/project"
    }
  }
}

Direct Binary Execution

{
  "mcpServers": {
    "document-mcp": {
      "command": "/path/to/node_modules/.bin/document-mcp"
    }
  }
}

Global Installation

# Install globally
npm install -g @tianyi-li/document-mcp

# Use in Claude Desktop config
{
  "mcpServers": {
    "document-mcp": {
      "command": "document-mcp"
    }
  }
}

Development

Build from Source

git clone https://github.com/TianyiLi/document-mcp.git
cd document-mcp
pnpm install
pnpm run build

Available Scripts

pnpm run build    # Compile TypeScript
pnpm run dev      # Watch mode compilation
pnpm start        # Run the server

Best Practices

  1. First Use: Run init_components to scan project components
  2. Change Tracking: Use compare_md5 to check for file modifications
  3. Specific Queries: Use get_component_info for individual component details
  4. Regular Sync: Periodically run init_components to keep data current
  5. Token Optimization: Use precise update tools instead of full rewrites

Requirements

  • Node.js >= 18.0.0
  • Components organized in /components folder structure
  • Each component should have a README.md file

License

ISC License

Contributing

Issues and pull requests are welcome on GitHub.

Repository

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