open-design/README.zh-TW.md
Zakaria a46764fb1b
Some checks failed
ci / Validate workspace (push) Has been cancelled
landing-page-ci / Validate landing page (push) Has been cancelled
landing-page-deploy / Deploy landing page (push) Has been cancelled
github-metrics / Generate repository metrics SVG (push) Has been cancelled
first-commit
2026-05-04 14:58:14 -04:00

55 KiB
Raw Blame History

Open Design

Claude Design 的開源替代品。 本地優先、可部署到 Vercel、每一層都 BYOK —— 10 套 coding-agent CLIPATH 上自動檢測Claude Code、Codex、Cursor Agent、Gemini CLI、OpenCode、Qwen、GitHub Copilot CLI、Hermes、Kimi、Pi就是設計引擎31 個可組合 Skills72 套品牌級 Design System 驅動。一個都沒裝?還有 OpenAI 相容的 BYOK 代理 /api/proxy/stream 備援,同一條 loop少一次 spawn 而已。

Open Design 封面:與本地 AI 智慧體共同設計

Stars Forks Issues Pull Requests Contributors Commit activity Last commit

License Agents Design systems Skills Quickstart

English · Deutsch · Français · 简体中文 · 繁體中文 · 한국어 · 日本語 · العربية · Русский · Українська


為什麼要做這個

Anthropic 的 Claude Design2026-04-17 釋出,基於 Opus 4.7)讓大家第一次看到:當一個 LLM 不再寫廢話、開始直接交付設計成品,會是什麼樣子。它瞬間爆紅 —— 然後保持閉源、付費、只跑在雲上、綁定 Anthropic 的模型和 Anthropic 的內部 skill。沒有 checkout沒有自託管沒有 Vercel 部署,也換不了自己的 agent。

Open DesignOD就是它的開源替代品。 同一套 loop、同一種「artifact-first」心智模型但沒有鎖定。我們不做 agent —— 你筆記本上最強的 coding agent 已經裝好了。我們要做的,是把它接進一個 skill 驅動的設計工作流:本地用 pnpm tools-dev 跑完整本地閉環,雲端可單獨部署 Web 層,每一層都 BYOK自帶 Key

輸入「幫我做一份雜誌風的種子輪 pitch deck」。在模型揮灑第一個畫素之前初始化問題表單已經先跳出來。Agent 從 5 套精選的視覺方向裡選一個。一張動態的 TodoWrite 計畫卡片即時流入 UI。Daemon 在磁碟上構建出一個真實的專案目錄,裡面有 seed 模板、佈局庫、自檢 checklist。Agent 強制 pre-flight 讀取它們,對自己的輸出跑一輪五維評審,幾秒後吐出一個 <artifact>,渲染在沙盒 iframe 裡。

這不是「AI 試圖做點設計」。這是一個被提示詞堆疊訓練得像高階設計師一樣工作的 AI —— 有可用的檔案系統、有確定性的色票庫、有 checklist 文化 —— 也就是 Claude Design 立下的那條線,只是這次它開源、歸你。

