Skip to main content
Glama

mermaid-mcp

An MCP server that renders Mermaid diagram markup to PNG images, using @mermaid-js/mermaid-cli (Puppeteer/Chromium) under the hood.

Give it AI-generated Mermaid — flowcharts, sequence, class, ER, gantt, state diagrams — and get back a rendered image, returned inline so the host can preview it and/or written to a file on disk.

Tool

render_mermaid

Parameter

Type

Required

Description

diagram

string

yes

Mermaid diagram source, e.g. graph TD; A-->B;

outputPath

string

no

Absolute path ending in .png to also save the image to. Omit to only return inline.

theme

enum

no

default | dark | forest | neutral (default default)

backgroundColor

string

no

e.g. white, transparent, #ffffff (default white)

width

number

no

Output width in pixels

height

number

no

Output height in pixels

scale

number

no

Device scale factor; higher = sharper/larger PNG (default 1)

Returns a short text summary plus the PNG as inline MCP image content. When outputPath is supplied, the file is written there and the path is included in the summary.

Related MCP server: Mermaid SVG MCP Server

Install & build

npm install
npx puppeteer browsers install chrome   # download the headless Chromium used for rendering
npm run build

Rendering runs a headless Chromium via Puppeteer. If npm install doesn't fetch it automatically, run npx puppeteer browsers install chrome (as above). It lands in Puppeteer's cache (~/.cache/puppeteer / %USERPROFILE%\.cache\puppeteer). On Windows, if extraction stalls, delete the partial chrome/win64-* folder and re-run the install.

Test

npm test

Integration tests using Node's built-in test runner (node:test). They exercise the renderer (input validation, inline render, render-to-file) and a full MCP stdio round-trip (spawn the server, list tools, call render_mermaid). The render tests launch headless Chromium, so they need the Chromium install above and take a few seconds each.

Configure in an MCP client

After npm run build, point your MCP client at the built entry over stdio.

Claude Code

# From a local build:
claude mcp add mermaid -- node /absolute/path/to/mermaid-mcp/dist/index.js

# Or from the published package:
claude mcp add mermaid -- npx -y @volare-consulting/mermaid-mcp

Claude Desktop / generic mcpServers config

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

Development

npm run dev     # run the server from TypeScript source via tsx

Releasing

Published to the public npm registry as @volare-consulting/mermaid-mcp via a tag-driven GitHub Actions release (.github/workflows/publish.yml), which calls the org's shared publish-npm-public reusable workflow.

  1. Bump version in package.json on a PR and merge to main.

  2. Tag the merge commit and push the tag:

    git tag v0.1.0 && git push origin v0.1.0

The tag must equal the package.json version or the job fails. Pushing a v* tag builds and publishes the package (tests are skipped — they need headless Chromium the publish runner doesn't provide). Authentication uses the org-level NPM_TOKEN secret.

License

MIT

Install Server
A
license - permissive license
A
quality
C
maintenance

Maintenance

Maintainers
Response time
Release cycle
Releases (12mo)
Commit activity

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/Volare-Consulting-Software/mermaid-mcp'

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