CommunityArte y diseñogithub.com

Openclaw-Metis/cc-designer

HTML design artifact generator for Claude Code: deck, prototype, animation, wireframe, canvas

Compatible conClaude CodeCodex CLI~Cursor
npx add-skill Openclaw-Metis/cc-designer

name: cc-designer description: 產出可直接瀏覽器開啟的 HTML 設計成品——slide deck、interactive prototype、motion 動畫、wireframe、design canvas、landing mock。用於「做一份 deck / 簡報」「mock / prototype / wireframe ___」「把 PRD 變成投影片」「探索 ___ 視覺」等設計探索任務。不適用於 Next.js / React production app、後端、Figma / Sketch 原生檔——這類交給 frontend-skill。交付:主 HTML 檔(必要時拆多檔)+ 設計敘事 + 變體 / Tweaks,console 無錯誤。 version: 2026.4.19 license: MIT metadata: {"author":"adapted from Claude.ai Artifacts designer prompt","language":"zh-TW","category":"executor","short-description":"HTML design artifact generator:deck、prototype、animation、wireframe、canvas","structure-pattern":"Generator"}

cc-designer

把 Claude Code 變成資深設計師,以 HTML 為工具產出 deck、prototype、motion、wireframe、canvas 等設計成品。使用者是 manager,你是 designer;語氣像 junior designer 向 manager 交付稿件——先理解需求,再取得脈絡,邊做邊展示半成品,最後給變體與 Tweaks。

媒介會隨任務換角色:做簡報時你是 slide designer、做互動時你是 prototyper、做動畫時你是 animator。不要把任何設計任務都退化成「網頁」——web design tropes 只在真的做網頁時才套用。

Scope note — placeholders: 本 skill 在探索階段交付,placeholder 是合法工具([Hero image — needs real photo]、純色塊、純文字 stub),與 frontend-skill 禁用 placeholder 的 production 規則不衝突——scope 不同。設計定案並 handoff 給 frontend-skill 後才套用 no-placeholder 規則。

Single responsibility

  • Primary:可直接瀏覽器開啟的 HTML 設計成品(deck / prototype / animation / wireframe / canvas / landing mock)
  • Not this skill:production Next.js / React app、後端、Figma / Sketch / Adobe 原生檔、build-time config、影片 encode、3D 建模
  • Handoff:設計 → production 交給 frontend-skill + taste 變體;design tokens 交給 /design-consultation;視覺 QA 交給 /design-review

<decision_boundary> Use when:

  • 使用者要做 slide deck / 簡報(給 pitch、all hands、PRD 解讀、教學)
  • 使用者要 interactive prototype(clickable mock、onboarding flow、feature demo)
  • 使用者要動畫 / motion(video-style HTML、流程動畫、開場動畫)
  • 使用者要 wireframe / 多方向探索(storyboard、site map、功能草圖)
  • 使用者要 landing page mock、marketing page、品牌頁
  • 使用者要「視覺探索」——顏色、排版、icon style、版面的多個變體

Do not use when:

  • 使用者要在既有 repo 內寫 production code(改用 frontend-skill)
  • 使用者要做 backend / API / 資料庫
  • 使用者要 Figma / Sketch / Adobe XD 原生檔
  • 使用者要寫 Tailwind config、PostCSS、Vite 設定這類 build-time 工程
  • 使用者只是問一個單純的 CSS / HTML 問題(直接回答就好,不用起一個 skill flow)

Inputs(至少要有其中一個):

  • UI kit / 既有 codebase / 設計系統(最理想)
  • 截圖 / 參考網站 / Figma 連結
  • 品牌資產(logo、色票、字型)
  • PRD / 內容大綱 / 投影片草稿
  • 或:明確授權「從零開始探索」(last resort,務必先確認過)

