slide-creator

Create beautiful, zero-dependency HTML presentations that run entirely in the browser — no npm, no build tools. 21 curated style presets with named layout variations, visual style discovery with live previews, viewport-fitted slides, inline browser editing, Presenter Mode, and optional PPTX export. Content-type routing suggests the best style for pitch decks, dev docs, data reports, and more. Supports --plan (outline), --generate (HTML from plan), and --export pptx flags.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "slide-creator" with this command: npx skills add kaisersong/slide-creator/kaisersong-slide-creator-slide-creator

Slide Creator

Generate zero-dependency HTML presentations that run entirely in the browser. This skill guides users from raw ideas to a polished, animated slide deck — using visual style discovery ("show, don't tell") to nail the aesthetic before writing a line of code.

Core Philosophy

  1. Zero Dependencies — Single HTML files with inline CSS/JS. No npm, no build tools.
  2. Show, Don't Tell — People can't articulate design preferences until they see options. Generate visual previews rather than asking abstract questions like "do you want minimalist or bold?"
  3. Distinctive Design — Avoid generic AI aesthetics (Inter font, purple gradients, predictable heroes). Every deck should feel custom-crafted.
  4. Viewport Fitting — Slides must fit exactly in the viewport with no scrolling. Content that overflows gets split across slides, not squished. A presentation that scrolls mid-slide is broken — this is why we enforce density limits.
  5. Plan Before Generate — For complex decks, --plan creates a PLANNING.md outline first; --generate then produces HTML. Separating thinking from execution leads to better structure and less backtracking.

Command Flags

Parse the invocation to determine mode:

  • --plan [prompt] — Planning mode. Inspect resources/, analyze the prompt, create PLANNING.md. Stop — do NOT generate HTML.
  • --generate [instructions] — Generation mode. Read PLANNING.md if present (skip Phase 1/2 questions), then generate HTML.
  • --export pptx [--scale N] — Export the most recently modified HTML as PPTX via the bundled Python script. Requires Python 3 + pip install playwright python-pptx. No Node.js required.
  • No flag — Auto-detect mode (Phase 0).

Planning Mode (--plan)

  1. Scan resources/ — read text/markdown files, note images. Tell the user what was found (or "Planning from prompt only" if empty).
  2. Extract: topic, audience, tone, language, slide count, goals from the prompt.
  3. Draft the plan following references/planning-template.md.
  4. Save as PLANNING.md in the working directory.
  5. Present slide count, structure, and key decisions. Ask for approval.
  6. Stop. Do NOT generate HTML.

Export Mode (--export pptx)

  1. Find *.html in current directory (prefer most recently modified).
  2. Run: python3 <skill-path>/scripts/export-pptx.py <presentation.html> [output.pptx]
  3. Report the PPTX file path and slide count.

The script uses Playwright with the user's existing system Chrome (--channel chrome flag, no Chromium download). It captures pixel-perfect screenshots of each slide and assembles them into a PPTX. Only pip install playwright python-pptx required — no Node.js, no 300MB browser download. If system Chrome is not found, the script will report an error and ask the user to install Chrome.


Phase 0: Detect Mode

Determine what the user wants:

  • Mode A — New Presentation: Check for PLANNING.md first. If it exists, read it as source of truth and jump directly to Phase 3 — skip Phase 1/2.
  • Mode B — PPT Conversion: User has a .ppt/.pptx file → go to Phase 4.
  • Mode C — Enhance Existing: Read the existing HTML, understand its structure, then enhance. When adding content, always check viewport fit — if adding would overflow a slide, split the content rather than cramming it in. Proactively split and inform the user.

