AgentSkillsCN

mermaid-builder

精通 Mermaid 图表的语法规范,助您轻松绘制各类图表。适用于创建流程图、序列图、类图、状态图、甘特图、ER 图,或数据血缘关系可视化时使用。

SKILL.md
--- frontmatter
name: mermaid-builder
description: Expert guidance for creating syntactically correct Mermaid diagrams. Use when creating flowcharts, sequence diagrams, class diagrams, state diagrams, Gantt charts, ER diagrams, or data lineage visualizations.
allowed-tools: Read, Write, Edit, MultiEdit, Grep, Glob, Bash, WebSearch, WebFetch

Mermaid Builder

Core Philosophy

  • Correctness: Follow Mermaid syntax rules strictly
  • Clarity: Diagrams communicate complex ideas simply
  • Simplicity: Avoid overloading with unnecessary detail
  • Modularity: Break complex diagrams into subgraphs

Critical: Label Quoting Rule

RULE: Wrap labels in double quotes if they contain spaces, special characters, or punctuation.

mermaid
%% CORRECT - labels with spaces quoted
flowchart LR
    A["User Login"] --> B["Process Request"]
    C["Pay $100?"] --> D["Confirm (Yes/No)"]

%% WRONG - will fail to render
flowchart LR
    A[User Login] --> B[Process Request]

Must quote: Spaces, special chars ($%&), punctuation (:,;), operators (()[]) Optional: Simple alphanumeric (Login, Process, Node1)

When in doubt, use quotes. It never hurts.

Quick Reference

Flowchart Shapes

SyntaxShape
["Text"]Rectangle
("Text")Rounded
{"Text"}Diamond (decision)
[("Text")]Cylinder (database)
(("Text"))Circle

Arrow Types

SyntaxType
-->Solid arrow
---Solid line
-.->Dotted arrow
==>Thick arrow
`-->Label

Diagram Types

TypeDeclarationUse Case
Flowchartflowchart TDProcesses, workflows, decisions
SequencesequenceDiagramComponent interactions, API flows
ClassclassDiagramOOP structure, models
StatestateDiagram-v2State transitions
GanttganttTimelines, scheduling
ERerDiagramDatabase schema
PiepieProportional data

Directions: TB/TD (top-down), BT (bottom-up), LR (left-right), RL (right-left)

See resources/diagram-examples.md for complete examples of each diagram type.

Minimal Examples

Flowchart

mermaid
flowchart TD
    Start["Start"] --> Check{Valid?}
    Check -->|Yes| Process["Process"]
    Check -->|No| Error["Error"]
    Process --> End["End"]

Sequence

mermaid
sequenceDiagram
    Client->>Server: Request
    Server-->>Client: Response

ER Diagram

mermaid
erDiagram
    USER ||--o{ ORDER : "places"
    USER { int id PK string email }
    ORDER { int id PK int user_id FK }

Subgraphs for Organization

mermaid
flowchart TD
    subgraph "Frontend"
        A["UI"]
    end
    subgraph "Backend"
        B["API"]
        C[("DB")]
    end
    A --> B --> C

Styling

mermaid
flowchart TD
    A["Success"] --> B["Error"]

    classDef successStyle fill:#C8E6C9,stroke:#388E3C
    classDef errorStyle fill:#FFCDD2,stroke:#D32F2F

    class A successStyle
    class B errorStyle

Common Errors to Avoid

ErrorWrongCorrect
Unquoted spacesA[User Login]A["User Login"]
Invalid arrowA -> BA --> B
Unquoted specialA[Cost: $100]A["Cost: $100"]
Missing bracketA["Node --> BA["Node"] --> B

Validation Checklist

  • Labels with spaces are quoted
  • Labels with special characters quoted
  • Brackets properly matched
  • Arrow syntax correct (--> not ->)
  • Node IDs unique and meaningful
  • Comments explain complex sections
  • Previewed without errors

Data Lineage Patterns

See resources/data-lineage.md for:

  • ETL pipeline patterns
  • Multi-layer data architecture
  • Cross-system data flows
  • Database schema lineage
  • Streaming data lineage
  • Column-level lineage

Resources


Remember: The quoting rule is the #1 cause of Mermaid rendering failures. When in doubt, quote it.