Refactor high-complexity React components in Dify frontend. Use when `pnpm analyze-component...
npx skills add a692570/deckforge
Or install specific skill: npx add-skill https://github.com/a692570/deckforge
# Description
AI presentation skill - generate polished HTML slide decks with any coding agent
# SKILL.md
DeckForge - AI Presentation Workflow
Create stunning, presentation-ready slide decks from a simple topic idea. This document describes a complete workflow for generating professional HTML presentations with AI assistance.
Output Quality Standard
Every presentation should feel like it belongs on a top-tier SaaS marketing page. Clean, confident, minimal, professional.
Quick Start
For a new presentation:
"Create a pitch deck about [topic]"
"Make a presentation on [subject] for [audience]"
With your own content:
"Turn these notes into slides: [paste content]"
"Style this outline as a presentation"
The 5-Phase Workflow
Phase 1: Content Planning
Gather the essentials before writing a single line of code.
Required inputs:
- Topic - What is this about?
- Audience - Who's watching? (Investors, customers, executives, technical team, general public)
- Slide count - Short (5-10), Medium (10-20), or Long (20+)
- Key messages - 3-5 things the audience must remember
- Purpose - Pitch deck, teaching/tutorial, conference talk, internal presentation, sales/marketing
Output: Slide-by-Slide Outline
Create a detailed outline with content types for each slide:
| Content Type | Use For |
|---|---|
title |
Opening slide, section breaks |
content |
Standard information slides |
quote |
Testimonials, key statements |
stats |
Numbers, metrics, data points |
comparison |
Side-by-side contrasts |
image-heavy |
Visual storytelling |
diagram |
Processes, flows, architecture |
split |
Two-column layouts |
closing |
Call to action, final slide |
Example outline:
Slide 1: title - Company name + one-line value prop
Slide 2: content - The problem (pain points)
Slide 3: content - The solution (your product)
Slide 4: image-heavy - Product screenshot/demo
Slide 5: stats - Key metrics (users, growth, revenue)
Slide 6: comparison - Us vs. competitors
Slide 7: quote - Customer testimonial
Slide 8: diagram - How it works (3-step process)
Slide 9: content - Business model
Slide 10: closing - Call to action + contact
Get user approval on the outline before proceeding.
Phase 2: HTML Generation
Write the complete HTML presentation. This is the main creative work.
Design requirements:
- Varied layouts - No two consecutive slides should look identical
- Typography hierarchy - Clear distinction between headlines, subheads, body
- Generous whitespace - Content needs room to breathe
- CSS custom properties - All colors/fonts defined in
:rootfor easy theming - Image placeholders - Mark where visuals would enhance (don't leave blank)
HTML structure:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>[Presentation Title]</title>
<link rel="stylesheet" href="https://api.fontshare.com/v2/css?f[]=inter@400,500,600,700&f[]=space-grotesk@400,500,600,700">
<style>
:root {
/* Colors */
--bg-primary: #ffffff;
--bg-dark: #0A0A0A;
--text-primary: #1a1a1a;
--text-secondary: #666666;
--text-on-dark: #ffffff;
--accent: #00E3AA;
/* Typography */
--font-display: 'Space Grotesk', sans-serif;
--font-body: 'Inter', sans-serif;
--font-mono: 'JetBrains Mono', monospace;
/* Spacing */
--slide-padding: 4rem;
--content-max-width: 1200px;
/* Animation */
--ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
}
/* ... slide styles ... */
</style>
</head>
<body>
<section class="slide title-slide" data-slide="1">
<h1>Title</h1>
<p class="subtitle">Subtitle</p>
<!-- Speaker notes -->
<div class="speaker-notes" style="display:none;">
Notes for presenter...
</div>
</section>
<!-- More slides... -->
<script>
// Navigation and animations
</script>
</body>
</html>
Layout variety examples:
/* Title slide - centered, large type */
.slide.title-slide {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
text-align: center;
background: var(--bg-dark);
color: var(--text-on-dark);
}
/* Content slide - left-aligned, generous padding */
.slide.content-slide {
display: flex;
flex-direction: column;
justify-content: center;
padding: var(--slide-padding);
background: var(--bg-primary);
}
/* Split slide - two columns */
.slide.split-slide {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 3rem;
align-items: center;
padding: var(--slide-padding);
}
/* Stats slide - big numbers */
.slide.stats-slide {
display: flex;
justify-content: space-around;
align-items: center;
background: var(--bg-dark);
color: var(--text-on-dark);
}
.stat-number { font-size: 4rem; font-weight: 700; color: var(--accent); }
/* Quote slide - testimonial style */
.slide.quote-slide {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
text-align: center;
padding: var(--slide-padding);
background: var(--bg-secondary);
}
blockquote { font-size: 1.5rem; font-style: italic; max-width: 800px; }
/* Image-heavy slide */
.slide.image-slide {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 2rem;
padding: 0;
}
.slide.image-slide .image-container {
background-size: cover;
background-position: center;
height: 100%;
}
Anti-patterns to avoid:
- ❌ Purple gradients on white backgrounds (AI slop)
- ❌ Generic stock photo backgrounds
- ❌ Walls of text (keep to 3-5 bullet points max)
- ❌ Identical layouts repeated
- ❌ "In today's rapidly evolving world..." copy
- ❌ Center-aligning everything
- ❌ System fonts without intention
Phase 3: Image Generation
Fill image placeholders with appropriate visuals.
When to use AI-generated images:
- Custom illustrations/diagrams
- Product mockups that don't exist yet
- Abstract concepts that need visualization
- Unique branded illustrations
When to use stock photos:
- Real-world scenes, people, locations
- Established product screenshots
- General business/technology imagery
- When photorealism matters
Stock photo search queries:
[topic] site:unsplash.com
[topic] professional free stock photo
[topic] business presentation pexels
Image embedding options:
- Base64 inline (for small icons/illustrations):
<img src=".">
- Relative paths (for generated/downloaded images):
<img src="assets/slide-3-diagram.png" alt="Process flow">
- CSS background (for full-bleed images):
.slide.image-slide .visual {
background-image: url('assets/hero-image.jpg');
background-size: cover;
}
Image guidelines:
- Use WebP or optimized PNG when possible
- Keep individual images under 500KB
- Always include descriptive alt text
- Ensure sufficient contrast with overlaid text
Phase 4: Design Review
Audit and refine the HTML for quality.
Review checklist:
□ Visual hierarchy - Is it clear what to read first?
□ Copy quality - Punchy headlines, no filler words
□ Layout variety - No monotony between slides
□ Color consistency - Theme colors applied correctly
□ Typography - Readable sizes, proper contrast
□ Accessibility - Alt text, keyboard nav, reduced motion
□ Image quality - Appropriate, well-placed, optimized
□ Spacing - Generous but not excessive
□ Animation - Subtle, not distracting
Apply fixes directly:
- Tighten copy (shorter headlines, punchier bullets)
- Adjust spacing and alignment
- Ensure consistent styling
- Add missing alt text
- Remove generic filler content
Phase 5: Export
Generate all deliverable formats.
Step 5.1: PPTX Export
python3 scripts/pptx_export.py [presentation].html --output [presentation].pptx
The exporter handles:
- Slide backgrounds from CSS
- Image embedding
- Typography sizing (h1/h2/body)
- Layout detection from CSS classes
- Speaker notes from HTML comments
- 16:9 widescreen dimensions
- Proper master slide layouts
Step 5.2: PDF Export (via headless Chrome)
chrome --headless --print-to-pdf=[presentation].pdf --run-all-compositor-stages-before-draw --virtual-time-budget=5000 [presentation].html
Or manually:
1. Open HTML in browser
2. Wait for animations to settle
3. Print to PDF (landscape, 16:9)
Step 5.3: Delivery
Provide all three files:
- [name].html - Full experience with animations
- [name].pptx - Editable in Google Slides/PowerPoint
- [name].pdf - Shareable, print-ready
Design Standards
The quality bar: Every slide should look like it belongs on a top-tier SaaS marketing page.
Typography:
- Clean, modern fonts (Inter, Space Grotesk)
- Clear hierarchy: Display font for headlines, body font for content
- Monospace for code/data (JetBrains Mono)
Color:
- Professional palettes (not neon/gradient-heavy)
- Generous use of white space
- Strategic accent colors
- High contrast for readability
Layout:
- Content-first, minimal decoration
- Generous whitespace
- Varied layouts per slide
- Grid-based alignment
Animation:
- Subtle, not flashy
- Purposeful motion (guide the eye)
- Respect prefers-reduced-motion
Brand Import Workflow
Extract brand tokens from existing assets and auto-generate custom style presets. This enables presentations that match your company's existing visual identity without manual color picking.
From PPTX (PowerPoint Files)
Read an existing .pptx file to extract its theme and styling:
Step 1: Unzip and locate theme files
unzip -q company-deck.pptx -d pptx_extracted/
Step 2: Parse theme XML (ppt/theme/theme1.xml)
Look for these elements:
- <a:clrScheme> - Color scheme with names: dk1, dk2, lt1, lt2, accent1 through accent6
- Each color has an <a:srgbClr val="RRGGBB"/> or <a:sysClr val="..."/> element
- Example extraction:
xml
<a:dk1><a:srgbClr val="1A1A1A"/></a:dk1>
<a:accent1><a:srgbClr val="00E3AA"/></a:accent1>
Step 3: Parse slide master for fonts (ppt/slideMasters/slideMaster1.xml)
Find the font scheme:
- <a:fontScheme> contains <a:majorFont> and <a:minorFont>
- <a:latin typeface="Font Name"/> gives you the font families
- Major font = headlines/display, Minor font = body text
Step 4: Extract background styles
Check ppt/slideLayouts/slideLayout1.xml for:
- <p:bg> elements with solid fills, gradients, or image references
- <a:solidFill> with color values
- <a:gradFill> for gradient definitions
Step 5: Generate custom preset
Map extracted values to CSS variables:
- dk1 → --text-primary or --bg-dark
- lt1 → --bg-primary
- accent1 → --accent
- accent2-6 → --accent-secondary, etc.
- majorFont → --font-display
- minorFont → --font-body
From Website URL
Fetch a company's website to extract their visual identity:
Step 1: Fetch the page
curl -s https://linear.app > website.html
Step 2: Extract CSS color variables
Look for in <style> blocks or linked CSS:
- :root CSS variables like --color-primary, --brand-color, --accent
- Common patterns: primary, brand, accent, main, theme
- Hex codes: #RRGGBB, rgb(), hsl()
Step 3: Identify primary/secondary/accent colors
Priority order for extraction:
1. Explicit brand color variables (--color-brand, --primary)
2. Button/link colors (CTAs reveal brand colors)
3. Header/navigation background
4. Logo color (if SVG or inspectable)
Step 4: Extract font families
From CSS font-family declarations:
- Body text font (most common font-family)
- Headline font (larger sizes, different family)
- Check Google Fonts or Fontshare URLs for exact names
Step 5: Capture logo (optional)
If accessible:
- Look for <img> with "logo" in class/name
- SVG logos in <svg> or <symbol>
- Favicon for color reference
Step 6: Generate preset
Use extracted colors/fonts to build a custom preset matching the website's visual identity.
From Brand Guidelines PDF
Read a brand guidelines PDF to extract official design tokens:
Step 1: Read the PDF
Extract text content looking for:
- "Primary color", "Brand color", "Main color" + hex codes
- "Secondary", "Accent", "Highlight" colors
- Typography sections with font names
- Color palette tables or swatches
Step 2: Identify color codes
Search patterns:
- Hex codes: #RRGGBB or #RGB
- RGB values: rgb(255, 255, 255)
- CMYK: C:100 M:0 Y:0 K:0 (convert to hex)
- Pantone references (use approximate hex if provided)
Step 3: Extract typography
Look for:
- "Primary typeface", "Brand font"
- Headline vs. body font distinctions
- Web-safe alternatives if specified
Step 4: Note spacing/sizing rules
If specified:
- Minimum logo clearspace
- Border/margin preferences (can inform --slide-padding)
- Grid systems (can inform layout approach)
Step 5: Generate preset
Apply extracted values to the standard preset format, respecting the brand's official guidelines.
Output Format
Each import method produces a Custom Brand Preset block:
/* Custom Brand Preset: [Company Name] */
:root {
/* Extracted Color Palette */
--bg-primary: #[from lt1 or website bg];
--bg-secondary: #[lightened primary];
--bg-dark: #[from dk1 or dark section];
--text-primary: #[from dk1 or body text];
--text-secondary: #[muted version];
--text-on-dark: #[from lt1 or white];
--accent: #[from accent1 or primary brand];
--accent-secondary: #[from accent2-6];
/* Extracted Typography */
--font-display: '[majorFont]', sans-serif;
--font-body: '[minorFont]', sans-serif;
/* Derived */
--border: rgba(0,0,0,0.1);
--slide-padding: 4rem;
}
Include a comment header noting the source:
/* Auto-generated from: company-deck.pptx */
/* Auto-generated from: https://linear.app */
/* Auto-generated from: brand-guidelines.pdf */
Usage Examples
Example 1: Import from PPTX
"Create a presentation using the brand from attached company-deck.pptx"
AI actions:
1. Unzip and parse the PPTX theme XML
2. Extract color scheme and fonts
3. Generate custom preset
4. Create presentation using extracted brand
Example 2: Import from Website URL
"Match the brand style of https://linear.app for this pitch deck"
AI actions:
1. Fetch linear.app homepage
2. Extract CSS colors and fonts
3. Build custom preset matching Linear's aesthetic
4. Generate presentation with that styling
Example 3: Import from Brand Guidelines PDF
"Use our brand-guidelines.pdf to style a 10-slide product launch deck"
AI actions:
1. Read the PDF content
2. Extract official colors, fonts, and rules
3. Generate compliant custom preset
4. Create presentation following brand guidelines
Style Presets
See STYLE_PRESETS.md for 11 curated styles including:
- Modern SaaS (default) - Clean, confident, developer-friendly
- Neon Cyber - Futuristic, techy
- Midnight Executive - Premium, corporate
- Deep Space - Inspiring, visionary
- Terminal Green - Developer/hacker aesthetic
- Paper & Ink - Editorial, refined
- Swiss Modern - Precise, Bauhaus-inspired
- Soft Pastel - Friendly, approachable
- Warm Editorial - Human, storytelling
- Brutalist - Bold, unconventional
- Gradient Wave - Modern SaaS, energetic
File Structure
presentation.html # Self-contained presentation
presentation.pptx # PowerPoint export
presentation.pdf # PDF export
presentation-assets/ # Images, if any
├── slide-1-hero.jpg
├── slide-4-diagram.png
└── slide-7-logo.svg
Speaker Notes
Include hidden speaker notes in HTML:
<div class="speaker-notes" style="display:none;">
Key points to mention:
- Context about this metric
- Mention the customer case study
- Transition to next section
</div>
These are extracted during PPTX export and added as PowerPoint speaker notes.
Navigation & Interactions
Every presentation includes:
- Keyboard: Arrow keys, Page Up/Down, Space
- Touch: Swipe left/right
- Mouse: Scroll wheel, click navigation
- Progress: Visual indicator of slide position
Required JavaScript:
class SlidePresentation {
constructor() {
this.slides = document.querySelectorAll('.slide');
this.current = 0;
this.init();
}
init() {
// Keyboard navigation
document.addEventListener('keydown', (e) => {
if (e.key === 'ArrowRight' || e.key === ' ') this.next();
if (e.key === 'ArrowLeft') this.prev();
});
// Touch/swipe support
let startX = 0;
document.addEventListener('touchstart', (e) => startX = e.touches[0].clientX);
document.addEventListener('touchend', (e) => {
const diff = startX - e.changedTouches[0].clientX;
if (Math.abs(diff) > 50) diff > 0 ? this.next() : this.prev();
});
// Scroll snap for slide container
document.documentElement.style.scrollSnapType = 'y mandatory';
this.slides.forEach(s => s.style.scrollSnapAlign = 'start');
}
next() { /* scroll to next slide */ }
prev() { /* scroll to prev slide */ }
}
Example Sessions
AI-Generated Pitch Deck
User: "Create a pitch deck for my AI startup"
→ Gather: topic, audience (investors), slides (12), key messages
→ Generate outline → Get approval
→ Write HTML with varied layouts
→ Generate custom product mockup image
→ Audit and apply fixes
→ Export PPTX + PDF
→ Deliver all files
User Content to Slides
User: "Turn these notes into a presentation: [content]"
→ Structure into slide outline
→ Pick style (Modern SaaS)
→ Generate HTML
→ Add relevant stock photos
→ Export formats
→ Deliver
Style Variations
User: "Make 3 style options for my deck"
→ Generate 3 mini preview slides with different themes
→ User picks their preferred style
→ Apply to full presentation
→ Export
Requirements
- Python 3 with
python-pptxlibrary (for PPTX export) - Modern browser (Chrome/Edge/Firefox/Safari)
Troubleshooting
| Issue | Solution |
|---|---|
| PPTX export fails | Check python-pptx installed: pip3 install python-pptx |
| Images not in PPTX | Verify image paths are relative to HTML file |
| Fonts not loading | Check Fontshare/Google Fonts URL |
| Animations not working | Verify Intersection Observer is running |
| PDF has blank pages | Wait for animations to settle before printing |
# README.md
DeckForge
An AI presentation skill that generates production-quality HTML slide decks. Your agent reads the workflow, builds the slides, and exports to PPTX. You review and ship.
Requires an AI coding agent with file system access: Claude Code, Cursor, Codex CLI, Windsurf, Aider, or OpenClaw.
What it does
DeckForge is a structured, multi-phase workflow. It's not a prompt template you paste into a chat window. Your agent reads SKILL.md, follows the phases (outline, content, code, polish, export), and writes real files to disk.
The output is a self-contained HTML file with animated slide transitions, keyboard and touch navigation, and responsive layout. Optionally exports to PowerPoint.
Installation
Claude Code, Cursor, Codex CLI, Windsurf, Aider:
git clone https://github.com/a692570/deckforge.git
Point your agent at SKILL.md when you ask it to build a deck.
OpenClaw:
cd ~/.openclaw/skills
git clone https://github.com/a692570/deckforge.git presentation-maker
Requirements
- An AI coding agent with file system and terminal access
- Any capable LLM backend (Claude Opus 4.5, Sonnet 4.5, GPT-5.2, Gemini 3 Pro, etc.)
- Python 3 +
python-pptxif you want PowerPoint export (pip3 install python-pptx)
No additional API keys. Everything runs locally.
Example prompts
"Build a 12-slide pitch deck for an AI customer support startup. Audience: Series A investors."
"Convert these notes into a technical presentation on Kubernetes autoscaling: [paste notes]"
"15-slide conference talk on the future of AI agents. Visionary tone, deep space theme."
Themes
11 built-in presets, plus custom brand import.
| Theme | Best for |
|---|---|
| Modern SaaS (default) | Pitch decks, product demos |
| Neon Cyber | Tech talks, gaming |
| Midnight Executive | Board meetings, enterprise |
| Deep Space | Keynotes, vision talks |
| Terminal Green | Engineering presentations |
| Paper & Ink | Education, storytelling |
| Swiss Modern | Design presentations |
| Soft Pastel | Marketing, community |
| Warm Editorial | Brand storytelling |
| Brutalist | Creative pitches |
| Gradient Wave | Startup pitches |
Full CSS and font details in STYLE_PRESETS.md.
Brand import
You can also extract a theme from existing assets instead of picking a preset:
- From a PPTX: The agent unzips the file, reads
theme1.xml, and pulls out colors, fonts, and backgrounds. - From a website URL: Fetches the page, extracts CSS colors and font families, builds a matching preset.
- From a brand guidelines PDF: Parses hex codes, typography rules, and spacing from the document.
"Create a presentation using the brand from company-deck.pptx"
"Match the style of https://linear.app for this pitch deck"
"Use our brand-guidelines.pdf to style a 10-slide launch deck"
Output
presentation.html- Self-contained, works offline, full animationspresentation.pptx- Editable PowerPoint via export scriptpresentation.pdf- Print from browser
python3 scripts/pptx_export.py presentation.html --output presentation.pptx
How the workflow runs
- Agent reads
SKILL.mdand learns the 5-phase process - You describe what you need (topic, audience, tone)
- Agent generates an outline for your review
- Agent writes the full HTML with your chosen theme
- Export to PPTX or PDF if needed
What's in the repo
deckforge/
├── SKILL.md # The workflow your agent follows
├── STYLE_PRESETS.md # 11 themes with full CSS
├── README.md
├── LICENSE # MIT
└── scripts/
└── pptx_export.py # PowerPoint export
Design principles
- Clean typography with intentional font pairings
- Plenty of whitespace
- No two consecutive slides share the same layout
- Content first, decoration second
- No filler copy, no generic gradients
Contributing
New themes, better export scripts, workflow improvements. PRs welcome.
License
MIT. Free for personal and commercial use.
# Supported AI Coding Agents
This skill is compatible with the SKILL.md standard and works with all major AI coding agents:
Learn more about the SKILL.md standard and how to use these skills with your preferred AI coding agent.