4.2 KiB
open-design-landing-deck
Sister skill to open-design-landing.
Produces a single-file slide deck in the Atelier Zero design
language — warm-paper background, italic-serif emphasis, coral
terminating dots, surreal collage plates — paginated as a horizontal
magazine swipe deck (←/→ · wheel · touch · ESC overview), the same
nav model as guizang-ppt.
Read first — agent contract, schema, and self-check live in
SKILL.md. This README is the human quick-start.
30-second tour
# 1. Compose the worked example.
npx tsx scripts/compose.ts inputs.example.json example.html
# 2. Open it.
open example.html
The deck assumes 16 collage assets at ../open-design-landing/assets/
(the sister skill ships them). Use ←/→ · Space · PageUp/PageDown ·
Home/End to navigate, ESC for the overview grid.
What you get
- N viewport-sized slides (the worked example has 11) laid out
horizontally on a
transform: translateX(...)flex track. - Per-slide chrome strip (top + bottom): brand mark · deck title ·
location · live
NN / TTcounter. - Coral progress bar at the bottom that fills as you advance.
- Dot indicator near the bottom (click to jump).
- ESC overview grid with scaled thumbnails.
- 7 slide kinds:
cover,section,content,stats,quote,cta,end. Mix freely. - Same 16-slot image library as the landing-page sister skill — no extra prompting or rendering.
Files
skills/open-design-landing-deck/
├── SKILL.md # ← agent contract (read this first)
├── README.md # ← you are here
├── schema.ts # typed slide variants + brand block (re-exports from sister)
├── inputs.example.json # Open Design 11-slide pitch deck
├── example.html # canonical rendering
└── scripts/
└── compose.ts # inputs.json + sister styles.css → index.html
Authoring a deck
-
Copy
inputs.example.jsonto your project asinputs.json. -
Edit
brand(or copy from a sister-skillinputs.jsonyou already have). -
Set
deck_title(the kicker shown in the chrome strip). -
Build the
slidesarray. Each entry is one of seven kinds — seeschema.tsfor the full type. A typical pitch:1. cover — title plate 2. section — chapter divider 3-5. content — manifesto, capabilities, method 6. stats — the numbers 7. section — chapter divider 8. content — selected work 9. quote — customer testimonial 10. cta — primary action 11. end — kicker word -
Run the composer:
npx tsx scripts/compose.ts inputs.json out/index.html
Image strategy
The deck inherits the sister skill's 16-slot image library. Set
inputs.imagery.assets_path to wherever those PNGs live; the example
uses '../open-design-landing/assets/'.
To regenerate or stub:
# Generate via gpt-image-2 (fal.ai)
FAL_KEY=fal-... npx tsx ../open-design-landing/scripts/imagegen.ts \
../open-design-landing/inputs.example.json \
--out=../open-design-landing/assets/
# Or paper-textured SVG placeholders
npx tsx ../open-design-landing/scripts/placeholder.ts ../open-design-landing/assets/
Migrating from editorial-collage-deck
This skill replaces the older editorial-collage-deck skill. The renames
are mechanical:
| Old | New |
|---|---|
skill folder editorial-collage-deck/ |
open-design-landing-deck/ |
shared assets ../editorial-collage/assets/ |
../open-design-landing/assets/ |
TS type EditorialCollageDeckInputs |
OpenDesignLandingDeckInputs |
The EditorialCollageDeckInputs alias re-exported from
schema.ts is a temporary bridge: it is kept for the
v0.3.x line and removed in the next minor release (v0.4.0).
Update imports before then.
See also
open-design-landing— landing page sister skill.guizang-ppt— the magazine-deck navigation pattern this skill borrows.design-systems/atelier-zero/DESIGN.md— design tokens.