# Frontend Slides A coding-agent skill for creating stunning HTML presentations — from scratch or by converting PowerPoint files. It is packaged as a Claude Code plugin, and the core `SKILL.md` can also be read by other coding agents with filesystem and shell access. ## What This Does **Frontend Slides** helps non-designers create beautiful web presentations without knowing CSS or JavaScript. It uses a "show, don't tell" approach: instead of asking you to describe your aesthetic preferences in words, it generates visual previews and lets you pick what you like. Here is a deck about the skill, made through the skill: https://github.com/user-attachments/assets/ef57333e-f879-432a-afb9-180388982478 ### Key Features - **Zero Dependencies** — Single HTML files with inline CSS/JS. No npm, no build tools, no frameworks. - **Visual Style Discovery** — Can't articulate design preferences? No problem. Pick from generated visual previews. - **PPT Conversion** — Convert existing PowerPoint files to web, preserving all images and content. - **Anti-AI-Slop** — Curated distinctive styles that avoid generic AI aesthetics (bye-bye, purple gradients on white). - **Bold Template Pack** — Optional design-forward templates from `beautiful-html-templates`, loaded progressively so safe presets still work as the default fallback. - **Production Quality** — Accessible, fixed 16:9, well-commented code you can customize. ## Installation ### Via Claude Code Custom Marketplace Source Install directly from this public GitHub repo. Run these as two separate Claude Code messages; do not paste both lines into the prompt at once. ```text /plugin marketplace add https://github.com/zarazhangrui/frontend-slides ``` After that finishes, run: ```text /plugin install frontend-slides@frontend-slides ``` Use the HTTPS URL. The shorter `zarazhangrui/frontend-slides` form may make Claude Code try SSH, which can fail if GitHub is not already in your `known_hosts` file. Then use it by typing `/frontend-slides:frontend-slides` in Claude Code. Claude Code namespaces plugin-installed skills as `/plugin-name:skill-name`. ### Claude Code Manual Installation Copy the skill files to your Claude Code skills directory: ```bash # Create the skill directory mkdir -p ~/.claude/skills/frontend-slides/scripts # Copy the user-facing skill files cp SKILL.md STYLE_PRESETS.md viewport-base.css html-template.md animation-patterns.md ~/.claude/skills/frontend-slides/ cp -R bold-template-pack ~/.claude/skills/frontend-slides/ cp scripts/extract-pptx.py scripts/deploy.sh scripts/export-pdf.sh ~/.claude/skills/frontend-slides/scripts/ ``` Or clone directly: ```bash git clone https://github.com/zarazhangrui/frontend-slides.git ~/.claude/skills/frontend-slides ``` Then use it by typing `/frontend-slides` in Claude Code. Standalone skills are not namespaced. ### Other Coding Agents Agents such as Codex, Kimi Code, OpenCode, Gemini CLI, or other local coding assistants can use the same core skill. The simplest path is to send the agent this GitHub repo link and ask it to use the Frontend Slides skill: ```text https://github.com/zarazhangrui/frontend-slides ``` If the agent can read GitHub repos or browse files, it should start from `SKILL.md` and load only the referenced support files it needs: - `STYLE_PRESETS.md` - `viewport-base.css` - `html-template.md` - `animation-patterns.md` - `bold-template-pack/` - `scripts/` Some agents can also install the skill for you if they have filesystem access and a known local skills directory. If not, they can still follow `SKILL.md` directly for the current session. The Claude Code plugin gives Claude Code a custom marketplace-source install flow and `/frontend-slides:frontend-slides` command. Other agents usually do not use that command surface. ## Usage ### Create a New Presentation ```text /frontend-slides:frontend-slides > "I want to create a pitch deck for my AI startup" ``` If installed manually as a standalone Claude Code skill, use `/frontend-slides` instead. In non-Claude agents, ask the agent to use the Frontend Slides skill and point it at this repo or `SKILL.md`. The skill will: 1. Ask about your content (slides, messages, images) 2. Generate 3 visual style previews for you to compare, inferring the vibe from your brief unless you already named one 3. Let you pick the visual direction 4. Create the full presentation in your chosen style 5. Open it in your browser ### Convert a PowerPoint ```text /frontend-slides:frontend-slides > "Convert my presentation.pptx to a web slideshow" ``` The skill will: 1. Extract all text, images, and notes from your PPT 2. Show you the extracted content for confirmation 3. Let you pick a visual style 4. Generate an HTML presentation with all your original assets ## Included Styles ### Dark Themes - **Bold Signal** — Confident, high-impact, vibrant card on dark - **Electric Studio** — Clean, professional, split-panel - **Creative Voltage** — Energetic, retro-modern, electric blue + neon - **Dark Botanical** — Elegant, sophisticated, warm accents ### Light Themes - **Notebook Tabs** — Editorial, organized, paper with colorful tabs - **Pastel Geometry** — Friendly, approachable, vertical pills - **Split Pastel** — Playful, modern, two-color vertical split - **Vintage Editorial** — Witty, personality-driven, geometric shapes ### Specialty - **Neon Cyber** — Futuristic, particle backgrounds, neon glow - **Terminal Green** — Developer-focused, hacker aesthetic - **Swiss Modern** — Minimal, Bauhaus-inspired, geometric - **Paper & Ink** — Literary, drop caps, pull quotes ### Bold Template Pack The skill also includes 34 optional bold design systems from `beautiful-html-templates`, such as **Neo-Grid Bold**, **Editorial Tri-Tone**, **Creative Mode**, **Broadside**, **Signal**, and **Vellum**. During style discovery, the preview set is: - 1 safe preset from `STYLE_PRESETS.md` - at least 1 bold template option from `bold-template-pack/selection-index.json` - 1 wildcard option, either another bold template or a self-generated custom design The agent reads the compact bold template index first, then loads only the shortlisted candidates' small `preview.md` cards for title-slide previews. It loads the full `design.md` for exactly one bold template only after the user picks that template for the final deck. If the user picks a custom wildcard, the agent expands that preview's own CSS and layout system into the full deck. ## Bold Template Gallery Frontend Slides can now draw from the 34 bold design systems in [`beautiful-html-templates`](https://github.com/zarazhangrui/beautiful-html-templates). Three screenshots per template show how each visual system handles different slide layouts. Click any template name to inspect the source template library. ### [Soft Editorial](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/soft-editorial/)

