mermaid
// Generate diagrams from text using [Mermaid](https://mermaid.js.org/).
$ git log --oneline --stat
stars:1,933
forks:367
updated:March 4, 2026
SKILL.mdreadonly
Mermaid Diagrams Skill
Generate diagrams from text using Mermaid.
Requirements
@mermaid-js/mermaid-cli(npm install -g @mermaid-js/mermaid-cli)
Usage
- Write Mermaid syntax to a
.mmdfile - Run
mmdcto render PNG/SVG - Return the image to the user
Basic Command
mmdc -i input.mmd -o output.png -t dark -b transparent
Options
| Flag | Description |
|---|---|
-i | Input .mmd file |
-o | Output file (.png, .svg, .pdf) |
-t | Theme: default, dark, forest, neutral |
-b | Background color (transparent, hex) |
-w | Width in pixels (default: 800) |
-H | Height in pixels |
-s | Scale factor (default: 1, use 2-3 for high-res) |
-c | Config JSON file for advanced theming |
Supported Diagram Types
- Flowchart:
graph TD/graph LR - Sequence:
sequenceDiagram - Class:
classDiagram - State:
stateDiagram-v2 - ER:
erDiagram - Gantt:
gantt - Pie:
pie - Mindmap:
mindmap - Timeline:
timeline - Git graph:
gitGraph - Quadrant:
quadrantChart - Block:
block-beta
Workflow
- Determine the best diagram type for what the user wants
- Write the
.mmdfile to/tmp/mermaid-<name>.mmd - Render:
mmdc -i /tmp/mermaid-<name>.mmd -o /tmp/mermaid-<name>.png -t dark -b transparent -s 2 - Show the image to the user via
Readtool - Clean up temp files if not needed
Example: Architecture Diagram
graph TD
A[Client] -->|HTTPS| B[API Gateway]
B --> C[Auth Service]
B --> D[App Server]
D --> E[(PostgreSQL)]
D --> F[(Redis Cache)]
Example: Sequence Diagram
sequenceDiagram
participant U as User
participant A as API
participant DB as Database
U->>A: POST /login
A->>DB: Validate credentials
DB-->>A: User record
A-->>U: JWT token
Tips
- Use
graph LRfor left-to-right flow,graph TDfor top-down - Keep node labels short — detail goes in tooltips or notes
- Use subgraphs to group related components
- For dark backgrounds, use
-t dark -b transparent - Scale
-s 2or-s 3for sharp images on retina displays - Always use
pty: falsewhen callingmmdc
Theming
For custom colors, create a config JSON:
{
"theme": "base",
"themeVariables": {
"primaryColor": "#f59e0b",
"primaryTextColor": "#1a1a1a",
"primaryBorderColor": "#d97706",
"lineColor": "#6b7280",
"secondaryColor": "#10b981",
"tertiaryColor": "#3b82f6"
}
}
Then: mmdc -i input.mmd -o output.png -c config.json