io.github.PavelGuzenfeld/media-forge

内容与创意

by pavelguzenfeld

用于为 Markdown 文档生成 diagrams、charts、presentations 和 animations 的 MCP server。

什么是 io.github.PavelGuzenfeld/media-forge

用于为 Markdown 文档生成 diagrams、charts、presentations 和 animations 的 MCP server。

README

MCP Media Forge

npm MCP Registry License: MIT

MCP server that generates diagrams, charts, HTML pages, and slide decks from text DSLs -- designed for AI coding agents to embed into Markdown.

LLM agents call tools like render_mermaid, render_html_page, or render_slides with text input, and get back file paths to assets ready to embed in docs.

Output Gallery

Mermaid Flowchart

<img src="docs/generated/example-flowchart.svg" width="400" alt="Mermaid flowchart">

Mermaid Sequence Diagram

<img src="docs/generated/example-sequence.svg" width="500" alt="Mermaid sequence diagram">

D2 Architecture Diagram

<img src="docs/generated/example-architecture.svg" width="600" alt="D2 architecture diagram">

Graphviz Dependency Graph

<img src="docs/generated/example-dependencies.svg" width="500" alt="Graphviz dependency graph">

Vega-Lite Bar Chart

<img src="docs/generated/example-bar-chart.svg" width="450" alt="Vega-Lite bar chart">

Tools

Diagram & Chart Renderers (Docker)

ToolInputFormatsUse Case
render_mermaidMermaid codeSVG, PNGFlowcharts, sequence, ER, state, Gantt, git graphs
render_d2D2 codeSVG, PNGArchitecture diagrams with containers and icons
render_graphvizDOT codeSVG, PNGDependency graphs, network diagrams
render_chartVega-Lite JSONSVG, PNGBar, line, scatter, area, heatmap charts

HTML Generators (No Docker)

ToolInputOutputUse Case
render_html_pageHTML body + themeSelf-contained HTMLTechnical docs, reports, dashboards
render_slidesJSON slide array + themeHTML slide deckPresentations, status updates, walkthroughs

Utilities

ToolDescription
get_tool_guideUsage examples, anti-patterns, complexity limits per tool
list_assetsList all generated files in the output directory

Quick Start

1. Start the rendering container (for diagram tools)

bash
cd docker
docker compose up -d

HTML page and slide tools work without Docker.

2. Install the MCP server

Option A -- npx (no install)

bash
npx mcp-media-forge

Option B -- Clone and build

bash
git clone https://github.com/PavelGuzenfeld/mcp-media-forge.git
cd mcp-media-forge
npm install
npm run build

3. Register with your MCP client

Any MCP-compatible client (Claude Code, Cursor, VS Code + Copilot, Cline, etc.) can use this server. The standard config:

json
{
  "mcpServers": {
    "media-forge": {
      "command": "node",
      "args": ["/path/to/mcp-media-forge/dist/index.js"],
      "env": {
        "PROJECT_ROOT": "/path/to/your/project"
      }
    }
  }
}

Where to add this depends on your client:

  • Claude Code: ~/.claude/settings.json
  • Cursor: MCP settings panel
  • VS Code (Copilot): .vscode/mcp.json
  • Cline: MCP server configuration

4. Use it

Ask your AI assistant to generate diagrams, pages, or presentations:

"Create a sequence diagram showing the OAuth2 flow and embed it in the README"

"Generate an HTML page summarizing the API architecture with KPI cards"

"Make a slide deck with our Q1 metrics and architecture overview"

The agent calls the appropriate tool, gets back a file path, and embeds it in your markdown.

How It Works

code
AI Agent (any MCP client)
    |
    | MCP Protocol (JSON-RPC over stdio)
    v
MCP Media Forge (Node.js on host)
    |
    |--- Diagrams: docker exec (sandboxed, no network)
    |       |
    |       v
    |   Rendering Container
    |     ├── mmdc       (Mermaid CLI + Chromium)
    |     ├── d2         (D2 diagrams)
    |     ├── dot/neato  (Graphviz)
    |     └── vl2svg     (Vega-Lite via vl-convert)
    |
    |--- HTML/Slides: template engine (no Docker)
    |       |
    |       v
    |   CSS Design System (4 themes, depth tiers, components)
    |
    v
docs/generated/
  mermaid-a1b2c3.svg
  d2-7f8e9a.svg
  html_page-d4e5f6.html
  slides-8b9c0d.html

Key design decisions:

  • Text in, file path out -- returns relative paths, never base64 blobs
  • Content-hash naming -- same input = same file = free caching + git-friendly
  • SVG preferred -- vector format, small files, diffs cleanly in git
  • Docker-contained -- diagram renderers run in a sandboxed container with network_mode: none
  • Self-contained HTML -- pages and slides have zero external dependencies (inline CSS/JS)
  • Input pre-validation -- catches common mistakes before Docker round-trips
  • Structured errors -- error responses include error_type, error_message, and suggestion to enable LLM self-correction

