Marp MCP Server
Create and manage Marp presentations using AI through natural language commands.
Initialize presentation projects - Set up complete project structure with directories, custom themes, and template files using project path, name, and title
Generate slide content - Create individual slides with 7 academic layout types: title, section, content, table, multi-column, figure (background images), and image (centered images)
List available layouts - View all slide layouts with their descriptions and accepted parameters
Customize themes - Modify colors, fonts, and layouts through CSS customization
Preview and export - View presentations in VS Code and export to PDF, HTML, or PowerPoint formats
Compatible with MCP-enabled applications - Works with Claude Code, Cursor, Cline and other tools
Includes pre-configured academic_custom.css theme with custom fonts, color schemes, table styles, and multi-column layouts for presentations
Automatically generates .gitignore files as part of presentation project initialization
References GitHub repository for the MCP server source code and contribution
Built using JavaScript/Node.js and distributed as an npm package
Generates presentation slides as Markdown files with Marp-specific syntax and formatting
Distributed as an npm package with installation options via npx, global, or local installation
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Marp MCP Servercreate a presentation about AI trends with a title slide and three list slides"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Marp MCP Server
This package includes aClaude Code Skill. After installing, Claude Code can create Marp presentations via the /marp command using the built-in CLI — no MCP server configuration required!
Auto-updating plugin install:
/plugin marketplace add masaki39/marp-mcp
/plugin install marp@marp-mcpAn MCP server for creating and editing Marp presentations with AI assistance. This MCP server allows LLMs to edit Markdown files according to a specified layout, supporting the built-in Marp themes (default, Gaia, Uncover) and a rich set of academic and professional presentation styles.
⚙️ Setup
Claude Code
Option 1 — CLI, user scope (recommended):
claude mcp add marp-mcp -- npx -y @masaki39/marp-mcp@latestOption 2 — CLI, project scope (shareable with team via .mcp.json):
claude mcp add --scope project marp-mcp -- npx -y @masaki39/marp-mcp@latestOption 3 — Manual config (~/.claude/settings.json or .mcp.json):
{
"mcpServers": {
"marp-mcp": {
"command": "npx",
"args": ["-y", "@masaki39/marp-mcp@latest"]
}
}
}Other MCP clients
{
"mcpServers": {
"marp-mcp": {
"command": "npx",
"args": ["-y", "@masaki39/marp-mcp@latest"]
}
}
}Setting server default theme/style
Use -t / --theme and -s / --style args to set the server-wide default. Choose from themes: default, gaia, uncover. Styles: default, rich, minimal, dark, corporate, academic, tech:
{
"mcpServers": {
"marp-mcp": {
"command": "npx",
"args": ["-y", "@masaki39/marp-mcp@latest", "-t", "default", "-s", "rich"]
}
}
}Omitting these flags defaults to default theme and default style.
External styles via marp-cli config
If a marp-cli configuration file (.marprc.{yml,yaml,json,js,cjs,mjs}, marp.config.{js,cjs,mjs}, or a marp field in package.json) is found anywhere up the directory tree at server start, every CSS file listed under its themeSet field is registered as an MCP style. The style name is read from the file's /* @theme NAME */ directive (lowercased). External entries reuse the active theme's layouts, so all existing tools work unchanged.
# .marprc.yml
themeSet:
- ./themes/sample.css/* themes/sample.css */
/* @theme sample */
section { background: #fff; }sample is then a valid value for -s and shows up in list_themes_and_styles with "external": true and the absolute CSS path under source. Built-in style names are protected; any external collision is logged and skipped.
Related MCP server: Slidev MCP Server
🛠️ Tools
Tool | Description |
| List all available themes and styles; shows current server defaults |
| List available slide layouts for a theme/style combination |
| Create a new presentation with frontmatter and title slide in one step |
| Insert, replace, delete, or move slides using slide IDs (ID-based operations) |
| Apply multiple slide operations in one call (single file read/write) |
| Ensure |
| Read slide content by ID or list all slides with their IDs and positions |
| Generate stable UUIDs for every slide (safe to re-run) |
| Export to HTML, PDF, or PPTX using marp-cli |
| Auto-generate an agenda slide; adds numbered icons to section slides for view-transition morphing (HTML only) |
| Insert a full-screen background image slide before a target slide and tag images for view-transition morphing (HTML only) |
Per-call theme/style override
list_layouts, manage_slide, and set_frontmatter accept optional theme and style parameters to override the server default for a single call. This lets one server instance handle all theme/style combinations without restarting:
{ "theme": "gaia", "style": "rich" }Omit either parameter to fall back to the server default.
🎨 Example
Rendered samples (GitHub Pages):
📐 Available Layouts
Default theme
Layout | Description |
| Title slide with heading and content |
| Section break slide with centered title and subtitle |
| List slide with bullet points (max 8 items) |
| Table slide with description (max 7 rows) |
| Slide with image on right and content list (allows more explanation than image-center) |
| Slide with centered image (fixed h:350) |
| Standard content slide with heading and free-form markdown body (supports bullets with -, bold with **, code with backticks) |
Styles
rich — Rich visual style with cards, timelines, grids, gradients, and more
Layout | Description |
| Hero title slide with dark gradient background |
| Section divider slide with gradient background |
| List slide with bullet points |
| Rich table slide with styled header and zebra stripes |
| Rich image-right slide with content on left and image on right (60:40 split) |
| Rich centered image slide with rounded corners and shadow |
| Image on the left with content list on the right (40:60 split) |
| Vertical timeline with labeled events (use 'Label: Description' format) |
| Grid of cards with icon, title, and description (use 'Icon |
| Statistics display with large numbers and labels (use 'Number |
| Centered gradient message box for key takeaways or announcements |
| Two-column layout with styled panels, optional accent highlight on one panel |
| Three-column layout with styled panels (use 'Title |
| Two images side by side with labels for comparison |
| Free-form markdown content slide |
| Quote slide with attribution |
| Horizontal process flow with numbered steps and arrows |
| Simple two-column layout with headings and lists |
| Large impactful statement slide with bold centered text |
| Main content with sidebar for supplementary info, definitions, or references |
| Horizontal progress bars for metrics visualization (use 'Label |
| Pure CSS horizontal bar chart for data visualization (use 'Label |
| Horizontal timeline with labeled events (use 'Label: Description' format) |
| Decorative impact quote with large quotation marks, centered layout |
| Bento Box modular grid for mixed content (use 'Size |
minimal — Clean, flat design with typography focus and minimal decoration
Layout | Description |
| Clean black title slide with white text |
| Simple black section divider slide |
| Pure markdown content slide |
| Simple bullet list slide |
| Minimal table with black header and clean borders |
| Text on left, image on right (60:40 split), clean design |
| Centered image slide, clean and minimal |
| Quote slide with left border accent, no extra decoration |
| Two-column layout with a thin divider line |
| Large impactful statement slide with bold centered text |
| Minimal statistics display with black numbers and thin underline (use 'Number |
| Minimal message box for key takeaways |
| Minimal decorative impact quote with large quotation marks |
| Clean agenda slide with numbered items and optional time durations (use 'Item name |
| Side-by-side comparison with explicit left/right titles and list items, separated by a thin divider |
dark — Dark mode style with indigo and emerald accents, developer-friendly
Layout | Description |
| Dark title slide with indigo-violet gradient |
| Dark section divider with slate-to-indigo gradient |
| Free-form markdown content slide on dark background |
| Bullet list slide on dark background |
| Dark table with indigo header |
| Dark card grid with icon, title, and description (use 'Icon |
| Dark vertical timeline with indigo-to-emerald gradient line (use 'Label: Description' format) |
| Dark statistics display with large indigo numbers (use 'Number |
| Text on left, image on right on dark background (60:40 split) |
| Terminal-style command display on dark background (prefix lines with '$ ' for commands) |
| Dark quote slide with attribution |
| Dark centered image slide |
| Dark horizontal process flow with numbered steps and arrows |
| Dark two-column layout with panels |
| Dark large impactful statement slide with bold centered text |
| Dark gradient message box for key takeaways or announcements |
| Dark horizontal progress bars for metrics visualization (use 'Label |
| Dark CSS horizontal bar chart for data visualization (use 'Label |
| Dark horizontal timeline with labeled events (use 'Label: Description' format) |
| Side-by-side code comparison (Before/After or two languages) |
| Code block with language badge, optional explanation text, and optional highlight bullet points |
corporate — Professional business style with navy color scheme, structured layouts
Layout | Description |
| Professional navy gradient title slide |
| Corporate navy-to-sky section divider slide |
| Standard business content slide with markdown |
| Business bullet list slide |
| Business table with navy header and clean rows |
| Two-column comparison layout with navy-accented panels |
| Three-column layout with sky-accented panels |
| Business metrics display with large navy numbers (use 'Number |
| Horizontal business process flow with numbered steps |
| Agenda slide with numbered items and optional duration (use 'Item name |
| Text on left, image on right, professional business style (60:40 split) |
| Navy key message box for important announcements or takeaways |
| Corporate quote slide with attribution |
| Corporate centered image slide |
| Corporate large impactful statement slide with bold centered text |
| Main content with sidebar for supplementary info or references |
| Corporate horizontal progress bars for metrics visualization (use 'Label |
| Corporate CSS horizontal bar chart for data visualization (use 'Label |
| Corporate decorative impact quote with large quotation marks |
| 2x2 matrix for SWOT, risk analysis, or priority grids |
academic — Academic conference presentation style with maroon color scheme, structured for scholarly talks
Layout | Description |
| Academic title slide with author, affiliation, and date |
| Maroon section divider with optional number |
| Free-form markdown content slide. Add sidebarTitle/sidebarItems to show a sidebar panel on the right side. |
| Bullet point list with optional citations |
| Table with maroon header. Write the table in standard markdown format. |
| Two-column panel layout. Use panelStyle='comparison' to highlight right panel (maroon) vs left panel (gray) for conventional vs proposed comparisons. |
| Content on left, image on right (60:40 split) |
| Centered image slide. Set figNumber to switch to figure-caption mode (renders 'Fig. X.' label with optional source attribution). |
| Conclusion or key takeaway box with maroon highlight |
| Method step flow diagram (use 'Label |
| Academic statistics display with maroon numbers (use 'Number |
tech — Modern tech/startup style with violet-cyan gradient accents, strong typography for product demos and engineering talks
Layout | Description |
| Gradient title slide with optional tagline and event/company name |
| Dark full-bleed section divider with cyan eyebrow label and bold heading |
| Standard content slide with heading and free-form markdown body, accented with a violet left border |
| Bullet list slide with violet arrow markers and thin dividers between items |
| Two-panel layout with violet top borders, ideal for comparing options or features |
| Large gradient metric numbers with optional trend indicators. Use 'Value |
| Stylized pull quote with violet left border, large quote mark, and attribution |
| Alert/callout box with color-coded variants: 'info' (cyan), 'warning' (amber), 'success' (green) |
| Grid of feature cards, each with an icon, title, and description. Use 'Icon |
| Horizontal milestone timeline with status indicators. Use 'Phase |
💡 Tips
Adjusting font size
Add an inline style to any slide to override the font size for the whole presentation:
<style>section { font-size: 1em; }</style>The academic style sets font-size: 0.95em by default.
Image morphing transitions (HTML only)
Use generate_agenda and add_image_transition to enable CSS View Transition morphing effects:
generate_agenda— scans section slides, inserts an agenda with numbered icons, and adds matching icons to each section slide so the icon morphs between agenda and section views.add_image_transition— inserts a full-screen background slide before an image slide and tags both with matchingview-transition-nameso the image appears to zoom in as you advance.
Both require HTML export (export_slide with format: "html") to render transitions.
🔧 Development
Working with Examples
Generate markdown examples:
pnpm run examples:generateGenerate HTML files locally:
pnpm run examples:htmlPreview examples with live reload (recommended for testing):
pnpm run examples:server
# Open http://localhost:8080 in your browserNote: HTML files are automatically generated and deployed to GitHub Pages by CI/CD. They are not committed to git.
📄 License
MIT License
🔗 Links
Maintenance
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/masaki39/marp-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server