Mermaid MCP-Server
Ein Model Context Protocol (MCP)-Server, der Mermaid-Diagramme in PNG-Bilder konvertiert. Dieser Server ermöglicht es KI-Assistenten und anderen Anwendungen, visuelle Diagramme aus Textbeschreibungen mithilfe der Mermaid-Markdown-Syntax zu generieren.
Merkmale
- Konvertiert den Mermaid-Diagrammcode in PNG-Bilder
- Unterstützt mehrere Diagrammthemen (Standard, Wald, Dunkel, Neutral)
- Anpassbare Hintergrundfarben
- Verwendet Puppeteer für hochwertiges Headless-Browser-Rendering
- Implementiert das MCP-Protokoll für die nahtlose Integration mit KI-Assistenten
- Flexible Ausgabeoptionen: Bilder direkt zurückgeben oder auf der Festplatte speichern
- Fehlerbehandlung mit detaillierten Fehlermeldungen
Wie es funktioniert
Der Server verwendet Puppeteer, um einen Headless-Browser zu starten, das Mermaid-Diagramm in SVG zu rendern und einen Screenshot des gerenderten Diagramms zu erstellen. Der Prozess umfasst:
- Starten einer Headless-Browserinstanz
- Erstellen einer HTML-Vorlage mit dem Mermaid-Code
- Laden der Mermaid.js-Bibliothek
- Rendern des Diagramms in SVG
- Erstellen eines Screenshots des gerenderten SVG als PNG
- Entweder das Bild direkt zurückgeben oder auf der Festplatte speichern
Bauen
Verwendung
Verwendung mit Claude Desktop
Verwendung mit Cursor und Cline
Sie finden eine Liste mit Meerjungfrauendiagrammen unter ./diagrams
. Sie werden mit dem Cursor-Agenten mit der Eingabeaufforderung erstellt: „Meerjungfrauendiagramme erstellen und in einem separaten Diagrammordner speichern, in dem erklärt wird, wie renderMermaidPng funktioniert.“
Mit Inspektor ausführen
Führen Sie den Server zum Testen und Debuggen mit Inspector aus:
Der Server wird gestartet und wartet auf stdio auf MCP-Protokollnachrichten.
Erfahren Sie hier mehr über Inspector.
Installation über Smithery
So installieren Sie Mermaid Diagram Generator für Claude Desktop automatisch über Smithery :
Docker- und Smithery-Umgebungen
Beim Ausführen in Docker-Containern (einschließlich über Smithery) müssen Sie möglicherweise Chrome-Abhängigkeiten verarbeiten:
- Der Server versucht nun standardmäßig, den mitgelieferten Browser von Puppeteer zu verwenden
- Wenn browserbezogene Fehler auftreten, haben Sie zwei Möglichkeiten:Option 1: Während der Erstellung des Docker-Images:
- Setzen Sie
PUPPETEER_SKIP_CHROMIUM_DOWNLOAD=true
bei der Installation von Puppeteer - Installieren Sie Chrome/Chromium in Ihrem Docker-Container
- Legen Sie
PUPPETEER_EXECUTABLE_PATH
zur Laufzeit fest, um auf die Chrome-Installation zu verweisen
Option 2: Verwenden Sie das mitgelieferte Chrome von Puppeteer:
- Stellen Sie sicher, dass Ihr Docker-Container über die erforderlichen Abhängigkeiten für Chrome verfügt.
PUPPETEER_SKIP_CHROMIUM_DOWNLOAD
muss nicht festgelegt werden- Der Code verwendet automatisch den mitgelieferten Browser
- Setzen Sie
Für Smithery-Benutzer sollte die neueste Version ohne zusätzliche Konfiguration funktionieren.
API
Der Server stellt ein einzelnes Tool bereit:
generate
: Konvertiert den Mermaid-Diagrammcode in ein PNG-Bild- Parameter:
code
: Der zu rendernde Code des Meerjungfrau-Diagrammstheme
: (optional) Thema für das Diagramm. Optionen: "Standard", "Wald", "Dunkel", "Neutral"backgroundColor
: (optional) Hintergrundfarbe für das Diagramm, zB 'weiß', 'transparent', '#F0F0F0'name
: Name der generierten Datei (erforderlich, wenn CONTENT_IMAGE_SUPPORTED=false)folder
: Absoluter Pfad zum Speichern des Bildes (erforderlich, wenn CONTENT_IMAGE_SUPPORTED=false)
- Parameter:
Das Verhalten des generate
hängt von der Umgebungsvariable CONTENT_IMAGE_SUPPORTED
ab:
- Wenn
CONTENT_IMAGE_SUPPORTED=true
(Standard): Das Tool gibt das Bild direkt in der Antwort zurück - Wenn
CONTENT_IMAGE_SUPPORTED=false
: Das Tool speichert das Bild im angegebenen Ordner und gibt den Dateipfad zurück
Umgebungsvariablen
CONTENT_IMAGE_SUPPORTED
: Steuert, ob Bilder direkt in der Antwort zurückgegeben oder auf der Festplatte gespeichert werdentrue
(Standard): Bilder werden direkt in der Antwort zurückgegebenfalse
: Bilder werden auf der Festplatte gespeichert und erfordern die Parametername
undfolder
.
Beispiele
Grundlegende Verwendung
Mit Design und Hintergrundfarbe
Auf Festplatte speichern (wenn CONTENT_IMAGE_SUPPORTED=false)
Häufig gestellte Fragen
Unterstützt Claude Desktop Mermaid nicht bereits über Canvas?
Ja, aber die Optionen theme
und backgroundColor
werden nicht unterstützt. Außerdem erleichtert ein dedizierter Server die Erstellung von Meerjungfrauendiagrammen mit verschiedenen MCP-Clients.
Warum muss ich bei Verwendung mit Cursor CONTENT_IMAGE_SUPPORTED=false angeben?
Cursor unterstützt noch keine Inline-Bilder in Antworten.
Veröffentlichen
Dieses Projekt verwendet GitHub Actions, um den Veröffentlichungsprozess in npm zu automatisieren.
Methode 1: Verwenden des Release-Skripts (empfohlen)
- Stellen Sie sicher, dass alle Ihre Änderungen übernommen und übertragen werden
- Führen Sie das Release-Skript entweder mit einer bestimmten Versionsnummer oder einem semantischen Versionsinkrement aus:
- Das Skript wird:
- Validieren Sie das Versionsformat oder das semantische Inkrement
- Überprüfen Sie, ob Sie sich im Hauptzweig befinden
- Erkennen und warnen Sie vor Versionskonflikten zwischen Dateien
- Aktualisieren Sie alle Versionsreferenzen konsistent (package.json, package-lock.json und index.ts).
- Erstellen Sie ein einzelnes Commit mit allen Versionsänderungen
- Erstellen und pushen Sie einen Git-Tag
- Der GitHub-Workflow wird dann automatisch erstellt und auf npm veröffentlicht
Methode 2: Manueller Prozess
- Aktualisieren Sie Ihren Code und übernehmen Sie die Änderungen
- Erstellen und pushen Sie ein neues Tag mit der Versionsnummer:
- Der GitHub-Workflow führt automatisch Folgendes aus:
- Erstellen des Projekts
- Veröffentlichen Sie in npm mit der Version aus dem Tag
Hinweis: Sie müssen das NPM_TOKEN
Geheimnis in den Einstellungen Ihres GitHub-Repositorys einrichten. Gehen Sie dazu wie folgt vor:
- Generieren Sie ein NPM-Zugriffstoken mit Veröffentlichungsberechtigungen
- Gehen Sie zu Ihrem GitHub-Repository → Einstellungen → Geheimnisse und Variablen → Aktionen
- Erstellen Sie ein neues Repository-Geheimnis mit dem Namen
NPM_TOKEN
und Ihrem NPM-Token als Wert.
Abzeichen
Lizenz
MIT
You must be authenticated.
hybrid server
The server is able to function both locally and remotely, depending on the configuration or use case.
Tools
Ein Model Context Protocol (MCP)-Server, der Mermaid-Diagramme in PNG-Bilder konvertiert.
- Merkmale
- Wie es funktioniert
- Bauen
- Verwendung
- API
- Umgebungsvariablen
- Beispiele
- Häufig gestellte Fragen
- Veröffentlichen
- Abzeichen
- Lizenz
Related Resources
Related MCP Servers
- AsecurityAlicenseAqualityModel Context Protocol server for fetching web content and processing images. This allows Claude Desktop (or any MCP client) to fetch web content and handle images appropriately.Last updated -127815JavaScriptMIT License
- AsecurityFlicenseAqualityA Model Context Protocol server that converts PDF documents into PNG images through a simple MCP tool call.Last updated -12Python
- AsecurityAlicenseAqualityA Model Context Protocol server that validates and renders Mermaid diagrams.Last updated -14011JavaScriptMIT License
- -securityAlicense-qualityA Model Context Protocol (MCP) server that enables Claude or other LLMs to fetch content from URLs, supporting HTML, JSON, text, and images with configurable request parameters.Last updated -PythonMIT License