Skip to main content
Glama
wzh4464

software-design-mermaid-mcp

by wzh4464

๐ŸŽจ Mermaid Visual Editor for Claude

Stop describing diagrams. Start designing them.

Turn Claude into a visual software design partner with a drag-and-drop Mermaid editor that opens right in your browser.

Tests License: MIT MCP TypeScript Node

Getting Started ยท Features ยท How It Works ยท Contributing


Visual diagram editor showing a microservice architecture with drag-and-drop nodes, subgraphs, edge labels, and live Mermaid preview

Claude generates the diagram, you refine it visually โ€” drag nodes, edit labels, draw connections, then submit back for the next iteration


The Problem

When designing software with Claude, you're stuck in a text-only loop:

You: "Add a cache layer between the API and database"
Claude: *regenerates entire Mermaid diagram from scratch*
You: "No, move the cache node to the left..."
Claude: *guesses what you mean, regenerates again*

It's like directing a painter blindfolded.

The Solution

This MCP server gives Claude a visual canvas. When Claude generates a diagram, it pops open a browser-based editor where you can:

  • Drag nodes exactly where you want them

  • Edit labels inline with a double-click

  • Draw connections between any nodes

  • Rearrange everything and submit back to Claude

Claude sees your visual changes and continues the conversation with full context. Design together, visually.

What is MCP? Model Context Protocol lets AI assistants use external tools. This server gives Claude the ability to open a visual diagram editor โ€” no plugins or extensions needed.


โšก Getting Started

git clone https://github.com/wzh4464/software-design-mermaid-mcp.git
cd software-design-mermaid-mcp
npm install && npm run build
claude mcp add software-design-mermaid node $(pwd)/dist/server/index.js

Then just ask Claude:

> Design a microservice architecture for a todo app

Your browser opens automatically with the visual editor. Edit, submit, iterate. โœจ

Add to your VS Code settings.json:

{
  "claude.mcpServers": {
    "software-design-mermaid": {
      "command": "node",
      "args": ["/absolute/path/to/software-design-mermaid-mcp/dist/server/index.js"]
    }
  }
}

Add to claude_desktop_config.json:

{
  "mcpServers": {
    "software-design-mermaid": {
      "command": "node",
      "args": ["/absolute/path/to/software-design-mermaid-mcp/dist/server/index.js"]
    }
  }
}

Add to your Cursor MCP settings (.cursor/mcp.json):

{
  "mcpServers": {
    "software-design-mermaid": {
      "command": "node",
      "args": ["/absolute/path/to/software-design-mermaid-mcp/dist/server/index.js"]
    }
  }
}

Any MCP-compatible client can use this server. The configuration pattern is the same:

  • Command: node

  • Args: ["/absolute/path/to/software-design-mermaid-mcp/dist/server/index.js"]

  • Transport: stdio

Refer to your client's documentation for the exact config file location.


โœจ Features

Feature

Description

๐Ÿ–ฑ๏ธ

Drag-and-Drop Canvas

Full React Flow editor with zoom, pan, minimap, grid snapping

๐Ÿ”ท

5 Shapes ร— 3 Edge Types

Rectangle, rounded, diamond, circle, stadium + arrow, dotted, thick

๐Ÿ“ฆ

Subgraphs & Auto-Layout

Group nodes into nested subgraphs; dagre auto-arranges (TD/LR/BT/RL)

๐Ÿ“

Live Mermaid Preview

See Mermaid code update in real-time as you edit

๐Ÿ”„

Multi-Round Iteration

Edit โ†’ Submit โ†’ Claude refines โ†’ Edit again. True visual collaboration.

โช

Undo / Redo

Full history with Ctrl+Z / Ctrl+Y

โš™๏ธ

Zero Config

Auto-finds an open port and launches your browser

Horizontal LR layout showing load balancer, backend cluster, and storage subgraphs