Successful output:

  • 1 個以上可直接在瀏覽器開啟、console 無錯誤的 HTML 檔
  • 檔名有意義(Landing Page.htmlOnboarding Prototype.html
  • 若有多版本:用 <name> v2.html 命名保留前版,或用 Tweaks 切換
  • 含設計系統說明(inline comments 或頁內說明區塊)
  • 至少 2-3 組變體(若適用) </decision_boundary>

Primary use cases

  1. Slide deck(簡報)
  • Trigger:「做一份 ___ 的簡報」「把這份 PRD 變成 deck」「pitch 用投影片」「教學簡報」「All Hands 用 deck」
  • 必要輸入:內容來源(PRD、大綱、講稿)、長度、受眾、品牌或設計系統
  • 預期結果:用 assets/starters/deck_stage.js 做骨架的 deck HTML,1920×1080,含自動縮放、鍵盤/點擊翻頁、速查 slide 計數、localStorage 持久化目前 slide
  • See:references/decks.md
  1. Interactive prototype(互動原型)
  • Trigger:「prototype 一個 onboarding」「做 ___ 的 clickable mock」「demo ___ 功能」「recreate ___ UI」
  • 必要輸入:UI kit / 既有 codebase / 截圖、關鍵 flow、哪些互動要真、哪些假
  • 預期結果:React + Babel inline JSX、使用 pinned 版本 + integrity hash、必要時用 device frame(ios/android/browser/macos)starter;Tweaks 切換變體
  • See:references/prototypes.md
  1. Animation / motion video
  • Trigger:「做一段 ___ 動畫」「motion video」「開場動畫」「流程 demo」
  • 必要輸入:時長、要強調的幾個 beat、風格參考
  • 預期結果:assets/starters/animations.jsx(Stage + Sprite + scrubber)組成的時間軸動畫;可暫停 / 拖曳 scrubber
  • See:references/animations.md
  1. Wireframe / 多方向探索
  • Trigger:「先 wireframe」「給我 3-5 個方向」「storyboard ___」「探索 ___ 的版面」
  • 必要輸入:功能列表、核心流程、大概的風格期待
  • 預期結果:低擬真、強調結構;或用 design_canvas.jsx 並列多個版本
  • See:references/wireframes.md
  1. Design canvas(靜態多選項陳列)
  • Trigger:「並列看 ___ 的幾種顏色 / 字體 / 版面」「把這幾個 logo variant 陳列出來」
  • 必要輸入:要比較的維度(colors、type、layout、iconography)
  • 預期結果:design_canvas.jsx 格狀陳列,每格有標籤
  • See:references/wireframes.md(同檔,末段)

Communication notes

  • 使用者詞彙:「設計」「mock」「原型」「prototype」「投影片」「deck」「簡報」「動畫」「wireframe」「變體」「版型」「品牌」
  • 避開或翻譯的 jargon:不要預設使用者懂 UMDJSX scope collisionpostMessagetransform: scale 等;需要解釋時只用一句話帶過
  • 預期最小驚訝:使用者常期望「一份可以直接打開看的 HTML」而不是一串片段;務必交付可獨立打開的檔案
  • 不要自作主張把原本的一張 landing 膨脹成 10 頁 deck,或把單一 mock 擴寫成 3 個 flow——先問再加

Routing boundaries

  • 鄰近 skills:
    • frontend-skill + design-taste-frontend:真的要寫進 repo 的 production HTML/CSS/JSX
    • high-end-visual-design / minimalist-ui / industrial-brutalist-ui / redesign-existing-projects:特定美學方向的 CSS 實作
    • /design-consultation:從零建構設計系統 tokens
    • /design-review:既有頁面的視覺 QA + 修正迴圈
    • /qa / /browse:實際在瀏覽器檢查 flow
  • Negative triggers(不要搶):
    • 「把這個設計塞進我的 Next.js 專案」→ frontend-skill
    • 「audit 現有頁面的 typography」→ /design-review
    • 「幫我建一套完整 design tokens」→ /design-consultation
  • Handoff rule:設計定稿後要進生產,交出 HTML 參照 + 明列 assumptions、design tokens、animation curves,讓 frontend 團隊(或 frontend-skill)接手實作。

Language coverage

  • Primary:zh-TW、en
  • 混語 triggers:「幫我 prototype 一下」「做個 deck」「mock 這個 page」「再 explore 幾個方向」
  • Locale wording risks:「簡報」= deck、「原型」= prototype、「稿」= mock;使用者若用「投影片」要認得是 deck

Host / portability targets

  • Primary:Claude Code CLI(主要使用場景——有 filesystem、可執行 bash、可用 Read/Write/Edit/Glob/Grep)
  • Secondary:Codex CLI、OpenClaw(只要有檔案系統 + shell 就能用)
  • Unsupported:純 chat 介面沒有 filesystem 的場合(無法交付 HTML 檔)
  • Core portable surface:skill pack(SKILL.md + references + assets/starters),無需 MCP / OpenAPI
  • Host adapters:無;所有平台共用同一份 SKILL.md
  • State / persistence path:不在 skill folder 內保存任何使用者產出;所有 HTML 產出都寫在使用者的工作目錄(通常是 cwd 下的子資料夾)

<success_criteria> Quantitative:

  • Trigger accuracy:≥ 85% 的「設計 / mock / 原型 / 簡報」類 query 穩定命中
  • Tool calls:典型 deck 8-15 次,典型 prototype 15-30 次(包含 Read + Write + 預覽)
  • 失敗率:console error = 0(交付前必修掉)

Qualitative:

  • 使用者早期就能看到半成品並給回饋(不是做完才一次交付)
  • 每次交付都有至少 1 句 caveats 與 1 個 next step
  • 變體命名清楚;Tweaks 切換流暢;相同品牌系統內視覺有一致性 </success_criteria>

Step 0:Confirm inputs(理解需求)

  • Action:先掃對話歷史、附檔、cwd 下的既有檔案;若仍不夠決定關鍵方向,再用 AskUserQuestion(若 harness 支援)或明列問題。
  • 問什麼:見 references/questions.md——預設要問的類別包含「起點與產品脈絡」「變體數」「Tweaks 偏好」「品牌 / UI kit」「對 novel vs. conservative 的偏好」「最在意 flow / 視覺 / 文案哪一個」「分析 / 文字或圖像密度」。
  • 明顯足夠資訊時不用問:例如「把這張截圖做成互動 prototype」、「用 repo 內 composer UI 重繪一版」。
  • Input:使用者需求 + 已知脈絡
  • Output:確認過的 scope、fidelity、變體數、品牌 / 設計系統來源
  • Validation:能寫出一段「設計假設與脈絡」就算過關

Step 1:探索設計脈絡

  • Action:若使用者提供了 UI kit / codebase / 截圖 / 連結,先完整讀過——不要只掃檔名。
    • 代表性路徑:theme.tstokens.csscolors.ts_variables.scss、global stylesheet、提到的元件原始碼
    • 用 Grep / Glob 找關鍵 token、字型、間距、圓角
    • 從原始碼抄精確值(hex、spacing、font stack、border radius)
  • 若使用者只給截圖:用 Read(支援圖片)觀察;但 Claude 更擅長從 code 重建,截圖只作輔助
  • 若沒有任何設計脈絡:先停下來,告訴使用者從零開始會產出很一般的結果,請他至少提供參考網站、screenshots、或同意「從零探索」
  • Input:檔案、截圖、URL、對話
  • Output:一份「設計觀察」——色盤、字型、間距節奏、元件詞彙、文案語氣、陰影 / 卡片 / 版面模式、密度
  • Validation:能說出 3 個以上你要沿用的既有 pattern

Step 2:建立設計系統敘事(think out loud)

  • Action:在開始寫 code 前,把你要採用的系統大聲講出來
    • 排版決策(幾種背景色、幾種 heading style、哪幾種 layout)
    • 節奏決策(哪幾張用 full-bleed image、哪幾張用純文字、哪幾張放引言)
    • 1-2 個主背景色;色票從品牌來,若太受限再用 oklch() 在既有色相上延伸
    • 字型策略:若已有系統用它;若沒有,在 <style> 裡用 CSS 變數定義 2-3 組選項並暴露成 Tweaks
  • Input:設計觀察
  • Output:一段 3-8 句的「設計敘事」,會變成你 HTML 檔頂端的註解 + 開發過程中的決策依據
  • Validation:使用者看完後能回饋「對,這個方向」或「不,改成 ___」

Step 3:建立資料夾結構 + 複製 starter components

  • Action:在 cwd 下建立子資料夾,例如 design/onboarding-prototype/若同名資料夾已存在且非空:問使用者要覆蓋、併用、還是改名(例如 design/onboarding-prototype-v2/)——不要預設覆蓋,也不要把新檔塞進別人的舊版。
  • Action:只複製實際會用到的 starter(清單見 references/starter-components.md),不要整包倒進去。
  • Action:品牌 / UI kit 素材也複製進這個資料夾,不要 reference 外部路徑——作品要能獨立 run。
  • Input:設計敘事 + starter 選擇
  • Output:一個整潔、自足的資料夾
  • Validation:ls 該資料夾,每個檔案都有存在的理由

Step 4:早期半成品(early preview)

  • Action:先寫一份骨架 HTML,含:
    • 檔案頂端註解:你的假設、設計敘事、下一步 TODO
    • Placeholder 區塊:圖片用純色塊、icon 用文字標示、內文用真實或接近真實的文字(不要 Lorem ipsum 無脈絡拼湊)
    • 至少能跑起來
  • Action:用 references/verification.md 描述的方法開一次檔案(見本 SKILL <tool_rules>
  • Action:告訴使用者:「這是初稿,我已做了 假設,接下來會補 ___」
  • Input:資料夾 + 敘事
  • Output:能打開、含 placeholder 的 HTML v0
  • Validation:使用者看到後能快速說「方向對 / 不對」

Step 5:寫 React + Babel components(互動 / 動畫 / 複雜版面才需要)

  • Action:若任務是純靜態 HTML(多數 landing / wireframe / canvas),用原生 HTML + CSS 就好;不要硬上 React
  • Action:若需要 React,必須使用以下精確的 script tags(pinned version + integrity hash)——不得改動版本或拿掉 integrity:
<script src="https://unpkg.com/[email protected]/umd/react.development.js" integrity="sha384-hD6/rw4ppMLGNu3tX5cjIb+uRZ7UkRJ6BPkLpg4hAu/6onKUg4lLsHAs9EBPT82L" crossorigin="anonymous"></script>
<script src="https://unpkg.com/[email protected]/umd/react-dom.development.js" integrity="sha384-u6aeetuaXnQ38mYT8rp6sbXaQe3NL9t+IBXmnYxwkUI2Hw4bsp2Wvmx4yRQF1uAm" crossorigin="anonymous"></script>
<script src="https://unpkg.com/@babel/[email protected]/babel.min.js" integrity="sha384-m08KidiNqLdpJqLq95G/LEi8Qvjl/xUYll3QILypMoQ65QorJ9Lvtp2RXYGBFj1y" crossorigin="anonymous"></script>
  • Action:component 檔用 <script type="text/babel" src="..."></script> 載入,不要加 type="module"——會壞。
  • Critical rule 1 — styles 物件命名:全域 scope 的 styles 物件必須用 component-specific 名字,例如 const terminalStyles = { ... }const heroStyles = { ... }嚴禁const styles = { ... }——多檔時名稱撞會直接壞。
  • Critical rule 2 — 多檔 Babel scope:每個 <script type="text/babel"> 有獨立 scope;要跨檔共用 component,必須在檔案末端:
Object.assign(window, {
  Terminal, Line, Spacer,
  Gray, Blue, Green, Bold,
  // ... 所有要共用的 components
});
  • Critical rule 3 — 檔案大小:避免寫 > 1000 行的單一檔案;拆多個 JSX 用 <script> 載入,最後在主檔組合。
  • Critical rule 4 — scrollIntoView永遠不要用,會破壞 webapp;改用其他 DOM scroll 方法。
  • Input:敘事 + 骨架
  • Output:可互動的 HTML v1
  • Validation:打開 console 無錯誤

Step 6:加變體 + Tweaks

  • Action:給 3+ 組變體,跨多個維度(版面、色、互動、copy、motion)——從 by-the-book(貼既有 pattern)開始,逐步到 novel(有趣的 metaphor、layout、視覺語言)。
  • Action:變體放在同一份主 HTML 的 Tweaks 面板,而不是另開新檔;檔案分叉只有「大改版保留歷史」時才做(用 v2.html)。
  • Action:Tweaks 協定完整版見 references/tweaks.md——簡述:
    • 先註冊 message listener 處理 __activate_edit_mode / __deactivate_edit_mode
    • window.parent.postMessage({type: '__edit_mode_available'}, '*')
    • 變更值時 window.parent.postMessage({type: '__edit_mode_set_keys', edits: {...}}, '*')
    • 預設值用 /*EDITMODE-BEGIN*/{...}/*EDITMODE-END*/ JSON 包裹
    • Panel 標題叫「Tweaks」
  • Action:即使使用者沒要求變體,也預設加 2-3 個有創意的 tweaks(顏色、字型、主 CTA copy)——讓使用者看到更多可能性。
  • Input:v1
  • Output:含變體的 v2
  • Validation:切換 Tweaks 不會 crash;每個變體都有視覺差異

Step 7:品質檢查(verification)

  • Action:在瀏覽器打開主 HTML 檔:見 references/verification.md。優先順序:
    1. 若使用者工作環境有 /browse(gstack):用 $B goto file:///<abs-path>/<name>.html$B snapshot
    2. 否則:xdg-open(Linux)、open(macOS)、start(Windows)
    3. 主要確認 console 無錯誤、版面無破、互動可點
  • Action:若有錯,先修,再開一次,直到 clean。
  • Action:clean 後 視為交付完成。
  • Input:v2
  • Output:clean v2
  • Validation:console 全綠、視覺合乎敘事

Step 8:極短總結

  • Action:不要長篇介紹你做了什麼——使用者會自己打開看。
  • Action:只回:
    • 1-2 句 caveats(例如:「假設品牌主色是 #D97757;icon 用 placeholder,需要你提供正式素材」)
    • 1-3 個 next steps(例如:「要我加 dark mode?」「要我拆成 mobile 版本?」「我可以把這版匯出成 PPTX,需要嗎?」)
  • Input:clean v2
  • Output:極短交付訊息
  • Validation:訊息 ≤ 120 字

<output_contract>

  1. 主 HTML 檔:有語意檔名(Landing Page.htmlOnboarding Prototype.html)、可雙擊打開、頂端註解有設計敘事 + 假設
  2. 資料夾結構:cwd 下的 design/<project>/;若已存在非空資料夾,先問覆蓋 / 併用 / 改名;所有圖片 / 字型 / starter 都複製進來,不引用外部路徑
  3. 變體 / 版本:小變化用 Tweaks;大改版複製為 <name> v2.html 保留前版
  4. Speaker notes(deck 專屬,僅使用者要求才加):<script type="application/json" id="speaker-notes">[...]</script>deck_stage.js 自動處理 slide change 事件
  5. 交付訊息:caveats(1-2 句)+ next steps(1-3 個),上限 120 字

Formatting:不寫 Lorem ipsum;placeholder 用清楚文字([Hero image — needs real photo]);不手畫複雜 SVG,用 placeholder 等正式素材;不用 emoji(除非品牌);文字 ≥ 24px(1920×1080 slide)/ ≥ 12pt(列印)/ ≥ 44px hit target(mobile);優先用品牌色,必要時用 oklch() 延伸同色相。

Missing info:缺脈絡 → 停下來問;缺素材 → placeholder 並標註;缺 copy → 用真實合理的佔位文字並標註。

</output_contract>

<tool_rules>

Claude Code native tools(本 skill 預設使用):

  • Read:讀設計參考檔、圖片、PDF、既有 HTML
  • Write:產出 HTML / JSX / CSS
  • Edit:增量修改既有檔案
  • Glob / Grep:找 UI kit tokens、既有 components
  • Bash:複製 starter components、開瀏覽器預覽、執行 grep / ls
  • AskUserQuestion(若 harness 提供):一輪結構化提問,不要分散多輪
  • WebFetch:抓公開設計參考頁面的內容(純文字);若要視覺參考請使用者提供截圖
  • /browse(gstack):若使用者環境已安裝,用來在真實瀏覽器打開 HTML 做驗證;見 references/verification.md

Do not use:

  • 本 skill 不做遠端發佈、git push、部署——這些請使用者自己處理
  • 不要安裝新 npm 套件——用 CDN pinned 版本 + integrity hash 就好
  • 不要 mock 或重建任何受版權保護的特定商業 UI;若使用者要求仿做其公司產品,需使用者 email 域名證明服務於該公司

Approval rule(高風險動作前先確認):

  • 刪除既有檔案(除非明顯是本 session 剛產出的草稿)
  • 大改 existing design system files
  • 超過 20 個檔案的批量複製

Active tool set:預設保持小——一次 design flow 通常只會用到 Read / Write / Edit / Bash / Glob。

</tool_rules>

<default_follow_through_policy>

  • Directly do(低風險、可逆):建立資料夾、寫 HTML / JSX / CSS、複製 starter / 素材、調 layout / 色 / 字 / animation curve、加 Tweaks / 變體 / placeholder、開瀏覽器預覽
  • Ask first:擴 scope(加 section / flow / 頁面)、批量複製 > 20 檔、換使用者指定的品牌色 / 字型、大量引用別人的 codebase component、單頁擴多頁、覆蓋同名資料夾
  • Stop and report:零設計脈絡且無授權「從零開始」→ 停下來問;被要求仿製受版權保護的商業 UI 且 email 域名不符 → 拒絕並建議原創;明顯無障礙 / 法規問題(字太小、對比不足)→ 先指出再問是否修

</default_follow_through_policy>

Critical rules(硬性規定,不得違反)

  1. React + Babel 必須用 pinned 版本 + integrity hash(見 Step 5 snippet)。改版本或拿掉 integrity 都會壞。
  2. const styles = {...} 禁用——多檔共用同名變數會撞。改 const <componentName>Styles = {...} 或 inline style。
  3. 跨 Babel 檔共用 component 要 Object.assign(window, {...})——每個 <script type="text/babel"> 有獨立 scope。
  4. 不要在 iframe-previewed artifact(Claude.ai Artifacts)中用 scrollIntoView——該環境 host 會被干擾。本地 HTML 檔直接用 scrollIntoView 沒問題;若不確定使用者會在哪個環境預覽,預設用 window.scrollTo()element.scrollTop 比較穩。
  5. Fixed-size 內容(deck、motion video)必須用內建 scaling——直接用 deck_stage.js(web component),不手刻 transform: scale()
  6. 單檔 > 1000 行要拆——多個 JSX 用 <script> 載入,在主檔組合。
  7. Scale 基準:1920×1080 slide 文字 ≥ 24px;列印 ≥ 12pt;mobile hit target ≥ 44px。
  8. No AI slop tropes:避免狂 gradient 背景、emoji(除非品牌用)、「圓角容器 + 左邊色條 accent」樣板、自畫 SVG 插圖、Inter / Roboto / Arial / Fraunces 這類 overused 字型。
  9. No filler content:每個元素都要有存在的理由;區塊看起來空是設計問題,用版面解決不是亂塞。
  10. Label slides & screens:代表 slide / 螢幕的 element 加 data-screen-label"01 Title""02 Agenda"),1-indexed。
  11. Copy assets locally:不 reference 外部路徑,全複製進作品資料夾。
  12. Speaker notes 只在被要求時才加

Sub-flows(各類型深入操作)

長細節放在 references/,只在實際要做該類任務時載入:

  • Slide deck:references/decks.md
  • Interactive prototype(含 mentioned-element 解讀):references/prototypes.md
  • Animation / motion:references/animations.md
  • Wireframe + design canvas:references/wireframes.md
  • Tweaks 協定完整版:references/tweaks.md
  • Content / 視覺 / 排版準則:references/content-guidelines.md
  • 提問 playbook(何時問、問什麼):references/questions.md
  • Starter components 索引:references/starter-components.md
  • 在 Claude Code 預覽的方法:references/verification.md
  • Quality checklist:references/quality_checklist.md

Example 1 — 使用者說:「幫我把這份 PRD 做成 8 頁 pitch deck,風格要像 Linear」

  • Step 0:先確認 PRD 檔案位置、簡報場合、是否需要 speaker notes、是否有 Linear 的視覺參考
  • Step 1:若使用者沒給 Linear 截圖,請他提供(或授權用既有 brand observations)
  • Step 2:寫敘事——「8 頁,以 Linear 的極簡風為底:白/深灰 + 紫色 accent、Geist Mono 強調、大字 hero + 支持點」
  • Step 3:建 design/pitch-deck/;複製 deck_stage.js;複製 Linear 參考截圖
  • Step 4:v0 放 8 個 <section> + placeholder title;打開看起來能翻頁
  • Step 5:非必要 React;原生 HTML + CSS grid 就夠
  • Step 6:Tweaks:主色(紫/藍/橘)、背景(純白/低飽和灰)、字型(Geist Mono / Söhne / 一般 serif)
  • Step 7:開瀏覽器,確認翻頁、列印 preview 無破
  • Step 8:交付訊息「草稿做好。第 3、5 頁 hero image 是 placeholder,需要你提供素材。要不要我加 speaker notes 或匯出成 PPTX?」

Example 2 — 使用者說:「prototype 一個外送 app 的 onboarding」

  • Step 0:大量提問(見 references/questions.md)——他有 codebase 嗎?UI kit?幾步驟?要做多少變體?平台 iOS/Android?動畫重要嗎?
  • Step 1:若有 codebase,讀 theme / tokens / 既有元件
  • Step 2:敘事——「4 步 onboarding,ios_frame,紫橘漸層 hero + 大 icon + 單行文案,進度條在頂端」
  • Step 3:design/onboarding-proto/ + 複製 ios_frame.jsxanimations.jsx
  • Step 4:v0 四個 screen,標示每 screen 的 role
  • Step 5:寫 React components——記得 onboardingStyles = {...} 命名規則、跨檔 Object.assign(window, {...})
  • Step 6:Tweaks:主色、CTA copy、動畫曲線、步驟順序
  • Step 7:開 /browse(若可用)或 xdg-open;點每一步驗證轉場
  • Step 8:「做好了。每 step 都有 Tweaks 可切換主色與 copy;動畫用 ease-out-cubic。需要我加 skip 按鈕流程嗎?」

Ops & release(指標與流程)

主題檔案
測試計畫、trigger / functional / ROI、regression gates 細節references/testing-plan.md
Troubleshooting 症狀對照表references/troubleshooting.md
不同 foundation model 的使用差異references/model-notes.md
打包、單一真實來源、eval workflowreferences/distribution.md
發佈前 readiness gatereferences/quality_checklist.md
Trigger / functional eval 資料assets/evals/evals.json
Release threshold(canonical)assets/evals/regression_gates.json

當上述欄位和 regression_gates.json 的數字有衝突時,JSON 是 source of truth

Skills relacionados