Content-type → Style hints (use when user hasn't chosen a style):

Content typeSuggested styles
Data report / KPI dashboardData Story, Enterprise Dark, Swiss Modern
Business pitch / VC deckBold Signal, Aurora Mesh, Enterprise Dark
Developer tool / API docsTerminal Green, Neon Cyber, Neo-Retro Dev Deck
Research / thought leadershipModern Newspaper, Paper & Ink, Swiss Modern
Creative / personal brandVintage Editorial, Split Pastel, Neo-Brutalism
Product launch / SaaSAurora Mesh, Glassmorphism, Electric Studio
Education / tutorialNotebook Tabs, Paper & Ink, Pastel Geometry
Chinese contentChinese Chan, Aurora Mesh, Blue Sky
Hackathon / indie devNeo-Retro Dev Deck, Neo-Brutalism, Terminal Green

Phase 1: Content Discovery

First, silently scan for a resources/ folder. If found, read text/markdown files and note images as background context. Don't ask the user to take any action.

Then gather everything in a single AskUserQuestion call with all 5 questions at once — collecting everything before submitting avoids back-and-forth.

  • Purpose (single select): Pitch deck / Teaching+Tutorial / Conference talk / Internal presentation
  • Length (single select): Short 5-10 / Medium 10-20 / Long 20+
  • Content (single select): All content ready / Rough notes / Topic only
  • Images (single select): No images / ./assets / Other (user types path)
  • Inline Editing (single select): Yes — edit text in-browser, auto-save (Recommended) / No — presentation only

Default: Always include inline editing unless user explicitly selects "No". When --generate skips Phase 1, include inline editing by default.

If user has content, ask them to share it after submitting the form.

Language: Detect from the user's message — never default to a fixed language. Maintain the detected language throughout all slide text including labels, CTAs, and captions. English may appear as secondary annotation text only when the style calls for it.

Image Evaluation

Skip if user chose "No images." Text-only decks are fully first-class — CSS-generated gradients, shapes, and typography create compelling visuals without any images.

If images are provided:

  1. ls the folder, then use Read (multimodal) to view each image.
  2. For each image: mark USABLE or NOT USABLE (with reason: blurry, irrelevant, broken) + what it represents + dominant colors + shape.
  3. Build a slide outline that co-designs text and images from the start. This is not "plan slides, then fit images in after." Example: 3 usable product screenshots → 3 feature slides anchored by those screenshots.
  4. Present the evaluation and proposed outline, then confirm via AskUserQuestion (Looks good → Style B / Adjust images / Adjust outline).

Phase 2: Style Discovery

Most people can't articulate design preferences in words. Generate 3 mini visual previews and let them react — this is the "wow moment" of the skill.

Style Path

Ask via AskUserQuestion:

  • "Show me options" → ask mood question → generate 3 previews based on answer
  • "I know what I want" → show preset picker (Bold Signal / Blue Sky / Modern Newspaper / Neo-Retro Dev Deck — with "Other" option for all 21 presets)

Before showing presets, silently scan <skill-path>/themes/ for subdirectories. Skip any directory whose name starts with _ (those are examples/templates, not real themes). Each remaining subdirectory with a reference.md is a custom theme. Append them to the preset list as Custom: <folder-name> entries. If any custom themes exist, mention them first: "I also found N custom theme(s) in your themes/ folder."

Available Presets (full details in STYLE-DESC.md):

PresetVibeBest For
Bold SignalConfident, high-impactPitch decks, keynotes
Electric StudioClean, professionalAgency presentations
Creative VoltageEnergetic, retro-modernCreative pitches
Dark BotanicalElegant, sophisticatedPremium brands
Blue SkyClean, airy, enterprise-readySaaS pitches, AI/tech decks
Notebook TabsEditorial, organizedReports, reviews
Pastel GeometryFriendly, approachableProduct overviews
Split PastelPlayful, modernCreative agencies
Vintage EditorialWitty, personality-drivenPersonal brands
Neon CyberFuturistic, techyTech startups
Terminal GreenDeveloper-focusedDev tools, APIs
Swiss ModernMinimal, preciseCorporate, data
Paper & InkLiterary, thoughtfulStorytelling
Aurora MeshVibrant, premium SaaSProduct launches, VC pitch
Enterprise DarkAuthoritative, data-drivenB2B, investor decks, strategy
GlassmorphismLight, translucent, modernConsumer tech, brand launches
Neo-BrutalismBold, uncompromisingIndie dev, creative manifesto
Chinese ChanStill, contemplativeDesign philosophy, brand, culture
Data StoryClear, precise, persuasiveBusiness review, KPI, analytics
Modern NewspaperPunchy, authoritative, editorialBusiness reports, thought leadership, research summaries
Neo-Retro Dev DeckOpinionated, technical, handmadeDev tool launches, API docs, hackathon presentations

Mood → Preset mapping:

MoodStyle Options
Impressed/ConfidentBold Signal, Enterprise Dark, Neo-Brutalism
Excited/EnergizedCreative Voltage, Neon Cyber, Aurora Mesh
Calm/FocusedNotebook Tabs, Paper & Ink, Chinese Chan
Inspired/MovedDark Botanical, Vintage Editorial, Glassmorphism
Clean/EnterpriseBlue Sky, Electric Studio, Enterprise Dark
Data-DrivenData Story, Enterprise Dark, Swiss Modern
Playful/CreativeSplit Pastel, Pastel Geometry, Neo-Brutalism
Developer-FocusedTerminal Green, Neon Cyber, Neo-Retro Dev Deck
Editorial/OrganizedNotebook Tabs, Vintage Editorial, Modern Newspaper

Generate Previews

Create 3 mini HTML files in .claude-design/slide-previews/ (style-a/b/c.html). Each is a single title slide (~50-100 lines, self-contained) demonstrating typography, color palette, and animation style.

If a USABLE logo was found in Step 1.2, embed it (base64) into each preview — seeing their own brand in 3 different aesthetics makes the choice feel personal, not abstract.

Never use: Inter/Roboto/Arial as display fonts, generic purple-on-white gradients, predictable centered hero layouts.

Present the 3 files with a one-sentence description each, then ask via AskUserQuestion which they prefer (Style A / B / C / Mix elements).


Phase 3: Generate Presentation

Generate the presentation based on content from Phase 1 and style from Phase 2. If PLANNING.md exists, it's the source of truth — skip Phases 1 and 2.

If Blue Sky style is selected → use the starter template

Read references/blue-sky-starter.html and use it as the base.

All 10 signature visual elements (orbs, noise texture, grid, glassmorphism, spring-physics horizontal track, gradient text, cloud hero, pill dots, counter, entrance animation) are already implemented in that file. You only need to:

  1. Set --slide-count in :root to your actual slide count
  2. Replace the example slides in #track with your content, following the slide-type patterns in the comment block
  3. Fill the orbPositions array in JS — one [l1,t1,s1, l2,t2,s2, l3,t3,s3] entry per slide

Do not rewrite the visual system CSS. Do not change the track/slide layout. Content goes inside .slide wrappers using the pre-built component classes: .g (glass card), .gt (gradient text), .pill, .stat, .divider, .cols2/3/4, .ctable, .co (amber callout), .warn (red warning), .info (blue info), .layer (org row), ul.bl (bullet list).

If a custom theme from themes/ is selected

Read the theme's reference.md for style constraints. If a starter.html exists in the theme folder, use it as the base (same as Blue Sky). Otherwise, follow the standard references below and apply the custom theme's colors, typography, and layout rules.

For all other styles → read the standard references

Read references/html-template.md — it contains the required HTML structure, JavaScript patterns, animation recipes, and edit button implementation.

IMPORTANT — MUST READ before writing any HTML. Do NOT implement the edit button or presenter button from memory. The correct pattern uses a hotzone <div> + JS mouseenter/mouseleave with a 400ms grace period. Using body:hover is a known mistake — it makes the button permanently visible. The exact implementation is in html-template.md; copy it directly.

Also read STYLE-DESC.md for viewport fitting CSS, responsive breakpoints, style preset details, and CSS gotchas (especially: never negate CSS functions directly — use calc(-1 * clamp(...)) not -clamp(...)).

Viewport Fitting

Each slide must equal exactly one viewport height (100vh / 100dvh). When content doesn't fit, split it across slides — never allow scrolling within a slide. This is what separates a polished presentation from a broken one.

Content density limits:

Slide TypeMaximum
Title slide1 heading + 1 subtitle
Content slide1 heading + 4-6 bullets
Feature grid1 heading + 6 cards max (2×3 or 3×2)
Code slide1 heading + 8-10 lines
Quote slide1 quote (3 lines max) + attribution
Image slide1 heading + 1 image (max 60vh height)

When in doubt → split the slide.

Visual Rhythm: Alternate between text-heavy and visual-heavy slides. Three or more consecutive slides with the same layout signal low effort. Vary between: headline-dominant → data/diagram → evidence list → quote or visual break → headline-dominant. Every 4–5 slides, one slide should be nearly empty (a single statement, a big number, or a quote).

Diagram Slides (when content calls for a visual relationship)

When a slide needs to show a process, comparison, hierarchy, timeline, or data — generate an inline SVG diagram instead of bullet points.

Read references/diagram-patterns.md for ready-to-use SVG templates:

NeedPattern
Steps in a processHorizontal Flowchart
Events over timeVertical Timeline
Ranking / metricsHorizontal Bar Chart
Prioritisation2×2 Comparison Grid
Team / structureOrg / Hierarchy Chart

Rules:

  • One diagram per slide, never combined with a bullet list
  • Use currentColor so diagrams inherit the slide's text color automatically
  • Apply --accent color to the most important element (first step, top bar, highlighted quadrant)
  • Never use Mermaid.js, Chart.js, or any external library — inline SVG only

Image Pipeline (skip if no images)

For each USABLE image from Step 1.2, determine processing needed (circular crop for logos, resize for large files, padding for screenshots needing breathing room) and run it with Pillow. Reference images with relative paths (assets/...) — don't base64 encode unless the user explicitly wants a fully self-contained file.

Rules:

  • Never repeat an image across slides (logos may bookend title + closing)
  • Always add style-matched CSS framing (border/glow matching the style's accent color) when image colors clash with the palette

Code Quality

  • Comment every section: what it does, why it exists, how to modify it
  • Semantic HTML (<section>, <nav>, <main>)
  • ARIA labels on nav elements and interactive controls
  • @media (prefers-reduced-motion: reduce) support
  • No markdown symbols (#, *, **, _) in slide text — use semantic HTML elements (<strong>, <em>, <h2>) for structure and emphasis

Phase 4: PPT Conversion

Read references/pptx-extraction.md for the Python extraction script.

  1. Run the extraction script to get slides_data (title, content, images, notes per slide)
  2. Present extracted structure to user, confirm it looks right
  3. Run Phase 2 (Style Discovery) with extracted content in mind
  4. Generate HTML preserving all text, images (from assets/), and slide order. Put speaker notes in data-notes attributes on each .slide section (not HTML comments) so they work in Presenter Mode.

Phase 5: Delivery

  1. Clean up: delete .claude-design/slide-previews/ if it exists.
  2. Embed speaker notes in HTML — every .slide section must have a data-notes="..." attribute with 2-4 sentences (what to say, key emphasis, transition cue). These power the built-in Presenter Mode.
  3. Generate PRESENTATION_SCRIPT.md if deck has 8+ slides or was created from PLANNING.md (same notes content, formatted as a readable document).
  4. Open: open [filename].html
  5. Summarize:
Your presentation is ready!

📁 File: [filename].html
🎨 Style: [Style Name]
📊 Slides: [count]

Navigation: Arrow keys or Space · Scroll or swipe · Click dots to jump
Presenter Mode: press P to open the presenter window (notes + timer + controls)

To customize: edit :root variables at the top of the CSS for colors, fonts, and spacing.

To export as PPTX: run `/slide-creator --export pptx` (requires Python 3 + playwright + python-pptx, no Node.js)

Always mention: hover the top-left corner or press E to enter edit mode (included by default unless user explicitly opted out).


Effect → Feeling Guide

FeelingTechniques
Dramatic/CinematicSlow fade-ins 1-1.5s, dark backgrounds, full-bleed images, parallax
Techy/FuturisticNeon glow, particle canvas, grid patterns, monospace accents, glitch text effects
Playful/FriendlyBouncy easing, large rounded corners, pastels, floating/bobbing animations
ProfessionalSubtle 200-300ms animations, clean sans-serif, minimal decoration, data-focus
Calm/MinimalVery slow motion, high whitespace, muted palette, generous padding, serif type
EditorialStrong typography hierarchy, pull quotes, serif headlines, one accent color

Example: New Presentation

  1. "Make a pitch deck for my AI startup"
  2. Single form → purpose=pitch, length=medium, content=rough notes, images=./assets, editing=yes
  3. User shares notes; skill evaluates assets (4 USABLE, 1 blurry — excluded with explanation)
  4. Slide outline co-designed around text + images; confirmed via AskUserQuestion
  5. Mood=Impressed+Excited → 3 previews generated → user picks Neon Cyber
  6. Pillow processes images; HTML generated with full viewport CSS + JS suite
  7. Browser opens; user requests tweaks; final deck delivered

Example: PPT Conversion

  1. "Convert slides.pptx to a web presentation"
  2. Run extraction script → present extracted content → user confirms
  3. Style Discovery (Phase 2) → HTML generation with preserved assets
  4. Final presentation delivered

Related Skills

  • frontend-design — For interactive pages that go beyond slides
  • design-and-refine:design-lab — For iterating on component designs

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

slide-creator

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

slide-creator

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

Skill Creator (Opencode)

Create new skills, modify and improve existing skills, and measure skill performance. Use when users want to create a skill from scratch, edit, or optimize a...

Registry SourceRecently Updated
Coding

Funnel Builder

Builds complete multi-channel revenue funnels adapted to any business model. Combines proven frameworks from elite operators: Yomi Denzel's viral top-of-funn...

Registry SourceRecently Updated