๐Ÿงฉ How It Works

  Claude                    MCP Server                 Browser Editor
    โ”‚                          โ”‚                            โ”‚
    โ”‚โ”€โ”€ show_diagram() โ”€โ”€โ”€โ”€โ”€โ”€โ”€>โ”‚                            โ”‚
    โ”‚                          โ”‚โ”€โ”€ starts HTTP server โ”€โ”€โ”€โ”€โ”€>โ”‚
    โ”‚                          โ”‚โ”€โ”€ opens browser โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€>โ”‚
    โ”‚<โ”€โ”€ { url, success } โ”€โ”€โ”€โ”€โ”€โ”‚                            โ”‚
    โ”‚                          โ”‚                            โ”‚
    โ”‚                          โ”‚<โ”€โ”€ polls /api/diagram โ”€โ”€โ”€โ”€โ”€โ”‚
    โ”‚                          โ”‚โ”€โ”€ returns diagram โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€>โ”‚
    โ”‚                          โ”‚                            โ”‚
    โ”‚                          โ”‚          user drags nodes, โ”‚
    โ”‚                          โ”‚          edits labels,     โ”‚
    โ”‚                          โ”‚          draws connections โ”‚
    โ”‚                          โ”‚                            โ”‚
    โ”‚                          โ”‚<โ”€โ”€ POST /api/submission โ”€โ”€โ”€โ”‚
    โ”‚โ”€โ”€ get_diagram_feedback()>โ”‚                            โ”‚
    โ”‚<โ”€โ”€ updated mermaid code โ”€โ”‚                            โ”‚
    โ”‚                          โ”‚                            โ”‚
    โ”‚โ”€โ”€ show_diagram() โ”€โ”€โ”€โ”€โ”€โ”€โ”€>โ”‚  (Claude sends new version)โ”‚
    โ”‚   ...iterate...          โ”‚                            โ”‚

MCP Tools

Tool

What it does

show_diagram

Opens the visual editor with a Mermaid flowchart

get_diagram_feedback

Gets the user's visual edits back as Mermaid code

close_diagram

Closes the editor session


๐Ÿ—๏ธ Architecture

TypeScript monorepo with npm workspaces:

software-design-mermaid-mcp/
โ”œโ”€โ”€ shared/          # Mermaid parser & serializer (bidirectional)
โ”œโ”€โ”€ src/             # MCP server (stdio) + HTTP server (REST API)
โ”œโ”€โ”€ editor/          # React Flow visual editor
โ””โ”€โ”€ dist/            # Pre-built artifacts
  • Parser: Full Mermaid flowchart syntax โ†’ structured FlowDiagram objects

  • Serializer: FlowDiagram โ†’ valid Mermaid code (round-trip safe)

  • Editor: React 19 + React Flow 12 with custom node/edge renderers


๐Ÿง‘โ€๐Ÿ’ป Development

npm install          # Install all workspace dependencies
npm test             # Run all tests (42 tests, 4 suites)
npm run build        # Build shared โ†’ server โ†’ editor
npm run dev:editor   # Editor dev mode with hot reload

๐Ÿค Contributing

Contributions welcome! Some ideas to get started:

  • ๐Ÿ“Š Sequence diagram support โ€” extend beyond flowcharts

  • ๐ŸŽจ Theme customization โ€” dark/light modes, color schemes

  • ๐Ÿ“ธ Export options โ€” PNG, SVG, PDF export from the editor

  • ๐Ÿ‘ฅ Collaborative editing โ€” multiple users on the same diagram

  • ๐Ÿ”ถ More node shapes โ€” hexagon, parallelogram, trapezoid

Please open an issue first to discuss what you'd like to change.


๐Ÿ“„ License

MIT โ€” use it however you want.


If this saves you time designing software, consider giving it a โญ

Made with React Flow ยท MCP SDK ยท dagre

A
license - permissive license
-
quality - not tested
B
maintenance

Maintenance

โ€“Maintainers
โ€“Response time
โ€“Release cycle
1Releases (12mo)

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/wzh4464/software-design-mermaid-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server