OD 站在四個開源專案的肩膀上:

  • alchaincyf/huashu-design(花叔的畫術) —— 設計哲學的指南針。Junior-Designer 工作流、5 步品牌資產協議、anti-AI-slop checklist、五維自評審、以及方向選擇器背後的「5 流派 × 20 種設計哲學」思路 —— 全部蒸餾進 apps/web/src/prompts/discovery.ts
  • op7418/guizang-ppt-skill(歸藏的雜誌風 PPT skill —— Deck 模式。原樣納入在 skills/guizang-ppt/ 下,原 LICENSE 保留雜誌版式、WebGL hero、P0/P1/P2 checklist。
  • OpenCoworkAI/open-codesign —— UX 北極星,也是我們最接近的同類。第一個開源的 Claude-Design 替代品。我們借鑑了它的流式 artifact 迴圈、沙盒 iframe 預覽模式(自帶 React 18 + Babel、即時 agent 面板todos + tool calls + 可中斷生成、5 種匯出格式列表HTML / PDF / PPTX / ZIP / Markdown。我們刻意在形態上做出差異化 —— 它是桌面 Electron 應用,把 pi-ai 打包進去做 agent我們是 Web 應用 + 本地 daemon把 agent 執行時委託給你已經裝好的 CLI。
  • multica-ai/multica —— Daemon 與執行時架構。PATH 掃描式 agent 檢測,本地 daemon 作為唯一的特權程序agent-as-teammate 的世界觀。

一眼概覽

你拿到的
Coding-agent CLI10 套) Claude Code · Codex CLI · Cursor Agent · Gemini CLI · OpenCode · Qwen Code · GitHub Copilot CLI · HermesACP· Kimi CLIACP· PiRPC—— 在 PATH 上自動檢測picker 一鍵切換
BYOK 備援 OpenAI 相容代理 /api/proxy/stream —— 填 baseUrl + apiKey + model,任意 vendorAnthropic-via-OpenAI、DeepSeek、Groq、MiMo、OpenRouter、自託管 vLLM或任何 OpenAI 相容的 provider都能直接當引擎用。daemon 邊界拒絕 loopback / link-local / RFC1918 防 SSRF。
內建 design system 72 套 —— 2 套手寫起手 + 70 套從 awesome-design-md 匯入的產品系統Linear、Stripe、Vercel、Airbnb、Tesla、Notion、Anthropic、Apple、Cursor、Supabase、Figma、小紅書…
內建 skill 31 個 —— 27 個 prototype 模式web-prototype、saas-landing、dashboard、mobile-app、gamified-app、social-carousel、magazine-poster、dating-web、sprite-animation、motion-frames、critique、tweaks、wireframe-sketch、pm-spec、eng-runbook、finance-report、hr-onboarding、invoice、kanban-board、team-okrs…+ 4 個 deck 模式(guizang-ppt · simple-deck · replit-deck · weekly-update。Picker 按 scenario 分組design / marketing / operation / engineering / product / finance / hr / sale / personal。
視覺方向 5 套精選流派Editorial Monocle · Modern Minimal · Warm Soft · Tech Utility · Brutalist Experimental每套自帶 OKLch 色票 + 字型堆疊(apps/web/src/prompts/directions.ts
裝置外殼 iPhone 15 Pro · Pixel · iPad Pro · MacBook · Browser Chrome —— 畫素級精確,跨 skill 共享,統一在 assets/frames/
Agent 執行時 本地 daemon 在你的專案目錄裡 spawn CLI —— agent 擁有真實的 Read / Write / Bash / WebFetch,作用在真實磁碟上;每個 adapter 都有 Windows ENAMETOOLONG 備援stdin / 臨時 prompt 檔案)
匯入 Claude Design 匯出的 ZIP 直接拖到歡迎彈窗 —— POST /api/import/claude-design 解壓成真實專案agent 接著 Anthropic 停下的地方繼續編輯,不用再向模型重述上下文
持久化 SQLite 在 .od/app.sqliteprojects · conversations · messages · tabs · 使用者 templates。明天再開todo 卡片和開啟的檔案都還在原位。
生命週期 唯一入口 pnpm tools-devstart / stop / run / status / logs / inspect / check—— 用型別化 sidecar stamp 啟動 daemon + web+ desktop
桌面版 可選 Electron 殼:渲染器 sandbox + sidecar IPCSTATUS / EVAL / SCREENSHOT / CONSOLE / CLICK / SHUTDOWN—— 同一通道驅動 tools-dev inspect desktop screenshot,跑 E2E
部署目標 本地 pnpm tools-dev · Vercel Web 層 · 打包 Electronapps/packaged/ 佔位中)
License Apache-2.0

效果展示

01 · 入口頁
入口頁 —— 選 skill、選 design system、寫一行需求。同一個表面服務原型、deck、行動版、dashboard、editorial 頁面所有 mode。
02 · 初始化問題表單
初始化問題表單 —— 模型動筆之前OD 先把需求鎖住surface、受眾、調性、品牌上下文、規模。30 秒勾選項秒殺 30 分鐘來回返工。
03 · 方向選擇器
方向選擇器 —— 使用者沒有品牌上下文時agent 自動跳第二個表單5 套精選方向Monocle / Modern Minimal / Tech Utility / Brutalist / Soft Warm一個 radio 選完,色票 + 字型堆疊直接鎖定,沒有 freestyle 空間。
04 · 即時 todo 進度
即時 todo 進度 —— Agent 的計畫以即時卡片形式流入 UI。in_progresscompleted 即時切換。使用者能在中途以極低成本介入修正。
05 · 沙盒預覽
沙盒預覽 —— 每個 <artifact> 都在乾淨的 srcdoc iframe 裡渲染。可在檔案工作區裡就地編輯;可下載為 HTML / PDF / ZIP。
06 · 72 套 design system 庫
72 套 design system 庫 —— 每套產品系統都展示 4 色色卡。點進去看完整的 DESIGN.md、色票網格、live showcase。
07 · 雜誌風 deck
Deck 模式guizang-ppt —— 內建的 guizang-ppt-skill 原樣接入。雜誌版式、WebGL hero 背景、單檔案 HTML 輸出、可導 PDF。
08 · 行動版原型
行動版原型 —— 畫素級精確的 iPhone 15 Pro chrome靈動島、狀態列 SVG、Home Indicator。多螢幕原型直接複用 /frames/ 共享資源agent 永遠不需要重新畫一遍手機。

內建 Skills

31 個 skill每個一個資料夾,都遵循 Claude Code 的 SKILL.md 規範,併疊加 OD 的 od: frontmatterdaemon 原樣解析 —— modeplatformscenariopreview.typedesign_system.requiresdefault_forfeaturedfidelityspeaker_notesanimationsexample_promptapps/daemon/src/skills.ts)。

兩種頂層 mode 撐起整個目錄:prototype27 個 —— 任何能被渲染成單頁 artifact 的產物,從雜誌風 landing 到手機螢幕到 PM 規格文件都算)和 deck4 個 —— 橫滑式演示,自帶 deck framework 框架)。scenario 是 picker 用來分組的欄位:design · marketing · operation · engineering · product · finance · hr · sale · personal

示例展示Showcase examples

視覺表現最強、最適合入門第一跑的幾條 skill。每條都附帶可直接開啟的 example.html —— 不用登入、不用配置,先看產出再動手。

dating-web
dating-web · prototype
消費級約會 / 婚戀儀表盤 —— 左側欄、社群動態 ticker、頭部 KPI、30 天雙向匹配柱狀圖editorial 字型,剋制點綴色。
digital-eguide
digital-eguide · template
兩頁數字 e-guide —— 封面標題、作者、TOC 預告)+ 內文跨頁pull-quote + 步驟列表),創作者 / 生活方式風。
email-marketing
email-marketing · prototype
品牌新品釋出郵件 —— 頂部 wordmark、hero 圖、標題鎖排、主 CTA、規格網格。居中單列 + 表格降級,郵件客戶端安全。
gamified-app
gamified-app · prototype
三螢幕遊戲化移動 app 原型,黑色舞臺 —— 封面 / 今日任務XP 緞帶 + 等級條)/ 任務詳情。
mobile-onboarding
mobile-onboarding · prototype
三螢幕行動版引導流 —— splash、價值主張、登入。狀態列、滑動點、主 CTA。
motion-frames
motion-frames · prototype
單幀 motion 設計 heroCSS 迴圈動畫 —— 旋轉字環、地球、計時器。可直接交給 HyperFrames 等關鍵幀匯出。
social-carousel
social-carousel · prototype
1080×1080 三連社媒輪播圖 —— 三張電影感面板標題前後呼應品牌標識、loop 標記。
sprite-animation
sprite-animation · prototype
畫素 / 8-bit 動畫直譯器單幀 —— 米白通螢幕、畫素吉祥物、動感日文標題、迴圈 CSS keyframes可直接錄螢幕成豎版影片。

