Canvas (app macOS)
O app macOS incorpora um painel Canvas controlado pelo agente usandoWKWebView. Ele
é um workspace visual leve para HTML/CSS/JS, A2UI e pequenas superfícies
de UI interativas.
Onde o Canvas fica
O estado do Canvas é armazenado em Application Support:~/Library/Application Support/OpenClaw/canvas/<session>/...
openclaw-canvas://<session>/<path>
openclaw-canvas://main/→<canvasRoot>/main/index.htmlopenclaw-canvas://main/assets/app.css→<canvasRoot>/main/assets/app.cssopenclaw-canvas://main/widgets/todo/→<canvasRoot>/main/widgets/todo/index.html
index.html na raiz, o app exibirá uma página scaffold integrada.
Comportamento do painel
- Painel sem bordas, redimensionável, ancorado próximo à barra de menus (ou ao cursor do mouse).
- Lembra tamanho/posição por sessão.
- Recarrega automaticamente quando arquivos locais do canvas mudam.
- Apenas um painel Canvas fica visível por vez (a sessão é trocada conforme necessário).
CANVAS_DISABLED.
Superfície da API do agente
O Canvas é exposto pelo Gateway WebSocket, então o agente pode:- mostrar/ocultar o painel
- navegar para um caminho ou URL
- avaliar JavaScript
- capturar uma imagem instantânea
canvas.navigateaceita caminhos locais de canvas, URLshttp(s)e URLsfile://.- Se você passar
"/", o Canvas mostrará o scaffold local ouindex.html.
A2UI no Canvas
O A2UI é hospedado pelo canvas host do Gateway e renderizado dentro do painel Canvas. Quando o Gateway anuncia um canvas host, o app macOS navega automaticamente para a página host do A2UI na primeira abertura. URL padrão do host A2UI:Comandos A2UI (v0.8)
Atualmente, o Canvas aceita mensagens servidor→cliente A2UI v0.8:beginRenderingsurfaceUpdatedataModelUpdatedeleteSurface
createSurface (v0.9) não é compatível.
Exemplo na CLI:
Acionando execuções de agente a partir do Canvas
O Canvas pode acionar novas execuções do agente por meio de links profundos:openclaw://agent?...
Observações de segurança
- O esquema do Canvas bloqueia travessia de diretório; os arquivos precisam ficar dentro da raiz da sessão.
- O conteúdo local do Canvas usa um esquema personalizado (nenhum servidor loopback é necessário).
- URLs externas
http(s)só são permitidas quando navegadas explicitamente.