# Início rápido

English · Português (Brasil) · Deutsch · Français · 日本語 · 简体中文 · 繁體中文

Rode o produto inteiro localmente. ## Requisitos de ambiente - **Node.js:** `~24` (Node 24.x). O repo força isso via `package.json#engines`. - **pnpm:** `10.33.x`. O repo fixa `pnpm@10.33.2` via `packageManager`; 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: ```bash # nvm nvm install 24 nvm use 24 # fnm fnm install 24 fnm use 24 ``` Em seguida, habilite o Corepack e deixe o repo escolher o pnpm: ```bash corepack enable corepack pnpm --version # should print 10.33.2 ``` ## Em um único comando (modo dev) ```bash corepack enable pnpm install pnpm tools-dev run web # starts daemon + web in the foreground # open the web URL printed by tools-dev ``` Para a shell desktop e todos os sidecars gerenciados em background: ```bash pnpm tools-dev # starts daemon + web + desktop in the background ``` No 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 `` é parseada e o HTML é renderizado ao vivo na direita. Ao terminar, clique em **Save to disk** para persistir o artifact em `./.od/artifacts/-/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`](https://github.com/bergside/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) e `magazine-web-ppt` (o bundle `guizang-ppt` de [`op7418/guizang-ppt-skill`](https://github.com/op7418/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 resolva `assets/template.html` e `references/*.md` contra 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. ## Outros scripts ```bash 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 typecheck ``` `pnpm 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. ## Verificações de geração de mídia / dispatcher de agente 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 para `apps/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: ```bash 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/health ``` Em 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: ```bash 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`. ```nginx 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; } ``` ## Dois modos de execução | 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(, ...)` → 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 `` 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). ## Composição de prompt 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 , 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. ## Mapa de arquivos ``` 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 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// # per-project working dir + agent cwd ├── pnpm-workspace.yaml # apps/* + packages/* + tools/* + e2e └── package.json # root quality scripts + `od` bin ``` ## Solução de problemas - **"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 `buildArgs` em `apps/daemon/src/agents.ts` se precisar ajustar. - **geração de mídia diz que `OD_BIN` está 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áveis `OD_*` novas. - **Codex carrega muito contexto de plugin** — suba o Open Design com `OD_CODEX_DISABLE_PLUGINS=1 pnpm tools-dev` para que processos Codex spawnados pelo daemon rodem com `--disable plugins`. - **artifact nunca renderiza** — o modelo emitiu texto sem empacotar em ``. 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. ## Voltando à visão Este Início rápido é a semente executável da spec em [`docs/`](docs/). A spec descreve para onde isso evolui (veja [`docs/roadmap.md`](docs/roadmap.md)). Destaques: - `docs/architecture.md` descreve a stack entregue: Next.js 16 App Router na frente, daemon local atrás, e os rewrites de `apps/web/next.config.ts` em dev mantendo o navegador conversando com a mesma superfície `/api`. - `docs/skills-protocol.md` descreve o frontmatter `od:` completo (inputs tipados, sliders, gating de capacidades). Este MVP lê apenas `name` / `description` / `triggers` / `od.mode` / `od.design_system.requires` — estenda `apps/daemon/src/skills.ts` para cobrir o resto. - `docs/agent-adapters.md` prevê dispatch mais rico (detecção de capacidade, tool-calls em streaming). Nosso `apps/daemon/src/agents.ts` é um dispatcher mínimo — suficiente para provar a fiação. - `docs/modes.md` lista quatro modos: prototype / deck / template / design-system. Entregamos skills para os dois primeiros; o picker já filtra por `mode`.