Soft Editorial — slide 4 Soft Editorial — slide 6 Soft Editorial — slide 10

> Cormorant Garamond serif on warm paper with sage, blush, and lemon accents. ### [Editorial Forest](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/editorial-forest/)

Editorial Forest — slide 1 Editorial Forest — slide 2 Editorial Forest — slide 5

> Forest green, dusty pink, and warm cream in Source Serif 4 — quiet, intentional quarterly-review aesthetic. ### [Pin & Paper](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/pin-and-paper/)

Pin & Paper — slide 1 Pin & Paper — slide 11 Pin & Paper — slide 3

> Yellow paper with safety-pin illustrations, ink-blue handwritten Caveat, paper-grain texture. ### [Sakura Chroma](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/sakura-chroma/)

Sakura Chroma — slide 1 Sakura Chroma — slide 3 Sakura Chroma — slide 4

> Vintage Japanese cassette-package aesthetic: cream paper, diagonal rainbow ribbons, condensed bold type, JIS-style spec checkboxes. ### [Stencil & Tablet](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/stencil-tablet/)

Stencil & Tablet — slide 1 Stencil & Tablet — slide 3 Stencil & Tablet — slide 8

> Bone paper with stencil-cut headlines and a six-color earth palette: archaeology meets brand. ### [Cobalt Grid](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/cobalt-grid/)

Cobalt Grid — slide 1 Cobalt Grid — slide 3 Cobalt Grid — slide 5

> Electric cobalt italic serifs on a graph-paper canvas, anchored by stair-stepped pixel-glitch decorations and slim hairline rules. ### [Vellum](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/vellum/)

Vellum — slide 1 Vellum — slide 4 Vellum — slide 8

> Deep navy canvas with warm-yellow italic Cormorant serifs and a single dusty teal accent. A quiet, scholarly aesthetic. ### [Emerald Editorial](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/emerald-editorial/)

Emerald Editorial — slide 1 Emerald Editorial — slide 3 Emerald Editorial — slide 6

> Magazine-cover business deck: emerald + navy + paper with double-rule masthead ornaments and a heavy Bodoni-style display serif. ### [Neo-Grid Bold](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/neo-grid-bold/)

Neo-Grid Bold — slide 1 Neo-Grid Bold — slide 3 Neo-Grid Bold — slide 8

> Editorial neo-brutalism with a single neon yellow accent on off-white paper. ### [Editorial Tri-Tone](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/editorial-tri-tone/)

