[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-73671":3},{"id":4,"name":5,"fullName":6,"owner":5,"repo":5,"description":7,"homepage":8,"htmlUrl":9,"language":10,"languages":9,"totalLinesOfCode":9,"stars":11,"forks":12,"watchers":13,"openIssues":14,"contributorsCount":15,"subscribersCount":15,"size":15,"stars1d":16,"stars7d":17,"stars30d":18,"stars90d":15,"forks30d":15,"starsTrendScore":19,"compositeScore":20,"rankGlobal":9,"rankLanguage":9,"license":21,"archived":22,"fork":22,"defaultBranch":23,"hasWiki":22,"hasPages":22,"topics":24,"createdAt":9,"pushedAt":9,"updatedAt":31,"readmeContent":32,"aiSummary":33,"trendingCount":15,"starSnapshotCount":15,"syncStatus":34,"lastSyncTime":35,"discoverSource":36},73671,"openchamber","openchamber\u002Fopenchamber","Desktop and web interface for OpenCode AI agent","https:\u002F\u002Fopenchamber.dev\u002F",null,"TypeScript",5150,519,24,345,0,152,384,1010,456,39.15,"MIT License",false,"main",[25,26,27,28,29,30],"ai","opencode","opencode-ai","opencode-app","opencode-ui","opencode-web","2026-06-12 02:03:16","# \u003Cpicture>\u003Csource media=\"(prefers-color-scheme: dark)\" srcset=\"docs\u002Freferences\u002Fbadges\u002Fopenchamber-logo-dark.svg\">\u003Cimg src=\"docs\u002Freferences\u002Fbadges\u002Fopenchamber-logo-light.svg\" width=\"32\" height=\"32\" align=\"absmiddle\" \u002F>\u003C\u002Fpicture> OpenChamber\n\n[![GitHub stars](https:\u002F\u002Fimg.shields.io\u002Fgithub\u002Fstars\u002Fbtriapitsyn\u002Fopenchamber?style=flat&logo=data%3Aimage%2Fsvg%2Bxml%3Bbase64%2CPHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzMiIgaGVpZ2h0PSIzMiIgZmlsbD0iI2YxZWNlYyIgdmlld0JveD0iMCAwIDI1NiAyNTYiPjxwYXRoIGQ9Ik0yMjkuMDYsMTA4Ljc5bC00OC43LDQyLDE0Ljg4LDYyLjc5YTguNCw4LjQsMCwwLDEtMTIuNTIsOS4xN0wxMjgsMTg5LjA5LDczLjI4LDIyMi43NGE4LjQsOC40LDAsMCwxLTEyLjUyLTkuMTdsMTQuODgtNjIuNzktNDguNy00MkE4LjQ2LDguNDYsMCwwLDEsMzEuNzMsOTRMOTUuNjQsODguOGwyNC42Mi01OS42YTguMzYsOC4zNiwwLDAsMSwxNS40OCwwbDI0LjYyLDU5LjZMMjI0LjI3LDk0QTguNDYsOC40NiwwLDAsMSwyMjkuMDYsMTA4Ljc5WiIgb3BhY2l0eT0iMC4yIj48L3BhdGg%2BPHBhdGggZD0iTTIzOS4xOCw5Ny4yNkExNi4zOCwxNi4zOCwwLDAsMCwyMjQuOTIsODZsLTU5LTQuNzZMMTQzLjE0LDI2LjE1YTE2LjM2LDE2LjM2LDAsMCwwLTMwLjI3LDBMOTAuMTEsODEuMjMsMzEuMDgsODZhMTYuNDYsMTYuNDYsMCwwLDAtOS4zNywyOC44Nmw0NSwzOC44M0w1MywyMTEuNzVhMTYuMzgsMTYuMzgsMCwwLDAsMjQuNSwxNy44MkwxMjgsMTk4LjQ5bDUwLjUzLDMxLjA4QTE2LjQsMTYuNCwwLDAsMCwyMDMsMjExLjc1bC0xMy43Ni01OC4wNyw0NS0zOC44M0ExNi40MywxNi40MywwLDAsMCwyMzkuMTgsOTcuMjZabS0xNS4zNCw1LjQ3LTQ4LjcsNDJhOCw4LDAsMCwwLTIuNTYsNy45MWwxNC44OCw2Mi44YS4zNy4zNywwLDAsMS0uMTcuNDhjLS4xOC4xNC0uMjMuMTEtLjM4LDBsLTU0LjcyLTMzLjY1YTgsOCwwLDAsMC04LjM4LDBMNjkuMDksMjE1Ljk0Yy0uMTUuMDktLjE5LjEyLS4zOCwwYS4zNy4zNywwLDAsMS0uMTctLjQ4bDE0Ljg4LTYyLjhhOCw4LDAsMCwwLTIuNTYtNy45MWwtNDguNy00MmMtLjEyLS4xLS4yMy0uMTktLjEzLS41cy4xOC0uMjcuMzMtLjI5bDYzLjkyLTUuMTZBOCw4LDAsMCwwLDEwMyw5MS44NmwyNC42Mi01OS42MWMuMDgtLjE3LjExLS4yNS4zNS0uMjVzLjI3LjA4LjM1LjI1TDE1Myw5MS44NmE4LDgsMCwwLDAsNi43NSw0LjkybDYzLjkyLDUuMTZjLjE1LDAsLjI0LDAsLjMzLjI5UzIyNCwxMDIuNjMsMjIzLjg0LDEwMi43M1oiPjwvcGF0aD48L3N2Zz4%3D&logoColor=FFFCF0&labelColor=100F0F&color=66800B)](https:\u002F\u002Fgithub.com\u002Fbtriapitsyn\u002Fopenchamber\u002Fstargazers)\n[![GitHub release](https:\u002F\u002Fimg.shields.io\u002Fgithub\u002Fv\u002Frelease\u002Fbtriapitsyn\u002Fopenchamber?style=flat&logo=data%3Aimage%2Fsvg%2Bxml%3Bbase64%2CPHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzMiIgaGVpZ2h0PSIzMiIgZmlsbD0iI2YxZWNlYyIgdmlld0JveD0iMCAwIDI1NiAyNTYiPjxwYXRoIGQ9Ik0xMjgsMTI5LjA5VjIzMmE4LDgsMCwwLDEtMy44NC0xbC04OC00OC4xOGE4LDgsMCwwLDEtNC4xNi03VjgwLjE4YTgsOCwwLDAsMSwuNy0zLjI1WiIgb3BhY2l0eT0iMC4yIj48L3BhdGg%2BPHBhdGggZD0iTTIyMy42OCw2Ni4xNSwxMzUuNjgsMThhMTUuODgsMTUuODgsMCwwLDAtMTUuMzYsMGwtODgsNDguMTdhMTYsMTYsMCwwLDAtOC4zMiwxNHY5NS42NGExNiwxNiwwLDAsMCw4LjMyLDE0bDg4LDQ4LjE3YTE1Ljg4LDE1Ljg4LDAsMCwwLDE1LjM2LDBsODgtNDguMTdhMTYsMTYsMCwwLDAsOC4zMi0xNFY4MC4xOEExNiwxNiwwLDAsMCwyMjMuNjgsNjYuMTVaTTEyOCwzMmw4MC4zNCw0NC0yOS43NywxNi4zLTgwLjM1LTQ0Wk0xMjgsMTIwLDQ3LjY2LDc2bDMzLjktMTguNTYsODAuMzQsNDRaTTQwLDkwbDgwLDQzLjc4djg1Ljc5TDQwLDE3NS44MlptMTc2LDg1Ljc4aDBsLTgwLDQzLjc5VjEzMy44MmwzMi0xNy41MVYxNTJhOCw4LDAsMCwwLDE2LDBWMTA3LjU1TDIxNiw5MHY4NS43N1oiPjwvcGF0aD48L3N2Zz4%3D&logoColor=FFFCF0&labelColor=100F0F&color=205EA6)](https:\u002F\u002Fgithub.com\u002Fbtriapitsyn\u002Fopenchamber\u002Freleases\u002Flatest)\n[![Created with OpenCode](docs\u002Freferences\u002Fbadges\u002Fcreated-with-opencode.svg)](https:\u002F\u002Fopencode.ai)\n[![Discord](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FDiscord-join.svg?style=flat&labelColor=100F0F&color=8B7EC8&logo=discord&logoColor=FFFCF0)](https:\u002F\u002Fdiscord.gg\u002FZYRSdnwwKA)\n[![Support the project](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FSupport-Project-black?style=flat&labelColor=100F0F&color=EC8B49&logo=ko-fi&logoColor=FFFCF0)](https:\u002F\u002Fko-fi.com\u002FG2G41SAWNS)\n\n## **OpenCode, everywhere.** Desktop. Browser. Phone.\n\n### A rich interface for [OpenCode](https:\u002F\u002Fopencode.ai). Review diffs, manage agents, run dev servers, and keep the big picture while your AI codes.\n\n![OpenChamber Chat](docs\u002Freferences\u002Fchat_example.png)\n\n\u003Cdetails>\n\u003Csummary>More screenshots\u003C\u002Fsummary>\n\n![Tool Output](docs\u002Freferences\u002Ftool_output_example.png)\n![Settings](docs\u002Freferences\u002Fsettings_example.png)\n![Diff View](docs\u002Freferences\u002Fdiff_example.png)\n![VS Code Extension](packages\u002Fvscode\u002Fextension.jpg)\n\n\u003Cp>\n\u003Cimg src=\"docs\u002Freferences\u002Fpwa_chat_example.png\" width=\"45%\" alt=\"PWA Chat\">\n\u003Cimg src=\"docs\u002Freferences\u002Fpwa_diff_example.png\" width=\"45%\" alt=\"PWA Diff\">\n\u003C\u002Fp>\n\n\u003C\u002Fdetails>\n\n## Why use OpenChamber?\n\n- **Cross-device continuity**: Start in TUI, continue on tablet\u002Fphone, return to terminal - same session\n- **Remote access**: Use OpenCode from anywhere via browser\n- **Familiarity**: A visual alternative for developers who prefer GUI workflows\n\n## Features\n\n### Core (all app versions)\n\n- Branchable chat timeline with `\u002Fundo`, `\u002Fredo`, and one-click forks from earlier turns\n- Smart tool UIs for diffs, file operations, permissions, and long-running task progress\n- Voice mode with speech input and read-aloud responses for hands-free workflows\n- Multi-agent runs from one prompt with isolated worktrees for safe side-by-side comparisons\n- Git workflows in-app: identities, commits, PR creation, checks, and merge actions\n- GitHub-native workflows: start sessions from issues and pull requests with context already attached\n- Plan\u002FBuild mode with a dedicated plan view for drafting and iterating implementation steps\n- Inline comment drafts on diffs, files, and plans that can be sent back to the agent\n- Context visibility tools (token\u002Fcost breakdowns, raw message inspection, and activity summaries)\n- Integrated terminal with per-directory sessions and stable performance on heavy output\n- Built-in skills catalog and local skill management for reusable automation workflows\n\n### Web \u002F PWA\n\n- Provider-aware tunnel access model with Cloudflare `quick`, `managed-remote`, and `managed-local` modes\n- One-scan onboarding with tunnel QR + password URL helpers\n- Mobile-first experience: optimized chat controls, keyboard-safe layouts, and attachment-friendly UI\n- Background notifications plus reliable cross-tab session activity tracking\n- Built-in self-update + restart flow that keeps your server settings intact\n\n### Desktop (macOS)\n\n- Native macOS menu integration with polished app actions and deep-link handling\n- Multi-window support for parallel project\u002Fsession workflows\n- \"Open In\" shortcuts for Finder, Terminal, and your preferred editor\n- Fast switching between local and remote instances\n- Workspace-first startup flow with directory picker and steadier window restore behavior\n\n### VS Code Extension\n\n- Editor-native workflow: open files directly from tool output and keep sessions beside your code\n- Agent Manager for parallel multi-model runs from a single prompt\n- Right-click actions to add context, explain selections, and improve code in-place\n- In-extension settings, responsive layout, and theme mapping that matches your editor\n- Hardened runtime lifecycle and health checks for faster startup and fewer stuck reconnect states\n\n### Custom Themes\n\n- **Use it from anywhere** - Cloudflare tunnel with QR code onboarding. Scan, connect, code from your couch.\n- **Branchable chat timeline** - Undo, redo, fork from any turn. Explore different approaches without losing your place.\n- **GitHub-native workflows** - Start sessions from issues and PRs with context already attached. Review checks, merge - all in-app.\n- **Project Actions** - Run dev servers, configure SSH port forwarding, open remote URLs locally. Your project commands, one click away.\n- **Connect to remote machines** - Desktop app connects to remote OpenChamber instances over SSH, with dedicated lifecycle and UX flows.\n\n## Quick Start\n\n> **Prerequisite:** [OpenCode CLI](https:\u002F\u002Fopencode.ai) installed.\n\n### **Desktop (macOS)**\nDownload from [Releases](https:\u002F\u002Fgithub.com\u002Fbtriapitsyn\u002Fopenchamber\u002Freleases).\n\n### **VS Code**\nInstall from [Marketplace](https:\u002F\u002Fmarketplace.visualstudio.com\u002Fitems?itemName=fedaykindev.openchamber) or search \"OpenChamber\" in Extensions.\n\n### **CLI (Web + PWA)**\n_requires Node.js 20+_\n\n```bash\ncurl -fsSL https:\u002F\u002Fraw.githubusercontent.com\u002Fbtriapitsyn\u002Fopenchamber\u002Fmain\u002Fscripts\u002Finstall.sh | bash\nopenchamber --ui-password be-creative-here\n```\n\n\u003Cdetails>\n\u003Csummary>Advanced CLI options\u003C\u002Fsummary>\n\n```bash\nopenchamber --port 8080              # Custom port\nopenchamber --ui-password secret     # Password-protect UI\nopenchamber tunnel help              # Tunnel lifecycle commands\nopenchamber tunnel providers         # Show provider capabilities\nopenchamber tunnel profile add --provider cloudflare --mode managed-remote --name prod-main --hostname app.example.com --token \u003Ctoken>\nopenchamber tunnel start --profile prod-main\nopenchamber tunnel start --provider cloudflare --mode quick --qr\nopenchamber tunnel start --provider cloudflare --mode managed-local --config ~\u002F.cloudflared\u002Fconfig.yml\nopenchamber tunnel status --all      # Show tunnel state across instances\nopenchamber tunnel stop --port 3000  # Stop tunnel only (server stays running)\nopenchamber logs                     # Follow latest instance logs\nOPENCODE_PORT=4096 OPENCODE_SKIP_START=true openchamber                    # Connect to external OpenCode server\nOPENCODE_HOST=https:\u002F\u002Fmyhost:4096 OPENCODE_SKIP_START=true openchamber  # Connect via custom host\u002FHTTPS\nopenchamber stop                     # Stop server\nopenchamber update                   # Update to latest\n```\n\nConnect to an existing OpenCode server:\n```bash\nOPENCODE_PORT=4096 OPENCODE_SKIP_START=true openchamber\nOPENCODE_HOST=https:\u002F\u002Fmyhost:4096 OPENCODE_SKIP_START=true openchamber\n```\n\nBind managed OpenCode server to all interfaces (use only on trusted networks):\n```bash\nOPENCHAMBER_OPENCODE_HOSTNAME=0.0.0.0 openchamber --port 3000\n```\n\n\u003C\u002Fdetails>\n\n\u003Cdetails>\n\u003Csummary>systemd service (VPN \u002F LAN access)\u003C\u002Fsummary>\n\nRun OpenChamber and OpenCode as separate persistent services — useful when you want to access your\ndev machine over a VPN (e.g. Tailscale) or LAN without a Cloudflare tunnel.\n\n**How it works:**\n- OpenCode runs as its own service, binding only to `localhost`.\n- OpenChamber connects to it via `OPENCODE_HOST` and `--host 0.0.0.0` makes it reachable on your VPN IP.\n- `--foreground` keeps the CLI process alive so systemd can track and restart it.\n\n**`~\u002F.config\u002Fsystemd\u002Fuser\u002Fopencode.service`**\n```ini\n[Unit]\nDescription=OpenCode Server\n\n[Service]\nType=simple\nExecStart=opencode serve --port 4095\nEnvironment=\"PATH=\u002Fhome\u002Flinuxbrew\u002F.linuxbrew\u002Fbin:\u002Fhome\u002Flinuxbrew\u002F.linuxbrew\u002Fsbin:\u002Fhome\u002FYOU\u002F.local\u002Fbin:\u002Fhome\u002FYOU\u002F.npm-global\u002Fbin:\u002Fusr\u002Flocal\u002Fbin:\u002Fusr\u002Fbin:\u002Fbin\"\nEnvironment=SSH_AUTH_SOCK=%t\u002Fssh-agent.socket\nRestart=on-failure\nRestartSec=5\n\n[Install]\nWantedBy=default.target\n```\n\n> **Why set `PATH` and `SSH_AUTH_SOCK`?**\n> systemd user services start with a minimal environment — no shell profile is sourced.\n> Without an explicit `PATH`, OpenCode won't find tools installed via Homebrew, npm, or `~\u002F.local\u002Fbin`.\n> Without `SSH_AUTH_SOCK`, git operations over SSH (push, pull, clone) will fail because the agent socket isn't inherited.\n> Adjust the `PATH` to match your own tool installation paths.\n> `%t` expands to `$XDG_RUNTIME_DIR` (e.g. `\u002Frun\u002Fuser\u002F1000`), where most SSH agents write their socket.\n\n**`~\u002F.config\u002Fsystemd\u002Fuser\u002Fopenchamber.service`**\n```ini\n[Unit]\nDescription=OpenChamber Web Server\nAfter=opencode.service\n\n[Service]\nType=simple\nExecStart=openchamber serve --port 3000 --host 0.0.0.0 --ui-password your-password --foreground\nEnvironment=\"OPENCODE_HOST=http:\u002F\u002Flocalhost:4095\"\nEnvironment=\"OPENCODE_SKIP_START=true\"\nRestart=on-failure\nRestartSec=5\n\n[Install]\nWantedBy=default.target\n```\n\n```bash\nsystemctl --user daemon-reload\nsystemctl --user enable --now opencode openchamber\n```\n\nOpenChamber will be reachable at `http:\u002F\u002F\u003Cyour-vpn-hostname>:3000` from any device on your VPN.\n\n> **Note:** `--host 0.0.0.0` is required to listen on all interfaces. The default\n> bind address is `127.0.0.1` (localhost only). Use `--host \u003Cip>` or\n> `OPENCHAMBER_HOST=\u003Cip>` to bind to a specific interface instead.\n\n\u003C\u002Fdetails>\n\n\u003Cdetails>\n\u003Csummary>Docker\u003C\u002Fsummary>\n\n```bash\ndocker compose up -d\n```\n\nAvailable at `http:\u002F\u002Flocalhost:3000`.\n\n**UI Password:**\n```yaml\nenvironment:\n  UI_PASSWORD: your_secure_password\n```\n\n**Cloudflare Tunnel (optional):**\n```yaml\nenvironment:\n  OPENCHAMBER_TUNNEL_MODE: quick # quick | managed-remote | managed-local\n  OPENCHAMBER_TUNNEL_PROVIDER: cloudflare\n```\n\nFor `managed-remote` mode, provide:\n\n```yaml\nenvironment:\n  OPENCHAMBER_TUNNEL_MODE: managed-remote\n  OPENCHAMBER_TUNNEL_HOSTNAME: app.example.com\n  OPENCHAMBER_TUNNEL_TOKEN: \u003Ctoken>\n```\n\nFor `managed-local` mode, optionally provide:\n\n```yaml\nenvironment:\n  OPENCHAMBER_TUNNEL_MODE: managed-local\n  OPENCHAMBER_TUNNEL_CONFIG: \u002Fhome\u002Fopenchamber\u002F.cloudflared\u002Fconfig.yml\n```\n\nManaged-local path note: `OPENCHAMBER_TUNNEL_CONFIG` must point to a path inside the container user home (`\u002Fhome\u002Fopenchamber\u002F...`). If your Cloudflare config references a credentials JSON file, that file path must also be accessible inside the container (mount with `volumes`).\n\n### Reverse proxy notes\n\n- For a complete reverse proxy setup guide, see [`docs\u002FREVERSE_PROXY.md`](.\u002Fdocs\u002FREVERSE_PROXY.md).\n- Website docs source lives at `packages\u002Fdocs\u002Fcontent\u002Fdocs\u002Freverse-proxy.mdx`.\n\n### Tunnel behavior notes\n\n- OpenChamber supports one active tunnel per running instance (port).\n- Starting a tunnel with a different mode\u002Fprovider on the same instance replaces the current tunnel.\n- Replacing or stopping a tunnel revokes existing connect links and invalidates remote tunnel sessions for that instance.\n- Connect links are one-time tokens; generating a new link revokes the previous unused link.\n\n**Data Directory Permission Note:** The `data\u002F` directory is mounted into the container for persistent storage (config, sessions, SSH keys, workspaces). Before running, ensure the directory exists and has proper permissions:\n\n```bash\nmkdir -p data\u002Fopenchamber data\u002Fopencode\u002Fshare data\u002Fopencode\u002Fconfig data\u002Fssh\nchown -R 1000:1000 data\u002F\n```\n\n**SSH\u002FGit:** If git push\u002Fpull fails, run `ssh -T git@github.com` in terminal.\n\n\u003C\u002Fdetails>\n\n\n## Features\n\n\u003Cdetails>\n\u003Csummary>\u003Cstrong>Chat & Interaction\u003C\u002Fstrong>\u003C\u002Fsummary>\n\n- Branchable chat timeline with `\u002Fundo`, `\u002Fredo`, and one-click forks from any turn\n- Multi-agent runs from one prompt with isolated worktrees for safe side-by-side comparisons\n- Voice mode with speech input and read-aloud responses for hands-free workflows\n- Plan\u002FBuild mode with a dedicated plan view for drafting and iterating steps\n- Inline comment drafts on diffs, files, and plans - send feedback back to the agent\n- Shell mode via leading `!` with inline output\n- Share messages as images\n- Mermaid diagrams render inline with copy\u002Fdownload actions\n- Smart tool UIs for diffs, file operations, permissions, and task progress\n\n\u003C\u002Fdetails>\n\n\u003Cdetails>\n\u003Csummary>\u003Cstrong>Git & GitHub\u003C\u002Fstrong>\u003C\u002Fsummary>\n\n- Full Git sidebar with staging, commits, push\u002Fpull, branch management, and rebase\u002Fmerge flows\n- PR creation with AI-generated descriptions, status checks, and merge actions\n- Start sessions from GitHub issues and pull requests with context baked in\n- Multi-remote push and fork-aware PR creation\n- Worktree integration: isolated sessions per branch, merge back with conflict handling\n- Git identities, gitmoji support, and multi-account GitHub auth\n\n\u003C\u002Fdetails>\n\n\u003Cdetails>\n\u003Csummary>\u003Cstrong>Files, Diff & Terminal\u003C\u002Fstrong>\u003C\u002Fsummary>\n\n- Workspace file browser with inline editing, syntax highlighting, and markdown preview\n- Beautiful diff viewer with stacked\u002Finline modes, lazy loading for large changesets\n- Integrated terminal with per-directory sessions, tabbed interface, and stable heavy-output performance\n- Clickable file paths in messages - jump to exact line locations\n- File-type icons across all views for faster visual scanning\n\n\u003C\u002Fdetails>\n\n\u003Cdetails>\n\u003Csummary>\u003Cstrong>Web \u002F PWA\u003C\u002Fstrong>\u003C\u002Fsummary>\n\n- Cloudflare tunnel with quick, managed-remote, and managed-local modes, secure one-time connect links, and QR onboarding\n- Mobile-first: optimized chat controls, keyboard-safe layouts, drag-to-reorder projects\n- Background notifications and cross-tab session tracking\n- Self-update + restart flow that keeps your server settings intact\n- Installable as PWA with project-aware naming\n\n\u003C\u002Fdetails>\n\n\u003Cdetails>\n\u003Csummary>\u003Cstrong>Desktop (macOS)\u003C\u002Fstrong>\u003C\u002Fsummary>\n\n- Connect to remote OpenChamber instances over SSH with dedicated lifecycle flows\n- Project Actions: run dev servers, SSH port forwarding, open remote URLs locally\n- Multi-window support for parallel project workflows\n- \"Open In\" shortcuts for Finder, Terminal, and your preferred editor\n- Fast switching between local and remote instances\n- Native macOS menu, deep-link handling, and polished startup\n\n\u003C\u002Fdetails>\n\n\u003Cdetails>\n\u003Csummary>\u003Cstrong>VS Code Extension\u003C\u002Fstrong>\u003C\u002Fsummary>\n\n- Editor-native: open files from tool output, keep sessions beside your code\n- Agent Manager for parallel multi-model runs from a single prompt\n- Right-click actions: add context, explain selections, improve code in-place\n- Session editor panel, responsive layout, and theme mapping to your editor\n- Edit-style tool results open directly in focused diff views\n\n\u003C\u002Fdetails>\n\n\u003Cdetails>\n\u003Csummary>\u003Cstrong>Customization\u003C\u002Fstrong>\u003C\u002Fsummary>\n\n- 18+ built-in themes with light\u002Fdark variants\n- Custom themes via JSON files in `~\u002F.config\u002Fopenchamber\u002Fthemes\u002F` - hot reload, no restart\n- Configurable keyboard shortcuts for chat, panels, and services\n- Font size, spacing, corner radius, and layout controls\n- Customizable project icons with upload and automatic favicon discovery\n- Skills catalog and local skill management for reusable automation\n\n[Read the Guide: Custom Themes](docs\u002FCUSTOM_THEMES.md)\n\n\u003C\u002Fdetails>\n\n\u003Cdetails>\n\u003Csummary>\u003Cstrong>Context & Productivity\u003C\u002Fstrong>\u003C\u002Fsummary>\n\n- Token usage, cost breakdowns, and raw message inspection panel\n- Usage quota tracking across multiple providers with pace\u002Fprediction indicators\n- Favorite model cycling via keyboard shortcuts\n- Session folders and subfolders with drag-to-reorder\n- Persistent project notes and todos per project\n- Draft persistence per session with expanded focus mode for longer prompts\n\n\u003C\u002Fdetails>\n\n## Roadmap\n\nActive development. Here's what's being worked on or planned:\n\n- Windows and Linux desktop apps\n- Mobile app with remote instance and laptop connectivity\n- More built-in tunneling options\n- Kanban board for multi-agent management - keeping the human in the loop and in control\n- Custom OpenCode plugins\u002Ftools built-in catalog\n- Linear integration\n- Built-in browser for running dev apps with agent integration\n\n## Acknowledgments\n\nIndependent project, not affiliated with the OpenCode team.\n\n**Special thanks to:**\n\n- [OpenCode](https:\u002F\u002Fopencode.ai) - For the excellent API and extensible architecture.\n- [Flexoki](https:\u002F\u002Fgithub.com\u002Fkepano\u002Fflexoki) - Beautiful color scheme by [Steph Ango](https:\u002F\u002Fstephango.com\u002Fflexoki).\n- [Pierre](https:\u002F\u002Fpierrejs-docs.vercel.app\u002F) - Fast, beautiful diff viewer with syntax highlighting.\n- [Tauri](https:\u002F\u002Fgithub.com\u002Ftauri-apps\u002Ftauri) - Desktop application framework.\n- [Ghostty-web](https:\u002F\u002Fgithub.com\u002Fcoder\u002Fghostty-web) - Great implementation of a Ghostty web renderer.\n- [David Hill](https:\u002F\u002Fx.com\u002Fiamdavidhill) - Who inspired me to release this without [overthinking](https:\u002F\u002Fx.com\u002Fiamdavidhill\u002Fstatus\u002F1993648326450020746).\n- [My wife](https:\u002F\u002Fgithub.com\u002Fyulia-ivashko), who - with zero AI background - sat down with the app for the first time and built the firework celebration that plays on every successful push.\n- Every contributor who shaped this project with their PRs, ideas, and attention to detail.\n\n## Contributing\n\nSee [CONTRIBUTING.md](.\u002FCONTRIBUTING.md) for development setup and guidelines.\n\nDocs source lives in [`packages\u002Fdocs`](packages\u002Fdocs\u002FREADME.md).\n\n## License\n\nMIT\n","OpenChamber 是一个为 OpenCode AI 代理设计的桌面和网页界面。它使用 TypeScript 构建，提供了一个直观且功能丰富的用户界面来与 AI 交互。该项目支持多种操作环境，允许用户通过简单的图形界面执行复杂的 AI 任务，如代码生成、问题解答等。其简洁的设计和强大的功能性使其特别适合开发者、研究人员以及任何希望更高效地利用 AI 技术进行工作的人士。MIT 许可证下开源，社区活跃度高，表明了其在实际应用中的广泛接受度和持续发展性。",2,"2026-06-11 03:46:50","high_star"]