設計與營銷類prototype 模式)

Skill 平臺 場景 產出
web-prototype 桌面 design 單頁 HTML —— landing、營銷、heroprototype 預設)
saas-landing 桌面 marketing hero / features / pricing / CTA 營銷版式
dashboard 桌面 operation 帶側欄 + 資料密集型的後臺
pricing-page 桌面 sale 獨立定價頁 + 對比表
docs-page 桌面 engineering 三欄文件版式
blog-post 桌面 marketing 長文 editorial
mobile-app 移動 design 帶 iPhone 15 Pro / Pixel 外殼的 app 螢幕
mobile-onboarding 移動 design 多螢幕行動版引導流splash · 價值主張 · 登入)
gamified-app 移動 personal 三螢幕遊戲化 app 原型
email-marketing 桌面 marketing 品牌新品釋出郵件(表格降級郵件客戶端安全)
social-carousel 桌面 marketing 1080×1080 三連社媒輪播
magazine-poster 桌面 marketing 單頁雜誌風海報
motion-frames 桌面 marketing CSS 迴圈動畫的 motion hero
sprite-animation 桌面 marketing 畫素 / 8-bit 動畫直譯器
dating-web 桌面 personal 消費級約會 / 婚戀儀表盤
digital-eguide 桌面 marketing 兩頁數字 e-guide封面 + 內文跨頁)
wireframe-sketch 桌面 design 手繪風線框稿 —— 服務於 "先把灰塊拼出來給使用者看" 的早期回合
critique 桌面 design 五維自評分卡Philosophy · Hierarchy · Detail · Function · Innovation
tweaks 桌面 design AI 自吐 tweaks 面板 —— 模型自己丟擲值得調的引數

Deck 類deck 模式)

Skill 預設 產出
guizang-ppt deck 預設 雜誌風網頁 PPT —— 來自 op7418/guizang-ppt-skill,原 LICENSE 保留
simple-deck 極簡橫滑 deck
replit-deck 產品演示 deckReplit 風)
weekly-update 團隊週報橫滑 deck進度 · 阻塞 · 下一步)

文件與辦公產物類prototype 模式 + 文件場景)

Skill Scenario 產出
pm-spec product PM 規格文件 + 目錄 + 決策日誌
team-okrs product OKR 計分表
meeting-notes operation 會議決策紀要
kanban-board operation 看板快照
eng-runbook engineering 故障 runbook
finance-report finance 高管財務摘要
invoice finance 單頁發票
hr-onboarding hr 崗位入職計畫

新增一個 skill 就是新增一個資料夾。讀 docs/skills-protocol.md 瞭解擴充套件 frontmatterfork 一個現有 skill重啟 daemon 即生效。目錄拉取走 GET /api/skills;單個 skill 的種子拼裝template + 邊角檔案 referencesGET /api/skills/:id/example

六個底層設計

1 · 我們不帶 agent你的就夠好

Daemon 啟動時掃 PATH,找 claudecodexcursor-agentgeminiopencodeqwencopilothermeskimipi。能找到的都成為候選設計引擎 —— 走 stdio每個 CLI 一個 adaptermodel picker 一鍵切換。靈感來自 multicacc-switch。一個 CLI 都沒裝?POST /api/proxy/stream 就是同一條管線減去 spawn —— 填任意 OpenAI 相容 baseUrl + apiKeydaemon 把 SSE 轉發回瀏覽器loopback / link-local / RFC1918 在邊界直接拒絕。

2 · Skill 是檔案,不是外掛

遵循 Claude Code SKILL.md 規範,每個 skill = SKILL.md + assets/ + references/。把一個資料夾丟進 skills/,重啟 daemonpicker 裡就能看到。內建的 magazine-web-ppt 就是 op7418/guizang-ppt-skill 原樣納入 —— 原 LICENSE 保留、原作者歸屬保留。

3 · Design System 是可移植的 Markdown不是 theme JSON

VoltAgent/awesome-design-md 的 9 段式 DESIGN.md —— color、typography、spacing、layout、components、motion、voice、brand、anti-patterns。每個 artifact 都從啟用的 system 裡讀 token。切換 system → 下一次渲染就用新的 token。下拉框裡現成的有Linear、Stripe、Vercel、Airbnb、Tesla、Notion、Apple、Anthropic、Cursor、Supabase、Figma、Resend、Raycast、Lovable、Cohere、Mistral、ElevenLabs、X.AI、Spotify、Webflow、Sanity、PostHog、Sentry、MongoDB、ClickHouse、Cal、Replicate、Clay、Composio、小紅書… 共 72 套。

4 · 初始化問題表單幹掉 80% 的來回返工

OD 的提示詞堆疊把 RULE 1 寫死了:每個新設計任務都從 <question-form id="discovery"> 開始,不是程式碼。Surface · 受眾 · 調性 · 品牌上下文 · 規模 · 約束。一段寫得很長的需求裡仍然有大量留白:視覺調性、色彩立場、規模 —— 而表單恰恰把這些用 30 秒勾選項鎖死。錯方向的代價是一輪對話,不是一份做完的 deck。

