Skip to main content

Web UI for deepagents — AI-powered workspace with streaming, file browser, and canvas

Project description

Cowork Dash

Web UI for LangGraph and deepagents agents. Provides a chat interface with real-time streaming, a workspace file browser, and a canvas for visualizations.

Cowork Dash

Stack: Python (FastAPI + WebSocket) backend, React (TypeScript + Vite) frontend.

Features

  • Chat with real-time token streaming via WebSocket
  • Tool call visualization — inline display of arguments, results, duration, and status
  • Rich inline content — HTML, Plotly charts, images, DataFrames, PDFs, and JSON rendered directly in the chat
  • Canvas panel — persistent visualizations (Plotly, matplotlib, Mermaid diagrams, DataFrames, Markdown, images)
  • File browser — workspace file tree with syntax-highlighted viewer and live file change detection
  • Task tracking — sidebar todo list with progress bar, synced with agent write_todos calls
  • Human-in-the-loop — interrupt dialog for reviewing and approving agent actions
  • Slash commands/save-workflow, /create-workflow, and /run-workflow with autocomplete
  • Print / export — print conversations via browser Print dialog with optimized CSS
  • Token usage — cumulative counter with per-turn breakdown chart
  • Authentication — optional HTTP Basic Auth for all endpoints
  • Theming — light, dark, and system-auto modes
  • Customization — title, subtitle, welcome message, agent name, and custom icon

Installation

pip install cowork-dash

Quick Start

From Python

from cowork_dash import CoworkApp

app = CoworkApp(
    agent=your_langgraph_agent,  # Any LangGraph CompiledGraph
    workspace="./workspace",
    title="My Agent",
)
app.run()

From CLI

# Point to a Python file exporting a LangGraph agent
cowork-dash run --agent my_agent.py:agent --workspace ./workspace

# With options
cowork-dash run --agent my_agent.py:agent --port 8080 --theme dark --title "My Agent"

Shorthand

from cowork_dash import run_app

run_app(agent=your_agent, workspace="./workspace")

Configuration

Configuration priority: Python args > CLI args > environment variables > defaults.

Option CLI Flag Env Var Default
Agent spec --agent DEEPAGENT_AGENT_SPEC Built-in default agent
Workspace --workspace DEEPAGENT_WORKSPACE_ROOT .
Host --host DEEPAGENT_HOST localhost
Port --port DEEPAGENT_PORT 8050
Debug --debug DEEPAGENT_DEBUG false
Title --title DEEPAGENT_TITLE Agent's .name or "Cowork Dash"
Subtitle --subtitle DEEPAGENT_SUBTITLE "AI-Powered Workspace"
Welcome message --welcome-message DEEPAGENT_WELCOME_MESSAGE (empty)
Theme --theme DEEPAGENT_THEME auto
Agent name --agent-name DEEPAGENT_AGENT_NAME Agent's .name or "Agent"
Icon URL --icon-url DEEPAGENT_ICON_URL (none)
Auth username --auth-username DEEPAGENT_AUTH_USERNAME admin
Auth password --auth-password DEEPAGENT_AUTH_PASSWORD (none — auth disabled)
Save workflow prompt --save-workflow-prompt DEEPAGENT_SAVE_WORKFLOW_PROMPT (built-in)
Run workflow prompt --run-workflow-prompt DEEPAGENT_RUN_WORKFLOW_PROMPT (built-in, use {filename})
Create workflow prompt --create-workflow-prompt DEEPAGENT_CREATE_WORKFLOW_PROMPT (built-in)

Slash Commands

Type / in the chat input to access built-in commands:

Command Description
/save-workflow Capture the current conversation as a reusable workflow in ./workflows/
/create-workflow Create a new workflow from scratch — prompts for a topic description
/run-workflow Execute a saved workflow — shows an autocomplete dropdown of .md files from ./workflows/

All commands support inline arguments:

/save-workflow focus on the data cleaning steps
/create-workflow daily sales report pipeline
/run-workflow etl-pipeline.md skip step 3

The prompt templates behind each command are configurable via Python API, CLI flags, or environment variables (see Configuration table above).

Stream Parser Config

Control how agent events are parsed by passing stream_parser_config to CoworkApp:

app = CoworkApp(
    agent=agent,
    stream_parser_config={
        "extractors": [...],  # Custom tool extractors
    },
)

See langgraph-stream-parser for details.

Architecture

Browser  <--WebSocket-->  FastAPI  <--astream_events-->  LangGraph Agent
            /ws/chat         |
                        REST APIs:
                          /api/config
                          /api/files/tree
                          /api/files/{path}
                          /api/canvas/items

The frontend is pre-built and bundled into the Python package as static files. No Node.js required at runtime.

Development

# Backend
pip install -e ".[dev]"
pytest tests/

# Frontend
cd frontend
npm install
npm run build    # outputs to cowork_dash/static/
npm run dev      # dev server with hot reload (proxy to backend on :8050)

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cowork_dash-0.3.5.tar.gz (1.9 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cowork_dash-0.3.5-py3-none-any.whl (1.1 MB view details)

Uploaded Python 3

File details

Details for the file cowork_dash-0.3.5.tar.gz.

File metadata

  • Download URL: cowork_dash-0.3.5.tar.gz
  • Upload date:
  • Size: 1.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.8

File hashes

Hashes for cowork_dash-0.3.5.tar.gz
Algorithm Hash digest
SHA256 97a32587afe8614750aa9bbad23a3d5fa37fd34c058bad45a523f0977b7d94ff
MD5 4ed05e4f891965f8cc97dd73589829f3
BLAKE2b-256 f5ddcc0fc8fdd77bd1499751345e4298633b59829ea8292ee2ea619b4c824597

See more details on using hashes here.

File details

Details for the file cowork_dash-0.3.5-py3-none-any.whl.

File metadata

File hashes

Hashes for cowork_dash-0.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 cfa5b0a11b6847cc08ac82279dfe14ad89dc833a66d6675dd93c4f15df209b6d
MD5 4d648c7a5a6b91f6c83205d42159da1c
BLAKE2b-256 2045f7ddb5d7db543d8720446494a347d86127e7cd6dba983321edddd4695444

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page