pdf-it
The pdf-it server converts markdown content into professionally designed PDF documents. You can:
Generate PDFs from Markdown (
generate_pdf): Convert markdown into a polished PDF with these options:research-reporttemplate (default): includes a cover page with title, author, and date; an auto-generated table of contents from H1/H2 headings; and a page-numbered footerplaintemplate: body content only — no cover, no TOCOptionally specify a title, author, and custom output path (defaults to
~/Documents/pdf-it/{slug}-{timestamp}.pdf)
List Available Templates (
list_templates): Retrieve all available templates with their descriptions.
Key highlights:
Bundled fonts (Newsreader, DM Sans, JetBrains Mono) ensure consistent output
Handles code blocks, tables, blockquotes, headings, and lists
Renders in under 2 seconds even for 30-page documents
pdf-it
A Model Context Protocol (MCP) server and Claude Code skill that turns markdown into PDFs that look like they were made on purpose. Cover page, table of contents, code blocks that hold across page breaks, page-numbered footer. One command from your Claude session to a file you can send to a client.
Fonts ship inside the package, so every PDF looks the same on every machine. Nothing to install, nothing to configure.

Why this exists
Every Claude Code research session ends the same way: a wall of useful markdown and no clean way to turn it into a PDF a person would actually want to read.
Chrome print: takes 30 seconds, output looks like a Word doc. Manual HTML conversion: 10 minutes per document. Pandoc: works but defaults look like a 2008 academic paper. None of it produces an artifact you would send to a client.
pdf-it is one command. The output is designed by default.

Related MCP server: Gen-PDF MCP Server
Install
npm install -g pdf-it-mcpOr run on demand with npx pdf-it-mcp.
Requirements
Node.js 20 or newer
Nothing else to install. The renderer and fonts ship inside the package.
Configure
Claude Desktop
Edit claude_desktop_config.json:
{
"mcpServers": {
"pdf-it": {
"command": "npx",
"args": ["-y", "pdf-it-mcp"]
}
}
}Claude Code
claude mcp add pdf-it -- npx -y pdf-it-mcpCursor
Add to ~/.cursor/mcp.json with the same shape as Claude Desktop.
Cline / Continue / Zed / Goose
Standard MCP config. Same npx -y pdf-it-mcp command.
Use
In any Claude session connected to the server, ask:
Save this as a PDF
Or any of these phrasings: export as PDF, make a PDF report from this, turn this into a PDF, /pdf. The skill picks up the request and routes it through pdf-it. The output lands in ~/Documents/pdf-it/ by default.
Tools
Tool | Description |
| Convert markdown into a PDF. Accepts a template ( |
| Return the list of available templates with descriptions. |
generate_pdf parameters
Parameter | Required | Description |
| yes | Markdown string to convert |
| no | Shown on the cover and in the page footer |
| no | Shown on the cover above the date |
| no | Absolute path for the output. Defaults to |
| no |
|
Templates
Name | Description |
| Cover page with title, author, and date. Auto-generated table of contents from H1 and H2 headings. Body with proper hierarchy. Footer with title and page number. Best for research, summaries, design docs, reports. |
| No cover, no TOC. Dense body content only. Best for short notes and quick exports. |
Skill
This package ships with a Claude Code skill at SKILL.md. Trigger phrases the skill responds to:
save this as PDFexport as PDFmake a PDF report from thisturn this into a PDFgenerate a PDF/pdf
See SKILL.md for the full skill spec.
Output
By default PDFs are written to ~/Documents/pdf-it/{slug}-{timestamp}.pdf. Pass output_path to override.
Design
Three families ship inside the package:
Newsreader for the cover title (display 60, light) and body H1 (display 32). High-contrast serif that holds editorial weight at large sizes.
DM Sans for H2, H3, table type, and the TOC heading. Quieter sub-hierarchy.
JetBrains Mono for page numbers, metadata, code, and figure captions.
Pure white paper, near-black ink (#111113), secondary ink for date and table cells (#2B2B2E), muted gray for page numbers and date (#7A7A7E), hairline borders (#E6E6E6). No accent colors. Code blocks render without syntax highlighting on purpose: color choices in PDFs age badly.
Every value lives in src/templates/design-tokens.ts as the single source of truth. If you want a different design language, fork the components. They live in src/templates/components/ and are plain React-PDF components with a small surface area.
How it works
Parse: remark converts your markdown into an AST.
Compose: the AST becomes typed React components (Cover, TOC, and body primitives like H1/H2/H3, Paragraph, CodeBlock, Blockquote, Table, lists, and charts).
Render:
@react-pdf/rendererrasterizes the React tree into a deterministic PDF with embedded fonts and TOC anchors.Output: the PDF lands in
~/Documents/pdf-it/{slug}-{timestamp}.pdfwith title/author metadata embedded.
Total time: typically sub-second for a 5-page document, 1-2 seconds for a 30-page document.
Recognition
Listed on npm, Glama, and LobeHub.
Disclaimer
This is an unofficial, community-built tool. It is not affiliated with, endorsed by, or sponsored by Anthropic PBC. Claude and Claude Code are trademarks of Anthropic PBC.
pdf-it runs locally and ships its own renderer (@react-pdf/renderer) and fonts. Use at your own risk. The author accepts no liability for issues arising from misuse, prompt injection, bugs, or rendering failures.
License
MIT. See LICENSE.
Maintenance
Tools
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/mrslbt/pdf-it'
If you have feedback or need assistance with the MCP directory API, please join our Discord server