這就是從 huashu-design 蒸餾出來的 Junior-Designer 模式:開工前一次性批次問完,儘早 show 出一些可見的東西(哪怕只是灰色方塊的 wireframe讓使用者用最低成本介入修正。再疊加品牌資產協議定位 · 下載 · grep hex · 寫 brand-spec.md · 複述這是輸出從「AI freestyle」跳到「先看資料再畫圖的設計師」最關鍵的一步。

5 · Daemon 讓 agent 感覺自己就在你筆記本上 —— 因為它就是

Daemon spawn CLI 時,cwd 設到該專案在 .od/projects/<id>/ 下的 artifact 資料夾。Agent 拿到的 Read / Write / Bash / WebFetch 都是真工具,作用在真檔案系統上。它能 Read skill 的 assets/template.html,能 grep 你的 CSS 拿 hex能寫一份 brand-spec.md,能實作生成的圖片,能產出 .pptx / .zip / .pdf —— 這些檔案在 turn 結束的時候作為下載 chip 出現在檔案工作區裡。Session、對話、訊息、tab 都持久化在本地 SQLite 裡 —— 明天再開啟這個專案agent 的 todo 卡片還在你昨天停下的地方。

6 · 提示詞堆疊本身就是產品

傳送時拼裝的不是「system + user」。它是

DISCOVERY 指令         turn-1 表單、turn-2 品牌分支、TodoWrite、五維評審
  + 身份與工作流憲章   OFFICIAL_DESIGNER_PROMPT、anti-AI-slop、Junior Designer 模式)
  + 啟用的 DESIGN.md   72 套備選)
  + 啟用的 SKILL.md    31 套備選)
  + 專案後設資料          kind、fidelity、speakerNotes、animations、靈感 system id
  + Skill 副檔案       (自動注入 pre-flight先讀 assets/template.html + references/*.md
  + deck kind 且無 skill 種子時) DECK_FRAMEWORK_DIRECTIVE   nav / counter / scroll / print

每一層都可組合。每一層都是一個你能改的檔案。看 apps/web/src/prompts/system.tsapps/web/src/prompts/discovery.ts 就知道真實契約長什麼樣。

技術架構

┌─────────────── 瀏覽器Next.js 16─────────────────────────────┐
│  chat · 檔案工作區 · iframe 預覽 · 設定 · 匯入                  │
└──────────────┬─────────────────────────────────┬───────────────┘
               │ /api/*dev 走 rewrites        │
               ▼                                  ▼
   ┌─────────────────────────────────┐  /api/proxy/stream (SSE)
   │  本地 daemonExpress + SQLite│  ─→ 任意 OpenAI 相容
   │                                 │      端點BYOK
   │  /api/agents         /api/skills│      含 SSRF 防禦
   │  /api/design-systems /api/projects/…
   │  /api/chat (SSE)     /api/proxy/stream (SSE)
   │  /api/templates      /api/import/claude-design
   │  /api/artifacts/save /api/artifacts/lint
   │  /api/upload         /api/projects/:id/files…
   │  /artifacts (靜態)   /frames (靜態)
   │
   │  可選 sidecar IPC/tmp/open-design/ipc/<ns>/<app>.sock
   │  STATUS · EVAL · SCREENSHOT · CONSOLE · CLICK · SHUTDOWN
   └─────────┬───────────────────────┘
             │ spawn(cli, [...], { cwd: .od/projects/<id> })
             ▼
   ┌──────────────────────────────────────────────────────────────────┐
   │  claude · codex · gemini · opencode · cursor-agent · qwen        │
   │  copilot · hermes (ACP) · kimi (ACP) · pi (RPC)                  │
   │  讀 SKILL.md + DESIGN.md把 artifact 寫到磁碟                   │
   └──────────────────────────────────────────────────────────────────┘
技術堆疊
前端 Next.js 16 App Router + React 18 + TypeScript可部署到 Vercel
Daemon Node 24 · Express · SSE 流 · better-sqlite3;表:projects · conversations · messages · tabs · templates
Agent 傳輸層 child_process.spawnClaude Code 走 claude-stream-json、Copilot 走 copilot-stream-json、Codex / Gemini / OpenCode / Cursor Agent 走 json-event-stream(每個 CLI 一個 parser、Hermes / Kimi 走 acp-json-rpcAgent Client Protocol、Pi 走 pi-rpcstdio JSON-RPC、Qwen Code 走 plain
BYOK 代理 POST /api/proxy/stream → OpenAI 相容 /v1/chat/completions 透傳 SSEdaemon 邊界拒絕 loopback / link-local / RFC1918
儲存 純檔案 .od/projects/<id>/ + SQLite .od/app.sqlite(已 gitignoredaemon 啟動自建)。OD_DATA_DIR 可改根目錄用於測試隔離
預覽 沙盒 iframesrcdoc+ 每個 skill 的 <artifact> parserapps/web/src/artifacts/parser.ts
匯出 HTML內聯資源· PDF瀏覽器列印deck-aware· PPTXagent 驅動經由 skill· ZIParchiver· Markdown
生命週期 pnpm tools-dev start | stop | run | status | logs | inspect | check;埠走 --daemon-port / --web-port,名稱空間走 --namespace
桌面版(可選) Electron 殼 —— 透過 sidecar IPC 拿 web URL不猜埠同一通道STATUS/EVAL/SCREENSHOT/CONSOLE/CLICK/SHUTDOWN)驅動 tools-dev inspect desktop … 跑 E2E

Quickstart

git clone https://github.com/nexu-io/open-design.git
cd open-design
corepack enable
corepack pnpm --version   # 應輸出 10.33.2
pnpm install
pnpm tools-dev run web
# 開啟 tools-dev 輸出的 web URL

環境要求Node ~24pnpm 10.33.xnvm / fnm 只是可選輔助工具,不是專案必需步驟;如果使用它們,先執行 nvm install 24 && nvm use 24fnm install 24 && fnm use 24,再執行 pnpm install

桌面版/後臺啟動、固定埠重啟,以及 media 生成派發器檢查(OD_BINOD_DAEMON_URLapps/daemon/dist/cli.js)見 QUICKSTART.md

第一次載入會:

  1. 檢測你 PATH 上有哪些 agent CLI自動選一個。
  2. 載入 31 個 skill + 72 套 design system。
  3. 彈歡迎對話方塊,讓你貼 Anthropic key僅 BYOK 備援路徑需要)。
  4. 自動建立 ./.od/ —— 本地執行時目錄,存放 SQLite 專案庫、各專案工作區、儲存下來的 artifact。沒有 od init 這一步daemon 啟動時會自己 mkdir

輸入需求,回車,看 question form 跳出來,填,看 todo 卡片流動,看 artifact 渲染。點 Save to disk 或匯出整個專案 ZIP。

第一次跑起來(./.od/ 解釋)

Daemon 在倉庫根下維護一個隱藏目錄,裡面所有內容都已 gitignore純本機資料不要 commit。

.od/
├── app.sqlite                 ← 專案 · 對話 · 訊息 · 開啟的 tab
├── artifacts/                 ← Save to disk 一次性渲染(帶時間戳)
└── projects/<id>/             ← 每個專案的工作目錄,也是 agent 的 cwd
想做什麼 怎麼做
看一眼裡面有啥 ls -la .od && sqlite3 .od/app.sqlite '.tables'
完全清空,從零再來 pnpm tools-dev stop,再 rm -rf .od,然後重新 pnpm tools-dev run web
換到別的位置 暫不支援 —— 路徑是相對倉庫根寫死的

完整檔案地圖、指令碼、排錯 → QUICKSTART.md

倉庫結構

open-design/
├── README.md                      ← 英文
├── README.de.md                   ← Deutsch
├── README.zh-CN.md                ← 简体中文
├── README.zh-TW.md                ← 本檔案
├── QUICKSTART.md                  ← 跑 / 構建 / 部署
├── package.json                   ← 單 bin: od
│
├── apps/
│   ├── daemon/                    ← Node + Express唯一的服務端
│   │   ├── src/                   ← TypeScript daemon 原始碼
│   │   │   ├── cli.ts             ← `od` bin 原始碼,編譯到 dist/cli.js
│   │   │   ├── server.ts          ← /api/* 路由projects、chat、files、exports
│   │   │   ├── agents.ts          ← PATH 掃描器 + 各 CLI 的 argv 拼裝
│   │   │   ├── claude-stream.ts   ← Claude Code stdout 流式 JSON 解析
│   │   │   ├── skills.ts          ← SKILL.md frontmatter 載入器
│   │   │   └── db.ts              ← SQLite schemaprojects/messages/templates/tabs
│   │   ├── sidecar/               ← tools-dev daemon sidecar wrapper
│   │   └── tests/                 ← daemon 包測試
│   │
│   └── web/                       ← Next.js 16 App Router + React 客戶端
│       ├── app/                   ← App Router 入口
│       ├── next.config.ts         ← dev rewrites + 生產 out/ 靜態匯出
│       └── src/                   ← React + TS 客戶端模組
│           ├── App.tsx            ← 路由、bootstrap、設定
│           ├── components/        ← chat、composer、picker、preview、sketch…
│           ├── prompts/           ← system、discovery、directions、deck framework
│           ├── artifacts/         ← streaming <artifact> parser + manifest
│           ├── runtime/           ← iframe srcdoc、markdown、匯出輔助
│           ├── providers/         ← daemon SSE + BYOK API 傳輸
│           └── state/             ← localStorage + daemon-backed 專案狀態
│
├── e2e/                           ← Playwright UI + 外部整合/Vitest harness
│
├── packages/
│   ├── contracts/                 ← web/daemon 共享 app contracts
│   ├── sidecar-proto/             ← Open Design sidecar protocol contract
│   ├── sidecar/                   ← 通用 sidecar runtime primitives
│   └── platform/                  ← 通用 process/platform primitives
│
├── skills/                        ← 31 個 SKILL.md skill 包27 prototype + 4 deck
│   ├── web-prototype/             ← prototype 預設
│   ├── saas-landing/  dashboard/  pricing-page/  docs-page/  blog-post/
│   ├── mobile-app/  mobile-onboarding/  gamified-app/
│   ├── email-marketing/  social-carousel/  magazine-poster/
│   ├── motion-frames/  sprite-animation/  digital-eguide/  dating-web/
│   ├── critique/  tweaks/  wireframe-sketch/
│   ├── pm-spec/  team-okrs/  meeting-notes/  kanban-board/
│   ├── eng-runbook/  finance-report/  invoice/  hr-onboarding/
│   ├── simple-deck/  replit-deck/  weekly-update/   ← deck 模式
│   └── guizang-ppt/               ← 內建 magazine-web-pptdeck 預設)
│       ├── SKILL.md
│       ├── assets/template.html   ← seed
│       └── references/{themes,layouts,components,checklist}.md
│
├── design-systems/                ← 72 套 DESIGN.md
│   ├── default/                   ← Neutral Modern起手
│   ├── warm-editorial/            ← Warm Editorial起手
│   ├── linear-app/  vercel/  stripe/  airbnb/  notion/  cursor/  apple/  …
│   └── README.md
│
├── assets/
│   └── frames/                    ← 跨 skill 共享裝置外殼
│       ├── iphone-15-pro.html
│       ├── android-pixel.html
│       ├── ipad-pro.html
│       ├── macbook.html
│       └── browser-chrome.html
│
├── templates/
│   └── deck-framework.html        ← deck 基線nav / counter / print
│
├── scripts/
│   └── sync-design-systems.ts     ← 從上游 awesome-design-md tarball 重新匯入
│
├── docs/
│   ├── spec.md                    ← 產品定義、場景、差異化
│   ├── architecture.md            ← 拓撲、資料流、元件
│   ├── skills-protocol.md         ← 擴充套件 SKILL.md 的 od: frontmatter
│   ├── agent-adapters.md          ← 各 CLI 檢測 + 派發
│   ├── modes.md                   ← prototype / deck / template / design-system
│   ├── references.md              ← 詳盡的引用與師承
│   ├── roadmap.md                 ← 分階段交付
│   ├── schemas/                   ← JSON schema
│   └── examples/                  ← 標準 artifact 樣例
│
└── .od/                           ← 執行時資料,已 gitignoredaemon 啟動自建
    ├── app.sqlite                 ← 專案 / 對話 / 訊息 / tab
    ├── projects/<id>/             ← 每個專案的工作目錄agent 的 cwd
    └── artifacts/                 ← 單次儲存的 artifact

Design System

72 套 Design Systems 庫 — 編輯版式雙頁

72 套開箱即用,每套一個 DESIGN.md

完整目錄(點選展開)

AI & LLM —— claude · cohere · mistral-ai · minimax · together-ai · replicate · runwayml · elevenlabs · ollama · x-ai

開發者工具 —— cursor · vercel · linear-app · framer · expo · clickhouse · mongodb · supabase · hashicorp · posthog · sentry · warp · webflow · sanity · mintlify · lovable · composio · opencode-ai · voltagent

生產力 —— notion · figma · miro · airtable · superhuman · intercom · zapier · cal · clay · raycast

金融科技 —— stripe · coinbase · binance · kraken · mastercard · revolut · wise

電商 / 出行 —— shopify · airbnb · uber · nike · starbucks · pinterest

媒體 —— spotify · playstation · wired · theverge · meta

汽車 —— tesla · bmw · ferrari · lamborghini · bugatti · renault

其他 —— apple · ibm · nvidia · vodafone · sentry · resend · spacex

起手 —— defaultNeutral Modern· warm-editorial

整個庫透過 scripts/sync-design-systems.tsVoltAgent/awesome-design-md 匯入。重新執行即可重新整理。

視覺方向

當用戶沒有品牌資產時agent 會跳第二個表單5 套精選方向 —— 這是 huashu-design 的「設計方向顧問 · 5 流派 × 20 種設計哲學」 fallback 在 OD 裡的實作。每一套都是確定性 spec —— OKLch 色票、字型堆疊、版式姿態、參考列表 —— agent 直接把它原樣綁進 seed 模板的 :root。一個 radio 選完,整套視覺系統全部鎖定。零 freestyle零 AI slop。

方向 調性 參考
Editorial — Monocle / FT 印刷雜誌,墨水 + 米色紙 + 暖紅強調 Monocle · FT Weekend · NYT Magazine
Modern minimal — Linear / Vercel 冷調、結構化、剋制強調 Linear · Vercel · Stripe
Tech utility 資訊密度、等寬、終端感 Bloomberg · Bauhaus 工具
Brutalist 粗糲、巨字、無陰影、刺眼強調 Bloomberg Businessweek · Achtung
Soft warm 大方、低對比、桃色中性 Notion 營銷頁 · Apple Health

完整 spec → apps/web/src/prompts/directions.ts

聊天迴圈之外,還交付了什麼

Chat / artifact 迴圈最顯眼,但這套倉庫裡還有幾個能力被埋得有點深,對照其它產品做選型之前值得先掃一遍:

  • Claude Design ZIP 匯入。 把 claude.ai 匯出的 ZIP 拖到歡迎彈窗,POST /api/import/claude-design 把它解壓成真實 .od/projects/<id>/,把入口檔案作為 tab 開啟,並預置一句「接著 Anthropic 停下的地方繼續編輯」給本地 agent。不用再讓模型重述上下文也不用「讓模型重新畫一遍」。(apps/daemon/src/server.ts/api/import/claude-design)
  • OpenAI 相容 BYOK 代理。 POST /api/proxy/stream 接收 { baseUrl, apiKey, model, messages },自動歸一化路徑(…/v1/chat/completions),把 SSE chunk 轉發回瀏覽器;同時拒絕 loopback / link-local / RFC1918 防 SSRF。任何說 OpenAI chat schema 的 vendor 都能直接用 —— Anthropic-via-OpenAI shim、DeepSeek、Groq、MiMo、OpenRouter、自託管 vLLM 都行。MiMo 會自動加 tool_choice: 'none',因為它的 tool schema 和 free-form 生成不太合得來。
  • 使用者自存 templates。 喜歡某次渲染?POST /api/templates 把 HTML + 後設資料快照進 SQLite templates 表。下個專案的 picker 裡多一行「你的模板」 —— 跟內建 31 套同一個挑選面,但是你的。
  • Tab 持久化。 每個專案記得自己開啟的檔案和當前 tab存在 tabs 表裡。明天再開啟,工作區還是你昨天離開時的樣子。
  • Artifact lint API。 POST /api/artifacts/lint 對生成的 artifact 跑結構性檢查(<artifact> 框架是否破損、必需的副檔案是否缺失、palette token 是否過期),返回 agent 下一回合可以讀回去的 findings。五維自評審就是用它把分數落到證據上而不是 vibe。
  • Sidecar 協議 + 桌面版自動化。 Daemon、web、desktop 程序都帶型別化的 5 欄位 stampapp · mode · namespace · ipc · source),並把 JSON-RPC IPC 通道暴露在 /tmp/open-design/ipc/<namespace>/<app>.socktools-dev inspect desktop status \| eval \| screenshot 就跑在這條通道上,所以 headless E2E 直接打到真實 Electron 殼,不用造定製夾具(packages/sidecar-proto/apps/desktop/src/main/)。
  • Windows 友好的 spawn。 任何在長 prompt 上會撞 CreateProcess 32 KB argv 上限的 adapterCodex、Gemini、OpenCode、Cursor Agent、Qwen、Pi都改走 stdin。Claude Code 和 Copilot 保留 -p;連 stdin 都裝不下時 daemon 退回臨時 prompt 檔案。
  • 按 namespace 隔離的 runtime data。 OD_DATA_DIR--namespace 給你完全隔離的 .od/-style 目錄樹Playwright、beta channel、你正經的專案永遠不會共用同一個 SQLite 檔案。

反 AI Slop 機制

下面整套機制都是 huashu-design 的 playbook被移植進 OD 的提示詞堆疊,並透過 skill 副檔案 pre-flight 讓每個 skill 都能實作執行。看 apps/web/src/prompts/discovery.ts 是真實文案:

  • 先表單。 Turn 1 必須是 <question-form>不準 thinking、不準 tools、不準旁白。使用者用 radio 速度選預設。
  • 品牌資產協議。 使用者貼截圖或 URL 時agent 走 5 步流程(定位 · 下載 · grep hex · 寫 brand-spec.md · 複述)才能開始寫 CSS。絕不從記憶裡猜品牌色
  • 五維評審。 在吐 <artifact> 之前agent 默默給自己 15 分打分,五個維度:哲學 / 層級 / 執行 / 具體度 / 剋制。任一維 < 3/5 視為退步 —— 修完再評。兩輪是常態。
  • P0/P1/P2 checklist。 每個 skill 都自帶 references/checklist.md,含硬性 P0。Agent 必須 P0 全過才能 emit。
  • Slop 黑名單。 暴力紫漸變、通用 emoji 圖示、左 border 圓角卡片、手繪 SVG 真人臉、Inter 當 display 字型、自編指標 —— 提示詞裡全部明令禁止。
  • 誠實佔位 > 假資料。 Agent 沒真數字時寫 或一個標註的灰塊,絕不寫「快 10 倍」。

橫向對比

維度 Claude DesignAnthropic Open CoDesign Open Design
License 閉源 MIT Apache-2.0
形態 Web (claude.ai) 桌面 (Electron) Web 應用 + 本地 daemon
可部署 Vercel
Agent 執行時 內建 (Opus 4.7) 內建 (pi-ai) 委託給使用者已裝好的 CLI
Skill 私有 12 套自定義 TS 模組 + SKILL.md 31 套基於檔案的 SKILL.md,可丟入
Design system 私有 DESIGN.mdv0.2 路線圖) DESIGN.md × 72 套,開箱即有
Provider 靈活度 僅 Anthropic 7+pi-ai 10 套 CLI adapter + OpenAI 相容 BYOK 代理
初始化問題表單 硬規則 turn 1
方向選擇器 5 套確定性方向
即時 todo 進度 + tool 流 UX 模式來自 open-codesign
沙盒 iframe 預覽 (模式來自 open-codesign
Claude Design ZIP 匯入 n/a POST /api/import/claude-design —— 接著 Anthropic 停下的地方繼續編輯
評論模式手術刀編輯 🚧 路線圖(移植自 open-codesign
AI 自吐 tweaks 面板 🟡 部分 —— tweaks skill 已發,專屬 chat-side 面板 UX 仍在路線圖
檔案系統級工作區 部分Electron 沙盒) 真 cwd、真工具、SQLite 持久化projects · conversations · messages · tabs · templates
五維自評審 Emit 前必跑
Artifact lint POST /api/artifacts/lint —— 把 findings 喂回 agent
Sidecar IPC + 無頭桌面版 stamped 程序 + tools-dev inspect desktop status | eval | screenshot
匯出格式 受限 HTML / PDF / PPTX / ZIP / Markdown HTML / PDF / PPTXagent 驅動)/ ZIP / Markdown
PPT skill 複用 N/A 內建 guizang-ppt-skill 直接接入deck 模式預設)
計費門檻 Pro / Max / Team BYOK BYOK —— 填任意 OpenAI 相容 baseUrl

支援的 Coding Agent

Daemon 啟動時從 PATH 自動檢測,無需配置。流式分發邏輯在 apps/daemon/src/agents.tsAGENT_DEFS 裡;每個 CLI 的 parser 也在同目錄。模型列表的來源要麼是探測 <bin> --list-models / <bin> models / ACP 握手,要麼走精選 fallback。

Agent 二進位制 流式格式 argv 形態(拼裝好的 prompt 路徑)
Claude Code claude claude-stream-json(型別化事件) claude -p <prompt> --output-format stream-json --verbose [--include-partial-messages] [--add-dir …] --permission-mode bypassPermissions
Codex CLI codex json-event-stream + codex parser codex exec --json --skip-git-repo-check --full-auto [-C cwd] [--model …] [-c model_reasoning_effort=…] -prompt 走 stdin
Gemini CLI gemini json-event-stream + gemini parser GEMINI_CLI_TRUST_WORKSPACE=true gemini --output-format stream-json --yolo [--model …]prompt 走 stdin
OpenCode opencode json-event-stream + opencode parser opencode run --format json --dangerously-skip-permissions [--model …] -prompt 走 stdin
Cursor Agent cursor-agent json-event-stream + cursor-agent parser cursor-agent --print --output-format stream-json --stream-partial-output --force --trust [--workspace cwd] [--model …] -prompt 走 stdin
Qwen Code qwen plain(原始 stdout chunk qwen --yolo [--model …] -prompt 走 stdin
GitHub Copilot CLI copilot copilot-stream-json(型別化事件) copilot -p <prompt> --allow-all-tools --output-format json [--model …] [--add-dir …]
Hermes hermes acp-json-rpcAgent Client Protocol hermes acp --accept-hooks
Kimi CLI kimi acp-json-rpc kimi acp
Pi pi pi-rpcstdio JSON-RPC pi --mode rpc --no-session [--model …] [--thinking …]prompt 走 RPC prompt 命令)
OpenAI 相容 BYOK n/a SSE 透傳 POST /api/proxy/stream<baseUrl>/v1/chat/completions;拒絕 loopback / link-local / RFC1918

加一個新 CLI = 在 apps/daemon/src/agents.ts 里加一項。流式格式從 claude-stream-json / copilot-stream-json / json-event-stream(搭配每 CLI 的 eventParser/ acp-json-rpc / pi-rpc / plain 中選一個。

引用與師承

每一個被借鑑的開源專案都列在這裡。點連結可以驗證師承。

專案 在這裡的角色
Claude Design 本倉庫為之提供開源替代的閉源產品。
alchaincyf/huashu-design(花叔的畫術) 設計哲學的核心。Junior-Designer 工作流、5 步品牌資產協議、anti-AI-slop checklist、五維自評審、以及方向選擇器背後的「5 流派 × 20 種設計哲學」庫 —— 全部蒸餾進 apps/web/src/prompts/discovery.tsapps/web/src/prompts/directions.ts
op7418/guizang-ppt-skill(歸藏) Magazine-web-PPT skill 原樣納入在 skills/guizang-ppt/ 下,原 LICENSE 保留。Deck 模式預設。P0/P1/P2 checklist 文化也被借給了所有其他 skill。
multica-ai/multica Daemon + adapter 架構。PATH 掃描式 agent 檢測、本地 daemon 作為唯一特權程序、agent-as-teammate 世界觀。我們採納模型,不 vendor 程式碼。
OpenCoworkAI/open-codesign 第一個開源的 Claude-Design 替代品,也是我們最接近的同類。已採納的 UX 模式:流式 artifact 迴圈、沙盒 iframe 預覽(自帶 React 18 + Babel、即時 agent 面板todos + tool calls + 可中斷、5 種匯出格式列表HTML/PDF/PPTX/ZIP/Markdown、本地優先的 designs hub、SKILL.md 品味注入。路線圖上的 UX 模式評論模式手術刀編輯、AI 自吐 tweaks 面板。我們刻意不 vendor pi-ai —— open-codesign 把它打包成 agent 執行時;我們則委託給使用者已經裝好的 CLI。
VoltAgent/awesome-claude-design / awesome-design-md 9 段式 DESIGN.md schema 的來源69 套產品系統透過 scripts/sync-design-systems.ts 匯入。
farion1231/cc-switch 跨多個 agent CLI 的 symlink 式 skill 分發靈感來源。
Claude Code skills SKILL.md 規範原樣採納 —— 任何 Claude Code skill 丟進 skills/ 都能被 daemon 識別。

詳盡的師承說明(每一項我們採納了什麼、刻意沒采納什麼)在 docs/references.md

Roadmap

  • Daemon + agent 檢測10 套 CLI adapter+ skill registry + design-system 目錄
  • Web 應用 + 對話 + question form + 5 套方向選擇器 + todo progress + 沙盒預覽
  • 31 個 skill + 72 套 design system + 5 套視覺方向 + 5 個裝置外殼
  • SQLite 後端的 projects · conversations · messages · tabs · templates
  • OpenAI 相容 BYOK 代理(/api/proxy/stream)含 SSRF 防禦
  • Claude Design ZIP 匯入(/api/import/claude-design
  • Sidecar 協議 + Electron 桌面版 + IPC 自動化STATUS / EVAL / SCREENSHOT / CONSOLE / CLICK / SHUTDOWN
  • Artifact lint API + 五維自評審 emit-前 gate
  • 評論模式手術刀編輯(點元素 → 指令 → 區域性 patch—— 模式來自 open-codesign
  • AI 自吐 tweaks 面板 UX —— 基礎積木(tweaks skill)已發,整合到 chat 的面板尚未完成
  • Vercel + 隧道部署食譜Topology B
  • 一行 npx od init 腳手架帶 DESIGN.md
  • Skill 市場(od skills install <github-repo>)和 od skill add | list | remove | test CLI 表面(在 docs/skills-protocol.md 裡有草案daemon 實現尚未跟上)
  • apps/packaged/ 出可分發 Electron 安裝包

分階段交付計畫在 docs/roadmap.md

專案狀態

這是一個早期實現 —— 閉環(檢測 → 選 skill + design system → 對話 → 解析 <artifact> → 預覽 → 儲存)已經端到端跑通。提示詞堆疊和 skill 庫是價值最重的部分,目前已穩定。元件級 UI 仍在每天迭代。

給我們點個 Star

給 Open Design 點個 Star —— github.com/nexu-io/open-design

如果這套東西幫你省了半小時,給它一個 ★。Star 不付房租但它告訴下一個設計師、Agent 和貢獻者:這個實驗值得他們的注意力。一次點選、三秒鐘、真實訊號:github.com/nexu-io/open-design

貢獻

歡迎 issue、PR、新 skill、新 design system。收益最高的貢獻往往就是一個資料夾、一份 Markdown或者一個 PR 大小的 adapter

完整流程、合併硬線、程式碼風格、我們不接收的 PR 型別 → CONTRIBUTING.zh-CN.mdEnglishDeutschFrançais)。

貢獻者牆

感謝每一位讓 Open Design 變得更好的朋友 —— 無論是寫程式碼、修文檔、提 issue、加 skill 還是加 design system每一次真實貢獻都會被記住。下面這面牆是最直觀的「Thank you」。

Open Design 貢獻者

第一次提 PR歡迎從 good-first-issue 標籤起步。

倉庫活躍度

Open Design 倉庫指標

上面的 SVG 由 .github/workflows/metrics.yml 藉助 lowlighter/metrics 每天自動重新生成。想要立刻重新整理可以去 Actions 選項卡手動觸發想開啟更豐富的外掛traffic、follow-up time 等)可在倉庫 secrets 里加一個細粒度 PAT 命名為 METRICS_TOKEN

Star History

Open Design star history

曲線往上走 —— 那就是我們想看到的訊號。點 ★ 推它一把。

License

Apache-2.0。內建的 skills/guizang-ppt/ 保留它原始的 LICENSEMIT和原作者 op7418 的歸屬。