English · Português (Brasil) · Deutsch · Français · 日本語 · 简体中文 · 繁體中文
Rode o produto inteiro localmente.
- Node.js:
~24(Node 24.x). O repo força isso viapackage.json#engines. - pnpm:
10.33.x. O repo fixapnpm@10.33.2viapackageManager; use Corepack para selecionar a versão fixada automaticamente. - SO: macOS, Linux e WSL2 são os caminhos principais. Windows nativo costuma funcionar para a maioria dos fluxos, mas WSL2 é a base mais segura.
- CLI de agente local (opcional): Claude Code, Codex, Devin for Terminal, Gemini CLI, OpenCode, Cursor Agent, Qwen, GitHub Copilot CLI etc. Sem nenhum instalado, use o modo BYOK API em Settings.
nvm / fnm são ferramentas opcionais de conveniência, não são parte obrigatória do setup do projeto. Se você usa um deles, instale/selecione o Node 24 antes de rodar pnpm:
# nvm
nvm install 24
nvm use 24
# fnm
fnm install 24
fnm use 24Em seguida, habilite o Corepack e deixe o repo escolher o pnpm:
corepack enable
corepack pnpm --version # should print 10.33.2corepack enable
pnpm install
pnpm tools-dev run web # starts daemon + web in the foreground
# open the web URL printed by tools-devPara a shell desktop e todos os sidecars gerenciados em background:
pnpm tools-dev # starts daemon + web + desktop in the backgroundNo primeiro carregamento, o app detecta o CLI de agente instalado (Claude Code / Codex / Devin for Terminal / Gemini / OpenCode / Cursor Agent / Qwen), seleciona automaticamente e usa por padrão o skill web-prototype + design system Neutral Modern. Digite um prompt e clique em Send. O agente faz streaming no painel da esquerda; a tag <artifact> é parseada e o HTML é renderizado ao vivo na direita. Ao terminar, clique em Save to disk para persistir o artifact em ./.od/artifacts/<timestamp>-<slug>/index.html.
O dropdown Design system vem com 129 design systems — 2 starters escritos à mão (Neutral Modern, Warm Editorial), 70 sistemas de produto bundled e 57 design skills vindos de awesome-design-skills. Escolha um para vestir cada protótipo na estética daquela marca.
O dropdown Skill agrupa por modo (Prototype / Deck / Template / Design system) e exibe o skill default de cada modo com um sufixo · default. Skills bundled:
- Prototype —
web-prototype(genérico),saas-landing,dashboard,pricing-page,docs-page,blog-post,mobile-app. - Deck / PPT —
simple-deck(swipe horizontal de arquivo único) emagazine-web-ppt(o bundleguizang-pptdeop7418/guizang-ppt-skill— default do modo deck, traz seus próprios assets/template + 4 referências). Skills com arquivos auxiliares ganham um preâmbulo automático "Skill root (absolute)" para que o agente resolvaassets/template.htmlereferences/*.mdcontra o caminho real em disco em vez do CWD.
Combine um skill com um design system e um único prompt produz um protótipo ou deck com layout adequado, na linguagem visual escolhida.
pnpm tools-dev # daemon + web + desktop in the background
pnpm tools-dev start web # daemon + web in the background
pnpm tools-dev run web # daemon + web in the foreground (e2e/dev server)
pnpm tools-dev restart # restart daemon + web + desktop
pnpm tools-dev restart --daemon-port 7457 --web-port 5175
pnpm tools-dev status # inspect managed runtimes
pnpm tools-dev logs # show daemon/web/desktop logs
pnpm tools-dev check # status + recent logs + common diagnostics
pnpm tools-dev stop # stop managed runtimes
pnpm --filter @open-design/daemon build # build apps/daemon/dist/cli.js for `od`
pnpm --filter @open-design/web build # build do pacote web quando necessário
pnpm typecheck # workspace typecheckpnpm tools-dev é o único entrypoint do ciclo de vida local. Não use os antigos atalhos do root removidos (pnpm dev, pnpm dev:all, pnpm daemon, pnpm preview, pnpm start).
Em desenvolvimento local, o tools-dev sobe o daemon primeiro, repassa a porta dele para apps/web, e o apps/web/next.config.ts reescreve /api/*, /artifacts/* e /frames/* para essa porta de daemon, permitindo que o app do App Router fale com o processo Express irmão sem configurar CORS.
Skills de imagem, vídeo, áudio e HyperFrames chamam o CLI local od por meio de variáveis de ambiente que o daemon injeta ao spawnar um agente:
OD_BIN— caminho absoluto paraapps/daemon/dist/cli.js.OD_DAEMON_URL— URL do daemon em execução.OD_PROJECT_ID— id do projeto ativo.OD_PROJECT_DIR— diretório de arquivos do projeto ativo.
Se a geração de mídia falhar com OD_BIN: parameter not set, com apps/daemon/dist/cli.js ausente ou com failed to reach daemon at http://127.0.0.1:0, recompile o CLI do daemon e reinicie o runtime gerenciado:
pnpm --filter @open-design/daemon build
pnpm tools-dev restart --daemon-port 7457 --web-port 5175
ls -la apps/daemon/dist/cli.js
curl -s http://127.0.0.1:7457/api/healthEm seguida, abra o projeto pelo app Open Design novamente em vez de retomar uma sessão antiga de agente no terminal. Um agente spawnado pelo daemon deve ver valores como:
echo "OD_BIN=$OD_BIN"
echo "OD_PROJECT_ID=$OD_PROJECT_ID"
echo "OD_PROJECT_DIR=$OD_PROJECT_DIR"
echo "OD_DAEMON_URL=$OD_DAEMON_URL"
ls -la "$OD_BIN"OD_DAEMON_URL precisa ser uma porta de daemon real, como http://127.0.0.1:7457, e não http://127.0.0.1:0. O :0 é apenas uma dica interna de "escolha uma porta livre" no launch e não deveria vazar para sessões de agente.
No modo de produção daemon-only, o próprio daemon serve o export estático do Next.js em http://localhost:7456, então não há reverse proxy envolvido.
Se você colocar nginx na frente do daemon, mantenha as rotas SSE sem buffering e sem compressão. Uma falha comum é o console do navegador mostrar net::ERR_INCOMPLETE_CHUNKED_ENCODING 200 (OK) depois de 80–90 segundos, porque o gzip on do nginx bufferiza respostas SSE em chunks mesmo quando o daemon envia X-Accel-Buffering: no.
location /api/ {
proxy_pass http://127.0.0.1:7456;
proxy_buffering off;
gzip off;
proxy_read_timeout 86400s;
proxy_send_timeout 86400s;
proxy_http_version 1.1;
proxy_set_header Connection "";
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}| Modo | Valor no picker | Como uma requisição flui |
|---|---|---|
| Local CLI (default quando o daemon detecta um agente) | "Local CLI" | Frontend → daemon /api/chat → spawn(<agent>, ...) → stdout → SSE → parser de artifact → preview |
| API mode (fallback / sem CLI) | "Anthropic API" / "OpenAI API" / "Azure OpenAI" / "Google Gemini" | Frontend → daemon /api/proxy/{provider}/stream → SSE do provider normalizado para delta/end/error → parser de artifact → preview |
Os dois modos alimentam o mesmo parser de <artifact> e o mesmo iframe sandboxed. A única diferença é o transporte e a entrega do system prompt (CLIs locais não têm um canal de sistema separado, então o prompt composto é dobrado dentro da mensagem do usuário).
A cada envio, o app monta um system prompt a partir de três camadas e o envia ao provider:
BASE_SYSTEM_PROMPT (output contract: wrap in <artifact>, no code fences)
+ active design system body (DESIGN.md — palette/type/layout)
+ active skill body (SKILL.md — workflow and output rules)
Troque o skill ou o design system na barra superior e o próximo envio usa a nova stack. Os corpos ficam em cache em memória por sessão, então é um único fetch ao daemon por escolha.
open-design/
├── apps/
│ ├── daemon/ # Node/Express — spawns local agents + serves APIs
│ │ └── src/
│ │ ├── cli.ts # `od` bin entry
│ │ ├── server.ts # /api/* + static serving
│ │ ├── agents.ts # PATH scanner for claude/codex/devin/gemini/opencode/cursor-agent/qwen/copilot
│ │ ├── skills.ts # SKILL.md loader (frontmatter parser)
│ │ └── design-systems.ts # DESIGN.md loader
│ │ ├── sidecar/ # tools-dev daemon sidecar wrapper
│ │ └── tests/ # daemon package tests
│ ├── web/ # Next.js 16 App Router + React client
│ ├── app/ # App Router entrypoints
│ ├── src/ # React + TypeScript client/runtime modules
│ │ ├── App.tsx # orchestrates mode / skill / DS pickers + send
│ │ ├── providers/ # daemon + BYOK API transports
│ │ ├── prompts/ # system, discovery, directions, deck framework
│ │ ├── artifacts/ # streaming <artifact> parser + manifests
│ │ ├── runtime/ # iframe srcdoc, markdown, export helpers
│ │ └── state/ # localStorage + daemon-backed project state
│ ├── sidecar/ # tools-dev web sidecar wrapper
│ └── next.config.ts # tools-dev rewrites + prod apps/web/out export config
│ └── desktop/ # Electron runtime, launched/inspected by tools-dev
├── packages/
│ ├── contracts/ # shared web/daemon app contracts
│ ├── sidecar-proto/ # Open Design sidecar protocol contract
│ ├── sidecar/ # generic sidecar runtime primitives
│ └── platform/ # generic process/platform primitives
├── tools/dev/ # `pnpm tools-dev` lifecycle and inspect CLI
├── e2e/ # Playwright UI + external integration/Vitest harness
├── skills/ # SKILL.md — drops in from any Claude Code skill repo
│ ├── web-prototype/ # generic single-screen prototype (default for prototype mode)
│ ├── saas-landing/ # marketing page (hero / features / pricing / CTA)
│ ├── dashboard/ # admin / analytics dashboard
│ ├── pricing-page/ # standalone pricing + comparison
│ ├── docs-page/ # 3-column documentation layout
│ ├── blog-post/ # editorial long-form
│ ├── mobile-app/ # phone-frame single screen
│ ├── simple-deck/ # minimal horizontal-swipe deck
│ └── guizang-ppt/ # magazine-web-ppt — bundled deck/PPT default
│ ├── SKILL.md
│ ├── assets/template.html
│ └── references/{themes,layouts,components,checklist}.md
├── design-systems/ # DESIGN.md — 9-section schema (awesome-claude-design)
│ ├── default/ # Neutral Modern (starter)
│ ├── warm-editorial/ # Warm Editorial (starter)
│ ├── README.md # catalog overview
│ └── …129 systems # 2 starters · 70 product systems · 57 design skills
├── scripts/sync-design-systems.ts # re-import from upstream getdesign tarball
├── docs/ # product vision + spec
├── .od/ # runtime data (gitignored, auto-created)
│ ├── app.sqlite # projects / conversations / messages / tabs
│ ├── artifacts/ # one-off "Save to disk" renders
│ └── projects/<id>/ # per-project working dir + agent cwd
├── pnpm-workspace.yaml # apps/* + packages/* + tools/* + e2e
└── package.json # root quality scripts + `od` bin
- "no agents found on PATH" — instale um destes:
claude,codex,devin,gemini,opencode,cursor-agent,qwen,copilot. Ou troque para o modo API em Settings e cole uma chave de provider. - daemon 500 em /api/chat — confira o terminal do daemon para a tail de stderr; geralmente o CLI rejeitou os args. CLIs diferentes aceitam formatos de argv diferentes; veja
buildArgsemapps/daemon/src/agents.tsse precisar ajustar. - geração de mídia diz que
OD_BINestá faltando ou que a URL do daemon é:0— rode as verificações do dispatcher de mídia acima. Não retome a sessão antiga do CLI; reabra o projeto pelo app Open Design para o daemon injetar variáveisOD_*novas. - Codex carrega muito contexto de plugin — suba o Open Design com
OD_CODEX_DISABLE_PLUGINS=1 pnpm tools-devpara que processos Codex spawnados pelo daemon rodem com--disable plugins. - artifact nunca renderiza — o modelo emitiu texto sem empacotar em
<artifact>. Confirme que o system prompt está chegando (cheque o log do daemon) e considere trocar para um modelo mais capaz ou um skill mais estrito.
Este Início rápido é a semente executável da spec em docs/. A spec descreve para onde isso evolui (veja docs/roadmap.md). Destaques:
docs/architecture.mddescreve a stack entregue: Next.js 16 App Router na frente, daemon local atrás, e os rewrites deapps/web/next.config.tsem dev mantendo o navegador conversando com a mesma superfície/api.docs/skills-protocol.mddescreve o frontmatterod:completo (inputs tipados, sliders, gating de capacidades). Este MVP lê apenasname/description/triggers/od.mode/od.design_system.requires— estendaapps/daemon/src/skills.tspara cobrir o resto.docs/agent-adapters.mdprevê dispatch mais rico (detecção de capacidade, tool-calls em streaming). Nossoapps/daemon/src/agents.tsé um dispatcher mínimo — suficiente para provar a fiação.docs/modes.mdlista quatro modos: prototype / deck / template / design-system. Entregamos skills para os dois primeiros; o picker já filtra pormode.