Processes Markdown-formatted resume content to generate optimized, single-page PDF resumes through automated layout adjustments and content reduction strategies.
resume-onepage-autofit-mcp
An MCP server that lets AI agents deliver formatted, single-page PDF resumes โ not just text answers.
๐ ไธญๆ | English
๐ค Tired of copying between AI and Word, tweaking formats, and adjusting to fit one page? What if AI could handle that feedback loop for you? This MCP lets AI render PDFs and auto-adjust content to perfectly fit one page with clean formatting.
๐ฏ How It Works
User: Please generate a single-page resume from my experience
AI Agent:
1. ๐ Generate initial Markdown
2. ๐ Call render_resume_pdf to validate
3. โ ๏ธ Detected 12% overflow
4. ๐ง Apply Level 2 reduction strategy
5. โ
Success! PDF generated๐ Quick Start
1. Install MCP Server
# Enter MCP Server directory and install dependencies
cd mcp_server
pip install -r requirements.txt
# โก Or using uv (recommended): uv pip install -r requirements.txt
# Install Chromium browser (first time only, ~150MB)
playwright install chromium2. Configure Claude Desktop
Edit %APPDATA%\Claude\claude_desktop_config.json:
{
"mcpServers": {
"resume-onepage-autofit-mcp": {
"command": "python",
"args": ["<your-path>/myresumebuilder/mcp_server/mcp_server.py"]
}
}
}Replace
<your-path>with your actual project path.โก If you prefer using uv:
"resume-onepage-autofit-mcp": { "command": "uv", "args": [ "run", "--directory", "<your-path>/myresumebuilder", "mcp_server/mcp_server.py" ] }
3. Prepare Your Resume Content
Write your resume content in myexperience.md (refer to example_resume.md for format).
4. Start Using
Restart Claude Desktop, then simply tell the AI: "Please generate a single-page resume from my experience"
Generated PDFs are saved to the generated_resume/ folder in the project directory by default.
๐ก Custom Output Path:
Copy
js/config.example.jstojs/config.jsand modify thepdfOutputsettings at the topOr specify
output_pathparameter when calling to save to any location
โจ Core Features
๐ฏ Smart Fitting: Automatically adjusts content to fit resume perfectly on one A4 page
๐ Precise Detection: Pixel-accurate page height detection based on Playwright
๐ Layered Reduction: Three-tier reduction strategy (format optimization โ content simplification โ deep reduction)
๐ Feedback Loop: AI Agent intelligently iterates based on overflow metrics
๐ MCP Integration: Supports direct calls from Claude Desktop and other AI clients
๐ธ Workflow
User provides experience โ AI generates Markdown resume
โ
MCP Server renders & validates
โ
โโโโโโโโ Detect page height โโโโโโโโ
โ โ
Success Failure
(within one page) (overflow X%)
โ โ
Generate PDF Return overflow metrics + hints
โ โ
โ AI applies reduction strategy
โ (Level 1/2/3)
โ โ
โโโโโโโโโโโโโ Re-render โโโโโโโโโโโโ๐จ Reduction Strategy Overview
Level | Overflow Range | Strategy | Information Loss |
Level 1 | < 5% | Merge orphan lines, single-line lists | Low |
Level 2 | 5-15% | Remove soft skills, simplify descriptions | Medium |
Level 3 | > 15% | Delete irrelevant experiences | High |
See AI_AGENT_PROMPT.md for detailed strategies.
๐ง Visual Preview (Optional)
To manually adjust default style parameters, use the control panel (pure frontend, no Python needed):
# Use VS Code Live Server extension (recommended)
# Right-click control_panel.html -> "Open with Live Server"
# Or Python simple server
python -m http.server 8080
# Visit http://localhost:8080/control_panel.html๐ก The control panel is primarily for manually debugging style limits (e.g., font size ranges, line spacing). For daily use, rely on the AI Agent, which automatically adapts layout within optimal ranges based on content. For technical details, see DEVELOPMENT.md.
๐ Documentation
AI_AGENT_PROMPT.md: AI Agent core reduction strategies (must read)
DEVELOPMENT.md: Technical architecture & development guide
mcp_server/README.md: MCP Server API documentation
๐ Known Limitations
Browser Dependency: Requires Chromium (~150MB first time)
Content Length: Very long resumes (10+ pages) may need multiple reduction rounds
Special Characters: Some emoji may affect layout
๐ Development Roadmap
v0.2.0 (Planned)
Custom templates
๐ค Contributing
Issues and Pull Requests welcome!
Development Setup
# Clone repository
git clone https://github.com/seriserendipia/resume-onepage-autofit-mcp.git
cd resume-onepage-autofit-mcp
# Create virtual environment
conda create -n agent_env python=3.10
conda activate agent_env
# Install dependencies
pip install -r mcp_server/requirements.txt
playwright install chromiumCommit Convention
feat:New featurefix:Bug fixdocs:Documentation updatetest:Test related
๐ License
MIT License - See LICENSE
๐ Acknowledgments
Playwright - Powerful browser automation
MCP - Unified AI tool protocol
Markdown-it - Reliable Markdown parser
Paged.js - PDF pagination in the browser
๐ง Contact
๐ Issues: GitHub Issues
๐ฌ Discussions: GitHub Discussions
โญ If this project helps you, please give it a Star!
โญ ๅฆๆ่ฟไธช้กน็ฎๅฏนไฝ ๆๅธฎๅฉ๏ผ่ฏท็ปไธไธช Star๏ผ