Editorial Tri-Tone — slide 1 Editorial Tri-Tone — slide 4 Editorial Tri-Tone — slide 3

> Three-color editorial system: dusty pink, mustard cream, and deep burgundy, set in Bricolage + Instrument Serif. ### [Creative Mode](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/creative-mode/)

Creative Mode — slide 1 Creative Mode — slide 4 Creative Mode — slide 6

> Cream paper canvas with confident multi-color (green, pink, orange, yellow) accents and Archivo Black display. ### [Monochrome](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/monochrome/)

Monochrome — slide 1 Monochrome — slide 4 Monochrome — slide 12

> Ivory ledger paper with all-black type; Lora serif headlines, Jost body, no color at all. ### [People's Platform (Block & Bold)](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/peoples-platform/)

People's Platform (Block & Bold) — slide 1 People's Platform (Block & Bold) — slide 4 People's Platform (Block & Bold) — slide 8

> Activist poster energy: blue, orange, red on cream, with Alfa Slab + Caveat Brush. ### [Pink Script — After Hours](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/pink-script/)

Pink Script — After Hours — slide 1 Pink Script — After Hours — slide 4 Pink Script — After Hours — slide 8

> Black canvas, hot pink accent, pearl-cream paper, Instrument Serif headlines: late-night editorial luxury. ### [8-Bit Orbit](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/8-bit-orbit/)

8-Bit Orbit — slide 1 8-Bit Orbit — slide 6 8-Bit Orbit — slide 5

> Pixel-art neon arcade aesthetic on a deep navy void. ### [BlockFrame](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/block-frame/)

BlockFrame — slide 1 BlockFrame — slide 4 BlockFrame — slide 8

> Neobrutalist deck with pastel-neon color blocks and chunky black borders. ### [Blue Professional](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/blue-professional/)

Blue Professional — slide 1 Blue Professional — slide 6 Blue Professional — slide 8

> Cream paper background with electric cobalt blue accents; clean modern professional. ### [Bold Poster](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/bold-poster/)

Bold Poster — slide 1 Bold Poster — slide 4 Bold Poster — slide 8

> Editorial poster aesthetic with massive Shrikhand display and a single fire-engine red accent. ### [Broadside](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/broadside/)

Broadside — slide 1 Broadside — slide 4 Broadside — slide 13

> Dark editorial canvas with a single fire orange accent and bilingual Latin/Chinese type stack. ### [Capsule](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/capsule/)

Capsule — slide 1 Capsule — slide 4 Capsule — slide 8

> Modular pill-shaped cards on warm bone with a full pastel-pop palette. ### [Cartesian](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/cartesian/)

Cartesian — slide 1 Cartesian — slide 4 Cartesian — slide 8

> Quiet warm-neutral palette with classical Playfair serifs; tasteful and unhurried. ### [Coral](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/coral/)

Coral — slide 1 Coral — slide 4 Coral — slide 8

> Cream and coral on near-black, set in oversized Bebas Neue. ### [Daisy Days](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/daisy-days/)

Daisy Days — slide 1 Daisy Days — slide 4 Daisy Days — slide 8

> Cheerful pastel deck with hand-drawn daisies, stars, and rainbows. Friendly, soft, and warm. ### [Grove](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/grove/)

Grove — slide 1 Grove — slide 4 Grove — slide 8

> Forest-green canvas with cream type, classical Playfair serifs, and a single rust accent. ### [Mat](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/mat/)

Mat — slide 1 Mat — slide 4 Mat — slide 8

> Dark sage canvas with bone paper and burnt-orange accent; mid-century modern with wood undertones. ### [Playful](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/playful/)

Playful — slide 1 Playful — slide 6 Playful — slide 8

> Sun-warm peach background with Syne display: a friendly indie launch deck. ### [Raw Grid](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/raw-grid/)

Raw Grid — slide 1 Raw Grid — slide 4 Raw Grid — slide 8

> Neo-brutalist deck with thick borders, offset shadows, and a pink/sage/ink palette. ### [Retro Windows](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/retro-windows/)

Retro Windows — slide 1 Retro Windows — slide 4 Retro Windows — slide 8

> Windows 95 chrome: gray title bars, MS Sans Serif, pixel typography, full nostalgia. ### [Retro Zine](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/retro-zine/)

Retro Zine — slide 1 Retro Zine — slide 4 Retro Zine — slide 8

> Beige paper with green accent and Bebas Neue + Caveat: a riso-printed zine in HTML form. ### [Scatterbrain](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/scatterbrain/)

