The macOS app embeds an agent‑controlled Canvas panel using WKWebView. It
is a lightweight visual workspace for HTML/CSS/JS, A2UI, and small interactive
UI surfaces.
Canvas state is stored under Application Support:
~/Library/Application Support/CoderClaw/canvas/<session>/...The Canvas panel serves those files via a custom URL scheme:
coderclaw-canvas://<session>/<path>Examples:
coderclaw-canvas://main/ → <canvasRoot>/main/index.htmlcoderclaw-canvas://main/assets/app.css → <canvasRoot>/main/assets/app.csscoderclaw-canvas://main/widgets/todo/ → <canvasRoot>/main/widgets/todo/index.htmlIf no index.html exists at the root, the app shows a built‑in scaffold page.
Canvas can be disabled from Settings → Allow Canvas. When disabled, canvas
node commands return CANVAS_DISABLED.
Canvas is exposed via the Gateway WebSocket, so the agent can:
CLI examples:
coderclaw nodes canvas present --node <id>
coderclaw nodes canvas navigate --node <id> --url "/"
coderclaw nodes canvas eval --node <id> --js "document.title"
coderclaw nodes canvas snapshot --node <id>
Notes:
canvas.navigate accepts local canvas paths, http(s) URLs, and file:// URLs."/", the Canvas shows the local scaffold or index.html.A2UI is hosted by the Gateway canvas host and rendered inside the Canvas panel. When the Gateway advertises a Canvas host, the macOS app auto‑navigates to the A2UI host page on first open.
Default A2UI host URL:
http://<gateway-host>:18789/__coderclaw__/a2ui/
Canvas currently accepts A2UI v0.8 server→client messages:
beginRenderingsurfaceUpdatedataModelUpdatedeleteSurfacecreateSurface (v0.9) is not supported.
CLI example:
cat > /tmp/a2ui-v0.8.jsonl <<'EOFA2'
{"surfaceUpdate":{"surfaceId":"main","components":[{"id":"root","component":{"Column":{"children":{"explicitList":["title","content"]}}}},{"id":"title","component":{"Text":{"text":{"literalString":"Canvas (A2UI v0.8)"},"usageHint":"h1"}}},{"id":"content","component":{"Text":{"text":{"literalString":"If you can read this, A2UI push works."},"usageHint":"body"}}}]}}
{"beginRendering":{"surfaceId":"main","root":"root"}}
EOFA2
coderclaw nodes canvas a2ui push --jsonl /tmp/a2ui-v0.8.jsonl --node <id>
Quick smoke:
coderclaw nodes canvas a2ui push --node <id> --text "Hello from A2UI"
Canvas can trigger new agent runs via deep links:
coderclaw://agent?...Example (in JS):
window.location.href = "coderclaw://agent?message=Review%20this%20design";
The app prompts for confirmation unless a valid key is provided.
http(s) URLs are allowed only when explicitly navigated.