Tool Reference

get_tool_guide

Get usage guide for any tool before rendering. Returns examples, anti-patterns to avoid, complexity limits, and tips.

json
{ "tool_name": "mermaid" }

Available guides: mermaid, d2, graphviz, vegalite, html_page, slides, or all for a summary.

render_mermaid

json
{
  "code": "flowchart TD\n    A[Start] --> B{Decision}\n    B -->|Yes| C[Done]",
  "format": "svg",
  "theme": "default"
}
ParameterTypeDefaultDescription
codestringrequiredMermaid diagram code (must start with diagram type)
formatsvg | pngsvgOutput format
themedefault | dark | forest | neutraldefaultMermaid theme

Pre-validation catches: missing diagram type, semicolons, HTML in labels, >25 nodes.

render_d2

json
{
  "code": "client -> server -> database",
  "format": "svg",
  "layout": "dagre"
}
ParameterTypeDefaultDescription
codestringrequiredD2 diagram code
formatsvg | pngsvgOutput format
themenumber--Theme ID (0=default, 1=neutral-grey, 3=terminal)
layoutdagre | elk | taladagreLayout engine

Pre-validation catches: Mermaid/D2 syntax confusion, unbalanced braces, >3 nesting depth.

render_graphviz

json
{
  "dot_source": "digraph G { A -> B -> C }",
  "engine": "dot",
  "format": "svg"
}
ParameterTypeDefaultDescription
dot_sourcestringrequiredGraphviz DOT source code
enginedot | neato | fdp | sfdp | twopi | circodotLayout engine
formatsvg | pngsvgOutput format

Pre-validation catches: missing graph wrapper, -> in undirected graphs, unbalanced braces.

render_chart

json
{
  "spec_json": "{\"$schema\":\"https://vega.github.io/schema/vega-lite/v5.json\",\"data\":{\"values\":[{\"x\":1,\"y\":10}]},\"mark\":\"bar\",\"encoding\":{\"x\":{\"field\":\"x\"},\"y\":{\"field\":\"y\"}}}",
  "format": "svg"
}
ParameterTypeDefaultDescription
spec_jsonstringrequiredVega-Lite JSON specification
formatsvg | pngsvgOutput format
scalenumber1Scale factor for PNG output

Pre-validation catches: invalid JSON, missing $schema/data/mark, >500 inline data rows.

render_html_page

Generates a self-contained themed HTML page. No Docker required.

json
{
  "title": "System Overview",
  "body_html": "<section id=\"metrics\"><h2>Metrics</h2><div class=\"mf-grid mf-grid-3\">...</div></section>",
  "theme": "swiss",
  "description": "Q1 architecture overview",
  "nav_sections": ["Metrics", "Architecture", "Roadmap"]
}
ParameterTypeDefaultDescription
titlestringrequiredPage title
body_htmlstringrequiredHTML body content (inner content only, no <html>/<head>/<body>)
themeswiss | midnight | warm | terminalswissVisual theme
descriptionstring--Page description (meta tag + header)
nav_sectionsstring[]--Section names for floating IntersectionObserver navigation

Design system CSS classes:

ClassPurpose
mf-heroPrimary highlight section (large shadow)
mf-elevatedSecondary highlight (medium shadow)
mf-cardBordered content card
mf-recessedDe-emphasized content
mf-grid mf-grid-2Responsive 2-column grid
mf-grid mf-grid-3Responsive 3-column grid
mf-splitTwo equal columns
mf-kpi + mf-kpi-value + mf-kpi-labelKey metric display
mf-badge-success/warning/error/infoStatus badges

Themes:

ThemeStyleBest for
swissWhite, geometric, blue accentTechnical docs
midnightDeep navy, serif, gold accentPresentations
warmCream paper, bold sans, terracottaReports
terminalDark, monospace, cyan accentDeveloper content

render_slides

Generates a self-contained HTML slide deck with keyboard/touch navigation. No Docker required.

json
{
  "title": "Q1 Review",
  "slides": "[{\"title\":\"Q1 Review\",\"content\":\"Engineering update\",\"type\":\"title\"},{\"title\":\"Metrics\",\"content\":\"<ul><li>99.9% uptime</li></ul>\",\"type\":\"content\"}]",
  "theme": "midnight",
  "author": "Engineering Team"
}
ParameterTypeDefaultDescription
titlestringrequiredPresentation title
slidesstringrequiredJSON array of slide objects
themeswiss | midnight | warm | terminalswissVisual theme
authorstring--Author (shown on title slide)