Scatterbrain — slide 1 Scatterbrain — slide 4 Scatterbrain — slide 8

> Post-it inspired: pastel sticky notes, Caveat handwriting, Shrikhand and Zilla Slab type stack. ### [Signal](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/signal/)

Signal — slide 1 Signal — slide 18 Signal — slide 8

> Deep navy canvas with bone paper and a single muted-gold accent; institutional with quiet weight. ### [Studio](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/studio/)

Studio — slide 1 Studio — slide 4 Studio — slide 8

> Black canvas with electric-yellow type; high-voltage design studio aesthetic. ### [Biennale Yellow](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/biennale-yellow/)

Biennale Yellow — slide 1 Biennale Yellow — slide 5 Biennale Yellow — slide 8

> Solar yellow on warm parchment with deep indigo serif and atmospheric sun-glow gradients. Dutch-editorial poster energy. ### [Long Table](https://github.com/zarazhangrui/beautiful-html-templates/tree/main/templates/long-table/)

Long Table — slide 1 Long Table — slide 3 Long Table — slide 7

> Warm cream and rust-red supper-club aesthetic with bold uppercase grotesk headlines, italic Fraunces, and pill-shaped outlined buttons. ## Architecture This skill uses **progressive disclosure** — the main `SKILL.md` is a workflow map, with supporting files loaded on-demand only when needed: | File | Purpose | Loaded When | | ------------------------- | ------------------------------ | ------------------------- | | `SKILL.md` | Core workflow and rules | Always (skill invocation) | | `STYLE_PRESETS.md` | 12 curated visual presets | Phase 2 (style selection) | | `bold-template-pack/selection-index.json` | Compact bold template metadata | Phase 2 (candidate selection) | | `bold-template-pack/templates/*/preview.md` | Tiny style cards for shortlisted bold previews | Phase 2 after shortlisting | | `bold-template-pack/templates/*/design.md` | Full design system for the selected bold template | Phase 3 after user selection | | `viewport-base.css` | Mandatory fixed-stage CSS | Phase 3 (generation) | | `html-template.md` | HTML structure and JS features | Phase 3 (generation) | | `animation-patterns.md` | CSS/JS animation reference | Phase 3 (generation) | | `scripts/extract-pptx.py` | PPT content extraction | Phase 4 (conversion) | | `scripts/deploy.sh` | Deploy to Vercel | Phase 6 (sharing) | | `scripts/export-pdf.sh` | Export slides to PDF | Phase 6 (sharing) | Maintenance-only source metadata and regeneration helpers live outside the user-facing skill package. Normal users do not need them. This design follows agent-skill best practices: give the agent a map first, then reveal only the specific files needed for the current choice. ## Philosophy This skill was born from the belief that: 1. **You don't need to be a designer to make beautiful things.** You just need to react to what you see. 2. **Dependencies are debt.** A single HTML file will work in 10 years. A React project from 2019? Good luck. 3. **Generic is forgettable.** Every presentation should feel custom-crafted, not template-generated. 4. **Comments are kindness.** Code should explain itself to future-you (or anyone else who opens it). ## Sharing Your Presentations After creating a presentation, the skill offers two ways to share it: ### Deploy to a Live URL One command deploys your slides to a permanent, shareable URL that works on any device — phones, tablets, laptops: ```bash bash scripts/deploy.sh ./my-deck/ # or bash scripts/deploy.sh ./presentation.html ``` Uses [Vercel](https://vercel.com) (free tier). The skill walks you through signup and login if it's your first time. ### Export to PDF Convert your slides to a PDF for email, Slack, Notion, or printing: ```bash bash scripts/export-pdf.sh ./my-deck/index.html bash scripts/export-pdf.sh ./presentation.html ./output.pdf ``` Uses [Playwright](https://playwright.dev) to screenshot each slide at 1920×1080 and combine into a PDF. Installs automatically if needed. Animations are not preserved (it's a static snapshot). ## Requirements - A local coding agent with filesystem access and the ability to run shell commands - Claude Code is required only for the custom marketplace-source install and `/frontend-slides:frontend-slides` command - For PPT conversion: Python with `python-pptx` library - For URL deployment: Node.js + Vercel account (free) - For PDF export: Node.js (Playwright installs automatically) ## Credits Created by [@zarazhangrui](https://github.com/zarazhangrui). ## License MIT — Use it, modify it, share it.