Watch your Claude Code subagents work — a live office for every conversation.
Project description
🎭 Claude Theater
Watch your Claude Code conversations and subagents work — a live office, in real time.
The demo office (claude-theater --demo): conversations and subagents at work, each agent walks in, sits, head-bobs while it types, then confetti on finish. A community visualizer for Claude Code — not affiliated with Anthropic.
Try it now, no Claude Code session required — pipx run claude-theater --demo
spins up the office above with synthetic agents.
Why? When you fan out a handful of subagents, the terminal becomes a wall of interleaved JSON. Claude Theater turns it into a glance — who's working, who's stuck, who just finished — without reading a single log line.
Safe by design: it runs entirely on your machine. Binds to 127.0.0.1, sends
nothing anywhere (no telemetry), only reads the journals, and the whole thing is
one auditable standard-library file with zero dependencies. (more)
Claude Theater reads the journals Claude Code writes for your conversations and the subagents they spawn, and renders them as a live office: every conversation is a room (titled by its subject), and inside it the conversation itself plus each subagent is a little character at a desk — avatar, name, the tool it's using right now, and a timer. Click any character to read its full task and result. When an agent finishes: confetti, a chime, and it quietly steps off the floor — and each room has its own show-finished toggle, so you control the history per conversation.
The UI is bilingual — English by default, Hebrew one click away (the choice
is remembered, and the layout flips to RTL). Adding another language is a single
edit to the I18N table in claude_theater.py; the server stays language-neutral.
Quick start
Zero install — run it straight from PyPI with pipx:
pipx run claude-theater # watches your real Claude Code sessions
pipx run claude-theater --demo # a synthetic, populated office — no sessions needed
New here? Start with --demo to look around before pointing it at your own work.
Or install it:
pipx install claude-theater # or: pip install claude-theater
claude-theater # add --demo for the synthetic office
Or run from a clone (pure standard library, nothing to install):
python -m claude_theater
Then open http://localhost:7333. The server opens your browser for you — pass
--no-browser to skip that (handy on a headless box or inside an editor panel).
On Windows, from a clone, you can also just run start.cmd.
Requires Python 3.9+. The non-demo mode reads the journals a Claude Code install writes under
~/.claude/projects/;--demoneeds nothing but Python.
VS Code extension
Prefer it inside your editor? The vscode-extension/ folder packages Claude
Theater as a VS Code extension: it starts the server in the background (toggle it
from a status-bar button) and opens the office in an interactive panel — no
separate terminal. The server is bundled into the extension, so it works without
a separate install, and it auto-starts when VS Code launches.
Install the prebuilt .vsix (easiest) — download
claude-theater-<version>.vsix from the
latest release,
then in VS Code run Extensions: Install from VSIX…, or from a terminal:
code --install-extension claude-theater-<version>.vsix
Or build it from source (needs Node.js):
git clone https://github.com/asafabram-ship-it/claude-theater
cd claude-theater/vscode-extension
npx @vscode/vsce package # produces claude-theater-<version>.vsix
code --install-extension claude-theater-*.vsix
Auto-start with Claude Code
The VS Code extension already starts the server on launch. If you use the CLI,
the recommended one-time setup is a SessionStart hook in your
~/.claude/settings.json, so the office comes up by itself whenever you begin a
Claude Code session. Each user adds it once. (Heads-up: this leaves an
unauthenticated loopback endpoint running in the background — see Privacy.)
macOS / Linux / Git Bash
{
"hooks": {
"SessionStart": [
{ "hooks": [ { "type": "command",
"command": "curl -sf http://127.0.0.1:7333/ -o /dev/null || (claude-theater --no-browser &)" } ] }
]
}
}
Windows (PowerShell)
{
"hooks": {
"SessionStart": [
{ "hooks": [ { "type": "command",
"command": "powershell -NoProfile -Command \"if(-not(Get-NetTCPConnection -LocalPort 7333 -State Listen -ErrorAction SilentlyContinue)){Start-Process -WindowStyle Hidden -FilePath claude-theater -ArgumentList '--no-browser'}\"" } ] }
]
}
}
Both check the port first, so they stay idempotent. (Requires claude-theater
on your PATH, e.g. via pipx install claude-theater.)
How it works
- Polls the journals Claude Code already writes — both the session files (your
conversations) and
**/subagents/agent-*.jsonl(the subagents they spawn). Claude Theater only reads them; it never starts or controls agents. - A single adapter,
parse_agent_event(line) -> Event, is the only code that touches the raw journal format. Everything else consumes the stableEvent, so a Claude Code format change is absorbed in one place. - Degrades, never crashes: corrupt lines are skipped (and counted), unknown keys are ignored, and an agent missing fields still shows up instead of vanishing.
- A non-blocking version banner appears when a journal comes from a Claude Code version this build hasn't been tested against — output may be partial, but the office keeps running.
Privacy
Your journals contain real conversation content, so Claude Theater is built to keep them on your machine:
- Binds to
127.0.0.1only — never reachable from the network, with a loopbackHostallowlist that blocks DNS-rebinding. - Never transmits anything anywhere. No telemetry, no remote calls.
- Read-only — it opens journals to read, never to write.
- A strict
Content-Security-PolicyandX-Content-Type-Options: nosniff, and cross-origin headers sent only to avscode-webview://origin, so an ordinary web page can't read your agents. - The committed
fixtures/are 100% synthetic — no real prompts or results.
The local endpoint is unauthenticated: any process running as you on this machine can read it — the same trust boundary as the journal files themselves. The auto-start hook above leaves that endpoint up in the background.
Development
python -m unittest discover -s tests # golden parser tests, zero dependencies
The tests run synthetic journal fixtures through the adapter and fail loudly if the format drifts. Contributing a journal sample from a new Claude Code build is the most valuable contribution — scrub every prompt and result first.
Compatibility
Tested against Claude Code 2.1.x. Newer builds will trigger the version banner; please open a format-drift report with a scrubbed sample so we can add a fixture and an adapter case.
License
MIT © 2026 Asaf Abramzon. "Claude" is a trademark of Anthropic; this is an independent, community project for Claude Code.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file claude_theater-0.1.1.tar.gz.
File metadata
- Download URL: claude_theater-0.1.1.tar.gz
- Upload date:
- Size: 2.1 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8109914001ff6148b7a038a6b571b0037f7e7101babdd35b63795feffbd5b519
|
|
| MD5 |
8e51f5650f60e4b4f1163888748a1aae
|
|
| BLAKE2b-256 |
f892dd418704427749c54d6ef4c69102f58c30594f0f0c8357251a953e929a59
|
Provenance
The following attestation bundles were made for claude_theater-0.1.1.tar.gz:
Publisher:
release.yml on asafabram-ship-it/claude-theater
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
claude_theater-0.1.1.tar.gz -
Subject digest:
8109914001ff6148b7a038a6b571b0037f7e7101babdd35b63795feffbd5b519 - Sigstore transparency entry: 1763949575
- Sigstore integration time:
-
Permalink:
asafabram-ship-it/claude-theater@6aced023bcebc3da6d19408e513b5d114c00334d -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/asafabram-ship-it
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@6aced023bcebc3da6d19408e513b5d114c00334d -
Trigger Event:
push
-
Statement type:
File details
Details for the file claude_theater-0.1.1-py3-none-any.whl.
File metadata
- Download URL: claude_theater-0.1.1-py3-none-any.whl
- Upload date:
- Size: 32.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0f34c12c84049ce2472b5045d51ec2a2749a553c47684fe4d06304d2336db767
|
|
| MD5 |
38171087280269be286a6206124d0ed5
|
|
| BLAKE2b-256 |
1e06a5a56270fed82bfa30602af295c55626b3206b2058763fc102005e9e78aa
|
Provenance
The following attestation bundles were made for claude_theater-0.1.1-py3-none-any.whl:
Publisher:
release.yml on asafabram-ship-it/claude-theater
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
claude_theater-0.1.1-py3-none-any.whl -
Subject digest:
0f34c12c84049ce2472b5045d51ec2a2749a553c47684fe4d06304d2336db767 - Sigstore transparency entry: 1763951735
- Sigstore integration time:
-
Permalink:
asafabram-ship-it/claude-theater@6aced023bcebc3da6d19408e513b5d114c00334d -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/asafabram-ship-it
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@6aced023bcebc3da6d19408e513b5d114c00334d -
Trigger Event:
push
-
Statement type: