Skip to main content

Text-based GitHub work triage dashboard.

Project description

workdash

Text-based GitHub work triage dashboard ( https://alessandro.molina.fyi/workdash/ )

workdash pulls together the issues and pull requests that matter to you across your GitHub repositories, suggests what to pick up next, and makes it easy to jump into a work item — either for a quick review, a deeper AI-assisted analysis, or a full coding session in a dedicated worktree.

workdash screenshot

Platform

Linux and macOS. workdash relies on xdg-open or open and expects zellij for the interactive dashboard and terminal-backed work actions. It has not been tested on Windows.

Requirements

  • Python >=3.12.
  • Authenticated gh for GitHub access. workdash --configure installs a local copy when gh is not available.
  • xdg-open or open for opening links and rendered analyses in your browser.
  • zellij for the interactive dashboard, terminal panes, and agent sessions. workdash --configure installs a local copy when zellij is not available.
  • Global gh and zellij binaries are preferred; configured local copies are used as fallbacks.
  • Optional, depending on which actions you use from the TUI:
    • claude — to analyze or launch a Claude coding session.
    • codex — to analyze or launch a ChatGPT Codex session.
    • code — to launch a VSCode + Copilot coding session.
    • pi — to launch a pi coding agent session.

Installation

With uv — one isolated install, workdash on your PATH:

uv tool install workdash

For development install:

pip install -e '.[test]'

First-time setup

On the first run you need a configuration file at ~/.config/workdash/config.json. Generate it interactively with:

workdash --configure

The wizard fills in:

  • Your GitHub username.
  • Zellij availability. If zellij is not on PATH, the wizard downloads the latest release binary into the workdash configuration directory.
  • GitHub CLI availability. If gh is not on PATH, the wizard downloads the latest release binary into the workdash configuration directory. Authentication is still handled by gh; run gh auth login if startup reports that gh is not authenticated.
  • The list of repositories to track (see Repository selectors below).
  • A working directory where per-item git worktrees will live.
  • The analyze and launch commands for Claude and Codex (auto-detected when the tools are on your PATH).

You can edit ~/.config/workdash/config.json by hand at any time. Re-running --configure only prompts for fields that are still empty, except for Zellij: the wizard always checks for a global zellij first and downloads a fresh local binary when no global binary exists. It does the same for gh, checking for a global GitHub CLI first and downloading a fresh local copy when none is available.

Usage

Launch the TUI:

workdash

Useful commands and flags:

workdash --server            # start the TUI plus localhost JSON control API
workdash list                # list server-backed dashboard items as plain text
workdash list --refresh      # ask the server to refresh items before listing
workdash list --json         # list items as machine-readable JSON
workdash info [--all] [--json]  # report live Workdash-owned Zellij panes
workdash analyze ITEM [--agent NAME] [--json]  # analyze a current server item
workdash code ITEM [--agent NAME] [--json]  # launch a terminal-backed coding agent
workdash read PANE_ID [--full] [--json]  # read text from a live pane
workdash write PANE_ID TEXT [--raw] [--json]  # send text to a live pane
workdash show-config [--json] # show configured agents and fixed server address
workdash --debug             # verbose logging
workdash --configure         # run the interactive setup wizard
workdash --direct            # start without the automatic Zellij wrapper
workdash --version           # print version and exit

What gets shown

workdash gathers the following for your configured GitHub username:

  • Open pull requests you authored.
  • Open pull requests where you are a requested reviewer, plus open pull requests you have already reviewed (shown as REVIEW).
  • Open issues assigned to you.
  • Open issues and pull requests across the tracked repositories.

Items are merged, deduplicated, and sorted by last update. One item is marked with * as the suggested next thing to pick up.

Repository selectors

The repositories list in config.json accepts:

  • owner/repo — a specific repository.
  • owner/* — every repository accessible to you under that owner.

TUI keybindings

  • o — open the selected item in your browser.
  • r — refresh the list from GitHub.
  • a — analyze the selected item. Opens a dialog to open the cached analysis (if any), or run a fresh analysis with Claude or Codex. Fresh analyses are cached and rendered as HTML in your browser.
  • c — launch a coding session on the selected item. Opens a dialog to pick Claude, Codex, VSCode Copilot, or pi. workdash prepares a dedicated git worktree for the item and starts the chosen tool in it, preloaded with context about the issue or PR.
  • t — open a terminal in the selected item's worktree (no agent launched).
  • q — quit.

Worktrees

Coding and analysis actions operate on a per-item git worktree rooted under the configured workdir. Each tracked repository gets a local clone, and each work item gets its own worktree alongside it, so you can hop between items without disturbing other in-progress work.

Local control server

workdash --server starts the normal TUI and a localhost JSON control API in the same process. V0 listens on 127.0.0.1:8765, accepts JSON only, and stops when the TUI exits. Client commands such as list, info, analyze, code, read, and write connect to this server instead of loading GitHub or Zellij state themselves.

List command

workdash list requires a running workdash --server session and emits one row per server-known item, sorted by last update (most recent first):

TYPE   repo#TYPE-N   YYYY-MM-DD   title

TYPE is ISSUE, PR, or REVIEW (for review-requested PRs). The row ID is copy/paste-friendly: repo#ISSUE-N, repo#PR-N, or repo#REVIEW-N. The suggested item's title is prefixed with * . If nothing matches, the output is No work items found..

Use workdash list --refresh to ask the server to refresh GitHub data before listing. Use workdash list --json to emit the same list as JSON records with item ID, type, kind, repository, number, title, URL, timestamps, and suggested status.

Info command

workdash info [--json] requires a running workdash --server session and reports live Workdash-owned Zellij panes for terminal-backed work actions, including pane title, cwd, command, tab, state, and mapped Workdash item. It maps each live pane's current working directory to the matching Workdash item ID when the pane is inside a known worktree, or reports unknown when no mapping is known. Add --all to include other live non-plugin panes from the server-backed Workdash session as kind=unknown with unknown item mapping.

Analyze command

workdash analyze ITEM [--agent NAME] [--json] requires a running workdash --server session and analyzes a current server-known Workdash item. ITEM can be a row ID from workdash list (such as owner/repo#ISSUE-123) or a GitHub issue/PR URL that is already in the current dashboard data. It reuses a fresh cached analysis when available, otherwise the server prepares the item's worktree and runs the selected configured analysis agent.

The server analyze response includes content_type (text/markdown), file_name, and base64 file_content so clients do not need filesystem access to the server cache. The CLI writes that content to a secure temporary local file and reports it as analysis_path. --json emits the same client-side result without the raw base64 content.

Code command

workdash code ITEM [--agent NAME] [--json] requires a running workdash --server session and launches a configured terminal-backed coding agent (claude, codex, or pi) for a current server-known Workdash item. ITEM accepts the same row IDs and GitHub URLs as workdash analyze.

Human output reports the item, agent, selected session, cwd, pane title, and pane id when available. --json emits the same result as machine-readable JSON.

Read and write commands

workdash read PANE_ID [--full] [--json] requires a running workdash --server session and reads pane text through the server-backed pane content API. Human output prints the pane text directly. Add --full to request full scrollback.

workdash write PANE_ID TEXT [--raw] [--json] requires a running workdash --server session and sends pane input through the server-backed pane send API. By default Workdash appends Enter; --raw or --no-enter sends the text exactly. Human output confirms that the pane accepted the input.

Show-config command

workdash show-config [--json] reports configured analysis agents, configured terminal-backed coding agents, and the fixed V0 server address. It does not require a running server. The same information is also available from the JSON API for HTTP clients.

Analysis cache

Analyses produced with a or workdash analyze are cached under ~/.config/workdash/cache/ so that re-opening an item is instant. The cache is keyed by the item's GitHub updated_at timestamp, so any change on GitHub automatically invalidates the cached analysis and the next analyze action will re-run it.

Product behavior

Canonical product behavior is described in features/.

The .feature files are the source of truth for what the software does. They are product specifications first and executable BDD scenarios second.

Implementation progress can be tracked separately. BDD is the integration point between humans and agents collaborating on the project as Workdash relied hevily on agents during its initial development cycle.

BDD-first development (mandatory)

Every new feature must start with a BDD definition under features/, and every change to existing behavior must update the relevant .feature file before any implementation or test code is modified. The .feature files are the contract; code follows them, not the other way around.

This applies to agents and humans alike. A change that lands code without a matching features/ update is incomplete.

Tests

From the repository root:

PYTHONPATH=src pytest

BDD suite

tests/bdd/ drives development from the .feature files in features/. pytest_bdd.scenarios(...) auto-generates one pytest test per Scenario, so adding a scenario to features/ is enough to pull it into the suite. Step definitions live under tests/bdd/steps/; scenarios whose steps are not yet implemented fail with StepDefinitionNotFoundError, which is the intended TDD signal for BDD-first development.

License

workdash is distributed under the terms of the GNU General Public License version 3. See LICENSE for the full text.

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

workdash-0.3.0.tar.gz (134.9 kB view details)

Uploaded Source

Built Distribution

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

workdash-0.3.0-py3-none-any.whl (89.1 kB view details)

Uploaded Python 3

File details

Details for the file workdash-0.3.0.tar.gz.

File metadata

  • Download URL: workdash-0.3.0.tar.gz
  • Upload date:
  • Size: 134.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for workdash-0.3.0.tar.gz
Algorithm Hash digest
SHA256 4520f9706b6f003cf5e0a16511d3fd2e02048d4278677e89785ebb8b850ae7f5
MD5 a8c794d7f300b67ec7798cbe3445af29
BLAKE2b-256 65bab7bd1c071c628184f8d66d3455071060cb0c2c577d79859cea79bf5fc5cf

See more details on using hashes here.

Provenance

The following attestation bundles were made for workdash-0.3.0.tar.gz:

Publisher: release.yml on amol-/workdash

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file workdash-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: workdash-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 89.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for workdash-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 518e3c7d273ef60f202d13399aeeb4b9fd592b84d4d4576a00f68835af0ace8a
MD5 7ca4386238bb7ad497d4e2ba88280fd8
BLAKE2b-256 7a2f03ba682ece20eac9d896d21008d1d3fb47ac8bddcb9f2050a8a0615fb556

See more details on using hashes here.

Provenance

The following attestation bundles were made for workdash-0.3.0-py3-none-any.whl:

Publisher: release.yml on amol-/workdash

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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