beautiful-mermaid
Render beautiful Mermaid diagrams as SVGs or ASCII art. Use when user sends Mermaid code blocks (\`\`\`mermaid ... \`\`\`) and wants to visualize them. Supports: Flowcharts, State, Sequence, Class, ER diagrams. Features: Ultra-fast (100+ diagrams <500ms), zero DOM dependencies, 15 built-in themes, Shiki theme compatibility. Perfect for: Telegram messages, terminal output, web interfaces, CLI tools.
Install
mkdir -p .claude/skills/beautiful-mermaid && curl -L -o skill.zip "https://mcp.directory/api/skills/download/9082" && unzip -o skill.zip -d .claude/skills/beautiful-mermaid && rm skill.zipInstalls to .claude/skills/beautiful-mermaid
About this skill
Beautiful Mermaid
Render Mermaid diagrams as beautiful SVGs or ASCII art. Ultra-fast, fully themeable, zero DOM dependencies. Built for the AI era.
When to Use
Use this skill when:
- User sends Mermaid code blocks (```mermaid ... ```)
- User asks to "render" or "visualize" a diagram
- User wants terminal/ASCII output for diagrams
- User needs themed diagrams (15 built-in themes)
- User wants SVG output for rich UIs
Installation
npm install beautiful-mermaid
# or
bun add beautiful-mermaid
# or
pnpm add beautiful-mermaid
Quick Start
SVG Output (Default)
import { renderMermaid } from 'beautiful-mermaid'
const svg = await renderMermaid(`
graph TD
A[Start] --> B{Decision}
B -->|Yes| C[Action]
B -->|No| D[End]
`)
ASCII Output (Terminal)
import { renderMermaidAscii } from 'beautiful-mermaid'
const ascii = renderMermaidAscii(`graph LR; A --> B --> C`)
Output:
┌───┐ ┌───┐ ┌───┐
│ │ │ │ │ │
│ A │────►│ B │────►│ C │
│ │ │ │ │ │
└───┘ └───┘ └───┘
Supported Diagrams
| Type | Syntax | Description |
|---|---|---|
| Flowchart | graph TD/LR/BT/RL | All directions supported |
| State | stateDiagram-v2 | State machine diagrams |
| Sequence | sequenceDiagram | Sequence/interaction diagrams |
| Class | classDiagram | Class inheritance diagrams |
| ER | erDiagram | Entity-relationship diagrams |
Flowchart Example
```mermaid graph TD A[Start] --> B{Decision} B -->|Yes| C[Action] B -->|No| D[End] C --> D ```
Sequence Example
```mermaid sequenceDiagram Alice->>Bob: Hello Bob! Bob-->>Alice: Hi Alice! ```
Theming System
Built-in Themes (15)
import { renderMermaid, THEMES } from 'beautiful-mermaid'
// Use a built-in theme
const svg = await renderMermaid(diagram, THEMES['tokyo-night'])
// Available themes:
THEMES['zinc-light']
THEMES['zinc-dark']
THEMES['tokyo-night']
THEMES['tokyo-night-storm']
THEMES['tokyo-night-light']
THEMES['catppuccin-mocha']
THEMES['catppuccin-latte']
THEMES['nord']
THEMES['nord-light']
THEMES['dracula']
THEMES['github-light']
THEMES['github-dark']
THEMES['solarized-light']
THEMES['solarized-dark']
THEMES['one-dark']
Custom Theme (Mono Mode)
// Just two colors - the system derives everything
const svg = await renderMermaid(diagram, {
bg: '#1a1b26', // Background
fg: '#a9b1d6', // Foreground
})
Enriched Theme
const svg = await renderMermaid(diagram, {
bg: '#1a1b26',
fg: '#a9b1d6',
line: '#3d59a1', // Edge color
accent: '#7aa2f7', // Arrow heads
muted: '#565f89', // Secondary text
surface: '#292e42', // Node fill
border: '#3d59a1', // Node stroke
})
Shiki Theme Compatibility
import { renderMermaid, fromShikiTheme } from 'beautiful-mermaid'
import { getHighlighter } from 'shiki'
const highlighter = await getHighlighter({ theme: 'vitesse-dark' })
const colors = fromShikiTheme(highlighter.getTheme('vitesse-dark'))
const svg = await renderMermaid(diagram, colors)
ASCII/Unicode Output
For terminal environments:
import { renderMermaidAscii } from 'beautiful-mermaid'
// Unicode (prettier, default)
const unicode = renderMermaidAscii(`graph LR; A --> B`)
// Pure ASCII (maximum compatibility)
const ascii = renderMermaidAscii(`graph LR; A --> B`, { useAscii: true })
// Custom spacing
renderMermaidAscii(diagram, {
useAscii: false,
paddingX: 5, // Horizontal spacing
paddingY: 5, // Vertical spacing
boxBorderPadding: 1, // Inner padding
})
API Reference
renderMermaid(text, options?): Promise<string>
Render Mermaid to SVG.
Options:
| Option | Type | Default | Description |
|---|---|---|---|
bg | string | #FFFFFF | Background color |
fg | string | #27272A | Foreground color |
line | string? | — | Edge color |
accent | string? | — | Arrow heads, highlights |
muted | string? | — | Secondary text |
surface | string? | — | Node fill tint |
border | string? | — | Node stroke |
font | string | Inter | Font family |
transparent | boolean | false | Transparent background |
renderMermaidAscii(text, options?): string
Render Mermaid to ASCII/Unicode. Synchronous.
Options:
| Option | Type | Default | Description |
|---|---|---|---|
useAscii | boolean | false | Use ASCII instead of Unicode |
paddingX | number | 5 | Horizontal node spacing |
paddingY | number | 5 | Vertical node spacing |
boxBorderPadding | number | 1 | Inner box padding |
THEMES: Record<string, DiagramColors>
All 15 built-in themes.
fromShikiTheme(theme): DiagramColors
Extract diagram colors from Shiki theme.
Usage in OpenClaw
Telegram Integration
For Telegram, render as SVG and send as photo:
import { renderMermaid } from 'beautiful-mermaid'
async function sendMermaid(message: string) {
const blocks = extractMermaidBlocks(message)
for (const block of blocks) {
const svg = await renderMermaid(block.code, THEMES['tokyo-night'])
// Send SVG as photo to Telegram
}
}
Terminal/CLI Output
import { renderMermaidAscii } from 'beautiful-mermaid'
function printDiagram(code: string) {
const ascii = renderMermaidAscii(code)
console.log(ascii)
}
Performance
- 100+ diagrams in under 500ms
- Zero DOM dependencies - pure TypeScript
- Ultra-fast - no browser/Puppeteer needed
Comparison to Alternatives
| Feature | beautiful-mermaid | mmdc |
|---|---|---|
| Dependencies | Zero DOM | Puppeteer |
| Speed | <500ms for 100+ diagrams | Slower |
| ASCII output | ✅ Native | ❌ No |
| Themes | 15 built-in + Shiki | CSS |
| Size | Lightweight | Heavy |
Example Workflow
Input:
Here is the system architecture:
\`\`\`mermaid
graph TD
User --> LB[Load Balancer]
LB --> API[API Server]
API --> DB[(Database)]
API --> Cache
\`\`\`
And the flow:
\`\`\`mermaid
sequenceDiagram
participant U as User
participant A as API
U->>A: Request
A-->>U: Response
\`\`\`
Action: Render both diagrams with appropriate theme.
Output: Send two SVG images with captions.
Resources
More by openclaw
View all skills by openclaw →You might also like
flutter-development
aj-geddes
Build beautiful cross-platform mobile apps with Flutter and Dart. Covers widgets, state management with Provider/BLoC, navigation, API integration, and material design.
drawio-diagrams-enhanced
jgtolentino
Create professional draw.io (diagrams.net) diagrams in XML format (.drawio files) with integrated PMP/PMBOK methodologies, extensive visual asset libraries, and industry-standard professional templates. Use this skill when users ask to create flowcharts, swimlane diagrams, cross-functional flowcharts, org charts, network diagrams, UML diagrams, BPMN, project management diagrams (WBS, Gantt, PERT, RACI), risk matrices, stakeholder maps, or any other visual diagram in draw.io format. This skill includes access to custom shape libraries for icons, clipart, and professional symbols.
ui-ux-pro-max
nextlevelbuilder
"UI/UX design intelligence. 50 styles, 21 palettes, 50 font pairings, 20 charts, 8 stacks (React, Next.js, Vue, Svelte, SwiftUI, React Native, Flutter, Tailwind). Actions: plan, build, create, design, implement, review, fix, improve, optimize, enhance, refactor, check UI/UX code. Projects: website, landing page, dashboard, admin panel, e-commerce, SaaS, portfolio, blog, mobile app, .html, .tsx, .vue, .svelte. Elements: button, modal, navbar, sidebar, card, table, form, chart. Styles: glassmorphism, claymorphism, minimalism, brutalism, neumorphism, bento grid, dark mode, responsive, skeuomorphism, flat design. Topics: color palette, accessibility, animation, layout, typography, font pairing, spacing, hover, shadow, gradient."
godot
bfollington
This skill should be used when working on Godot Engine projects. It provides specialized knowledge of Godot's file formats (.gd, .tscn, .tres), architecture patterns (component-based, signal-driven, resource-based), common pitfalls, validation tools, code templates, and CLI workflows. The `godot` command is available for running the game, validating scripts, importing resources, and exporting builds. Use this skill for tasks involving Godot game development, debugging scene/resource files, implementing game systems, or creating new Godot components.
nano-banana-pro
garg-aayush
Generate and edit images using Google's Nano Banana Pro (Gemini 3 Pro Image) API. Use when the user asks to generate, create, edit, modify, change, alter, or update images. Also use when user references an existing image file and asks to modify it in any way (e.g., "modify this image", "change the background", "replace X with Y"). Supports both text-to-image generation and image-to-image editing with configurable resolution (1K default, 2K, or 4K for high resolution). DO NOT read the image file first - use this skill directly with the --input-image parameter.
pdf-to-markdown
aliceisjustplaying
Convert entire PDF documents to clean, structured Markdown for full context loading. Use this skill when the user wants to extract ALL text from a PDF into context (not grep/search), when discussing or analyzing PDF content in full, when the user mentions "load the whole PDF", "bring the PDF into context", "read the entire PDF", or when partial extraction/grepping would miss important context. This is the preferred method for PDF text extraction over page-by-page or grep approaches.
Related MCP Servers
Browse all serversMermaid Diagram Generator converts Mermaid diagrams to crisp PNGs with customizable themes and backgrounds for perfect v
Render Mermaid diagrams in real-time with live preview, browser refresh, WebSocket updates, and SVG/PNG/PDF export plus
Create and organize Mermaid diagrams with real-time visualization, export, and git integration—perfect for mermaid js an
Validate and render Mermaid diagrams as SVG images using Mermaid JS. Get clear error messages to improve your JavaScript
Pandoc Markdown to PowerPoint converts Markdown to PowerPoint with diagrams, templates, and custom file paths for fast d
Mermaid Chart: validate and render Mermaid diagrams via hosted endpoints - a Mermaid renderer, live editor, and diagram
Stay ahead of the MCP ecosystem
Get weekly updates on new skills and servers.