Slide types:

TypeLayoutBest for
titleCentered large text + subtitleOpening/closing slides
sectionCentered heading + descriptionTopic dividers
contentHeading + body (bullets, text)Most content
splitHeading + two columnsBefore/after, comparisons
codeHeading + code blockCode walkthroughs
quoteLarge blockquote + attributionTestimonials, key quotes
kpiHeading + auto-grid metricsDashboards, stats
imageHeading + centered imageScreenshots, diagrams

Navigation: Arrow keys, Space, PageUp/PageDown, Home/End. Touch: swipe left/right. Click dots to jump.

list_assets

json
{ "directory": "" }

Returns a JSON array of all generated files with name, path, size, and modification time.

Error Handling

All tools return structured errors that help LLMs self-correct:

json
{
  "status": "error",
  "error_type": "syntax_error",
  "error_message": "First line must declare diagram type. Got: \"A --> B\"",
  "suggestion": "Start with: flowchart TD, sequenceDiagram, erDiagram, ... See https://mermaid.js.org/syntax/"
}

Error types: syntax_error, rendering_error, dependency_missing.

Pre-validation catches common LLM mistakes before hitting the renderer:

  • Mermaid: missing diagram type, semicolons, HTML tags, legacy graph syntax
  • D2: Mermaid syntax confusion (-->, subgraph), unbalanced braces
  • Graphviz: missing digraph/graph wrapper, -> in undirected graphs
  • Vega-Lite: invalid JSON, missing required fields, oversized inline data

Environment Variables

VariableDefaultDescription
PROJECT_ROOTcwd()Project root for output path resolution
OUTPUT_DIRdocs/generatedOutput directory relative to PROJECT_ROOT
MEDIA_FORGE_CONTAINERmedia-forge-rendererDocker container name

Development

bash
npm install
npm run build          # Build with tsup
npm run dev            # Watch mode
npm test               # Run all tests (95 total)
npm run test:unit      # Unit tests only (no Docker needed)
npm run test:component # Integration tests (Docker tools need container)
npm run lint           # Type-check with tsc

Running integration tests

bash
cd docker && docker compose up -d   # Start renderer (diagram tools only)
cd .. && npm run test:component     # All integration tests

HTML page and slide integration tests run without Docker.

Examples

See examples/ for sample input files:

FileToolDescription
mermaid/flowchart.mmdrender_mermaidDecision flowchart
mermaid/sequence.mmdrender_mermaidClient-server sequence
d2/architecture.d2render_d2Backend architecture with containers
graphviz/dependencies.dotrender_graphviznpm dependency graph
vegalite/bar-chart.jsonrender_chartTool performance comparison

See examples/README.md for MCP tool call examples and expected responses.

License

MIT

常见问题

io.github.PavelGuzenfeld/media-forge 是什么?

用于为 Markdown 文档生成 diagrams、charts、presentations 和 animations 的 MCP server。

相关 Skills

主题工厂

by anthropics

Universal
热门

给幻灯片、文档、报告和 HTML 落地页快速套用专业配色与字体主题,内置 10 套预设风格并支持现场生成新主题,适合统一品牌或内容视觉。

主题工厂能帮你把幻灯片、文档到落地页快速统一视觉风格,内置 10 套主题,还能按需即时生成新主题。

内容与创意
未扫描109.6k

品牌规范

by anthropics

Universal
热门

把文档、幻灯片等内容快速套用 Anthropic 官方品牌配色与字体规范,统一标题、正文和图形视觉风格,适合做品牌化排版、视觉润色和公司设计标准校准。

把文档、页面和素材快速套用 Anthropic 官方色彩与字体系,少翻设计手册也能稳稳保持统一品牌感。

内容与创意
未扫描109.6k

文档共著

by anthropics

Universal
热门

围绕文档、提案、技术规格、决策记录等写作任务,按上下文收集、结构迭代、读者测试三步协作共创,减少信息遗漏,写出更清晰、经得起他人阅读的内容。

写文档、方案或技术规格时容易思路散、信息漏,它用结构化共著流程帮你高效传递上下文、反复打磨内容,还能从读者视角做验证。

内容与创意
未扫描109.6k

相关 MCP Server

热门

免费的加密新闻聚合 MCP,汇集 Bitcoin、Ethereum、DeFi、Solana 与 altcoins 资讯源。

内容与创意
111

by ProfessionalWiki

让 Large Language Model 客户端无缝连接任意 MediaWiki 站点,可创建、更新、搜索页面,并通过 OAuth 2.0 安全管理内容。

内容与创意16 个工具
72

借助 86+ 个云端 media processing robots,处理视频、音频、图像和文档。

内容与创意
71

评论