launchframe 0.4.2 → 0.4.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,45 +1,505 @@
1
1
  # AUTO-GENERATED from .claude/skills/launchframe/SKILL.md
2
2
  # Run `node scripts/sync-skills.mjs` to regenerate.
3
3
 
4
- description = "Scaffold with npx launchframe@latest into the current folder no arguments required"
4
+ description = "Reverse-engineer a reference URL into this repo + SaaS landing copy — /launchframe"
5
5
 
6
6
  [prompt]
7
7
  text = '''
8
8
 
9
9
  # Launchframe
10
10
 
11
- Help the user create a **new** Launchframe project. The CLI is **parameterless**:
11
+ **`/launchframe`** is the **only** slash command for reverse-engineering a live site into this codebase. Parse **{{args}}**:
12
12
 
13
- ```bash
14
- npx launchframe@latest
13
+ 1. **Reference URL(s)** — Every `http://` or `https://` token (clone each site; use `docs/research/<hostname>/` when there are multiple).
14
+ 2. **SaaS idea** — All remaining text that is not a URL (often quoted): product pitch for hero and key marketing lines.
15
+
16
+ You are a **foreman walking the job site** — write specs per section, dispatch builders in parallel where possible, merge, QA. Not a shallow inspect-then-guess flow.
17
+
18
+ ## Step 0 — Persist Launchframe inputs
19
+
20
+ Before reconnaissance, write or update:
21
+
22
+ - `src/lib/launchframe-config.ts` — `LAUNCHFRAME_SOURCE_URL` (primary URL, usually first), `LAUNCHFRAME_SAAS_IDEA`
23
+ - `launchframe.context.json`
24
+ - `docs/research/LAUNCHFRAME.md` — URLs and SaaS idea
25
+
26
+ ## SaaS copy overlay (Phase 4 assembly and final polish)
27
+
28
+ After structure and styles match the reference, apply the **SaaS idea** to hero, headings, and primary CTAs where the reference uses interchangeable marketing copy, **without** changing layout grids, spacing, or motion from extracted specs. Respect third-party brands.
29
+
30
+ ---
31
+
32
+ ## Scope Defaults
33
+
34
+ The target page(s) are the URL(s) you parsed in Pre-Flight. Clone exactly what's visible at each URL. Unless the user specifies otherwise, use these defaults:
35
+
36
+ - **Fidelity level:** Pixel-perfect — exact match in colors, spacing, typography, animations
37
+ - **In scope:** Visual layout and styling, component structure and interactions, responsive design, mock data for demo purposes
38
+ - **Out of scope:** Real backend / database, authentication, real-time features, SEO optimization, accessibility audit
39
+ - **Customization:** Structure and visuals — pure emulation of the reference. **Marketing copy** — apply the parsed **SaaS idea** where hero/headlines/CTAs are interchangeable (see “SaaS copy overlay” above); do not invent a different product than the user’s idea.
40
+
41
+ If the user provides additional instructions (specific fidelity level, customizations, extra context), honor those over the defaults.
42
+
43
+ ## Pre-Flight
44
+
45
+ 1. **Browser automation is required.** Check for available browser MCP tools (Chrome MCP, Playwright MCP, Browserbase MCP, Puppeteer MCP, etc.). Use whichever is available — if multiple exist, prefer Chrome MCP. If none are detected, ask the user which browser tool they have and how to connect it. This skill cannot work without browser automation.
46
+ 2. **Parse arguments** — extract every `http://` / `https://` URL token (there may be several). **SaaS idea** = the remaining non-URL text (trim outer quotes). Normalize and validate each URL; if any are invalid, or the SaaS idea is missing, ask the user once. For each valid URL, verify it is accessible via your browser MCP tool.
47
+ 3. Verify the base project builds: `npm run build`. The Next.js + shadcn/ui + Tailwind v4 scaffold should already be in place. If not, tell the user to set it up first.
48
+ 4. Create the output directories if they don't exist: `docs/research/`, `docs/research/components/`, `docs/design-references/`, `scripts/`. For multiple clones, also prepare per-site folders like `docs/research/<hostname>/` and `docs/design-references/<hostname>/`.
49
+ 5. When working with multiple sites in one command, optionally confirm whether to run them in parallel (recommended, if resources allow) or sequentially to avoid overload.
50
+
51
+ ## Guiding Principles
52
+
53
+ These are the truths that separate a successful clone from a "close enough" mess. Internalize them — they should inform every decision you make.
54
+
55
+ ### 0. Visual crawl priority (images, SVGs, motion — first)
56
+
57
+ When you traverse the DOM and the Network panel, do **not** treat all nodes equally. Work in this **priority order** so the clone feels like the original, not a wireframe:
58
+
59
+ 1. **Images (raster + video stills)** — Enumerate `<img>`, `<picture>`, responsive `srcset`, `data-*` lazy URLs, **computed `background-image`** on the element and parents (including pseudo-elements), mask images, `<video poster>`, hero media. **Scrape:** download binary assets to `public/images/` (or `public/videos/`) with stable paths referenced in specs. **Create** a replacement PNG/WebP/SVG only when the asset is blocked (CORS, auth cookie, 403), ephemeral, or impossible to URL-fetch — use a high-DPI screenshot crop, traced artwork, or CSS gradient approximation, and mark `ASSET_SOURCE: generated` in the component spec with a short reason.
60
+ 2. **SVGs & iconography** — Inline `<svg>`, sprite `symbol` defs, **SVG used as masks/filters**, icon fonts (prefer path extraction). Convert to `@/components/icons.tsx` (or section-local components) with meaningful names. Prioritize crisp edges and correct `viewBox` over shrinking bundle size during emulation.
61
+ 3. **Motion & animation** — CSS `@keyframes`, `animation`, `animation-timeline`, `transition`, `transform`, will-change hints; JS-driven motion (carousel timing, IntersectionObserver reveals); libraries (GSAP, Framer, Lottie JSON, Lenis). Capture **numbers** (ms, easing curves, stagger, scroll thresholds), not adjectives. Include **reduced-motion** behavior if present.
62
+
63
+ Only after the above are accounted for should you spend cycle time on minor text or non-visual refactors. A perfect grid with missing hero art and dead animation still fails the clone.
64
+
65
+ ### 1. Completeness Beats Speed
66
+
67
+ Every builder agent must receive **everything** it needs to do its job perfectly: screenshot, exact CSS values, downloaded assets with local paths, real text content, component structure. If a builder has to guess anything — a color, a font size, a padding value — you have failed at extraction. Take the extra minute to extract one more property rather than shipping an incomplete brief.
68
+
69
+ ### 2. Small Tasks, Perfect Results
70
+
71
+ When an agent gets "build the entire features section," it glosses over details — it approximates spacing, guesses font sizes, and produces something "close enough" but clearly wrong. When it gets a single focused component with exact CSS values, it nails it every time.
72
+
73
+ Look at each section and judge its complexity. A simple banner with a heading and a button? One agent. A complex section with 3 different card variants, each with unique hover states and internal layouts? One agent per card variant plus one for the section wrapper. When in doubt, make it smaller.
74
+
75
+ **Complexity budget rule:** If a builder prompt exceeds ~150 lines of spec content, the section is too complex for one agent. Break it into smaller pieces. This is a mechanical check — don't override it with "but it's all related."
76
+
77
+ ### 3. Real Content, Real Assets
78
+
79
+ Extract the actual text, images, videos, and SVGs from the live site. This is a clone, not a mockup. Use `element.textContent`, download every `<img>` and `<video>`, extract inline `<svg>` elements as React components. The only time you generate content is when something is clearly server-generated and unique per session.
80
+
81
+ **Prioritize** (see §0): downloadable imagery and backgrounds first, then SVG/icon layers, then motion. If you must **fabricate** an asset, prefer screenshot-based exports or traced vectors tied to measured box sizes — avoid unrelated stock art.
82
+
83
+ **Layered assets matter.** A section that looks like one image is often multiple layers — a background watercolor/gradient, a foreground UI mockup PNG, an overlay icon. Inspect each container's full DOM tree and enumerate ALL `<img>` elements and background images within it, including absolutely-positioned overlays. Missing an overlay image makes the clone look empty even if the background is correct.
84
+
85
+ ### 4. Foundation First
86
+
87
+ Nothing can be built until the foundation exists: global CSS with the target site's design tokens (colors, fonts, spacing), TypeScript types for the content structures, and global assets (fonts, favicons). This is sequential and non-negotiable. Everything after this can be parallel.
88
+
89
+ ### 5. Extract How It Looks AND How It Behaves
90
+
91
+ A website is not a screenshot — it's a living thing. Elements move, change, appear, and disappear in response to scrolling, hovering, clicking, resizing, and time. If you only extract the static CSS of each element, your clone will look right in a screenshot but feel dead when someone actually uses it.
92
+
93
+ For every element, extract its **appearance** (exact computed CSS via `getComputedStyle()`) AND its **behavior** (what changes, what triggers the change, and how the transition happens). Not "it looks like 16px" — extract the actual computed value. Not "the nav changes on scroll" — document the exact trigger (scroll position, IntersectionObserver threshold, viewport intersection), the before and after states (both sets of CSS values), and the transition (duration, easing, CSS transition vs. JS-driven vs. CSS `animation-timeline`).
94
+
95
+ Examples of behaviors to watch for — these are illustrative, not exhaustive. The page may do things not on this list, and you must catch those too:
96
+ - A navbar that shrinks, changes background, or gains a shadow after scrolling past a threshold
97
+ - Elements that animate into view when they enter the viewport (fade-up, slide-in, stagger delays)
98
+ - Sections that snap into place on scroll (`scroll-snap-type`)
99
+ - Parallax layers that move at different rates than the scroll
100
+ - Hover states that animate (not just change — the transition duration and easing matter)
101
+ - Dropdowns, modals, accordions with enter/exit animations
102
+ - Scroll-driven progress indicators or opacity transitions
103
+ - Auto-playing carousels or cycling content
104
+ - Dark-to-light (or any theme) transitions between page sections
105
+ - **Tabbed/pill content that cycles** — buttons that switch visible card sets with transitions
106
+ - **Scroll-driven tab/accordion switching** — sidebars where the active item auto-changes as content scrolls past (IntersectionObserver, NOT click handlers)
107
+ - **Smooth scroll libraries** (Lenis, Locomotive Scroll) — check for `.lenis` class or scroll container wrappers
108
+
109
+ ### 6. Identify the Interaction Model Before Building
110
+
111
+ This is the single most expensive mistake in cloning: building a click-based UI when the original is scroll-driven, or vice versa. Before writing any builder prompt for an interactive section, you must definitively answer: **Is this section driven by clicks, scrolls, hovers, time, or some combination?**
112
+
113
+ How to determine this:
114
+ 1. **Don't click first.** Scroll through the section slowly and observe if things change on their own as you scroll.
115
+ 2. If they do, it's scroll-driven. Extract the mechanism: `IntersectionObserver`, `scroll-snap`, `position: sticky`, `animation-timeline`, or JS scroll listeners.
116
+ 3. If nothing changes on scroll, THEN click/hover to test for click/hover-driven interactivity.
117
+ 4. Document the interaction model explicitly in the component spec: "INTERACTION MODEL: scroll-driven with IntersectionObserver" or "INTERACTION MODEL: click-to-switch with opacity transition."
118
+
119
+ A section with a sticky sidebar and scrolling content panels is fundamentally different from a tabbed interface where clicking switches content. Getting this wrong means a complete rewrite, not a CSS tweak.
120
+
121
+ ### 7. Extract Every State, Not Just the Default
122
+
123
+ Many components have multiple visual states — a tab bar shows different cards per tab, a header looks different at scroll position 0 vs 100, a card has hover effects. You must extract ALL states, not just whatever is visible on page load.
124
+
125
+ For tabbed/stateful content:
126
+ - Click each tab/button via browser MCP
127
+ - Extract the content, images, and card data for EACH state
128
+ - Record which content belongs to which state
129
+ - Note the transition animation between states (opacity, slide, fade, etc.)
130
+
131
+ For scroll-dependent elements:
132
+ - Capture computed styles at scroll position 0 (initial state)
133
+ - Scroll past the trigger threshold and capture computed styles again (scrolled state)
134
+ - Diff the two to identify exactly which CSS properties change
135
+ - Record the transition CSS (duration, easing, properties)
136
+ - Record the exact trigger threshold (scroll position in px, or viewport intersection ratio)
137
+
138
+ ### 8. Spec Files Are the Source of Truth
139
+
140
+ Every component gets a specification file in `docs/research/components/` BEFORE any builder is dispatched. This file is the contract between your extraction work and the builder agent. The builder receives the spec file contents inline in its prompt — the file also persists as an auditable artifact that the user (or you) can review if something looks wrong.
141
+
142
+ The spec file is not optional. It is not a nice-to-have. If you dispatch a builder without first writing a spec file, you are shipping incomplete instructions based on whatever you can remember from a browser MCP session, and the builder will guess to fill gaps.
143
+
144
+ ### 9. Build Must Always Compile
145
+
146
+ Every builder agent must verify `npx tsc --noEmit` passes before finishing. After merging worktrees, you verify `npm run build` passes. A broken build is never acceptable, even temporarily.
147
+
148
+ ## Phase 1: Reconnaissance
149
+
150
+ Navigate to the target URL with browser MCP.
151
+
152
+ Follow **§0 (Visual crawl priority)** during the entire reconnaissance pass: images and backgrounds → SVGs/icons → motion/animations — before spending time on secondary copy tweaks.
153
+
154
+ ### Screenshots
155
+ - Take **full-page screenshots** at desktop (1440px) and mobile (390px) viewports
156
+ - Save to `docs/design-references/` with descriptive names
157
+ - These are your master reference — builders will receive section-specific crops/screenshots later
158
+
159
+ ### Global Extraction
160
+ Extract these from the page before doing anything else:
161
+
162
+ **Fonts** — Inspect `<link>` tags for Google Fonts or self-hosted fonts. Check computed `font-family` on key elements (headings, body, code, labels). Document every family, weight, and style actually used. Configure them in `src/app/layout.tsx` using `next/font/google` or `next/font/local`.
163
+
164
+ **Colors** — Extract the site's color palette from computed styles across the page. Update `src/app/globals.css` with the target's actual colors in the `:root` and `.dark` CSS variable blocks. Map them to shadcn's token names (background, foreground, primary, muted, etc.) where they fit. Add custom properties for colors that don't map to shadcn tokens.
165
+
166
+ **Favicons & Meta** — Download favicons, apple-touch-icons, OG images, webmanifest to `public/seo/`. Update `layout.tsx` metadata.
167
+
168
+ **Global UI patterns** — Identify any site-wide CSS or JS: custom scrollbar hiding, scroll-snap on the page container, global keyframe animations, backdrop filters, gradients used as overlays, **smooth scroll libraries** (Lenis, Locomotive Scroll — check for `.lenis`, `.locomotive-scroll`, or custom scroll container classes). Add these to `globals.css` and note any libraries that need to be installed.
169
+
170
+ ### Mandatory Interaction Sweep
171
+
172
+ This is a dedicated pass AFTER screenshots and BEFORE anything else. Its purpose is to discover every behavior on the page — many of which are invisible in a static screenshot.
173
+
174
+ **Scroll sweep:** Scroll the page slowly from top to bottom via browser MCP. At each section, pause and observe:
175
+ - Does the header change appearance? Record the scroll position where it triggers.
176
+ - Do elements animate into view? Record which ones and the animation type.
177
+ - Does a sidebar or tab indicator auto-switch as you scroll? Record the mechanism.
178
+ - Are there scroll-snap points? Record which containers.
179
+ - Is there a smooth scroll library active? Check for non-native scroll behavior.
180
+
181
+ **Click sweep:** Click every element that looks interactive:
182
+ - Every button, tab, pill, link, card
183
+ - Record what happens: does content change? Does a modal open? Does a dropdown appear?
184
+ - For tabs/pills: click EACH ONE and record the content that appears for each state
185
+
186
+ **Hover sweep:** Hover over every element that might have hover states:
187
+ - Buttons, cards, links, images, nav items
188
+ - Record what changes: color, scale, shadow, underline, opacity
189
+
190
+ **Responsive sweep:** Test at 3 viewport widths via browser MCP:
191
+ - Desktop: 1440px
192
+ - Tablet: 768px
193
+ - Mobile: 390px
194
+ - At each width, note which sections change layout (column → stack, sidebar disappears, etc.) and at approximately which breakpoint the change occurs.
195
+
196
+ Save all findings to `docs/research/BEHAVIORS.md`. This is your behavior bible — reference it when writing every component spec.
197
+
198
+ ### Page Topology
199
+ Map out every distinct section of the page from top to bottom. Give each a working name. Document:
200
+ - Their visual order
201
+ - Which are fixed/sticky overlays vs. flow content
202
+ - The overall page layout (scroll container, column structure, z-index layers)
203
+ - Dependencies between sections (e.g., a floating nav that overlays everything)
204
+ - **The interaction model** of each section (static, click-driven, scroll-driven, time-driven)
205
+
206
+ Save this as `docs/research/PAGE_TOPOLOGY.md` — it becomes your assembly blueprint.
207
+
208
+ ## Phase 2: Foundation Build
209
+
210
+ This is sequential. Do it yourself (not delegated to an agent) since it touches many files:
211
+
212
+ 1. **Update fonts** in `layout.tsx` to match the target site's actual fonts
213
+ 2. **Update globals.css** with the target's color tokens, spacing values, keyframe animations, utility classes, and any **global scroll behaviors** (Lenis, smooth scroll CSS, scroll-snap on body)
214
+ 3. **Create TypeScript interfaces** in `src/types/` for the content structures you've observed
215
+ 4. **Extract SVG icons** — find all inline `<svg>` elements on the page, deduplicate them, and save as named React components in `src/components/icons.tsx`. Name them by visual function (e.g., `SearchIcon`, `ArrowRightIcon`, `LogoIcon`).
216
+ 5. **Download global assets** — write and run a Node.js script (`scripts/download-assets.mjs`) that downloads all images, videos, and other binary assets from the page to `public/`. Preserve meaningful directory structure.
217
+ 6. Verify: `npm run build` passes
218
+
219
+ ### Asset Discovery Script Pattern
220
+
221
+ Use browser MCP to enumerate all assets on the page:
222
+
223
+ ```javascript
224
+ // Run this via browser MCP to discover all assets
225
+ JSON.stringify({
226
+ images: [...document.querySelectorAll('img')].map(img => ({
227
+ src: img.src || img.currentSrc,
228
+ alt: img.alt,
229
+ width: img.naturalWidth,
230
+ height: img.naturalHeight,
231
+ // Include parent info to detect layered compositions
232
+ parentClasses: img.parentElement?.className,
233
+ siblings: img.parentElement ? [...img.parentElement.querySelectorAll('img')].length : 0,
234
+ position: getComputedStyle(img).position,
235
+ zIndex: getComputedStyle(img).zIndex
236
+ })),
237
+ videos: [...document.querySelectorAll('video')].map(v => ({
238
+ src: v.src || v.querySelector('source')?.src,
239
+ poster: v.poster,
240
+ autoplay: v.autoplay,
241
+ loop: v.loop,
242
+ muted: v.muted
243
+ })),
244
+ backgroundImages: [...document.querySelectorAll('*')].filter(el => {
245
+ const bg = getComputedStyle(el).backgroundImage;
246
+ return bg && bg !== 'none';
247
+ }).map(el => ({
248
+ url: getComputedStyle(el).backgroundImage,
249
+ element: el.tagName + '.' + el.className?.split(' ')[0]
250
+ })),
251
+ svgCount: document.querySelectorAll('svg').length,
252
+ fonts: [...new Set([...document.querySelectorAll('*')].slice(0, 200).map(el => getComputedStyle(el).fontFamily))],
253
+ favicons: [...document.querySelectorAll('link[rel*="icon"]')].map(l => ({ href: l.href, sizes: l.sizes?.toString() }))
254
+ });
255
+ ```
256
+
257
+ Then write a download script that fetches everything to `public/`. Use batched parallel downloads (4 at a time) with proper error handling.
258
+
259
+ ## Phase 3: Component Specification & Dispatch
260
+
261
+ This is the core loop. For each section in your page topology (top to bottom), you do THREE things: **extract**, **write the spec file**, then **dispatch builders**.
262
+
263
+ ### Step 1: Extract
264
+
265
+ For each section, use browser MCP to extract everything:
266
+
267
+ 1. **Screenshot** the section in isolation (scroll to it, screenshot the viewport). Save to `docs/design-references/`.
268
+
269
+ 2. **Extract CSS** for every element in the section. Use the extraction script below — don't hand-measure individual properties. Run it once per component container and capture the full output:
270
+
271
+ ```javascript
272
+ // Per-component extraction — run via browser MCP
273
+ // Replace SELECTOR with the actual CSS selector for the component
274
+ (function(selector) {
275
+ const el = document.querySelector(selector);
276
+ if (!el) return JSON.stringify({ error: 'Element not found: ' + selector });
277
+ const props = [
278
+ 'fontSize','fontWeight','fontFamily','lineHeight','letterSpacing','color',
279
+ 'textTransform','textDecoration','backgroundColor','background',
280
+ 'padding','paddingTop','paddingRight','paddingBottom','paddingLeft',
281
+ 'margin','marginTop','marginRight','marginBottom','marginLeft',
282
+ 'width','height','maxWidth','minWidth','maxHeight','minHeight',
283
+ 'display','flexDirection','justifyContent','alignItems','gap',
284
+ 'gridTemplateColumns','gridTemplateRows',
285
+ 'borderRadius','border','borderTop','borderBottom','borderLeft','borderRight',
286
+ 'boxShadow','overflow','overflowX','overflowY',
287
+ 'position','top','right','bottom','left','zIndex',
288
+ 'opacity','transform','transition','cursor',
289
+ 'objectFit','objectPosition','mixBlendMode','filter','backdropFilter',
290
+ 'whiteSpace','textOverflow','WebkitLineClamp'
291
+ ];
292
+ function extractStyles(element) {
293
+ const cs = getComputedStyle(element);
294
+ const styles = {};
295
+ props.forEach(p => { const v = cs[p]; if (v && v !== 'none' && v !== 'normal' && v !== 'auto' && v !== '0px' && v !== 'rgba(0, 0, 0, 0)') styles[p] = v; });
296
+ return styles;
297
+ }
298
+ function walk(element, depth) {
299
+ if (depth > 4) return null;
300
+ const children = [...element.children];
301
+ return {
302
+ tag: element.tagName.toLowerCase(),
303
+ classes: element.className?.toString().split(' ').slice(0, 5).join(' '),
304
+ text: element.childNodes.length === 1 && element.childNodes[0].nodeType === 3 ? element.textContent.trim().slice(0, 200) : null,
305
+ styles: extractStyles(element),
306
+ images: element.tagName === 'IMG' ? { src: element.src, alt: element.alt, naturalWidth: element.naturalWidth, naturalHeight: element.naturalHeight } : null,
307
+ childCount: children.length,
308
+ children: children.slice(0, 20).map(c => walk(c, depth + 1)).filter(Boolean)
309
+ };
310
+ }
311
+ return JSON.stringify(walk(el, 0), null, 2);
312
+ })('SELECTOR');
313
+ ```
314
+
315
+ 3. **Extract multi-state styles** — for any element with multiple states (scroll-triggered, hover, active tab), capture BOTH states:
316
+
317
+ ```javascript
318
+ // State A: capture styles at current state (e.g., scroll position 0)
319
+ // Then trigger the state change (scroll, click, hover via browser MCP)
320
+ // State B: re-run the extraction script on the same element
321
+ // The diff between A and B IS the behavior specification
322
+ ```
323
+
324
+ Record the diff explicitly: "Property X changes from VALUE_A to VALUE_B, triggered by TRIGGER, with transition: TRANSITION_CSS."
325
+
326
+ 4. **Extract real content** — all text, alt attributes, aria labels, placeholder text. Use `element.textContent` for each text node. For tabbed/stateful content, **click each tab and extract content per state**.
327
+
328
+ 5. **Identify assets** this section uses — which downloaded images/videos from `public/`, which icon components from `icons.tsx`. Check for **layered images** (multiple `<img>` or background-images stacked in the same container).
329
+
330
+ 6. **Assess complexity** — how many distinct sub-components does this section contain? A distinct sub-component is an element with its own unique styling, structure, and behavior (e.g., a card, a nav item, a search panel).
331
+
332
+ ### Step 2: Write the Component Spec File
333
+
334
+ For each section (or sub-component, if you're breaking it up), create a spec file in `docs/research/components/`. This is NOT optional — every builder must have a corresponding spec file.
335
+
336
+ **File path:** `docs/research/components/<component-name>.spec.md`
337
+
338
+ **Template:**
339
+
340
+ ```markdown
341
+ # <ComponentName> Specification
342
+
343
+ ## Overview
344
+ - **Target file:** `src/components/<ComponentName>.tsx`
345
+ - **Screenshot:** `docs/design-references/<screenshot-name>.png`
346
+ - **Interaction model:** <static | click-driven | scroll-driven | time-driven>
347
+
348
+ ## DOM Structure
349
+ <Describe the element hierarchy — what contains what>
350
+
351
+ ## Computed Styles (exact values from getComputedStyle)
352
+
353
+ ### Container
354
+ - display: ...
355
+ - padding: ...
356
+ - maxWidth: ...
357
+ - (every relevant property with exact values)
358
+
359
+ ### <Child element 1>
360
+ - fontSize: ...
361
+ - color: ...
362
+ - (every relevant property)
363
+
364
+ ### <Child element N>
365
+ ...
366
+
367
+ ## States & Behaviors
368
+
369
+ ### <Behavior name, e.g., "Scroll-triggered floating mode">
370
+ - **Trigger:** <exact mechanism — scroll position 50px, IntersectionObserver rootMargin "-30% 0px", click on .tab-button, hover>
371
+ - **State A (before):** maxWidth: 100vw, boxShadow: none, borderRadius: 0
372
+ - **State B (after):** maxWidth: 1200px, boxShadow: 0 4px 20px rgba(0,0,0,0.1), borderRadius: 16px
373
+ - **Transition:** transition: all 0.3s ease
374
+ - **Implementation approach:** <CSS transition + scroll listener | IntersectionObserver | CSS animation-timeline | etc.>
375
+
376
+ ### Hover states
377
+ - **<Element>:** <property>: <before> → <after>, transition: <value>
378
+
379
+ ## Per-State Content (if applicable)
380
+
381
+ ### State: "Featured"
382
+ - Title: "..."
383
+ - Subtitle: "..."
384
+ - Cards: [{ title, description, image, link }, ...]
385
+
386
+ ### State: "Productivity"
387
+ - Title: "..."
388
+ - Cards: [...]
389
+
390
+ ## Assets
391
+ - Background image: `public/images/<file>.webp`
392
+ - Overlay image: `public/images/<file>.png`
393
+ - Icons used: <ArrowIcon>, <SearchIcon> from icons.tsx
394
+
395
+ ## Text Content (verbatim)
396
+ <All text content, copy-pasted from the live site>
397
+
398
+ ## Responsive Behavior
399
+ - **Desktop (1440px):** <layout description>
400
+ - **Tablet (768px):** <what changes — e.g., "maintains 2-column, gap reduces to 16px">
401
+ - **Mobile (390px):** <what changes — e.g., "stacks to single column, images full-width">
402
+ - **Breakpoint:** layout switches at ~<N>px
15
403
  ```
16
404
 
17
- It unpacks the full template into the **current working directory** (the folder root where the user runs the command). They should `mkdir`, `cd` into an **empty** folder first.
405
+ Fill every section. If a section doesn't apply (e.g., no states for a static footer), write "N/A" but think twice before marking States & Behaviors as N/A. Even a footer might have hover states on links.
406
+
407
+ ### Step 3: Dispatch Builders
408
+
409
+ Based on complexity, dispatch builder agent(s) in worktree(s):
410
+
411
+ **Simple section** (1-2 sub-components): One builder agent gets the entire section.
412
+
413
+ **Complex section** (3+ distinct sub-components): Break it up. One agent per sub-component, plus one agent for the section wrapper that imports them. Sub-component builders go first since the wrapper depends on them.
414
+
415
+ **What every builder agent receives:**
416
+ - The full contents of its component spec file (inline in the prompt — don't say "go read the spec file")
417
+ - Path to the section screenshot in `docs/design-references/`
418
+ - Which shared components to import (`icons.tsx`, `cn()`, shadcn primitives)
419
+ - The target file path (e.g., `src/components/HeroSection.tsx`)
420
+ - Instruction to verify with `npx tsc --noEmit` before finishing
421
+ - For responsive behavior: the specific breakpoint values and what changes
422
+
423
+ **Don't wait.** As soon as you've dispatched the builder(s) for one section, move to extracting the next section. Builders work in parallel in their worktrees while you continue extraction.
424
+
425
+ ### Step 4: Merge
426
+
427
+ As builder agents complete their work:
428
+ - Merge their worktree branches into main
429
+ - You have full context on what each agent built, so resolve any conflicts intelligently
430
+ - After each merge, verify the build still passes: `npm run build`
431
+ - If a merge introduces type errors, fix them immediately
432
+
433
+ The extract → spec → dispatch → merge cycle continues until all sections are built.
434
+
435
+ ## Phase 4: Page Assembly
436
+
437
+ After all sections are built and merged, wire everything together in `src/app/page.tsx`:
438
+
439
+ - Import all section components
440
+ - Implement the page-level layout from your topology doc (scroll containers, column structures, sticky positioning, z-index layering)
441
+ - Connect real content to component props
442
+ - Implement page-level behaviors: scroll snap, scroll-driven animations, dark-to-light transitions, intersection observers, smooth scroll (Lenis etc.)
443
+ - Verify: `npm run build` passes clean
18
444
 
19
- ## What you do
445
+ ## Phase 5: Visual QA Diff
20
446
 
21
- 1. Ensure the user has an **empty** directory (no existing `package.json`, `src/`, or `next.config.ts` there). If the workspace is already a Launchframe/Next project, they may only need `/clone-website` instead — clarify.
447
+ After assembly, do NOT declare the clone complete. Take side-by-side comparison screenshots:
22
448
 
23
- 2. Run exactly:
449
+ 1. Open the original site and your clone side-by-side (or take screenshots at the same viewport widths)
450
+ 2. Compare section by section, top to bottom, at desktop (1440px)
451
+ 3. Compare again at mobile (390px)
452
+ 4. For each discrepancy found:
453
+ - Check the component spec file — was the value extracted correctly?
454
+ - If the spec was wrong: re-extract from browser MCP, update the spec, fix the component
455
+ - If the spec was right but the builder got it wrong: fix the component to match the spec
456
+ 5. Test all interactive behaviors: scroll through the page, click every button/tab, hover over interactive elements
457
+ 6. Verify smooth scroll feels right, header transitions work, tab switching works, animations play
24
458
 
25
- ```bash
26
- npx launchframe@latest
27
- ```
459
+ Only after this visual QA pass is the clone complete.
28
460
 
29
- Optional: `LAUNCHFRAME_SOURCE_URL` and `LAUNCHFRAME_SAAS_IDEA` environment variables in the same shell if they want values pre-filled without editing files later.
461
+ ## Pre-Dispatch Checklist
30
462
 
31
- 3. **Never** run this with the output target **inside** the `launchframe` package directory (the npm-installed template). If the open folder is this monorepo/template, have them `mkdir ../my-app && cd ../my-app` (sibling path), then run `npx launchframe@latest` there.
463
+ Before dispatching ANY builder agent, verify you can check every box. If you can't, go back and extract more.
32
464
 
33
- 4. Optional flags (same as CLI): `--dir <path>` to scaffold into another folder instead of cwd, `--skip-install` to skip `npm install`.
465
+ - [ ] Spec file written to `docs/research/components/<name>.spec.md` with ALL sections filled
466
+ - [ ] Every CSS value in the spec is from `getComputedStyle()`, not estimated
467
+ - [ ] Interaction model is identified and documented (static / click / scroll / time)
468
+ - [ ] For stateful components: every state's content and styles are captured
469
+ - [ ] For scroll-driven components: trigger threshold, before/after styles, and transition are recorded
470
+ - [ ] For hover states: before/after values and transition timing are recorded
471
+ - [ ] All images in the section are identified (including overlays and layered compositions)
472
+ - [ ] Responsive behavior is documented for at least desktop and mobile
473
+ - [ ] Text content is verbatim from the site, not paraphrased
474
+ - [ ] The builder prompt is under ~150 lines of spec; if over, the section needs to be split
34
475
 
35
- 5. After it finishes: they should **`npm run dev`** from **that same folder** (no extra `cd` if they scaffolded into cwd). Then they edit **`src/lib/launchframe-config.ts`** for reference URL and SaaS idea, and run **`/clone-website`** with that URL.
476
+ ## What NOT to Do
36
477
 
37
- ## If {{args}} are present
478
+ These are lessons from previous failed clones — each one cost hours of rework:
38
479
 
39
- The user may still paste a URL or idea in chat **do not** require them for the CLI. Put any extra context into **`src/lib/launchframe-config.ts`** or `launchframe.context.json` for them after scaffold.
480
+ - **Don't build click-based tabs when the original is scroll-driven (or vice versa).** Determine the interaction model FIRST by scrolling before clicking. This is the #1 most expensive mistake it requires a complete rewrite, not a CSS fix.
481
+ - **Don't extract only the default state.** If there are tabs showing "Featured" on load, click Productivity, Creative, Lifestyle and extract each one's cards/content. If the header changes on scroll, capture styles at position 0 AND position 100+.
482
+ - **Don't miss overlay/layered images.** A background watercolor + foreground UI mockup = 2 images. Check every container's DOM tree for multiple `<img>` elements and positioned overlays.
483
+ - **Don't build mockup components for content that's actually videos/animations.** Check if a section uses `<video>`, Lottie, or canvas before building elaborate HTML mockups of what the video shows.
484
+ - **Don't approximate CSS classes.** "It looks like `text-lg`" is wrong if the computed value is `18px` and `text-lg` is `18px/28px` but the actual line-height is `24px`. Extract exact values.
485
+ - **Don't build everything in one monolithic commit.** The whole point of this pipeline is incremental progress with verified builds at each step.
486
+ - **Don't reference docs from builder prompts.** Each builder gets the CSS spec inline in its prompt — never "see DESIGN_TOKENS.md for colors." The builder should have zero need to read external docs.
487
+ - **Don't skip asset extraction.** Without real images, videos, and fonts, the clone will always look fake regardless of how perfect the CSS is.
488
+ - **Don't give a builder agent too much scope.** If you're writing a builder prompt and it's getting long because the section is complex, that's a signal to break it into smaller tasks.
489
+ - **Don't bundle unrelated sections into one agent.** A CTA section and a footer are different components with different designs — don't hand them both to one agent and hope for the best.
490
+ - **Don't skip responsive extraction.** If you only inspect at desktop width, the clone will break at tablet and mobile. Test at 1440, 768, and 390 during extraction.
491
+ - **Don't forget smooth scroll libraries.** Check for Lenis (`.lenis` class), Locomotive Scroll, or similar. Default browser scrolling feels noticeably different and the user will spot it immediately.
492
+ - **Don't dispatch builders without a spec file.** The spec file forces exhaustive extraction and creates an auditable artifact. Skipping it means the builder gets whatever you can fit in a prompt from memory.
40
493
 
41
- ## Fallback (local dev only)
494
+ ## Completion
42
495
 
43
- From a checkout of this repo: `node bin/launchframe.mjs` with the same empty-folder rules (optionally `--dir` outside the package root).
496
+ When done, report:
497
+ - Total sections built
498
+ - Total components created
499
+ - Total spec files written (should match components)
500
+ - Total assets downloaded (images, videos, SVGs, fonts)
501
+ - Build status (`npm run build` result)
502
+ - Visual QA results (any remaining discrepancies)
503
+ - Any known gaps or limitations
44
504
 
45
505
  '''
