* fix(docker): support multi-platform builds and fix monorepo paths Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * perf(renderer): cache pre-rasterized paragraph images to avoid per-frame glyph rasterization (#76) * fix(canvas): stabilize frame label size during zoom Draw frame labels in screen-space after the viewport transform restore, converting scene coords manually. Previously fontSize=12/zoom fed into Math.ceil caused integer-boundary jumps that made labels flicker during zoom. Also skip shadow rendering while actively zooming for smoother performance. * perf(renderer): cache pre-rasterized paragraph images to avoid per-frame glyph rasterization - Add paraImageCache (SkImage, 128 MB LRU limit) keyed on the same key as paraCache - Use drawImageRect instead of drawParagraph on cache hit, skipping per-frame glyph shaping and rasterization - Fall back to direct drawParagraph only when off-screen surface creation (MakeSurface) fails - Extract _dpr getter to deduplicate device-pixel-ratio resolution logic across draw paths - Evict oldest entries when cache exceeds byte limit; delete SkImage on eviction and dispose() * feat(cli): introduce OpenPencil CLI for terminal control of the design tool - Added a new CLI application under `apps/cli` to manage OpenPencil from the terminal. - Implemented commands for app control (`start`, `stop`, `status`), document operations (`open`, `save`, `get`, `selection`), and design manipulation (`design`, `import`). - Enhanced documentation with usage instructions and platform support details. - Updated build scripts to include CLI compilation and publishing processes. - Introduced a new GitHub Actions workflow for publishing the CLI to npm. - Updated existing workflows to integrate CLI build steps and ensure proper versioning across packages. * docs: update README files to include CLI tool details and multi-platform code export - Added CLI section to README files in multiple languages, detailing commands for terminal control of the design tool. - Included instructions for global installation and usage examples for the CLI. - Expanded documentation on multi-platform code export capabilities from a single `.op` file to various frameworks. - Updated CLAUDE.md to reference the new CLI documentation and its integration with the design tool. * chore(bun.lock): update package dependencies to specific versions - Removed workspace references for several packages in the bun.lock file. - Updated dependencies for `@zseven-w/pen-core`, `@zseven-w/pen-types`, `@zseven-w/pen-codegen`, `@zseven-w/pen-figma`, and `@zseven-w/pen-renderer` to version `0.5.1-beta.1`. - Ensured consistency in dependency management across the project. --------- Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com> Co-authored-by: leinaldo <60176594+leinaldo@users.noreply.github.com>
16 KiB
OpenPencil
A primeira ferramenta de design vetorial open-source nativa com IA do mundo.
Equipes de Agentes Concorrentes • Design-as-Code • Servidor MCP Integrado • Inteligência Multi-modelo
English · 简体中文 · 繁體中文 · 日本語 · 한국어 · Français · Español · Deutsch · Português · Русский · हिन्दी · Türkçe · ไทย · Tiếng Việt · Bahasa Indonesia
Clique na imagem para assistir ao vídeo de demonstração
Por que OpenPencil
🎨 Prompt → CanvasDescreva qualquer UI em linguagem natural. Veja-a aparecer no canvas infinito em tempo real com animação de streaming. Modifique designs existentes selecionando elementos e conversando. |
🤖 Equipes de Agentes ConcorrentesO orquestrador decompõe páginas complexas em sub-tarefas espaciais. Vários agentes de IA trabalham em diferentes seções simultaneamente — hero, features, footer — tudo em streaming paralelo. |
🧠 Inteligência Multi-ModeloAdapta-se automaticamente às capacidades de cada modelo. Claude recebe prompts completos com thinking; GPT-4o/Gemini desativam thinking; modelos menores (MiniMax, Qwen, Llama) recebem prompts simplificados para saída confiável. |
🔌 Servidor MCPInstalação com um clique no Claude Code, Codex, Gemini, OpenCode, Kiro ou Copilot CLIs. Faça design pelo seu terminal — leia, crie e modifique arquivos |
📦 Design-as-CodeArquivos |
🖥️ Roda em Qualquer LugarApp web + desktop nativo no macOS, Windows e Linux via Electron. Atualização automática a partir do GitHub Releases. Associação de arquivos |
⌨️ CLI —
|
🎯 Exportação de Código MultiplataformaExporte de um único arquivo |
Início Rápido
# Instalar dependências
bun install
# Iniciar servidor de desenvolvimento em http://localhost:3000
bun --bun run dev
Ou executar como aplicativo desktop:
bun run electron:dev
Docker
Várias variantes de imagem estão disponíveis — escolha a que se adequa às suas necessidades:
| Imagem | Tamanho | Inclui |
|---|---|---|
openpencil:latest |
~226 MB | Apenas aplicação web |
openpencil-claude:latest |
— | + Claude Code CLI |
openpencil-codex:latest |
— | + Codex CLI |
openpencil-opencode:latest |
— | + OpenCode CLI |
openpencil-copilot:latest |
— | + GitHub Copilot CLI |
openpencil-gemini:latest |
— | + Gemini CLI |
openpencil-full:latest |
~1 GB | Todas as ferramentas CLI |
Executar (apenas web):
docker run -d -p 3000:3000 ghcr.io/zseven-w/openpencil:latest
Executar com AI CLI (ex. Claude Code):
O chat de IA depende do login OAuth do Claude CLI. Use um volume Docker para persistir a sessão de login:
# Passo 1 — Login (apenas uma vez)
docker volume create openpencil-claude-auth
docker run -it --rm \
-v openpencil-claude-auth:/root/.claude \
ghcr.io/zseven-w/openpencil-claude:latest claude login
# Passo 2 — Iniciar
docker run -d -p 3000:3000 \
-v openpencil-claude-auth:/root/.claude \
ghcr.io/zseven-w/openpencil-claude:latest
Compilar localmente:
# Base (apenas web)
docker build --target base -t openpencil .
# Com um CLI específico
docker build --target with-claude -t openpencil-claude .
# Completo (todos os CLIs)
docker build --target full -t openpencil-full .
Design Nativo com IA
Do Prompt à UI
- Texto para design — descreva uma página e ela será gerada no canvas em tempo real com animação de streaming
- Orquestrador — decompõe páginas complexas em sub-tarefas espaciais para geração paralela
- Modificação de design — selecione elementos e descreva as alterações em linguagem natural
- Entrada de visão — anexe capturas de tela ou mockups para design baseado em referência
Suporte Multi-Agente
| Agente | Configuração |
|---|---|
| Claude Code | Sem configuração — usa o Claude Agent SDK com OAuth local |
| Codex CLI | Conectar nas Configurações do Agente (Cmd+,) |
| OpenCode | Conectar nas Configurações do Agente (Cmd+,) |
| GitHub Copilot | copilot login e depois conectar nas Configurações do Agente (Cmd+,) |
| Gemini CLI | Conectar nas Configurações do Agente (Cmd+,) |
Perfis de Capacidade de Modelo — adapta automaticamente prompts, modo de thinking e timeouts por nível de modelo. Modelos de nível completo (Claude) recebem prompts completos; nível padrão (GPT-4o, Gemini, DeepSeek) desativam thinking; nível básico (MiniMax, Qwen, Llama, Mistral) recebem prompts simplificados de JSON aninhado para máxima confiabilidade.
Servidor MCP
- Servidor MCP integrado — instalação com um clique no Claude Code / Codex / Gemini / OpenCode / Kiro / Copilot CLIs
- Detecção automática de Node.js — se não instalado, recurso automático para transporte HTTP e início automático do servidor MCP HTTP
- Automação de design pelo terminal: leia, crie e modifique arquivos
.opvia qualquer agente compatível com MCP - Fluxo de design em camadas —
design_skeleton→design_content→design_refinepara designs multi-seção de maior fidelidade - Recuperação segmentada de prompts — carregue apenas o conhecimento de design necessário (schema, layout, roles, icons, planning, etc.)
- Suporte a múltiplas páginas — crie, renomeie, reordene e duplique páginas via ferramentas MCP
Geração de Código
- React + Tailwind CSS, HTML + CSS, CSS Variables
- Vue, Svelte, Flutter, SwiftUI, Jetpack Compose, React Native
CLI — op
Instale globalmente e controle a ferramenta de design pelo terminal:
npm install -g @zseven-w/openpencil
op start # Iniciar app desktop
op design @landing.txt # Design em lote a partir de arquivo
op insert '{"type":"RECT"}' # Inserir um nó
op export react --out . # Exportar para React + Tailwind
op import:figma design.fig # Importar arquivo Figma
cat design.dsl | op design - # Entrada por pipe via stdin
Suporta três métodos de entrada: string inline, @filepath (ler de arquivo) ou - (ler de stdin). Funciona com o app desktop ou servidor web de desenvolvimento. Veja o CLI README para referência completa de comandos.
Funcionalidades
Canvas e Desenho
- Canvas infinito com pan, zoom, guias de alinhamento inteligentes e snapping
- Retângulo, Elipse, Linha, Polígono, Caneta (Bezier), Frame, Texto
- Operações booleanas — união, subtração, interseção com barra de ferramentas contextual
- Seletor de ícones (Iconify) e importação de imagens (PNG/JPEG/SVG/WebP/GIF)
- Auto-layout — vertical/horizontal com gap, padding, justify, align
- Documentos com múltiplas páginas e navegação por abas
Sistema de Design
- Variáveis de design — tokens de cor, número e string com referências
$variable - Suporte a múltiplos temas — vários eixos, cada um com variantes (Claro/Escuro, Compacto/Confortável)
- Sistema de componentes — componentes reutilizáveis com instâncias e substituições
- Sincronização CSS — propriedades personalizadas geradas automaticamente,
var(--name)na saída de código
Importação do Figma
- Importe arquivos
.figpreservando layout, preenchimentos, traços, efeitos, texto, imagens e vetores
Aplicativo Desktop
- macOS, Windows e Linux nativos via Electron
- Associação de arquivos
.op— clique duplo para abrir, bloqueio de instância única - Atualização automática a partir do GitHub Releases
- Menu de aplicativo nativo e diálogos de arquivo
Stack Tecnológica
| Frontend | React 19 · TanStack Start · Tailwind CSS v4 · shadcn/ui |
| Canvas | CanvasKit/Skia (WASM, acelerado por GPU) |
| Estado | Zustand v5 |
| Servidor | Nitro |
| Desktop | Electron 35 |
| CLI | op — controle pelo terminal, DSL de design em lote, exportação de código |
| IA | Anthropic SDK · Claude Agent SDK · OpenCode SDK · Copilot SDK |
| Runtime | Bun · Vite 7 |
| Formato de arquivo | .op — baseado em JSON, legível por humanos, compatível com Git |
Estrutura do Projeto
openpencil/
├── apps/
│ ├── web/ Aplicação web TanStack Start
│ │ ├── src/
│ │ │ ├── canvas/ Motor CanvasKit/Skia — desenho, sincronização, layout
│ │ │ ├── components/ UI React — editor, painéis, diálogos compartilhados, ícones
│ │ │ ├── services/ai/ Chat IA, orquestrador, geração de design, streaming
│ │ │ ├── stores/ Zustand — canvas, documento, páginas, histórico, IA
│ │ │ ├── mcp/ Ferramentas do servidor MCP para integração com CLI externo
│ │ │ ├── hooks/ Atalhos de teclado, soltar arquivos, colar do Figma
│ │ │ └── uikit/ Sistema de kit de componentes reutilizáveis
│ │ └── server/
│ │ ├── api/ai/ API Nitro — chat em streaming, geração, validação
│ │ └── utils/ Wrappers de cliente Claude CLI, OpenCode, Codex, Copilot
│ ├── desktop/ Aplicativo desktop Electron
│ │ ├── main.ts Janela, fork do Nitro, menu nativo, atualizador automático
│ │ ├── ipc-handlers.ts Diálogos de arquivo nativos, sincronização de tema, preferências IPC
│ │ └── preload.ts Ponte IPC
│ └── cli/ Ferramenta CLI — comando `op`
│ ├── src/commands/ Comandos de design, documento, exportação, importação, nó, página, variável
│ ├── connection.ts Conexão WebSocket com o app em execução
│ └── launcher.ts Detecção automática e inicialização do app desktop ou servidor web
├── packages/
│ ├── pen-types/ Definições de tipos para o modelo PenDocument
│ ├── pen-core/ Operações de árvore de documento, motor de layout, variáveis
│ ├── pen-codegen/ Geradores de código (React, HTML, Vue, Flutter, ...)
│ ├── pen-figma/ Parser e conversor de arquivos .fig do Figma
│ ├── pen-renderer/ Renderizador CanvasKit/Skia independente
│ └── pen-sdk/ SDK guarda-chuva (re-exporta todos os pacotes)
└── .githooks/ Sincronização de versão no pre-commit a partir do nome da branch
Atalhos de Teclado
| Tecla | Ação | Tecla | Ação | |
|---|---|---|---|---|
V |
Selecionar | Cmd+S |
Salvar | |
R |
Retângulo | Cmd+Z |
Desfazer | |
O |
Elipse | Cmd+Shift+Z |
Refazer | |
L |
Linha | Cmd+C/X/V/D |
Copiar/Recortar/Colar/Duplicar | |
T |
Texto | Cmd+G |
Agrupar | |
F |
Frame | Cmd+Shift+G |
Desagrupar | |
P |
Ferramenta caneta | Cmd+Shift+E |
Exportar | |
H |
Mão (pan) | Cmd+Shift+C |
Painel de código | |
Del |
Excluir | Cmd+Shift+V |
Painel de variáveis | |
[ / ] |
Reordenar | Cmd+J |
Chat IA | |
| Setas | Mover 1px | Cmd+, |
Configurações do agente | |
Cmd+Alt+U |
União booleana | Cmd+Alt+S |
Subtração booleana | |
Cmd+Alt+I |
Interseção booleana |
Scripts
bun --bun run dev # Servidor de desenvolvimento (porta 3000)
bun --bun run build # Build de produção
bun --bun run test # Executar testes (Vitest)
npx tsc --noEmit # Verificação de tipos
bun run bump <version> # Sincronizar versão em todos os package.json
bun run electron:dev # Desenvolvimento com Electron
bun run electron:build # Empacotamento do Electron
bun run cli:dev # Executar CLI a partir do código-fonte
bun run cli:compile # Compilar CLI para dist
Contribuindo
Contribuições são bem-vindas! Consulte o CLAUDE.md para detalhes de arquitetura e estilo de código.
- Faça fork e clone
- Configure a sincronização de versão:
git config core.hooksPath .githooks - Crie uma branch:
git checkout -b feat/my-feature - Execute as verificações:
npx tsc --noEmit && bun --bun run test - Faça commit com Conventional Commits:
feat(canvas): add rotation snapping - Abra um PR contra
main
Roadmap
- Variáveis de design e tokens com sincronização CSS
- Sistema de componentes (instâncias e substituições)
- Geração de design com IA e orquestrador
- Integração com servidor MCP e fluxo de design em camadas
- Suporte a múltiplas páginas
- Importação do Figma
.fig - Operações booleanas (união, subtração, interseção)
- Perfis de capacidade multi-modelo
- Reestruturação em monorepo com pacotes reutilizáveis
- Ferramenta CLI (
op) para controle pelo terminal - Edição colaborativa
- Sistema de plugins
Contribuidores
Comunidade
Star History
Licença
MIT — Copyright (c) 2026 ZSeven-W