@@ -23,7 +23,7 @@ body:
23
23
  label: Steps to Reproduce
24
24
  description: Step-by-step instructions to reproduce the behavior.
25
25
  placeholder: |
26
- 1. Run `/clone-website https://example.com`
26
+ 1. Run `/launchframe https://example.com "your saas pitch"`
27
27
  2. Wait for agents to finish
28
28
  3. See error in terminal...
29
29
  validations:
@@ -10,7 +10,7 @@ This version has breaking changes — APIs, conventions, and file structure may
10
10
  # Website Reverse-Engineer Template
11
11
 
12
12
  ## What This Is
13
- A reusable template for reverse-engineering any website into a clean, modern Next.js codebase using AI coding agents. The Next.js + shadcn/ui + Tailwind v4 base is pre-scaffolded — for a **new** folder, `mkdir`, `cd` into an **empty** directory, run **`npx launchframe@latest`** (no parameters), then edit **`src/lib/launchframe-config.ts`** and run **`/clone-website`** with your URL (or invoke **`/launchframe`** so the agent runs the same command). Or work in this repo and run **`/clone-website <url1> [<url2> ...]`** to clone into the current tree.
13
+ A reusable template for reverse-engineering any website into a clean, modern Next.js codebase using AI coding agents. The Next.js + shadcn/ui + Tailwind v4 base is pre-scaffolded — use **`/launchframe <url> "saas idea"`** for the full pixel-perfect clone plus SaaS landing copy (`src/lib/launchframe-config.ts`, `launchframe.context.json`, `docs/research/LAUNCHFRAME.md`). For a **new empty folder** only, **`npx launchframe@latest`** unpacks this template; then run **`/launchframe`** in that project with your URL and pitch.
14
14
 
15
15
  ## Tech Stack
16
16
  - **Framework:** Next.js 16 (App Router, React 19, TypeScript strict)
@@ -64,7 +64,7 @@ scripts/ # Asset download scripts
64
64
  ## MOST IMPORTANT NOTES
65
65
  - When launching Claude Code agent teams, ALWAYS have each teammate work in their own worktree branch and merge everyone's work at the end, resolving any merge conflicts smartly since you are basically serving the orchestrator role and have full context to our goals, work given, work achieved, and desired outcomes.
66
66
  - After editing `AGENTS.md`, run `bash scripts/sync-agent-rules.sh` to regenerate platform-specific instruction files.
67
- - After editing `.claude/skills/*/SKILL.md` (for example `clone-website` or `launchframe`), run `node scripts/sync-skills.mjs` to regenerate skill and command files for all platforms.
67
+ - After editing `.claude/skills/launchframe/SKILL.md`, run `node scripts/sync-skills.mjs` to regenerate the `/launchframe` command for all platforms.
68
68
 
69
69
  # Website Inspection Guide
70
70