Beads Viewer (bv)

May 14, 2026 ยท View on GitHub

Release Go Version License Coverage

The elegant, keyboard-driven terminal interface for the Beads issue tracker.

Main split view
Main split view: fast list + rich details
Kanban board
Kanban board (`b`) for flow at a glance
Insights view
Insights panel: PageRank, critical path, cycles
Graph view
Graph view (`g`): navigate the dependency DAG

Installation

brew install dicklesworthstone/tap/bv

This method provides:

  • Automatic updates via brew upgrade
  • Dependency management
  • Easy uninstall via brew uninstall

Windows: Scoop

scoop bucket add dicklesworthstone https://github.com/Dicklesworthstone/scoop-bucket
scoop install dicklesworthstone/bv

Alternative: Direct Download

Download the latest release archive for your platform:

These links target the moving latest release aliases.

Alternative: Install Script

Linux/macOS:

curl -fsSL "https://raw.githubusercontent.com/Dicklesworthstone/beads_viewer/main/install.sh?$(date +%s)" | bash

Windows (PowerShell):

irm "https://raw.githubusercontent.com/Dicklesworthstone/beads_viewer/main/install.ps1" | iex

Note: Windows requires Go 1.21+ (download). For best display, use Windows Terminal with a Nerd Font.


Generating the JSONL File (br and bd)

bv reads from .beads/beads.jsonl. Both the Rust-based br and the original Go-based bd can generate this file.

Rust (br) users โ€” br writes .beads/beads.jsonl by default; no extra steps needed.

Go (bd) users โ€” run:

bd export --no-memories -o .beads/beads.jsonl

Once the file exists, bv works identically regardless of which tool produced it.


๐Ÿค– Agent Quickstart (Robot Mode)

โš ๏ธ Never run bare bv in an agent context โ€” it launches the interactive TUI. Always use --robot-*.

# 1) Start with triage (single-call mega-command)
bv --robot-triage

# 2) Minimal mode: just the top pick + claim command
bv --robot-next

# 3) Token-optimized output (TOON)
bv --robot-triage --format toon
export BV_OUTPUT_FORMAT=toon

# 4) Full robot help
bv --robot-help

Output conventions

  • stdout = JSON/TOON data only
  • stderr = diagnostics
  • exit 0 = success

๐Ÿ’ก TL;DR

bv is a high-performance Terminal User Interface (TUI) for browsing and managing tasks in projects that use the Beads issue tracking system.

Why you'd care:

  • Speed: Browse thousands of issues instantly with zero network latency.
  • Focus: Stay in your terminal and use Vim-style keys (j/k) to navigate.
  • Intelligence: It visualizes your project as a dependency graph, automatically highlighting bottlenecks, cycles, and critical paths that traditional list-based trackers miss.
  • AI-Ready: It provides structured, pre-computed insights for AI coding agents, acting as a "brain" for your project's task management.

๐Ÿ“– The Core Experience

At its heart, bv is about viewing your work nicely.

โšก Fast, Fluid Browsing

No web page loads, no heavy clients. bv starts instantly and lets you fly through your issue backlog using standard Vim keys (j/k).

  • Split-View Dashboard: On wider screens, see your list on the left and full details on the right.
  • Markdown Rendering: Issue descriptions, comments, and notes are beautifully rendered with syntax highlighting, headers, and lists.
  • Instant Filtering: Zero-latency filtering. Press o for Open, c for Closed, or r for Ready (unblocked) tasks.
  • Live Reload: Watches .beads/beads.jsonl and refreshes lists, details, and insights automatically when the file changesโ€”no restart needed.

๐Ÿ”Ž Rich Context

Don't just read the title. bv gives you the full picture:

  • Comments & History: Scroll through the full conversation history of any task.
  • Metadata: Instantly see Assignees, Labels, Priority badges, and creation dates.
  • Search: Powerful fuzzy search (/) finds issues by ID, title, or content instantly.

๐ŸŽฏ Focused Workflows

  • Kanban Board: Press b to switch to a columnar view (Open, In Progress, Blocked, Closed) to visualize flow.
  • Visual Graph: Press g to explore the dependency tree visually.
  • Insights: Press i to see graph metrics and bottlenecks.
  • History View: Press h to see the timeline of changes, correlating git commits with bead modifications. On wider terminals, enjoy a responsive three-pane layout showing commits, affected beads, and details.
  • Ultra-Wide Mode: On large monitors, the list expands to show extra columns like sparklines and label tags.

๐Ÿ› ๏ธ Quick Actions

  • Export: Press E to export all issues to a timestamped Markdown file with Mermaid diagrams.
  • Graph Export (CLI): bv --robot-graph outputs the dependency graph as JSON, DOT (Graphviz), or Mermaid format. Use --graph-format=dot for rendering with Graphviz, or --graph-root=ID --graph-depth=3 to extract focused subgraphs.
  • Copy: Press C to copy the selected issue as formatted Markdown to your clipboard.
  • Edit: Press O to open the .beads/beads.jsonl file in your preferred GUI editor.
  • Time-Travel: Press t to compare against any git revision, or T for quick HEAD~5 comparison. Combined with History view (h), you can navigate to any commit and see exactly what changed.

๐Ÿ”Œ Automation Hooks

Configure pre- and post-export hooks in .bv/hooks.yaml to run validations, notifications, or uploads. Defaults: pre-export hooks fail fast on errors (on_error: fail), post-export hooks log and continue (on_error: continue). Empty commands are ignored with a warning for safety. Hook env includes BV_EXPORT_PATH, BV_EXPORT_FORMAT, BV_ISSUE_COUNT, BV_TIMESTAMP, plus any custom env entries.


๐Ÿค– Ready-made Blurb to Drop Into Your AGENTS.md or CLAUDE.md Files

### Using bv as an AI sidecar

bv is a graph-aware triage engine for Beads projects (.beads/beads.jsonl). Instead of parsing JSONL or hallucinating graph traversal, use robot flags for deterministic, dependency-aware outputs with precomputed metrics (PageRank, betweenness, critical path, cycles, HITS, eigenvector, k-core).

**Scope boundary:** bv handles *what to work on* (triage, priority, planning). For agent-to-agent coordination (messaging, work claiming, file reservations), use [MCP Agent Mail](https://github.com/Dicklesworthstone/mcp_agent_mail).

**โš ๏ธ CRITICAL: Use ONLY `--robot-*` flags. Bare `bv` launches an interactive TUI that blocks your session.**

#### The Workflow: Start With Triage

**`bv --robot-triage` is your single entry point.** It returns everything you need in one call:
- `quick_ref`: at-a-glance counts + top 3 picks
- `recommendations`: ranked actionable items with scores, reasons, unblock info
- `quick_wins`: low-effort high-impact items
- `blockers_to_clear`: items that unblock the most downstream work
- `project_health`: status/type/priority distributions, graph metrics
- `commands`: copy-paste shell commands for next steps

bv --robot-triage        # THE MEGA-COMMAND: start here
bv --robot-next          # Minimal: just the single top pick + claim command

# Token-optimized output (TOON) for lower LLM context usage:
bv --robot-triage --format toon
export BV_OUTPUT_FORMAT=toon
bv --robot-next

Before claiming, verify the current bead state with `br show <id> --json` or
`br ready --json`. `recommendations` can include graph-important blocked or
assigned work; only `quick_ref.top_picks` and non-empty `claim_command` fields
represent claimable work.

#### Other Commands

**Planning:**
| Command | Returns |
|---------|---------|
| `--robot-plan` | Parallel execution tracks with `unblocks` lists |
| `--robot-priority` | Priority misalignment detection with confidence |

**Graph Analysis:**
| Command | Returns |
|---------|---------|
| `--robot-insights` | Full metrics: PageRank, betweenness, HITS (hubs/authorities), eigenvector, critical path, cycles, k-core, articulation points, slack |
| `--robot-label-health` | Per-label health: `health_level` (healthy\|warning\|critical), `velocity_score`, `staleness`, `blocked_count` |
| `--robot-label-flow` | Cross-label dependency: `flow_matrix`, `dependencies`, `bottleneck_labels` |
| `--robot-label-attention [--attention-limit=N]` | Attention-ranked labels by: (pagerank ร— staleness ร— block_impact) / velocity |

**History & Change Tracking:**
| Command | Returns |
|---------|---------|
| `--robot-history` | Bead-to-commit correlations: `stats`, `histories` (per-bead events/commits/milestones), `commit_index` |
| `--robot-diff --diff-since <ref>` | Changes since ref: new/closed/modified issues, cycles introduced/resolved |

**Other Commands:**
| Command | Returns |
|---------|---------|
| `--robot-burndown <sprint>` | Sprint burndown, scope changes, at-risk items |
| `--robot-forecast <id\|all>` | ETA predictions with dependency-aware scheduling |
| `--robot-alerts` | Stale issues, blocking cascades, priority mismatches |
| `--robot-suggest` | Hygiene: duplicates, missing deps, label suggestions, cycle breaks |
| `--robot-graph [--graph-format=json\|dot\|mermaid]` | Dependency graph export |
| `--export-graph <file.html>` | Self-contained interactive HTML visualization |

#### Scoping & Filtering

bv --robot-plan --label backend              # Scope to label's subgraph
bv --robot-insights --as-of HEAD~30          # Historical point-in-time
bv --recipe actionable --robot-plan          # Pre-filter: ready to work (no blockers)
bv --recipe high-impact --robot-triage       # Pre-filter: top PageRank scores
bv --robot-triage --robot-triage-by-track    # Group by parallel work streams
bv --robot-triage --robot-triage-by-label    # Group by domain

#### Understanding Robot Output

**All robot JSON includes:**
- `data_hash` โ€” Fingerprint of source beads.jsonl (verify consistency across calls)
- `status` โ€” Per-metric state: `computed|approx|timeout|skipped` + elapsed ms
- `as_of` / `as_of_commit` โ€” Present when using `--as-of`; contains ref and resolved SHA

**Two-phase analysis:**
- **Phase 1 (instant):** degree, topo sort, density โ€” always available immediately
- **Phase 2 (async, 500ms timeout):** PageRank, betweenness, HITS, eigenvector, cycles โ€” check `status` flags

**For large graphs (>500 nodes):** Some metrics may be approximated or skipped. Always check `status`.

#### jq Quick Reference

bv --robot-triage | jq '.quick_ref'                        # At-a-glance summary
bv --robot-triage | jq '.recommendations[0]'               # Top recommendation
bv --robot-plan | jq '.plan.summary.highest_impact'        # Best unblock target
bv --robot-insights | jq '.status'                         # Check metric readiness
bv --robot-insights | jq '.Cycles'                         # Circular deps (must fix!)
bv --robot-label-health | jq '.results.labels[] | select(.health_level == "critical")'

**Performance:** Phase 1 instant, Phase 2 async (500ms timeout). Prefer `--robot-plan` over `--robot-insights` when speed matters. Results cached by data hash.

Use bv instead of parsing beads.jsonlโ€”it computes PageRank, critical paths, cycles, and parallel tracks deterministically.

Automatic Integration

bv can automatically add the above instructions to your project's agent file:

  • On first run, bv checks for AGENTS.md (or similar files) and offers to inject the blurb if not present
  • Choose "Yes" to add the instructions, "No" to skip, or "Don't ask again" to remember your preference
  • Preferences are stored per-project in ~/.config/bv/agent-prompts/

Supported Files (checked in order):

  1. AGENTS.md (preferred)
  2. CLAUDE.md
  3. agents.md
  4. claude.md

Manual Control:

bv --agents-check             # Check if blurb is present in agent file
bv --agents-add               # Add blurb to agent file (creates file if needed)
bv --agents-remove            # Remove blurb from agent file
bv --agents-update            # Update blurb to latest version
bv --agents-dry-run           # Show what would happen without executing

Version Tracking:

The blurb uses HTML comment markers for version tracking:

<!-- bv-agent-instructions-v1 -->
... content ...
<!-- end-bv-agent-instructions -->

When a new version of the blurb is released, bv can detect the outdated version and offer to update it.


๐Ÿ“ Architecture & Design

bv treats your project as a Directed Acyclic Graph (DAG), not just a list. This allows it to derive insights about what is truly important.

graph TD
    %% Soft Pastel Theme โ€” Refined
    classDef data fill:#e3f2fd,stroke:#90caf9,stroke-width:2px,color:#1565c0,rx:8
    classDef logic fill:#fff8e1,stroke:#ffcc80,stroke-width:2px,color:#e65100,rx:8
    classDef ui fill:#f3e5f5,stroke:#ce93d8,stroke-width:2px,color:#6a1b9a,rx:8
    classDef output fill:#e8f5e9,stroke:#a5d6a7,stroke-width:2px,color:#2e7d32,rx:8

    subgraph storage [" ๐Ÿ“‚ Data Layer "]
        A[".beads/beads.jsonl<br/>JSONL Issue Store"]:::data
    end

    subgraph engine [" โš™๏ธ Analysis Engine "]
        B["Loader"]:::logic
        C["Graph Builder"]:::logic
        D["9 Metrics<br/>PageRank ยท Betweenness ยท HITS..."]:::logic
    end

    subgraph interface [" ๐Ÿ–ฅ๏ธ TUI Layer "]
        E["Bubble Tea Model"]:::ui
        F["List View"]:::ui
        G["Graph View"]:::ui
        G2["Tree View"]:::ui
        H["Insights Dashboard"]:::ui
    end

    subgraph outputs [" ๐Ÿ“ค Outputs "]
        I["--robot-insights<br/>JSON for AI Agents"]:::output
        J["--export-md<br/>Markdown Report"]:::output
    end

    A --> B
    B --> C
    C --> D
    D --> E
    D --> I
    D --> J
    E --> F
    E --> G
    E --> G2
    E --> H

    linkStyle 0,1,2 stroke:#90caf9,stroke-width:2px
    linkStyle 3,4,5 stroke:#ffcc80,stroke-width:2px
    linkStyle 6,7,8,9 stroke:#ce93d8,stroke-width:2px

Key Metrics & Algorithms

bv computes 9 graph-theoretic metrics to surface hidden project dynamics:

#MetricWhat It MeasuresKey Insight
1PageRankRecursive dependency importanceFoundational blockers
2BetweennessShortest-path trafficBottlenecks & bridges
3HITSHub/Authority dualityEpics vs. utilities
4Critical PathLongest dependency chainKeystones with zero slack
5EigenvectorInfluence via neighborsStrategic dependencies
6DegreeDirect connection countsImmediate blockers/blocked
7DensityEdge-to-node ratioProject coupling health
8CyclesCircular dependenciesStructural errors
9Topo SortValid execution orderWork queue foundation

1. PageRank (Dependency Authority)

The Math: Originally designed to rank web pages by "importance" based on incoming links, PageRank models a "random surfer" walking the graph. In our dependency graph (u โ†’ v implies u depends on v), we treat dependencies as "votes" of importance.

PR(v)=1โˆ’dN+dโˆ‘uโˆˆM(v)PR(u)L(u)PR(v) = \frac{1-d}{N} + d \sum_{u \in M(v)} \frac{PR(u)}{L(u)}

The Intuition: If many tasks depend on Task A, or if a single very important Task B depends on Task A, then Task A implicitly becomes "heavy." A random walker following dependency links will frequently get stuck at Task A.

Pragmatic Meaning: Foundational Blocks. High PageRank tasks are the bedrock of your project. They are rarely "features" in the user-facing sense; they are often schemas, core libraries, or architectural decisions. Breaking them breaks the graph.

2. Betweenness Centrality (Bottlenecks)

The Math: Defined as the fraction of all shortest paths in the network that pass through a given node vv. CB(v)=โˆ‘sโ‰ vโ‰ tฯƒst(v)ฯƒstC_B(v) = \sum_{s \neq v \neq t} \frac{\sigma_{st}(v)}{\sigma_{st}}

The Intuition: Imagine information (or progress) flowing from every task to every other task along the most efficient route. "Bridge nodes" that connect otherwise isolated clusters (e.g., the Frontend cluster and the Backend cluster) will see a massive amount of traffic.

Pragmatic Meaning: Gatekeepers & Bottlenecks. A task with high Betweenness is a choke point. It might be an API contract that both the mobile app and the server team are waiting on. If this task is delayed, it doesn't just block one thread; it prevents entire sub-teams from synchronizing.

3. HITS (Hubs & Authorities)

The Math: An iterative algorithm that defines two scores for every node:

  • Authority: The sum of Hub scores of nodes pointing to it.
  • Hub: The sum of Authority scores of nodes it points to.

The Intuition: This models a "mutually reinforcing" relationship. Good libraries (Authorities) are used by many applications. Good applications (Hubs) use many good libraries.

Pragmatic Meaning: Epics vs. Infrastructure.

  • High Hub Score: These are your Epics or Product Features. They aggregate many dependencies to deliver value.
  • High Authority Score: These are your Utilities. They provide value to many consumers.

4. Critical Path (Longest Path in DAG)

The Math: In a DAG, the longest path represents the minimum time required to complete the project (assuming infinite parallelism). bv computes this recursively: Impact(u)=1+maxโก({Impact(v)โˆฃuโ†’v})Impact(u) = 1 + \max(\{Impact(v) \mid u \to v\})

The Intuition: If you hold the graph by its "leaf" nodes (tasks with no dependencies) and let it dangle, the tasks at the very top that support the longest chains are carrying the most weight.

Pragmatic Meaning: Keystones. A Keystone task is one where any delay translates 1:1 into a delay for the final project delivery. These tasks have zero "slack."

5. Eigenvector Centrality (Influential Neighbors)

The Math: Eigenvector centrality measures a node's influence by considering not just its connections, but the importance of those connections. A node with few but highly influential neighbors can score higher than a node with many unimportant neighbors. xi=1ฮปโˆ‘jโˆˆN(i)xjx_i = \frac{1}{\lambda} \sum_{j \in N(i)} x_j

Where ฮป\lambda is the largest eigenvalue of the adjacency matrix and N(i)N(i) are neighbors of node ii.

The Intuition: It's not just how many connections you have, but who you're connected to. Being depended on by a critical task makes you more important than being depended on by many trivial tasks.

Pragmatic Meaning: Strategic Dependencies. High Eigenvector tasks are connected to the "power players" in your graph. They may not have many direct dependents, but their dependents are themselves critical.

6. Degree Centrality (Direct Connections)

The Math: The simplest centrality measureโ€”just count the edges. CDin(v)=โˆฃ{u:uโ†’v}โˆฃC_D^{in}(v) = |\{u : u \to v\}|

CDout(v)=โˆฃ{u:vโ†’u}โˆฃC_D^{out}(v) = |\{u : v \to u\}|

The Intuition:

  • In-Degree: How many tasks depend on me? (I am a blocker)
  • Out-Degree: How many tasks do I depend on? (I am blocked)

Pragmatic Meaning: Immediate Impact.

  • High In-Degree: This task is a direct blocker for many others. Completing it immediately unblocks work.
  • High Out-Degree: This task has many prerequisites. It's likely to be blocked and should be scheduled later in the execution plan.

7. Graph Density (Interconnectedness)

The Math: Density measures how "connected" the graph is relative to its maximum possible connections. D=โˆฃEโˆฃโˆฃVโˆฃ(โˆฃVโˆฃโˆ’1)D = \frac{|E|}{|V|(|V|-1)}

Where โˆฃEโˆฃ|E| is the edge count and โˆฃVโˆฃ|V| is the node count. For a directed graph, the maximum edges is โˆฃVโˆฃ(โˆฃVโˆฃโˆ’1)|V|(|V|-1).

The Intuition: A density of 0.0 means no dependencies exist (isolated tasks). A density approaching 1.0 means everything depends on everything (pathological complexity).

Pragmatic Meaning: Project Health Indicator.

  • Low Density (< 0.05): Healthy. Tasks are relatively independent and can be parallelized.
  • Medium Density (0.05 - 0.15): Normal. Reasonable interconnection reflecting real-world dependencies.
  • High Density (> 0.15): Warning. Overly coupled project. Consider breaking into smaller modules.

8. Cycle Detection (Circular Dependencies)

The Math: A cycle in a directed graph is a path vโ‚ โ†’ vโ‚‚ โ†’ โ‹ฏ โ†’ vโ‚– โ†’ vโ‚ where the start and end nodes are identical. bv uses Tarjan's algorithm variant via topo.DirectedCyclesIn to enumerate all elementary cycles.

The Intuition: If A depends on B, and B depends on A, neither can ever be completed. This is a logical impossibility that must be resolved.

Pragmatic Meaning: Structural Errors. Cycles are bugs in your project plan, not just warnings. They indicate:

  • Misclassified dependencies (A doesn't really block B, or vice versa)
  • Missing intermediate tasks (A and B both depend on an unstated C)
  • Scope confusion (A and B should be merged into a single task)

9. Topological Sort (Execution Order)

The Math: A topological ordering of a DAG is a linear sequence of all vertices such that for every edge u โ†’ v, vertex u appears before v in the sequence. Only acyclic graphs have valid topological orderings.

The Intuition: If you must complete tasks in dependency order, topological sort gives you a valid order (there may be many).

Pragmatic Meaning: Work Queue. The topological order is the foundation of bv's execution planning. Combined with priority weights, it generates the "what to work on next" recommendations that power --robot-plan.


๐Ÿค– The Robot Protocol (AI Interface)

bv bridges the gap between raw data and AI agents. Agents struggle with graph algorithms; bv solves this by acting as a deterministic "sidecar" that offloads the cognitive burden of graph traversal.

sequenceDiagram
    %%{init: {'theme': 'base', 'themeVariables': { 'primaryColor': '#e8f5e9', 'primaryTextColor': '#2e7d32', 'primaryBorderColor': '#81c784', 'lineColor': '#90a4ae', 'secondaryColor': '#fff8e1', 'tertiaryColor': '#fce4ec'}}}%%

    participant User
    participant Agent as ๐Ÿค– AI Agent
    participant BV as โšก bv
    participant File as ๐Ÿ“„ beads.jsonl

    User->>Agent: "Fix the next blocked task"

    rect rgba(232, 245, 233, 0.4)
        Note over Agent, BV: Cognitive Offloading
        Agent->>BV: bv --robot-plan
        BV->>File: Read & Parse
        BV->>BV: PageRank + Topo Sort
        BV-->>Agent: { next: "TASK-123", unblocks: 5 }
    end

    rect rgba(255, 243, 224, 0.3)
        Note over Agent: Implementation Phase
        Agent->>Agent: Fix TASK-123
        Agent->>BV: bv --robot-insights
        BV-->>Agent: Updated graph metrics
    end

The "Cognitive Offloading" Strategy

The primary design goal of the Robot Protocol is Cognitive Offloading. Large Language Models (LLMs) are probabilistic engines; they are excellent at semantic reasoning (coding, writing) but notoriously unreliable at algorithmic graph traversal (finding cycles, computing shortest paths). The two-phase analyzer returns degree/topo/density immediately and completes PageRank/Betweenness/HITS/Eigenvector/Critical Path/Cycles asynchronously with size-aware timeouts and hashed caching, so repeat robot calls stay fast when the graph hasnโ€™t changed.

If you feed an Agent raw beads.jsonl data, you are forcing the Agent to:

  1. Parse thousands of lines of JSON.
  2. Reconstruct the dependency graph in its context window.
  3. "Hallucinate" a path traversal or cycle check.

bv solves this by providing a deterministic graph engine sidecar.

Why bv vs. Raw Beads?

Using beads directly gives an agent data. Using bv --robot-insights gives an agent intelligence.

CapabilityRaw Beads (JSONL)bv Robot Mode
Query"List all issues.""List the top 5 bottlenecks blocking the release."
Context CostHigh (Linear with issue count).Low (Fixed summary struct).
Graph LogicAgent must infer/compute.Pre-computed (PageRank/Brandes).
SafetyAgent might miss a cycle.Cycles explicitly flagged.

Agent Usage Patterns

Agents typically use bv in three phases:

  1. Triage & Orientation: Before starting a session, the agent runs bv --robot-insights. It receives a lightweight JSON summary of the project's structural health. It immediately knows:

    • "I should not work on Task C yet because it depends on Task B, which is a Bottleneck."
    • "The graph has a cycle (A->B->A); I must fix this structural error before adding new features."
  2. Impact Analysis: When asked to "refactor the login module," the agent checks the PageRank and Impact Scores of the relevant beads. If the scores are high, the agent knows this is a high-risk change with many downstream dependents, prompting it to run more comprehensive tests.

  3. Execution Planning: Instead of guessing the order of operations, the agent uses bv's topological sort to generate a strictly linearized plan.

JSON Output Schema (--robot-insights): The output is designed to be strictly typed and easily parseable by tools like jq or standard JSON libraries.

{
  "bottlenecks": [
    { "id": "CORE-123", "value": 0.45 }
  ],
  "keystones": [
    { "id": "API-001", "value": 12.0 }
  ],
  "influencers": [
    { "id": "AUTH-007", "value": 0.82 }
  ],
  "hubs": [
    { "id": "EPIC-100", "value": 0.67 }
  ],
  "authorities": [
    { "id": "UTIL-050", "value": 0.91 }
  ],
  "cycles": [
    ["TASK-A", "TASK-B", "TASK-A"]
  ],
  "clusterDensity": 0.045,
  "stats": {
    "pageRank": { "CORE-123": 0.15, "...": "..." },
    "betweenness": { "CORE-123": 0.45, "...": "..." },
    "eigenvector": { "AUTH-007": 0.82, "...": "..." },
    "hubs": { "EPIC-100": 0.67, "...": "..." },
    "authorities": { "UTIL-050": 0.91, "...": "..." },
    "inDegree": { "CORE-123": 5, "...": "..." },
    "outDegree": { "CORE-123": 2, "...": "..." },
    "criticalPathScore": { "API-001": 12.0, "...": "..." },
    "density": 0.045,
    "topologicalOrder": ["CORE-123", "API-001", "..."]
  }
}
FieldMetricWhat It Contains
bottlenecksBetweennessTop nodes bridging graph clusters
keystonesCritical PathTop nodes on longest dependency chains
influencersEigenvectorTop nodes connected to important neighbors
hubsHITS HubTop dependency aggregators (Epics)
authoritiesHITS AuthorityTop prerequisite providers (Utilities)
cyclesCycle DetectionAll circular dependency paths
clusterDensityDensityOverall graph interconnectedness
statsAll MetricsFull raw data for custom analysis

๐ŸŽจ TUI Engineering & Craftsmanship

bv is built with the Bubble Tea framework, ensuring a glitch-free, 60fps experience. It features an adaptive layout engine that responds to terminal resize events and a custom ASCII/Unicode graph renderer.

flowchart LR
    classDef core fill:#fef3e2,stroke:#f5d0a9,stroke-width:2px,color:#8b5a2b
    classDef engine fill:#f0e6f6,stroke:#d4b8e0,stroke-width:2px,color:#5d3a6b
    classDef ui fill:#e6f3e6,stroke:#b8d9b8,stroke-width:2px,color:#2d5a2d
    classDef output fill:#e8f4f8,stroke:#b8d4e3,stroke-width:2px,color:#2c5f7c

    INPUT["โŒจ๏ธ Input<br/>Keys ยท Mouse ยท Resize"]:::core
    MODEL["๐Ÿซ– Model<br/>Issues ยท Stats ยท Focus"]:::core
    GRAPH["๐Ÿงฎ Graph Engine<br/>PageRank ยท HITS ยท Cycles"]:::engine
    VIEWS["๐Ÿ–ผ๏ธ Views<br/>List ยท Board ยท Graph ยท Tree ยท Insights"]:::ui
    LAYOUT["๐Ÿ“ Layout<br/>Mobile ยท Split ยท Wide"]:::ui
    TERM["๐Ÿ–ฅ๏ธ Terminal<br/>60fps Output"]:::output

    INPUT -->|tea.Msg| MODEL
    GRAPH -->|metrics| MODEL
    MODEL -->|state| VIEWS
    VIEWS --> LAYOUT
    LAYOUT --> TERM

    linkStyle 0 stroke:#f5d0a9,stroke-width:2px
    linkStyle 1 stroke:#d4b8e0,stroke-width:2px
    linkStyle 2 stroke:#b8d9b8,stroke-width:2px
    linkStyle 3,4 stroke:#b8d4e3,stroke-width:2px

1. Adaptive Layout Engine

bv doesn't just dump text; it calculates geometry on every render cycle.

  • Dynamic Resizing: The View() function inspects the current terminal width (msg.Width) on every frame.
  • Breakpoint Logic:
    • < 100 cols: Mobile Mode. List takes 100% width.
    • > 100 cols: Split Mode. List takes 40%, Details take 60%.
    • > 140 cols: Ultra-Wide. List injects extra columns (Sparklines, Labels) that are normally hidden.
  • Padding Awareness: The layout engine explicitly accounts for borders (2 chars) and padding (2 chars) to prevent "off-by-one" wrapping errors that plague many TUIs.

2. Zero-Latency Virtualization

Rendering 10,000 issues would choke a naive terminal app. bv implements Viewport Virtualization:

  • Windowing: We only render the slice of rows currently visible in the terminal window.
  • Pre-Computation: Graph metrics (PageRank, etc.) are computed once at startup in a separate goroutine, not on every frame. The underlying graph uses a compact adjacency-list implementation that's 50-100ร— faster than naive map-backed approaches.
  • Detail Caching: The Markdown renderer is instantiated lazily and reused, avoiding expensive regex recompilation.

3. Visual Graph Engine (pkg/ui/graph.go)

We built a custom 2D ASCII/Unicode rendering engine from scratch to visualize the dependency graph.

  • Canvas Abstraction: A 2D grid of rune cells and style pointers allows us to draw "pixels" in the terminal.
  • Manhattan Routing: Edges are drawn using orthogonal lines with proper Unicode corner characters ( โ•ญ, โ”€, โ•ฎ, โ”‚, โ•ฐ, โ•ฏ) to minimize visual noise.
  • Topological Layering: Nodes are arranged in layers based on their "Impact Depth," ensuring that dependencies always flow downwards.

4. Thematic Consistency

We use Lipgloss to enforce a strict design system.

  • Semantic Colors: Colors are defined semantically (Theme.Blocked, Theme.Open) rather than hardcoded hex values. This allows bv to switch between "Dracula" (Dark) and "Light" modes seamlessly.
  • Status Indicators: We use Nerd Font glyphs (๐Ÿ›, โœจ, ๐Ÿ”ฅ) paired with color coding to convey status instantly without reading text.

๐Ÿ“ˆ Visual Data Encoding: Sparklines & Heatmaps

In dense information environments like the terminal, text is expensive. bv employs high-density data visualization techniques (pkg/ui/visuals.go) inspired by Edward Tufte to convey complex metrics in minimal space.

1. Unicode Sparklines

When viewing the list in Ultra-Wide mode, bv renders a "Graph Score" column using Unicode block characters ( , โ–‚, โ–ƒ, โ–„, โ–…, โ–†, โ–‡, โ–ˆ).

  • The Math: RenderSparkline(val, width) normalizes a float value (0.0 - 1.0) against the available character width. It calculates the precise block height for each character cell to create a continuous bar chart effect.
  • The Utility: This allows you to scan a list of 50 issues and instantly spot the "spikes" in complexity or centrality without reading a single number.

2. Semantic Heatmaps

We don't just use random colors. pkg/ui/visuals.go implements a perceptually uniform color ramp (GetHeatmapColor) that maps metric intensity to a gradient:

  • 0.0 - 0.2: Low (Gray/Dim)
  • 0.2 - 0.5: Mid (Blue/Cool)
  • 0.5 - 0.8: High (Purple/Warm)
  • 0.8 - 1.0: Peak (Pink/Hot) This visual encoding is applied to badges in the Insights Dashboard, allowing you to differentiate between "somewhat important" and "critically urgent" tasks at a glance.

๐Ÿ” Search Architecture

In a project with thousands of issues, you cannot afford to wait for a backend query. bv implements a composite, in-memory fuzzy search that feels instantaneous.

The "Flattened Vector" Index

Instead of searching fields individually (which requires complex UI controls), bv flattens every issue into a single searchable "vector" at load time. The FilterValue() method constructs a composite string containing:

  • Core Identity: ID ("CORE-123") and Title ("Fix login race condition")
  • Metadata: Status ("open"), Type ("bug"), Priority
  • Context: Assignee ("@steve") and Labels ("frontend, v1.0")

Fuzzy Subsequence Matching

When you press /, the search engine performs a fuzzy subsequence match against this composite vector.

  • Example: Typing "log fix" successfully matches "Fix login race condition".
  • Example: Typing "steve bug" finds bugs assigned to Steve.
  • Example: Typing "open v1.0" filters for open items in the v1.0 release.

Performance Characteristics

  • Zero Allocation: The search index is built once during the initial load (loader.LoadIssues).
  • Client-Side Filtering: Filtering happens entirely within the render loop. There is no database latency, no network round-trip, and no "loading" spinner.
  • Stable Sort: Search results maintain the topological and priority sorting of the main list, ensuring that even filtered views reflect the project's true priorities.

๐Ÿงœ Mermaid Integration: Diagrams in the Terminal?

A common question is: "How do you render complex diagrams in a text-only terminal?"

bv approaches this problem in two ways:

1. The Native Graph Visualizer (g)

For the interactive TUI, we built a specialized ASCII/Unicode Graph Engine (pkg/ui/graph.go) that replicates the core value of a Mermaid flowchart without requiring graphical protocol support (like Sixel).

  • Topological Layering: Nodes are automatically sorted by their dependency depth.
  • Orthogonal Routing: Connections use box-drawing characters (โ”‚, โ”€, โ•ญ, โ•ฏ) to draw clean, right-angled paths that avoid crossing through node text.
  • Adaptive Canvas: The virtual canvas expands infinitely, but the viewport (pkg/ui/viewport.go) clips rendering to exactly what fits on your screen, panning smoothly with h/j/k/l.

2. The Export Engine (--export-md)

For external reporting, bv includes a robust Mermaid Generator (pkg/export/markdown.go).

  • Sanitization: It automatically escapes unsafe characters in issue titles to prevent syntax errors in the Mermaid parser.
  • Collision-Proof IDs: When sanitization would collide (e.g., symbol-only IDs), nodes get a stable hash suffix so edges never merge or disappear.
  • Class-Based Styling: Nodes are assigned CSS classes (classDef open, classDef blocked) based on their status, so the resulting diagram visually matches the TUI's color scheme when rendered on GitHub or GitLab.
  • Semantic Edges: Blockers are rendered with thick arrows (==>), while loose relations use dashed lines (-.->), encoding the severity of the link into the visual syntax.
graph TD
    %% Generated by bv โ€” Soft Pastel Theme
    classDef open fill:#c8e6c9,stroke:#81c784,stroke-width:2px,color:#2e7d32
    classDef blocked fill:#ffcdd2,stroke:#e57373,stroke-width:2px,color:#c62828
    classDef inProgress fill:#fff3e0,stroke:#ffb74d,stroke-width:2px,color:#ef6c00

    A["CORE-123<br/>Refactor Login"]:::open
    B["UI-456<br/>Login Page"]:::blocked
    C["API-789<br/>Auth Endpoint"]:::inProgress

    A --> B
    A --> C
    C -.-> B

    linkStyle 0 stroke:#81c784,stroke-width:2px
    linkStyle 1 stroke:#81c784,stroke-width:2px
    linkStyle 2 stroke:#e57373,stroke-width:1px,stroke-dasharray:5

๐Ÿ“ธ Graph Export (--robot-graph)

Export the dependency graph in multiple formats for visualization, documentation, or integration with other tools:

bv --robot-graph                              # JSON (default)
bv --robot-graph --graph-format=dot           # Graphviz DOT
bv --robot-graph --graph-format=mermaid       # Mermaid diagram

# Focused subgraph extraction
bv --robot-graph --graph-root=bv-123          # Subgraph from specific root
bv --robot-graph --graph-root=bv-123 --graph-depth=3  # Limited depth

Output Formats

FormatUse CaseRendering
jsonProgrammatic processing, custom visualizationParse with jq or code
dotHigh-quality static imagesdot -Tpng file.dot -o graph.png
mermaidEmbed in Markdown, GitHub renderingPaste into docs

Subgraph Extraction

For large projects, extract focused views around specific issues:

  • --graph-root=ID: Start from a specific issue and include all its dependencies and dependents
  • --graph-depth=N: Limit traversal to N levels (0 = unlimited)

JSON Schema

{
  "nodes": [
    { "id": "bv-123", "title": "Fix auth", "status": "open", "priority": 1 }
  ],
  "edges": [
    { "from": "bv-124", "to": "bv-123", "type": "blocks" }
  ],
  "metadata": {
    "data_hash": "abc123",
    "node_count": 45,
    "edge_count": 62
  }
}

๐ŸŒŒ Interactive Graph Visualization (--export-graph)

For deep exploration of complex dependency structures, bv generates self-contained HTML visualizations powered by a force-directed graph engine. Unlike static exports, these are fully interactiveโ€”pan, zoom, filter, and drill into individual beads without any server or dependencies.

# Generate interactive HTML graph
bv --export-graph graph.html                    # Export to specific file
bv --export-graph                               # Auto-generate timestamped filename
bv --export-graph --graph-title "Q4 Sprint"     # Custom title
bv --export-graph --graph-include-closed        # Include closed issues

Why Interactive Graph Visualization?

Traditional list-based views show tasks in isolation. The interactive graph reveals the hidden structure of your project:

  • Dependency Chains: See at a glance which tasks are blocking others, and trace critical paths through your backlog
  • Bottleneck Detection: Nodes sized by PageRank/betweenness instantly reveal which items have outsized impact
  • Cluster Discovery: Force-directed layout naturally groups related work, exposing team boundaries or feature clusters
  • Context Switching: Hover over any node to see full detailsโ€”description, design notes, acceptance criteriaโ€”without leaving the visualization

What's Included in the Export

Each HTML file is completely self-contained (typically 400KB-1MB depending on project size):

ComponentDescription
Full Bead DataTitle, description, design, acceptance criteria, notes, labels, timestamps
Graph MetricsPageRank, betweenness, critical path score, slack, hub/authority scores
Triage AnalysisComplete triage recommendations with scores and reasons
Git CorrelationCommit history linked to each bead (when available)
Dependency MapFull blocked-by/blocks relationships with visual edges

Interface Overview

The visualization provides a rich, keyboard-driven interface:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿ“Š Project Graph | [Search...] | Layout โ–พ | Filters โ–พ | ๐Ÿ”ฅ ๐Ÿ“‹ โญ โ˜€๏ธ โ“    โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚                      โ”‚                                                      โ”‚
โ”‚   Bead Details       โ”‚              Force-Directed Graph                    โ”‚
โ”‚   โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•    โ”‚                                                      โ”‚
โ”‚   ID: bv-xyz         โ”‚         โ—โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ—                                    โ”‚
โ”‚   Title: Feature X   โ”‚        /โ”‚\      โ”‚                                    โ”‚
โ”‚                      โ”‚       โ— โ— โ—     โ—โ”€โ”€โ”€โ—                                โ”‚
โ”‚   Description:       โ”‚         โ”‚           โ”‚                                โ”‚
โ”‚   [markdown...]      โ”‚         โ—โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ—                                โ”‚
โ”‚                      โ”‚                                                      โ”‚
โ”‚   Graph Metrics:     โ”‚              โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”                    โ”‚
โ”‚   PageRank: 2.34%    โ”‚              โ”‚ Low โ–ฐโ–ฐโ–ฐโ–ฐ High   โ”‚  <- Heatmap Legend โ”‚
โ”‚   Betweenness: 0.12  โ”‚              โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜                    โ”‚
โ”‚   Critical Path: 4.0 โ”‚         โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”                              โ”‚
โ”‚                      โ”‚         โ”‚ Mini-map    โ”‚                              โ”‚
โ”‚   Blocked By: [...]  โ”‚         โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜                              โ”‚
โ”‚   Blocks: [...]      โ”‚                                                      โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Visual Encoding

Nodes encode multiple dimensions of information simultaneously:

Visual PropertyMeaning
ColorStatus: ๐ŸŸข Open, ๐ŸŸ  In Progress, ๐Ÿ”ด Blocked, โšซ Closed
SizeConfigurable metric (PageRank, betweenness, critical path, in-degree)
ShapeType: โ— Feature, โ–ฒ Bug, โ–  Task, โ—† Epic
GlowGolden halo on hover shows connected subgraph (2-hop neighbors)
Edge ColorPink edges indicate critical path connections

Keyboard Shortcuts

The visualization is fully keyboard-driven:

KeyActionKeyAction
?Help overlayDDock/detach detail panel
FFit all in viewLToggle light/dark mode
RReset to defaultsHToggle heatmap coloring
SpaceFullscreenTTop nodes panel
EscClear/cancelGTriage panel
1-4Layout modesYRecently viewed
PPath finder mode

Features

Filtering & Search

  • Full-text search: Find beads by ID, title, or content with live preview
  • Status filter: Open, In Progress, Blocked, Closed
  • Type filter: Feature, Bug, Task, Epic
  • Priority filter: P0 (Critical) through P4 (Backlog)
  • Label filter: Dynamically populated from your data

Navigation

  • Path Finder: Press P, then click two nodes to find and highlight the shortest path between them
  • Recently Viewed: Press Y to see your navigation history and jump back to previous nodes
  • Mini-map: Overview in the corner shows your current viewport position

Panels

  • Docked Detail Panel: Left sidebar shows full bead information on hover (default)
  • Floating Mode: Press D to detach the panel for floating tooltip-style display
  • Triage Panel: Shows top recommendations with scores and reasoning
  • Top Nodes: Lists highest PageRank nodes for quick navigation

Customization

  • Layout Modes: Force-directed (default), DAG top-down, DAG left-right, Radial
  • Size Metric: Choose what determines node size (PageRank, betweenness, critical path, in-degree)
  • Light/Dark Mode: Full theme support with proper contrast
  • Preferences Saved: Theme and layout choices persist via localStorage

Use Cases

ScenarioHow the Graph Helps
Sprint PlanningIdentify which items unblock the most downstream work
Stakeholder UpdatesShare a single HTML fileโ€”no setup required to view
Architecture ReviewSpot unexpected dependencies between features
OnboardingNew team members can explore the codebase's work structure
RetrospectivesVisualize completed work and remaining blockers

Example Workflow

# 1. Generate the visualization
bv --export-graph sprint_review.html --graph-title "Sprint 42 Review"

# 2. Open in browser
open sprint_review.html    # macOS
xdg-open sprint_review.html  # Linux
start sprint_review.html   # Windows

# 3. Share with team
# The HTML file is self-containedโ€”just send it or host anywhere

Technical Notes

  • No Server Required: Everything runs client-side in the browser
  • Offline Capable: Works completely offline once opened
  • Modern Browsers: Tested on Chrome, Firefox, Safari, Edge
  • Performance: Handles 500+ nodes smoothly with WebGL-accelerated rendering
  • File Size: Typically 400KB-1MB depending on project size and content

๐Ÿ“„ The Status Report Engine

bv isn't just for personal browsing; it's a communication tool. The --export-md flag generates a Management-Ready Status Report that converts your repo state into a polished document suitable for stakeholders.

1. The "Hybrid Document" Architecture

The exporter (pkg/export/markdown.go) constructs a document that bridges human readability and visual data:

  • Summary at a Glance: Top-level statistics (Total, Open, Blocked, Closed) give immediate health context.
  • Embedded Graph: It injects the full dependency graph as a Mermaid diagram right into the document. On platforms like GitHub or GitLab, this renders as an interactive chart.
  • Anchor Navigation: A generated Table of Contents uses URL-friendly slugs (#core-123-refactor-login) to link directly to specific issue details, allowing readers to jump between the high-level graph and low-level specs.

2. Semantic Formatting

We don't just dump JSON values. The exporter applies specific formatting rules to ensure the report looks professional:

  • Metadata Tables: Key fields (Assignee, Priority, Status) are aligned in GFM (GitHub Flavored Markdown) tables with emoji indicators.
  • Conversation threading: Comments are rendered as blockquotes (>) with relative timestamps, preserving the flow of discussion distinct from the technical spec.
  • Intelligent Sorting: The report doesn't list issues ID-sequentially. It applies the same priority logic as the TUI: Open Critical issues appear first, ensuring the reader focuses on what matters now.

โณ Time-Travel: Snapshot Diffing & Git History

One of bv's most powerful capabilities is Time-Travelโ€”the ability to compare your project's state across any two points in git history. This transforms bv from a "viewer" into a progress tracking and regression detection system.

The Snapshot Model

bv captures the complete state of your project at any moment:

graph LR
    %%{init: {'theme': 'base', 'themeVariables': { 'primaryColor': '#e8f5e9', 'primaryTextColor': '#2e7d32', 'primaryBorderColor': '#81c784', 'lineColor': '#90a4ae'}}}%%

    subgraph "Git History"
        A["HEAD~10<br/><small>10 commits ago</small>"]
        B["HEAD~5<br/><small>5 commits ago</small>"]
        C["HEAD<br/><small>Current</small>"]
    end

    subgraph "Snapshots"
        D["Snapshot A<br/><small>45 issues, 3 cycles</small>"]
        E["Snapshot B<br/><small>52 issues, 1 cycle</small>"]
        F["Snapshot C<br/><small>58 issues, 0 cycles</small>"]
    end

    A --> D
    B --> E
    C --> F
    D -.->|"diff"| E
    E -.->|"diff"| F

    style D fill:#ffcdd2,stroke:#e57373,stroke-width:2px
    style E fill:#fff3e0,stroke:#ffb74d,stroke-width:2px
    style F fill:#c8e6c9,stroke:#81c784,stroke-width:2px

What Gets Tracked

The SnapshotDiff captures every meaningful change:

CategoryTracked Changes
IssuesNew, Closed, Reopened, Removed, Modified
FieldsTitle, Status, Priority, Tags, Dependencies
GraphNew Cycles, Resolved Cycles
Metricsฮ” PageRank, ฮ” Betweenness, ฮ” Density

Git History Integration (pkg/loader/git.go)

The GitLoader enables loading issues from any git revision:

loader := NewGitLoader("/path/to/repo")

// Load from various references
current, _ := loader.LoadAt("HEAD")
lastWeek, _ := loader.LoadAt("HEAD~7")
release, _ := loader.LoadAt("v1.0.0")
byDate, _ := loader.LoadAt("main@{2024-01-15}")

Cache Architecture:

  • Revisions are resolved to commit SHAs for stable caching
  • Thread-safe sync.RWMutex protects concurrent access
  • 5-minute TTL prevents stale data while avoiding redundant git calls

Use Cases

  1. Sprint Retrospectives: "How many issues did we close this sprint?"
  2. Regression Detection: "Did we accidentally reintroduce a dependency cycle?"
  3. Trend Analysis: "Is our graph density increasing? Are we creating too many dependencies?"
  4. Release Notes: "Generate a diff of all changes between v1.0 and v2.0"

๐Ÿณ Recipe System: Declarative View Configuration

Instead of memorizing CLI flags or repeatedly setting filters, bv supports Recipesโ€”YAML-based view configurations that can be saved, shared, and version-controlled.

Recipe Structure

# .beads/recipes/sprint-review.yaml
name: sprint-review
description: "Issues touched in the current sprint"

filters:
  status: [open, in_progress, closed]
  updated_after: "14d"              # Relative time: 14 days ago
  exclude_tags: [backlog, icebox]

sort:
  field: updated
  direction: desc
  secondary:
    field: priority
    direction: asc

view:
  columns: [id, title, status, priority, updated]
  show_metrics: true
  max_items: 50

export:
  format: markdown
  include_graph: true

Filter Capabilities

FilterTypeExamples
statusArray[open, closed, blocked, in_progress]
priorityArray[0, 1] (P0 and P1 only)
tagsArray[frontend, urgent]
exclude_tagsArray[wontfix, duplicate]
created_afterRelative/ISO"7d", "2w", "2024-01-01"
updated_beforeRelative/ISO"30d", "1m"
actionableBooleantrue = no open blockers
has_blockersBooleantrue = waiting on dependencies
id_prefixString"bv-" for project filtering
title_containsStringSubstring search

Built-in Recipes

bv ships with 11 pre-configured recipes:

RecipePurpose
defaultAll open issues sorted by priority
actionableReady to work (no blockers)
recentUpdated in last 7 days
blockedWaiting on dependencies
high-impactTop PageRank scores
staleOpen but untouched for 30+ days
triageSorted by computed triage score (impact + unblocking potential)
closedRecently closed issues
release-cutClosed in last 14 days (for changelog generation)
quick-winsEasy P2/P3 items with no blockers
bottlenecksHigh betweenness nodes (project bottlenecks)

Using Recipes

# Interactive picker (press 'R' in TUI)
bv

# Direct recipe invocation
bv --recipe actionable
bv --recipe high-impact

# Custom recipe file
bv --recipe .beads/recipes/sprint-review.yaml

๐ŸŽฏ Composite Impact Scoring

Traditional issue trackers sort by a single dimensionโ€”usually priority. bv computes a multi-factor Impact Score that blends graph-theoretic metrics with temporal and priority signals.

The Scoring Formula

Impact=0.30โ‹…PageRank+0.30โ‹…Betweenness+0.20โ‹…BlockerRatio+0.10โ‹…Staleness+0.10โ‹…PriorityBoost\text{Impact} = 0.30 \cdot \text{PageRank} + 0.30 \cdot \text{Betweenness} + 0.20 \cdot \text{BlockerRatio} + 0.10 \cdot \text{Staleness} + 0.10 \cdot \text{PriorityBoost}

Component Breakdown

ComponentWeightWhat It Measures
PageRank30%Recursive dependency importance
Betweenness30%Bottleneck/bridge position
BlockerRatio20%Direct dependents (In-Degree)
Staleness10%Days since last update (aging)
PriorityBoost10%Human-assigned priority

Why These Weights?

  • 60% Graph Metrics: The structure of dependencies is the primary driver of true importance.
  • 20% Blocker Ratio: Direct dependents matter for immediate unblocking.
  • 10% Staleness: Old issues deserve attention; they may be forgotten blockers.
  • 10% Priority: Human judgment is valuable but can be outdated or politically biased.

Score Output

{
  "issue_id": "CORE-123",
  "title": "Refactor auth module",
  "score": 0.847,
  "breakdown": {
    "pagerank": 0.27,
    "betweenness": 0.25,
    "blocker_ratio": 0.18,
    "staleness": 0.07,
    "priority_boost": 0.08
  }
}

Priority Recommendations

bv generates actionable recommendations when the computed impact score diverges significantly from the human-assigned priority:

โš ๏ธ CORE-123 has Impact Score 0.85 but Priority P3. Reason: High PageRank (foundational dependency) + High Betweenness (bottleneck) Recommendation: Consider escalating to P1.

Priority Hints Overlay

Press p in the list view to toggle Priority Hintsโ€”inline visual indicators showing which issues have misaligned priorities:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  OPEN     CORE-123 โฌ† Database schema migration       P3  ๐ŸŸข โ”‚
โ”‚  OPEN     UI-456     Login page styling              P2  ๐ŸŸข โ”‚
โ”‚  BLOCKED  API-789  โฌ‡ Legacy endpoint wrapper         P1  ๐Ÿ”ด โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
        โฌ† = Impact suggests higher priority (red arrow)
        โฌ‡ = Impact suggests lower priority (teal arrow)

This provides at-a-glance feedback on whether your priority assignments match the computed graph importance.


๐Ÿ›ค๏ธ Parallel Execution Planning

When you ask "What should I work on next?", bv doesn't just pick the highest-priority item. It generates a complete execution plan that respects dependencies and identifies opportunities for parallel work.

Track-Based Planning

The planner uses Union-Find to identify connected components in the dependency graph, grouping related issues into independent "tracks" that can be worked on concurrently.

graph TD
    %%{init: {'theme': 'base', 'themeVariables': { 'primaryColor': '#e8f5e9', 'lineColor': '#90a4ae'}}}%%

    subgraph track_a ["๐Ÿ…ฐ๏ธ Track A: Auth System"]
        A1["AUTH-001<br/>P1 ยท Unblocks 3"]:::actionable
        A2["AUTH-002"]:::blocked
        A3["AUTH-003"]:::blocked
    end

    subgraph track_b ["๐Ÿ…ฑ๏ธ Track B: UI Polish"]
        B1["UI-101<br/>P2 ยท Unblocks 1"]:::actionable
        B2["UI-102"]:::blocked
    end

    subgraph track_c ["๐Ÿ…ฒ Track C: Independent"]
        C1["DOCS-001<br/>P3 ยท Unblocks 0"]:::actionable
    end

    A1 --> A2
    A2 --> A3
    B1 --> B2

    classDef actionable fill:#c8e6c9,stroke:#81c784,stroke-width:2px,color:#2e7d32
    classDef blocked fill:#ffcdd2,stroke:#e57373,stroke-width:2px,color:#c62828

    linkStyle 0,1,2 stroke:#81c784,stroke-width:2px

Plan Output (--robot-plan)

{
  "tracks": [
    {
      "track_id": "track-A",
      "reason": "Independent work stream",
      "items": [
        { "id": "AUTH-001", "priority": 1, "unblocks": ["AUTH-002", "AUTH-003", "API-005"] }
      ]
    },
    {
      "track_id": "track-B",
      "reason": "Independent work stream",
      "items": [
        { "id": "UI-101", "priority": 2, "unblocks": ["UI-102"] }
      ]
    }
  ],
  "total_actionable": 3,
  "total_blocked": 5,
  "summary": {
    "highest_impact": "AUTH-001",
    "impact_reason": "Unblocks 3 tasks",
    "unblocks_count": 3
  }
}

The Algorithm

  1. Identify Actionable Issues: Filter to non-closed issues with no open blockers.
  2. Compute Unblocks: For each actionable issue, calculate what becomes unblocked if it's completed.
  3. Find Connected Components: Use Union-Find to group issues by their dependency relationships.
  4. Build Tracks: Create parallel tracks from each component, sorted by priority within each track.
  5. Compute Summary: Identify the single highest-impact issue (most downstream unblocks).

Benefits for AI Agents

  • Deterministic: Same input always produces same plan (no LLM hallucination).
  • Parallelism-Aware: Multiple agents can grab different tracks without conflicts.
  • Impact-Ranked: The highest_impact field tells agents exactly where to start.

๐Ÿ”ฌ Insights Dashboard: Interactive Graph Analysis

The Insights Dashboard (i) transforms abstract graph metrics into an interactive exploration interface. Instead of just showing numbers, it lets you drill into why a bead scores high and what that means for your project.

The 6-Panel Layout

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿšง Bottlenecks     โ”‚  ๐Ÿ›๏ธ Keystones       โ”‚  ๐ŸŒ Influencers     โ”‚
โ”‚  Betweenness        โ”‚  Impact Depth       โ”‚  Eigenvector        โ”‚
โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€  โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€  โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€  โ”‚
โ”‚  โ–ธ 0.45 AUTH-001    โ”‚    12.0 CORE-123    โ”‚    0.82 API-007     โ”‚
โ”‚    0.38 API-005     โ”‚    10.0 DB-001      โ”‚    0.71 AUTH-001    โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿ›ฐ๏ธ Hubs            โ”‚  ๐Ÿ“š Authorities     โ”‚  ๐Ÿ”„ Cycles          โ”‚
โ”‚  HITS Hub Score     โ”‚  HITS Auth Score    โ”‚  Circular Deps      โ”‚
โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€  โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€  โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€  โ”‚
โ”‚    0.67 EPIC-100    โ”‚    0.91 UTIL-050    โ”‚  โš  A โ†’ B โ†’ C โ†’ A    โ”‚
โ”‚    0.54 FEAT-200    โ”‚    0.78 LIB-010     โ”‚  โš  X โ†’ Y โ†’ X        โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Panel Descriptions

PanelMetricWhat It ShowsActionable Insight
๐Ÿšง BottlenecksBetweennessBeads on many shortest pathsPrioritize to unblock parallel work
๐Ÿ›๏ธ KeystonesImpact DepthDeep in dependency chainsComplete firstโ€”delays cascade
๐ŸŒ InfluencersEigenvectorConnected to important beadsReview carefully before changes
๐Ÿ›ฐ๏ธ HubsHITS HubAggregate many dependenciesTrack for milestone completion
๐Ÿ“š AuthoritiesHITS AuthorityDepended on by many hubsStabilize earlyโ€”breaking ripples
๐Ÿ”„ CyclesTarjan SCCCircular dependency loopsMust resolveโ€”logical impossibility

The Detail Panel: Calculation Proofs

When you select a bead, the right-side Detail Panel shows not just the score, but the proofโ€”the actual beads and values that contributed:

โ”€โ”€โ”€ CALCULATION PROOF โ”€โ”€โ”€
BW(v) = ฮฃ (ฯƒst(v) / ฯƒst) for all sโ‰ vโ‰ t

Betweenness Score: 0.452

Beads depending on this (5):
  โ†“ UI-Login: Implement login form
  โ†“ UI-Dashboard: User dashboard
  โ†“ API-Auth: Authentication endpoint
  ... +2 more

This depends on (2):
  โ†‘ DB-Schema: User table migration
  โ†‘ CORE-Config: Environment setup

This bead lies on many shortest paths between
other beads, making it a critical junction.

Dashboard Navigation

KeyAction
Tab / Shift+TabMove between panels
j / kNavigate within panel
EnterFocus selected bead in main view
eToggle explanations
iExit dashboard

๐Ÿ“‹ Kanban Board: Visual Workflow State

The Kanban Board (b) provides a columnar workflow view with intelligent swimlane grouping, visual dependency indicators, and rich card details. Empty columns automatically collapse to maximize screen real estate.

Swimlane Grouping Modes

Press s to cycle through three grouping modes:

ModeColumnsUse Case
Status (default)Open | In Progress | Blocked | ClosedWorkflow state tracking
PriorityP0 Critical | P1 High | P2 Medium | P3+ OtherUrgency-based triage
TypeBug | Feature | Task | EpicWork categorization

The current mode is shown in the status bar. Each mode uses distinct column colors for quick visual identification.

Visual Dependency Indicators

Card borders are color-coded to show dependency status at a glance:

โ”Œโ”€ ๐Ÿ”ด RED โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”    โ”Œโ”€ ๐ŸŸก YELLOW โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚ BLOCKED                    โ”‚    โ”‚ HIGH-IMPACT                  โ”‚
โ”‚ This card has unresolved   โ”‚    โ”‚ This card blocks others.     โ”‚
โ”‚ dependencies. Work on      โ”‚    โ”‚ Completing it will unblock   โ”‚
โ”‚ blockers first.            โ”‚    โ”‚ downstream work.             โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜    โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

โ”Œโ”€ ๐ŸŸข GREEN โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”    โ”Œโ”€ โฌœ DEFAULT โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚ READY TO WORK              โ”‚    โ”‚ NORMAL                       โ”‚
โ”‚ Open issue with no         โ”‚    โ”‚ Standard priority, no        โ”‚
โ”‚ blockers. Pick this up!    โ”‚    โ”‚ blocking relationships.      โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜    โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Search matches overlay with purple (current match) or blue (other matches) borders.

Rich 4-Line Card Format

Each card displays comprehensive metadata in a compact format:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚ ๐Ÿ› P1 BUG-1234           3d       โ”‚  โ† Line 1: Type, Priority, ID, Age
โ”‚ Fix authentication timeout         โ”‚  โ† Line 2: Title (truncated)
โ”‚ ๐Ÿ‘คalice  โ›”3  โ†’2  ๐Ÿท๏ธ2             โ”‚  โ† Line 3: Assignee, Blockers, Blocks, Labels
โ”‚ auth, backend, critical            โ”‚  โ† Line 4: Label names
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
ElementMeaning
Type Icon๐Ÿ› Bug, โœจ Feature, ๐Ÿ“ Task, ๐ŸŽฏ Epic, ๐Ÿ”ง Chore
PriorityP0 (red), P1 (red), P2 (muted), P3+ (gray)
Age Color๐ŸŸข <7d (fresh), ๐ŸŸก 7-30d (aging), ๐Ÿ”ด >30d (stale)
โ›”NBlocked by N issues
โ†’NBlocks N downstream issues
๐Ÿท๏ธNHas N labels

Column Statistics

Each column header shows aggregate statistics:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  IN PROGRESS (5)  ๐Ÿ”ฅ2 โš ๏ธ1          โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
         โ”‚          โ”‚   โ”‚
         โ”‚          โ”‚   โ””โ”€โ”€ โš ๏ธ Blocked items in this column
         โ”‚          โ””โ”€โ”€โ”€โ”€โ”€โ”€ ๐Ÿ”ฅ P0/P1 critical items
         โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€ Total count

Inline Card Expansion

Press d to expand the selected card inline, showing:

  • Full issue description
  • All blocking dependencies (with titles)
  • All downstream dependents
  • Complete label list
  • Comments preview

Navigation (j/k) auto-collapses expanded cards for smooth browsing.

Detail Panel

Press Tab to open a side panel with the full issue detail view (on wide terminals). Scroll with Ctrl+J/Ctrl+K.

Board Navigation

KeyAction
Movement
h / lMove between columns
j / kMove within column
gg / GJump to top/bottom of column
0 / $First/last item in column
H / LJump to first/last column
1-4Jump directly to column 1-4
Ctrl+D / Ctrl+UPage down/up
Grouping & Display
sCycle swimlane mode (Status โ†’ Priority โ†’ Type)
eToggle empty column visibility
dExpand/collapse inline card detail
TabToggle side detail panel
Search
/Start search
n / NNext/previous search match
EscCancel search
Filtering
oFilter: Open only
cFilter: Closed only
rFilter: Ready (no blockers)
Actions
yCopy issue ID to clipboard
VPreview related cass sessions (if cass installed)
EnterFocus selected bead in detail view
bExit board view

๐Ÿ”„ List Sorting: Multi-Dimensional Organization

Press s to cycle through five distinct sort modes, giving you instant control over how issues are organized. The current sort mode is displayed in the status bar.

Sort Modes

ModeKey DisplayOrdering LogicUse Case
DefaultDefaultPriority (asc) โ†’ Created (desc)Standard priority-driven workflow
Created โ†‘Created โ†‘Creation date ascending (oldest first)Audit: find long-standing issues
Created โ†“Created โ†“Creation date descending (newest first)Review: see recently created work
PriorityPriorityPriority only (P0 โ†’ P4)Pure priority triage
UpdatedUpdatedLast update descending (newest first)Activity tracking: see active issues

Design Philosophy

The sort system uses a stable secondary sort to ensure deterministic ordering. When primary sort values are equal, issues fall back to ID ordering for consistency across sessions. This prevents the "shuffling list" problem where equal-priority items randomly reorder.

Status Bar Indicator

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿ“‹ ISSUES                                    [Created โ†“]  โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚  OPEN   FEAT-789  Add dark mode toggle           P2  ๐ŸŸข   โ”‚
โ”‚  OPEN   BUG-456   Fix login race condition       P1  ๐ŸŸข   โ”‚
โ”‚  OPEN   TASK-123  Update documentation           P3  ๐ŸŸข   โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

The [Created โ†“] badge instantly communicates the active sort mode without requiring you to remember which mode you're in.


๐ŸŒฒ Hierarchical Tree View: Parent-Child Visualization

Press E to open the Hierarchical Tree Viewโ€”a collapsible tree that visualizes parent-child relationships between issues. Unlike the Graph View which shows all dependency types, the Tree View focuses exclusively on structural hierarchy: which issues are "part of" other issues.

Why Parent-Child Matters

In complex projects, issues often have two distinct relationship types:

  • Blocking dependencies (blocks/blocked_by): Task B cannot start until Task A completes
  • Parent-child relationships (parent): Feature X contains Tasks A, B, and C as sub-work

The Tree View renders only parent-child relationships, creating a work breakdown structure (WBS) that answers questions like:

  • "What sub-tasks make up this epic?"
  • "Which feature does this bug belong to?"
  • "How is work decomposed across the project?"

Tree Layout

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐ŸŒฒ TREE VIEW                                           3 roots ยท 12 nodes  โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚                                                                             โ”‚
โ”‚  โ–พ ๐ŸŽฏ P1 EPIC-100   Auth System Overhaul                        โ— open     โ”‚
โ”‚  โ”‚ โ”œโ”€ โ–ธ โœจ P1 FEAT-101   Implement OAuth2 flow                  โ— open     โ”‚
โ”‚  โ”‚ โ”‚   โ””โ”€ โ€ข ๐Ÿ“ P2 TASK-102   Add token refresh logic            โ—‹ closed   โ”‚
โ”‚  โ”‚ โ””โ”€ โ€ข ๐Ÿ› P0 BUG-103   Fix session timeout race               โš  blocked  โ”‚
โ”‚  โ”‚                                                                          โ”‚
โ”‚  โ–พ ๐ŸŽฏ P2 EPIC-200   UI Polish Sprint                            โ— open     โ”‚
โ”‚  โ”‚ โ”œโ”€ โ€ข โœจ P2 FEAT-201   Dark mode support                      โ— open     โ”‚
โ”‚  โ”‚ โ””โ”€ โ€ข โœจ P3 FEAT-202   Responsive layout                      โ— open     โ”‚
โ”‚  โ”‚                                                                          โ”‚
โ”‚  โ€ข ๐Ÿ“ P3 TASK-300   Update documentation                        โ— open     โ”‚
โ”‚                                                                             โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Visual Encoding

ElementMeaning
โ–พ / โ–ธExpanded / Collapsed (has children)
โ€ขLeaf node (no children)
โ”œโ”€ / โ””โ”€Tree branch connectors
Type Icon๐ŸŽฏ Epic, โœจ Feature, ๐Ÿ› Bug, ๐Ÿ“ Task, ๐Ÿ”ง Chore
PriorityP0 (critical red), P1 (high), P2 (medium gray), P3+ (muted)
Status Dotโ— Open (green), โ— In Progress (yellow), โš  Blocked (red), โ—‹ Closed (gray)

Tree Building Algorithm

The tree construction uses a parent-child only filter with intelligent root detection:

  1. Filter Dependencies: Only DepParentChild type dependencies are considered; blocking and related dependencies are ignored
  2. Build Index: Create a parent โ†’ children mapping for efficient traversal
  3. Identify Roots: Issues with no parent (or whose parent doesn't exist in the dataset) become root nodes
  4. Recursive Build: Depth-first traversal with cycle detection prevents infinite loops
  5. Sort Children: Within each parent, children are sorted by: Priority (ascending) โ†’ Type (epic > feature > bug > task) โ†’ Creation Date (newest first)

Handling Edge Cases:

  • Orphan References: If an issue references a parent that doesn't exist, it becomes a root node (not silently dropped)
  • Cycles: Detected during traversal; cyclic nodes are rendered without recursing further
  • Deep Hierarchies: No depth limitโ€”the tree faithfully represents arbitrarily nested structures

Tree Navigation

KeyAction
Movement
j / k / โ†“ / โ†‘Move cursor down / up
g / GJump to first / last node
Ctrl+D / Ctrl+UPage down / up (half viewport)
Expand/Collapse
Enter / SpaceToggle expand/collapse on current node
l / โ†’Expand node, or move to first child if already expanded
h / โ†Collapse node, or jump to parent if already collapsed
oExpand all nodes in the tree
OCollapse all nodes in the tree
Integration
TabSync selection to detail panel (in split view)
E / EscExit tree view, return to list

Use Cases

ScenarioHow Tree View Helps
Sprint PlanningExpand epics to see all sub-work and estimate scope
Progress TrackingCollapse completed branches, focus on open work
OnboardingNew team members understand project structure at a glance
RefactoringSee which tasks fall under a feature before restructuring
Status MeetingsWalk through the hierarchy top-down for stakeholder updates

Tree vs. Graph View

AspectTree View (E)Graph View (g)
RelationshipsParent-child onlyAll dependency types
LayoutIndented hierarchyForce-directed / DAG
FocusWork breakdown structureDependency flow
NavigationVim-style (j/k/h/l)Viewport panning
Best For"What's inside this epic?""What blocks this task?"

Both views complement each other: use Tree View to understand structure, Graph View to understand flow.


๐ŸŽฏ Actionable Plan View: Parallel Execution Tracks

Press a to open the Actionable Plan Viewโ€”a structured display of work items grouped into independent execution tracks. This view transforms abstract graph analysis into a concrete "what to work on next" interface.

Why Tracks Matter

Traditional priority lists show tasks in a single ordered queue. But in complex dependency graphs, some work streams are completely independentโ€”working on one doesn't affect another. The Actionable Plan View identifies these parallel tracks using Union-Find connected component analysis, letting multiple agents or team members work concurrently without stepping on each other.

Visual Layout

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐ŸŽฏ ACTIONABLE PLAN                                      3 tracks ยท 8 items  โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚                                                                             โ”‚
โ”‚  โ”โ”โ” Track A: Auth System โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”  โ”‚
โ”‚                                                                             โ”‚
โ”‚  โ–ธ ๐ŸŽฏ P1 AUTH-001   Implement OAuth2 flow                    unblocks 3    โ”‚
โ”‚    โœจ P2 AUTH-002   Add token refresh                        unblocks 1    โ”‚
โ”‚                                                                             โ”‚
โ”‚  โ”โ”โ” Track B: UI Polish โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”  โ”‚
โ”‚                                                                             โ”‚
โ”‚    ๐Ÿ“ P2 UI-101     Dark mode toggle                         unblocks 2    โ”‚
โ”‚    ๐Ÿ“ P3 UI-102     Responsive layout                        unblocks 0    โ”‚
โ”‚                                                                             โ”‚
โ”‚  โ”โ”โ” Track C: Independent โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”  โ”‚
โ”‚                                                                             โ”‚
โ”‚    ๐Ÿ“ P3 DOCS-001   Update API documentation                 unblocks 0    โ”‚
โ”‚                                                                             โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚  Highest Impact: AUTH-001 (unblocks 3)                                      โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

What Makes an Item "Actionable"

An issue appears in the Actionable Plan when:

  1. Status is open or in_progress (not closed)
  2. No open blockers exist (all blocking dependencies are closed)

This ensures every item in the view can be started immediately without waiting on anything else.

Unblock Analysis

Each item shows an unblocks countโ€”the number of other issues that would become actionable if this item were completed. High unblock counts indicate force multipliers: completing them unlocks a cascade of downstream work.

The Highest Impact summary at the bottom identifies the single item that, when completed, unblocks the most additional work. This is your optimal "next thing to pick up."

KeyAction
j / kMove between items (across tracks)
EnterFocus selected item in detail view
a / EscExit actionable view

Use Cases

ScenarioHow Actionable View Helps
Solo DevelopmentAlways know the highest-impact next task
Team StandupEach person claims a different track
AI Agent DispatchAgents grab highest_impact deterministically
Sprint PlanningEstimate work by counting actionable items per track

๐Ÿ”€ Flow Matrix View: Cross-Label Dependency Analysis

Press f to open the Flow Matrix Viewโ€”an interactive dashboard visualizing how labels (domains/teams) depend on each other. This reveals cross-team bottlenecks that aren't visible in single-issue views.

Why Cross-Label Flow Matters

In large projects, work is often organized by labels: frontend, backend, api, auth, infra. Dependencies between issues create implicit dependencies between labels. The Flow Matrix exposes these patterns:

  • Which team is blocking others the most?
  • Which domain is waiting on the most external work?
  • Where are the cross-team coordination bottlenecks?

Visual Layout

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿ”€ FLOW MATRIX                                             5 labels ยท 23 deps โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚  LABELS                                   โ”‚  DETAIL                          โ”‚
โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€    โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€   โ”‚
โ”‚                                           โ”‚                                  โ”‚
โ”‚  โ–ธ ๐Ÿ”ด api      โ”โ”โ”โ”โ”โ”โ”โ”โ”โ” 0.72           โ”‚  Label: api                      โ”‚
โ”‚       outgoing: 8 โ†’ [auth, db, infra]    โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€          โ”‚
โ”‚       incoming: 3 โ† [frontend, mobile]   โ”‚                                  โ”‚
โ”‚                                           โ”‚  Bottleneck Score: 0.72         โ”‚
โ”‚    ๐ŸŸก auth     โ”โ”โ”โ”โ”โ”โ”โ”   0.58           โ”‚  (top 20% = critical)            โ”‚
โ”‚       outgoing: 4 โ†’ [db]                 โ”‚                                  โ”‚
โ”‚       incoming: 5 โ† [api, frontend]      โ”‚  Outgoing Dependencies:          โ”‚
โ”‚                                           โ”‚    โ†’ auth (3 issues)             โ”‚
โ”‚    ๐ŸŸข frontend โ”โ”โ”โ”โ”     0.31            โ”‚    โ†’ db (4 issues)               โ”‚
โ”‚       outgoing: 2 โ†’ [api]                โ”‚    โ†’ infra (1 issue)             โ”‚
โ”‚       incoming: 0                        โ”‚                                  โ”‚
โ”‚                                           โ”‚  Incoming Dependencies:          โ”‚
โ”‚    ๐ŸŸข db       โ”โ”โ”       0.22            โ”‚    โ† frontend (2 issues)         โ”‚
โ”‚       outgoing: 0                        โ”‚    โ† mobile (1 issue)            โ”‚
โ”‚       incoming: 7 โ† [api, auth]          โ”‚                                  โ”‚
โ”‚                                           โ”‚  Critical Path: YES              โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Bottleneck Score

The bottleneck score (0.0โ€“1.0) measures how much a label blocks cross-domain work:

Bottleneck=Outgoingย DepsTotalย Cross-Labelย Depsร—Criticalityย Weight\text{Bottleneck} = \frac{\text{Outgoing Deps}}{\text{Total Cross-Label Deps}} \times \text{Criticality Weight}
ScoreColorMeaning
0.7 โ€“ 1.0๐Ÿ”ด RedCritical bottleneckโ€”prioritize unblocking
0.4 โ€“ 0.7๐ŸŸก YellowModerate blockingโ€”monitor closely
0.0 โ€“ 0.4๐ŸŸข GreenHealthy flowโ€”no coordination issues

Drilldown Mode

Press Enter on a label to drill down into the specific issues creating cross-label dependencies:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿ”€ FLOW MATRIX > api โ†’ auth                                    3 issues    โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚                                                                             โ”‚
โ”‚    ๐Ÿ› P1 API-123   Auth endpoint returns 500         blocks AUTH-456       โ”‚
โ”‚    โœจ P2 API-456   Add OAuth scope validation        blocks AUTH-789       โ”‚
โ”‚    ๐Ÿ“ P2 API-789   Token refresh rate limiting       blocks AUTH-101       โ”‚
โ”‚                                                                             โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
KeyAction
j / kMove between labels
TabToggle focus between labels list and detail panel
EnterDrill down into cross-label issues
EscExit drilldown / Exit view
f / qExit flow matrix view

Robot Command

bv --robot-label-flow | jq '.flow.bottleneck_labels'

๐ŸŽช Attention View: Label Priority Ranking

Press ] to open the Attention Viewโ€”a ranked table of labels by attention score, helping you identify which project areas need focus.

Attention Score Formula

The attention score combines multiple signals to surface neglected or problematic areas:

Attention=PageRankavgร—Stalenessร—BlockImpactVelocity+ฯต\text{Attention} = \frac{\text{PageRank}_{\text{avg}} \times \text{Staleness} \times \text{BlockImpact}}{\text{Velocity} + \epsilon}
ComponentWhat It Measures
PageRank (avg)Average importance of issues in this label
StalenessHow long since issues were updated (higher = more stale)
Block ImpactHow many issues are blocked within this label
VelocityCompletion rate (issues closed per week)

High attention scores indicate labels that are both important and neglectedโ€”they need intervention.

Visual Layout

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐ŸŽช ATTENTION VIEW                                                          โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚ Rank โ”‚ Label      โ”‚ Attention โ”‚ Reason                                      โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚  1   โ”‚ api        โ”‚    2.45   โ”‚ blocked=5 stale=3 vel=0.8                   โ”‚
โ”‚  2   โ”‚ auth       โ”‚    1.89   โ”‚ blocked=2 stale=4 vel=1.2                   โ”‚
โ”‚  3   โ”‚ infra      โ”‚    1.23   โ”‚ blocked=1 stale=6 vel=0.5                   โ”‚
โ”‚  4   โ”‚ frontend   โ”‚    0.67   โ”‚ blocked=0 stale=1 vel=3.5                   โ”‚
โ”‚  5   โ”‚ docs       โ”‚    0.34   โ”‚ blocked=0 stale=2 vel=2.1                   โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Interpreting Results

  • High Attention + Low Velocity: Area is stuckโ€”investigate blockers
  • High Attention + High Stale: Work forgottenโ€”resurface and reprioritize
  • Low Attention + High Velocity: Healthy areaโ€”keep momentum
  • High Blocked Count: Dependencies creating bottleneck
KeyAction
j / kMove between labels
] / EscExit attention view

Robot Command

bv --robot-label-attention --attention-limit=10

๐Ÿ“š Shortcuts Sidebar: Persistent Keyboard Reference

Press ; (semicolon) or F2 to toggle the Shortcuts Sidebarโ€”a persistent panel showing context-aware keyboard shortcuts alongside your current view.

Why a Sidebar (Not Just Help)?

The ? help overlay shows shortcuts but blocks your view. The shortcuts sidebar stays visible while you work, perfect for:

  • Learning keyboard shortcuts without interrupting your flow
  • Quick reference during complex navigation
  • Teaching new users while pair programming

Context Awareness

The sidebar automatically filters shortcuts to show only those relevant to your current view:

ContextShown Sections
List ViewNavigation, Filters, Views, Actions
Board ViewNavigation, Board-specific, Swimlanes
Graph ViewNavigation, Panning, Zoom
InsightsNavigation, Panels, Toggles
HistoryNavigation, View Modes, Timeline

Visual Layout

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚                                              โ”‚  โŒจ๏ธ SHORTCUTS         โ”‚
โ”‚                                              โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€  โ”‚
โ”‚               Main Content Area              โ”‚                      โ”‚
โ”‚                                              โ”‚  Navigation          โ”‚
โ”‚           (List, Board, Graph, etc.)         โ”‚  j/k    Move โ†“/โ†‘     โ”‚
โ”‚                                              โ”‚  G/gg   End/Start    โ”‚
โ”‚                                              โ”‚  ^d/^u  Page โ†“/โ†‘     โ”‚
โ”‚                                              โ”‚                      โ”‚
โ”‚                                              โ”‚  Views               โ”‚
โ”‚                                              โ”‚  b      Board        โ”‚
โ”‚                                              โ”‚  g      Graph        โ”‚
โ”‚                                              โ”‚  i      Insights     โ”‚
โ”‚                                              โ”‚                      โ”‚
โ”‚                                              โ”‚  ; to hide           โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
KeyAction
; or F2Toggle sidebar visibility
Ctrl+JScroll sidebar down (when visible)
Ctrl+KScroll sidebar up (when visible)

The sidebar occupies a fixed 34-character width on the right edge of the terminal.


๐ŸŽ“ Interactive Tutorial System

Press ` (backtick) to open the Interactive Tutorialโ€”a comprehensive multi-page walkthrough that teaches all bv features through rich, styled content.

Tutorial Architecture

The tutorial uses a component-based rendering system that produces beautiful terminal output:

ComponentPurposeExample
SectionStyled headers with underlines## Navigation
ParagraphFlowing text with proper wrappingExplanation text
KeyTableAligned key-description pairsj/k โ†’ Move up/down
TipHighlighted advice boxes๐Ÿ’ก TIP: Press g to jump...
WarningAlert boxes for important notesโš ๏ธ WARN: This action...
CodeSyntax-highlighted code blocksbv --robot-triage
BulletStyled bullet listsโ€ข First item
TreeHierarchical structure displayDirectory trees
StatusFlowVisual workflow diagramsOpen โ†’ In Progress โ†’ Closed
InfoBoxBordered information panelsFeature highlights

Tutorial Sections

The tutorial covers these topics in depth:

  1. Introduction โ€” What bv is and why it exists
  2. Core Concepts โ€” Beads, dependencies, labels, priorities
  3. List View โ€” Navigation, filtering, sorting
  4. Board View โ€” Kanban workflows, swimlanes
  5. Graph View โ€” Dependency visualization
  6. Tree View โ€” Parent-child hierarchies
  7. Insights Dashboard โ€” Graph metrics deep dive
  8. History View โ€” Git correlation
  9. Robot Protocol โ€” AI agent integration
  10. Workflows โ€” Triage, planning, sprint management

Progress Tracking

The tutorial automatically tracks which pages you've viewed:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿ“– TUTORIAL                                           Page 3/10 ยท 30% โ–ˆโ–ˆโ–ˆโ–ˆโ–‘โ–‘โ–‘โ–‘โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚                                                                             โ”‚
โ”‚  ## List View Navigation                                                    โ”‚
โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€                                                  โ”‚
โ”‚                                                                             โ”‚
โ”‚  The list view is your home base. Navigate with vim-style keys:             โ”‚
โ”‚                                                                             โ”‚
โ”‚    j / k       Move down / up                                               โ”‚
โ”‚    g / G       Jump to top / bottom                                         โ”‚
โ”‚    Ctrl+D/U    Page down / up                                               โ”‚
โ”‚                                                                             โ”‚
โ”‚  โ•ญโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฎ   โ”‚
โ”‚  โ”‚ ๐Ÿ’ก TIP  Press `/` to search, then type any part of an issue title   โ”‚   โ”‚
โ”‚  โ•ฐโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฏ   โ”‚
โ”‚                                                                             โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚  โ† h previous โ”‚ l next โ†’ โ”‚ t TOC โ”‚ q close                                  โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Progress persists across sessions, so you can close bv and resume where you left off.

Tutorial Navigation

KeyAction
h / l or โ† / โ†’Previous / Next page
j / kScroll content up / down
tToggle Table of Contents
g / GFirst / Last page
q / EscClose tutorial

Context-Sensitive Filtering

When you open the tutorial from a specific view (e.g., press ` while in Board view), the tutorial can filter to show only pages relevant to that context. This provides focused learning without overwhelming new users.

Quick Reference vs. Full Tutorial

bv provides two help levels:

FeatureKeyPurpose
Quick Reference?Compact keyboard shortcuts for current view
Full Tutorial`Multi-page walkthrough with examples
Shortcuts Sidebar;Persistent reference while working

From Quick Reference, press Space to jump directly into the full tutorial.


๐Ÿ“œ History View: Bead-to-Commit Correlation

Press h to open the History Viewโ€”an interactive timeline that correlates beads with their related git commits. This bridges the gap between "what work was planned" and "what code was actually written."

The Correlation Engine

The pkg/correlation package implements a multi-strategy correlation system that infers relationships between beads and commits using several techniques:

graph TD
    %%{init: {'theme': 'base', 'themeVariables': { 'primaryColor': '#e8f5e9', 'lineColor': '#90a4ae'}}}%%

    subgraph strategies ["๐Ÿ” Correlation Strategies"]
        E["Explicit Mentions<br/><small>Commit contains bead ID</small>"]
        T["Temporal Proximity<br/><small>Commit near bead events</small>"]
        C["Co-Commit Analysis<br/><small>Files changed together</small>"]
        P["Path Matching<br/><small>File paths match bead scope</small>"]
    end

    subgraph scorer ["๐Ÿ“Š Confidence Scorer"]
        S["Multi-Factor Scoring<br/><small>Weighted combination</small>"]
    end

    subgraph output ["๐Ÿ“ˆ Output"]
        H["BeadHistory<br/><small>Events + Commits + Milestones</small>"]
    end

    E --> S
    T --> S
    C --> S
    P --> S
    S --> H

    classDef strategy fill:#e3f2fd,stroke:#90caf9,stroke-width:2px,color:#1565c0
    classDef score fill:#fff8e1,stroke:#ffcc80,stroke-width:2px,color:#e65100
    classDef out fill:#e8f5e9,stroke:#a5d6a7,stroke-width:2px,color:#2e7d32

    class E,T,C,P strategy
    class S score
    class H out

Correlation Strategies

StrategyWeightHow It Works
Explicit MentionsHighCommit message contains bead ID (e.g., fix(auth): resolve race condition [BV-123])
Temporal ProximityMediumCommit timestamp falls within bead's active lifecycle window
Co-Commit AnalysisMediumFiles frequently modified together suggest shared purpose
Path MatchingLowFile paths match bead's label scope (e.g., pkg/auth/* for auth label)

Confidence Scoring

Each correlation receives a confidence score (0.0โ€“1.0) computed by:

Confidence=w1โ‹…Explicit+w2โ‹…Temporal+w3โ‹…CoCommit+w4โ‹…Path\text{Confidence} = w_1 \cdot \text{Explicit} + w_2 \cdot \text{Temporal} + w_3 \cdot \text{CoCommit} + w_4 \cdot \text{Path}

Default weights: Explicit=0.5, Temporal=0.25, CoCommit=0.15, Path=0.10

History View Layout

The History View uses a responsive three-pane layout that adapts to terminal width:

WidthLayout
< 100Single pane: List with inline details
100-160Two panes: List + Detail
> 160Three panes: List + Timeline + Detail

Wide Terminal (3-pane) Layout:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿ“œ HISTORY VIEW                                          [Bead Mode] [โ‰ฅ 0.5]   โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚  BEADS                โ”‚  TIMELINE         โ”‚  COMMIT DETAIL                      โ”‚
โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€    โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€    โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€          โ”‚
โ”‚ โ–ธ BV-123 (3 commits)  โ”‚    โ”ƒ              โ”‚  abc1234 - Fix auth race            โ”‚
โ”‚   ๐ŸŽฏ BV-456 (1)       โ”‚   โ”โ•‹โ” Jan 15      โ”‚  Author: alice@example.com          โ”‚
โ”‚   ๐Ÿ”— BV-789 (5)       โ”‚    โ”ƒ   โ–ชโ–ชโ–ช        โ”‚  Date:   2025-01-15 14:32           โ”‚
โ”‚   ๐Ÿ“ BV-100 (2)       โ”‚   โ”โ•‹โ” Jan 14      โ”‚  Confidence: 0.85 (explicit)        โ”‚
โ”‚                       โ”‚    โ”ƒ   โ–ช          โ”‚                                      โ”‚
โ”‚                       โ”‚   โ”โ•‹โ” Jan 13      โ”‚  Files changed:                      โ”‚
โ”‚                       โ”‚    โ”ƒ   โ–ชโ–ชโ–ชโ–ชโ–ช      โ”‚    M pkg/auth/session.go            โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Timeline Panel (t Toggle)

Press t to show/hide the Timeline Panelโ€”a visual density chart of project activity:

  • Vertical axis: Time (newest at top)
  • Horizontal bars: Activity density (commits per day)
  • Bar magnitude: โ–ช = 1-2, โ–ชโ–ช = 3-5, โ–ชโ–ชโ–ช = 6-10, โ–ชโ–ชโ–ชโ–ช = 11+
  • Highlights: Selected bead's commits are marked with โ”

Click or navigate to a date to filter the view to that time period.

Causality Markers

Each bead-commit correlation shows its detection method as a visual marker:

MarkerMeaningConfidence
๐ŸŽฏ DirectCommit message explicitly mentions bead IDHigh (0.8-1.0)
๐Ÿ”— TemporalCommit falls within bead's active lifecycleMedium (0.4-0.7)
๐Ÿ“ FileCommit touches files associated with beadLow (0.2-0.5)

View Modes

Press v to toggle between two view modes:

ModeShowsUse Case
Bead Mode (default)Beads grouped with their correlated commits"What commits relate to this task?"
Git ModeCommits chronologically with correlated beads"What tasks did this commit touch?"

File-Centric Drill-Down (f Key)

Press f to switch to File Modeโ€”a tree view of changed files grouped by directory:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿ“ FILE MODE                                              [12 files]   โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚  โ–ผ pkg/auth/                                                            โ”‚
โ”‚      session.go       42 changes   BV-123, BV-456                       โ”‚
โ”‚      token.go         18 changes   BV-123                               โ”‚
โ”‚      middleware.go    8 changes    BV-789                               โ”‚
โ”‚  โ–ผ pkg/api/                                                             โ”‚
โ”‚      handler.go       25 changes   BV-100                               โ”‚
โ”‚      routes.go        12 changes   BV-100, BV-456                       โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Navigate to a file and press Enter to see all beads and commits that touched it.

History Navigation

KeyAction
Navigation
j / kMove in primary pane (beads or commits)
J / KMove in secondary pane (commits or detail)
TabCycle focus: List โ†’ Timeline โ†’ Detail
EnterExpand/collapse or drill into selection
View Modes
vToggle Bead Mode โ†” Git Mode
fToggle File-centric drill-down
tToggle Timeline panel visibility
Filtering
cCycle confidence threshold (0.0 โ†’ 0.3 โ†’ 0.5 โ†’ 0.7)
/Search commits or beads
Actions
yCopy selected commit SHA to clipboard
oOpen commit in browser (GitHub/GitLab)
VPreview cass sessions for selected bead
EscReturn to list view

Robot Command: --robot-history

bv --robot-history                          # Full history report
bv --robot-history --bead-history BV-123    # Single bead focus
bv --robot-history --history-since '30 days ago'
bv --robot-history --min-confidence 0.7     # High-confidence only

Output Schema:

{
  "stats": {
    "total_beads": 58,
    "beads_with_commits": 42,
    "total_commits": 156,
    "avg_cycle_time_hours": 72.5,
    "method_distribution": {
      "explicit": 89,
      "temporal": 45,
      "cocommit": 22
    }
  },
  "histories": {
    "BV-123": {
      "events": [...],
      "commits": [...],
      "milestones": [...],
      "cycle_time_hours": 48.2
    }
  },
  "commit_index": {
    "abc1234": ["BV-123", "BV-456"]
  }
}

Beyond simple bead-to-commit correlation, bv provides deep analysis of how beads relate to each other through shared code changes. This helps identify hidden dependencies, find related work, and understand the true impact of changes.

Impact Network Graph

The Impact Network visualizes implicit relationships between beads based on:

graph LR
    %%{init: {'theme': 'base', 'themeVariables': { 'primaryColor': '#e3f2fd', 'lineColor': '#90a4ae'}}}%%

    subgraph connections ["๐Ÿ”— Edge Types"]
        SC["Shared Commit<br/><small>Same commit touches both beads</small>"]
        SF["Shared File<br/><small>Both beads modify same files</small>"]
        DEP["Dependency<br/><small>Explicit blocker relationship</small>"]
    end

    classDef edge fill:#fff8e1,stroke:#ffcc80,stroke-width:2px
    class SC,SF,DEP edge
Edge TypeWeightMeaning
Shared CommitHighA single commit references both beads (strong coupling)
Shared FileMediumBoth beads touched the same source file
DependencyExplicitDirect blocking relationship from issue tracker

Network Clusters

bv automatically detects clusters of tightly-connected beads using community detection:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿ”— IMPACT NETWORK                                        [3 clusters]  โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚                                                                         โ”‚
โ”‚  โ”Œโ”€โ”€โ”€ Cluster 1: Auth Module โ”€โ”€โ”€โ”     โ”Œโ”€โ”€โ”€ Cluster 2: API Layer โ”€โ”€โ”€โ”   โ”‚
โ”‚  โ”‚  BV-123 โ†โ”€โ”€โ†’ BV-456          โ”‚     โ”‚  BV-789 โ†โ”€โ”€โ†’ BV-100        โ”‚   โ”‚
โ”‚  โ”‚    โ†•           โ†•              โ”‚     โ”‚    โ†•                        โ”‚   โ”‚
โ”‚  โ”‚  BV-321 โ†โ”€โ”€โ†’ BV-654          โ”‚โ”€โ”€โ”€โ”€โ†’โ”‚  BV-111                     โ”‚   โ”‚
โ”‚  โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜     โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜   โ”‚
โ”‚                                                                         โ”‚
โ”‚  Central bead: BV-123 (highest degree)                                 โ”‚
โ”‚  Internal connectivity: 0.85 (tightly coupled)                         โ”‚
โ”‚  External edges: 1 (to API layer cluster)                              โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

File-to-Bead Lookup

Find all beads that have touched a specific file using --robot-file-beads:

bv --robot-file-beads pkg/ui/board.go

Returns beads sorted by recency with commit details:

{
  "file_path": "pkg/ui/board.go",
  "total_beads": 21,
  "open_beads": [],
  "closed_beads": [
    {
      "bead_id": "bv-v67w",
      "title": "Board: Integration & Polish",
      "status": "closed",
      "commit_shas": ["abc123"],
      "last_touch": "2025-12-18T00:19:21-05:00",
      "total_changes": 17
    }
  ]
}

Use cases:

  • Code ownership: "Who has worked on this file recently?"
  • Impact analysis: "What work items are affected by this file?"
  • Bug investigation: "What changes might have introduced this regression?"

Orphan Commit Detection

Find commits that should be linked to beads but aren't using --robot-orphans:

bv --robot-orphans

Returns candidate commits with probable bead matches:

{
  "stats": {
    "total_commits": 500,
    "correlated_count": 242,
    "orphan_count": 258,
    "orphan_ratio": 0.516
  },
  "candidates": [
    {
      "sha": "abc1234",
      "message": "feat: add auth caching",
      "suspicion_score": 100,
      "probable_beads": [
        {
          "bead_id": "bv-xyz",
          "confidence": 65,
          "reasons": ["touches file pkg/auth/cache.go", "same author worked on bead nearby"]
        }
      ]
    }
  ]
}

Use cases:

  • Hygiene: Find commits that slipped through without proper linking
  • Audit: Ensure all code changes are tracked to work items
  • Correlation improvement: Train the system by confirming/rejecting suggestions

For any bead, bv can find related work across four dimensions:

Relation TypeHow DetectedExample
File OverlapBoth beads modify same source files"BV-123 and BV-456 both touch session.go"
Commit OverlapBoth beads referenced in same commit"BV-123 and BV-456 fixed in commit abc123"
Dependency ClusterBoth in same tightly-connected subgraph"BV-123 is in the Auth cluster with BV-456"
ConcurrentActive during the same time window"BV-123 and BV-456 both worked on last week"

Each relation includes a relevance score (0-100) indicating strength.

Robot Commands

# Get the full impact network (use "all" for complete graph)
bv --robot-impact-network all

# Get subnetwork focused on specific bead (default depth=2, max=3)
bv --robot-impact-network bv-123 --network-depth 2

# Find related work for a bead
bv --robot-related bv-123

# Include closed beads in related work results
bv --robot-related bv-123 --related-include-closed

# Tune related work thresholds
bv --robot-related bv-123 --related-min-relevance 30 --related-max-results 20

# Analyze causal chain for a bead (timeline, blockers, insights)
bv --robot-causality bv-123

# Find beads that touched a file
bv --robot-file-beads pkg/auth/session.go

# Find orphan commits (unlinked to beads)
bv --robot-orphans

Causal Chain Analysis

The --robot-causality command reveals why a bead took as long as it did by reconstructing its timeline of events:

Event TypeDescription
createdBead was opened
claimedWork started (status โ†’ in_progress)
commitCode commit linked to bead
blockedBead became blocked by another bead
unblockedBlocking dependency was resolved
closedBead was completed
reopenedBead was reopened after closure

Insights provided:

  • Blocked percentage: How much time was spent waiting on dependencies
  • Critical path: The chain of events determining minimum completion time
  • Longest gap: Identifies stalled periods needing investigation
  • Recommendations: Actionable suggestions (e.g., "Consider breaking into smaller beads")

Causality Output Schema:

{
  "generated_at": "2025-01-15T14:32:00Z",
  "data_hash": "abc123...",
  "chain": {
    "bead_id": "bv-123",
    "title": "Implement auth caching",
    "status": "closed",
    "events": [
      {"id": 1, "type": "created", "timestamp": "2025-01-10T10:00:00Z"},
      {"id": 2, "type": "claimed", "timestamp": "2025-01-10T11:00:00Z", "caused_by_id": 1},
      {"id": 3, "type": "blocked", "timestamp": "2025-01-11T09:00:00Z", "blocker_id": "bv-456"},
      {"id": 4, "type": "unblocked", "timestamp": "2025-01-12T16:00:00Z"},
      {"id": 5, "type": "commit", "timestamp": "2025-01-13T10:00:00Z", "commit_sha": "abc1234"},
      {"id": 6, "type": "closed", "timestamp": "2025-01-13T17:00:00Z"}
    ],
    "edge_count": 5,
    "total_time": "79h0m0s",
    "is_complete": true
  },
  "insights": {
    "total_duration": "79h0m0s",
    "blocked_duration": "31h0m0s",
    "active_duration": "48h0m0s",
    "blocked_percentage": 39.2,
    "blocked_periods": [
      {"start_time": "2025-01-11T09:00:00Z", "end_time": "2025-01-12T16:00:00Z", "blocker_id": "bv-456"}
    ],
    "commit_count": 1,
    "critical_path_desc": "created โ†’ claimed โ†’ blocked โ†’ unblocked โ†’ commit โ†’ closed",
    "summary": "Bead took 79h total; 39% blocked by bv-456",
    "recommendations": ["Consider unblocking bv-456 earlier to reduce wait time"]
  }
}

Correlation Feedback System

Train the correlation engine by confirming or rejecting its suggestions:

# Explain why a correlation exists
bv --robot-explain-correlation abc1234:bv-xyz

# Confirm a correct correlation (boosts confidence)
bv --robot-confirm-correlation abc1234:bv-xyz

# Reject an incorrect correlation (removes it)
bv --robot-reject-correlation abc1234:bv-xyz

# View feedback statistics
bv --robot-correlation-stats

Feedback Stats Output:

{
  "total_feedback": 15,
  "confirmed": 12,
  "rejected": 3,
  "accuracy_rate": 0.80,
  "avg_confirm_conf": 0.85,
  "avg_reject_conf": 0.42
}

This feedback loop improves correlation accuracy over timeโ€”confirmed correlations strengthen pattern recognition, while rejections help eliminate false positives.

Impact Network Output Schema:

{
  "generated_at": "2025-01-15T14:32:00Z",
  "data_hash": "abc123...",
  "stats": {
    "total_nodes": 58,
    "total_edges": 142,
    "cluster_count": 5,
    "avg_degree": 4.9,
    "density": 0.086,
    "isolated_nodes": 3
  },
  "clusters": [
    {
      "cluster_id": 1,
      "bead_ids": ["BV-123", "BV-456", "BV-321"],
      "label": "Auth Module",
      "internal_connectivity": 0.85,
      "central_bead": "BV-123",
      "shared_files": ["pkg/auth/session.go", "pkg/auth/token.go"]
    }
  ],
  "edges": [
    {"from_bead": "BV-123", "to_bead": "BV-456", "edge_type": "shared_commit", "weight": 5}
  ]
}

๐Ÿค– Cass Integration: AI Session Correlation (Optional)

bv optionally integrates with cass (Claude Agent Session Store)โ€”a tool that captures and indexes coding sessions from AI assistants like Claude. When cass is installed, bv automatically enhances its correlation capabilities with session-based insights.

How It Works

graph LR
    %%{init: {'theme': 'base', 'themeVariables': { 'primaryColor': '#e8f5e9', 'lineColor': '#90a4ae'}}}%%

    CASS["๐Ÿค– cass<br/><small>Session Store</small>"]
    BV["โšก bv<br/><small>Issue Viewer</small>"]
    CORR["๐Ÿ”— Enhanced<br/>Correlation"]

    CASS --> BV
    BV --> CORR

    classDef tool fill:#e3f2fd,stroke:#90caf9,stroke-width:2px
    class CASS,BV,CORR tool

Graceful Degradation: If cass is not installed, bv works normallyโ€”no errors, broken UI, or loading states. Cass features simply become unavailable.

Detection & Status

bv automatically detects cass on startup:

StatusIndicatorMeaning
Healthy๐Ÿค– in status barcass is installed, indexed, and ready
Needs Indexโš ๏ธ in status barcass installed but needs cass index
Not Installed(none)cass not in PATHโ€”features hidden

Session Preview Modal (V Key)

Press V on any bead to open the Session Preview Modalโ€”a view of AI coding sessions that may have contributed to that issue:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿค– Related Coding Sessions for BV-123                                  โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚                                                                         โ”‚
โ”‚  โ–ธ Session 1 (claude-opus-4)                         Dec 15, 2:30 PM   โ”‚
โ”‚    "Implementing session refresh timeout handling..."                   โ”‚
โ”‚    Confidence: 0.92 (explicit mention)                                  โ”‚
โ”‚                                                                         โ”‚
โ”‚    Session 2 (claude-opus-4)                         Dec 14, 10:15 AM  โ”‚
โ”‚    "Refactoring token validation middleware..."                         โ”‚
โ”‚    Confidence: 0.67 (file overlap)                                      โ”‚
โ”‚                                                                         โ”‚
โ”‚    Session 3 (claude-opus-4)                         Dec 13, 4:45 PM   โ”‚
โ”‚    "Adding retry logic to auth service..."                              โ”‚
โ”‚    Confidence: 0.45 (temporal)                                          โ”‚
โ”‚                                                                         โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚  j/k: Navigate   y: Copy search command   Enter: View full session      โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Session Correlation Methods:

MethodWeightMeaning
Explicit0.9-1.0Session mentions bead ID directly
File Overlap0.5-0.8Session touched files associated with bead
Temporal0.3-0.6Session occurred during bead's active lifecycle
Keyword0.2-0.5Session contains keywords from bead title/description

Status Bar Indicator

When cass is healthy, the status bar shows agent activity:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿ“‹ 437 issues  โ€ข  ๐Ÿค– claude-opus-4 (active)  โ€ข  Last: 5m ago          โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
StateDisplayMeaning
Active๐Ÿค– agent-nameSession in progress within last 15 minutes
Idle๐Ÿ’คNo recent sessions

Installing Cass

# Install cass (see https://github.com/Dicklesworthstone/coding_agent_session_search for full docs)
brew install dicklesworthstone/tap/cass   # macOS
# or
cargo install cass                         # From source

# Index your coding sessions
cass index

# Verify integration
bv  # Look for ๐Ÿค– in status bar

Cass-Enhanced History View

When cass is available, the History View gains additional capabilities:

  • Session Timeline: V key shows sessions alongside commits
  • Agent Attribution: See which AI assistant contributed to changes
  • Enhanced Search: Search across both commits and sessions

๐Ÿ“… Sprint Dashboard: Burndown & Progress Tracking

Press P (uppercase) to open the Sprint Dashboardโ€”a comprehensive view of sprint progress with burndown visualization, scope change tracking, and at-risk detection.

Dashboard Layout

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿ“… Sprint: January 2025                                                โ”‚
โ”‚  โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€    โ”‚
โ”‚  Dates:     Jan 6 โ†’ Jan 20                                              โ”‚
โ”‚  Remaining: 5 days                                                      โ”‚
โ”‚                                                                         โ”‚
โ”‚  โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•    โ”‚
โ”‚                          PROGRESS                                       โ”‚
โ”‚  โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•    โ”‚
โ”‚                                                                         โ”‚
โ”‚  Total: 24 beads    Closed: 18 (75%)    Remaining: 6                    โ”‚
โ”‚  [โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–‘โ–‘โ–‘โ–‘โ–‘โ–‘] 75%                                       โ”‚
โ”‚                                                                         โ”‚
โ”‚  โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•    โ”‚
โ”‚                          BURNDOWN                                       โ”‚
โ”‚  โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•    โ”‚
โ”‚                                                                         โ”‚
โ”‚  24 โ”ค ยท                                                                 โ”‚
โ”‚  20 โ”ค  ยทยทยทยทยท                                                            โ”‚
โ”‚  16 โ”ค       ยทยทยทยทโ–ธ                                                       โ”‚
โ”‚  12 โ”ค            โ•ฒ    (ideal)                                           โ”‚
โ”‚   8 โ”ค             โ•ฒ                                                     โ”‚
โ”‚   4 โ”ค              โ•ฒ                                                    โ”‚
โ”‚   0 โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€    โ”‚
โ”‚     Jan 6          Jan 13                Jan 20                         โ”‚
โ”‚                                                                         โ”‚
โ”‚  Legend: ยท = Actual    โ•ฒ = Ideal    โ–ธ = Today                           โ”‚
โ”‚                                                                         โ”‚
โ”‚  โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•    โ”‚
โ”‚                       SCOPE CHANGES                                     โ”‚
โ”‚  โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•    โ”‚
โ”‚                                                                         โ”‚
โ”‚  Jan 8:  +2 beads added (BV-456, BV-457)                                โ”‚
โ”‚  Jan 10: -1 bead removed (BV-100 moved to backlog)                      โ”‚
โ”‚                                                                         โ”‚
โ”‚  โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•    โ”‚
โ”‚                        AT-RISK ITEMS                                    โ”‚
โ”‚  โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•    โ”‚
โ”‚                                                                         โ”‚
โ”‚  โš  BV-789 (P0 Critical) - Blocked for 3 days                           โ”‚
โ”‚  โš  BV-234 (P1 High) - No activity for 5 days                           โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Burndown Calculation

The burndown chart implements a scope-aware algorithm that tracks not just completion velocity but also scope changes:

  1. Ideal Burn Rate: Total Beads / Sprint Duration
  2. Actual Burn Rate: Closed Beads / Days Elapsed
  3. Scope Events: Added/removed beads create discontinuities in the ideal line

When beads are added mid-sprint, the burndown recalculates the ideal trajectory from that point forward, providing a realistic view of progress rather than a misleading "behind schedule" indicator.

At-Risk Detection

Items are flagged as at-risk based on multiple heuristics:

SignalThresholdReason
Blocked Duration> 2 daysDependency bottleneck
No Activity> 4 daysPotentially stuck or forgotten
High Priority BlockedP0/P1 blockedCritical path impediment
Dependencies Not ClosingBlockers still openCascading delay risk

Robot Commands

bv --robot-sprint-list                # List all sprints
bv --robot-sprint-show sprint-1       # Details for specific sprint
bv --robot-burndown current           # Burndown for active sprint
bv --robot-burndown sprint-1          # Burndown for specific sprint

Burndown Output:

{
  "sprint_id": "sprint-1",
  "total_days": 14,
  "elapsed_days": 9,
  "remaining_days": 5,
  "total_issues": 24,
  "completed_issues": 18,
  "remaining_issues": 6,
  "ideal_burn_rate": 1.71,
  "actual_burn_rate": 2.0,
  "projected_complete": "2025-01-18",
  "on_track": true,
  "scope_changes": [
    {"date": "2025-01-08", "delta": 2, "reason": "Added BV-456, BV-457"}
  ]
}

๐Ÿท๏ธ Label Analytics: Domain-Centric Health Monitoring

Press L (uppercase) to open the Label Dashboardโ€”a table view showing health metrics for each label in your project. This enables domain-driven prioritization by surfacing which areas of your codebase need attention.

Label Dashboard Layout

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿท๏ธ LABEL HEALTH                                                        โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚  Label       โ”‚ Health โ”‚ Status โ”‚ Open   โ”‚ Blockedโ”‚ Stale  โ”‚ Velocity   โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚  ๐Ÿ”ด api      โ”‚  0.32  โ”‚ CRIT   โ”‚   12   โ”‚   5    โ”‚   3    โ”‚   0.8/wk   โ”‚
โ”‚  ๐ŸŸก auth     โ”‚  0.58  โ”‚ WARN   โ”‚    8   โ”‚   2    โ”‚   1    โ”‚   2.1/wk   โ”‚
โ”‚  ๐ŸŸข ui       โ”‚  0.85  โ”‚ OK     โ”‚    4   โ”‚   0    โ”‚   0    โ”‚   4.2/wk   โ”‚
โ”‚  ๐ŸŸข docs     โ”‚  0.92  โ”‚ OK     โ”‚    2   โ”‚   0    โ”‚   0    โ”‚   1.5/wk   โ”‚
โ”‚  ๐ŸŸก infra    โ”‚  0.61  โ”‚ WARN   โ”‚    6   โ”‚   1    โ”‚   2    โ”‚   1.2/wk   โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Health Score Calculation

The label health score combines multiple factors:

Health=1โˆ’(w1โ‹…BlockedOpen+w2โ‹…StaleOpen+w3โ‹…(1โˆ’VelocityScore))\text{Health} = 1 - \left( w_1 \cdot \frac{\text{Blocked}}{\text{Open}} + w_2 \cdot \frac{\text{Stale}}{\text{Open}} + w_3 \cdot (1 - \text{VelocityScore}) \right)
ComponentWeightMeaning
Blocked Ratio0.4High blocked count indicates bottlenecks
Stale Ratio0.3Stale issues suggest neglect
Velocity Inverse0.3Low throughput indicates capacity issues

Health Levels

LevelScore RangeIndicatorAction
Critical0.0 โ€“ 0.4๐Ÿ”ดImmediate attention required
Warning0.4 โ€“ 0.7๐ŸŸกMonitor closely
Healthy0.7 โ€“ 1.0๐ŸŸขOn track

Robot Commands for Label Analysis

--robot-label-health: Per-label health metrics

bv --robot-label-health
bv --robot-label-health | jq '.results.labels[] | select(.health_level == "critical")'

--robot-label-flow: Cross-label dependency flow matrix

bv --robot-label-flow
bv --robot-label-flow | jq '.flow.bottleneck_labels'

--robot-label-attention: Attention-ranked labels for prioritization

bv --robot-label-attention --attention-limit=5

Label-Scoped Analysis

Use --label to scope any robot command to a specific label's subgraph:

bv --robot-insights --label api    # Graph metrics for api-labeled issues only
bv --robot-plan --label backend    # Execution plan for backend domain
bv --robot-priority --label auth   # Priority recommendations for auth work

This enables domain isolation: analyze and plan within a bounded context rather than the entire project graph.

Flow Matrix: Cross-Label Dependencies

The flow matrix reveals how labels depend on each other:

          โ†’ api  โ†’ auth  โ†’ ui   โ†’ docs
api         -      3       2      0
auth        1      -       0      1
ui          4      2       -      0
docs        0      0       0      -

Read as: "api has 3 issues that depend on auth issues." High values indicate coupling between domains; the bottleneck_labels field highlights labels that block the most cross-domain work.


๐ŸŒ Static Site Export: Shareable Dashboards

bv can generate self-contained static websites for sharing project status with stakeholders who don't have terminal access.

Interactive Wizard

bv --pages

Launches an interactive wizard that guides you through:

  1. Export: Generate the static bundle
  2. Preview: Local server at http://localhost:9000 (or next available port)
  3. Deploy: Push to GitHub Pages with automatic repository creation

Direct Export

bv --export-pages ./bv-pages                    # Export to directory
bv --export-pages ./bv-pages --pages-title "Sprint 42 Status"
bv --export-pages ./bv-pages --pages-exclude-closed   # Omit closed issues
bv --export-pages ./bv-pages --pages-exclude-history  # Omit git history

# Preview an existing bundle without regenerating
bv --preview-pages ./bv-pages                   # Serve at localhost:9000 (or next available port)

Optional: Hybrid Search WASM Scorer

For very large datasets, you can build an optional WASM scorer used by the static viewer.

# Build once (requires wasm-pack)
./scripts/build_hybrid_wasm.sh

# Or build during export
BV_BUILD_HYBRID_WASM=1 bv --export-pages ./bv-pages

If the wasm/ assets are missing, the viewer automatically falls back to the JS scorer.

What Gets Generated

./bv-pages/
โ”œโ”€โ”€ index.html              # Main dashboard with Alpine.js + Tailwind
โ”œโ”€โ”€ beads.sqlite3           # Full SQLite database (~2MB for 400+ issues)
โ”œโ”€โ”€ data/
โ”‚   โ”œโ”€โ”€ graph_layout.json   # Pre-computed positions + metrics (~82KB)
โ”‚   โ”œโ”€โ”€ meta.json           # Export metadata
โ”‚   โ”œโ”€โ”€ triage.json         # Triage recommendations
โ”‚   โ””โ”€โ”€ history.json        # Bead-commit correlation data
โ””โ”€โ”€ vendor/
    โ”œโ”€โ”€ d3.v7.min.js        # Visualization library
    โ”œโ”€โ”€ force-graph.min.js  # Graph rendering
    โ””โ”€โ”€ bv_graph.js         # WASM graph engine

Graph Visualization: 16x Faster Render

The export uses a hybrid architecture for instant graph loading:

ComponentSizePurpose
graph_layout.json~82KBPre-computed node positions + graph metrics
beads.sqlite3~2MBFull issue data for detail pane, search, tables

How it works:

  1. Browser loads tiny graph_layout.json first (~100ms over broadband)
  2. Graph renders instantly with pre-computed fx/fy fixed positions
  3. SQLite loads in parallel for search and detail functionality
  4. Force simulation is completely bypassedโ€”no jittering, no layout delay

Performance comparison:

MetricWithout Pre-computeWith Pre-compute
Initial load4+ seconds~250ms
Force simulation2+ seconds0ms (skipped)
Graph data914KB (redundant)82KB (compact)

Detail Pane

Click any node to open a 400px sliding detail pane:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚                              โ”‚ โ•ญโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฎ          โ”‚
โ”‚                              โ”‚ โ”‚ BV-123: Auth refactor   โ”‚          โ”‚
โ”‚       [Interactive Graph]    โ”‚ โ”‚ โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€ โ”‚          โ”‚
โ”‚                              โ”‚ โ”‚ Priority: P1 (High)     โ”‚          โ”‚
โ”‚             โฌค               โ”‚ โ”‚ Type: Feature           โ”‚          โ”‚
โ”‚            /โ”‚\               โ”‚ โ”‚ Status: In Progress     โ”‚          โ”‚
โ”‚           / โ”‚ \              โ”‚ โ”‚                         โ”‚          โ”‚
โ”‚          โฌค  โฌค  โฌค           โ”‚ โ”‚ **Description**         โ”‚          โ”‚
โ”‚                              โ”‚ โ”‚ Refactor auth module... โ”‚          โ”‚
โ”‚                              โ”‚ โ”‚                         โ”‚          โ”‚
โ”‚                              โ”‚ โ”‚ โ›” 3 blockers           โ”‚          โ”‚
โ”‚                              โ”‚ โ”‚ ๐Ÿ“ค blocks 5 issues      โ”‚          โ”‚
โ”‚                              โ”‚ โ•ฐโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฏ          โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Detail pane includes:

  • Full issue title and description (markdown rendered)
  • Priority, type, status with visual indicators
  • Blockers count ("โ›” 3 blockers")โ€”issues that must complete first
  • Blocks count ("๐Ÿ“ค blocks 5 issues")โ€”downstream work waiting on this
  • PageRank, betweenness metrics (from pre-computed data)

Features

  • Full-Text Search: SQLite FTS5 powers instant search across all issue titles and descriptions. Results appear as you typeโ€”no server required.
  • Interactive Graph: Visualize dependencies with D3.js force-graph, featuring zoom, pan, and node selection
  • Detail Pane: Click any node to see full issue details with dependency info
  • Triage View: Same recommendations as --robot-triage
  • Offline Support: Works without network after initial load
  • Mobile Responsive: Adapts to phone/tablet screens with touch-friendly interactions

Technical Notes

The static export uses a hybrid architecture combining:

  1. Pure-Go SQLite (modernc.org/sqlite):

    • No C compiler requiredโ€”works on any system without CGO
    • Cross-platform bundle generation
    • FTS5 full-text search built-in
  2. Pre-computed Graph Layout:

    • BFS hierarchical layout with depth-based X positioning
    • Node positions stored as [x, y] pairs
    • Metrics stored as compact 5-element arrays: [pagerank, betweenness, inDegree, outDegree, inCycle]
    • ~91% size reduction vs. full graph JSON
  3. WASM Graph Engine (bv_graph.js):

    • Client-side cycle detection
    • Efficient neighbor lookups
    • Path finding for blocker chains

Deployment Options

PlatformCommandNotes
GitHub Pagesbv --pages (wizard)Auto-creates gh-pages branch
Cloudflare Pagesbv --export-pages ./dist + CF dashboardConnect to git repo
Any Static Hostbv --export-pages ./distNetlify, Vercel, S3, etc.

๐Ÿšจ Alerts System: Proactive Health Monitoring

The Alerts System surfaces potential problems before they become blockers. It combines drift detection (changes from baseline) with proactive analysis (pattern-based warnings).

Alert Types

TypeTriggerSeverityExample
stale_issueNo updates in 30+ daysWarning"BV-123 hasn't been touched since Oct 15"
blocking_cascadeIssue blocks 5+ othersCritical"AUTH-001 is blocking 8 downstream tasks"
priority_mismatchLow priority but high PageRankWarning"BV-456 has P3 but ranks #2 in PageRank"
cycle_introducedNew circular dependencyCritical"Cycle detected: A โ†’ B โ†’ C โ†’ A"
scope_creep20%+ increase in open issuesInfo"Open issues grew from 45 to 58 this week"

TUI Integration

Press ! to open the Alerts Panel:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿšจ ALERTS (3 active)                               [!] close โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚  โš ๏ธ  WARNING: bv-123 stale for 45 days                       โ”‚
โ”‚  ๐Ÿ”ด CRITICAL: bv-456 blocks 8 tasks (cascade risk)           โ”‚
โ”‚  โ„น๏ธ  INFO: Open issues increased 23% this sprint             โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚  j/k navigate โ€ข Enter jump to issue โ€ข d dismiss โ€ข q close   โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Robot Integration

# Get all alerts as JSON
bv --robot-alerts

# Filter by severity (info, warning, critical)
bv --robot-alerts --severity=critical

# Filter by type
bv --robot-alerts --alert-type=blocking_cascade

# Filter by affected label
bv --robot-alerts --alert-label=backend

Output Schema

{
  "alerts": [
    {
      "type": "blocking_cascade",
      "severity": "critical",
      "issue_id": "bv-456",
      "message": "Blocks 8 downstream tasks",
      "blocked_ids": ["bv-101", "bv-102", "..."],
      "suggested_action": "Prioritize completion or break into smaller tasks"
    }
  ],
  "summary": {
    "total": 3,
    "critical": 1,
    "warning": 1,
    "info": 1
  }
}

๐Ÿค– Complete CLI Reference

Beyond the interactive TUI, bv provides a comprehensive command-line interface for scripting, automation, and AI agent integration.

Core Commands

bv                      # Launch interactive TUI
bv --help               # Show all options
bv --version            # Show version

Robot Protocol Commands

These commands output structured JSON designed for programmatic consumption:

CommandOutputUse Case
--robot-triageTHE MEGA-COMMAND: unified triage with all analysisSingle entry point for agents
--robot-nextSingle top recommendation + claim commandQuick "what's next?" answer
--robot-insightsGraph metrics + top N listsProject health assessment
--robot-planActionable tracks + dependenciesWork queue generation
--robot-priorityPriority recommendationsAutomated priority fixing
--robot-historyBead-to-commit correlationsCode change tracking
--robot-label-healthPer-label health metricsDomain health monitoring
--robot-label-flowCross-label dependency matrixInter-domain analysis
--robot-label-attentionAttention-ranked labelsDomain prioritization
--robot-sprint-listAll sprints as JSONSprint planning
--robot-burndownSprint burndown dataProgress tracking
--robot-suggestHygiene suggestions (deps/dupes/labels/cycles)Project cleanup automation
--robot-diffJSON diff (with --diff-since)Change tracking
--robot-recipesAvailable recipe listRecipe discovery
--robot-graphDependency graph as JSON/DOT/MermaidGraph visualization & export
--robot-forecastETA predictions per issueCompletion timeline estimates
--robot-capacityTeam capacity simulationResource planning
--robot-alertsDrift + proactive warningsHealth monitoring
--robot-helpDetailed AI agent documentationAgent onboarding

All robot commands support --as-of <ref> for historical analysis. Output includes as_of and as_of_commit metadata fields when specified.

Time-Travel Commands

The --as-of flag lets you view project state at any historical point without modifying your working tree. It works with both the interactive TUI and all robot commands.

# View historical state (TUI)
bv --as-of HEAD~10              # 10 commits ago
bv --as-of v1.0.0               # At release tag
bv --as-of 2024-01-15           # At specific date
bv --as-of main@{2024-01-15}    # Branch at date

# Historical analysis with robot commands
bv --robot-insights --as-of HEAD~30    # Graph metrics from 30 commits ago
bv --robot-plan --as-of v1.0.0         # Execution plan at release
bv --robot-triage --as-of 2024-06-01   # Full triage from specific date
bv --robot-priority --as-of HEAD~5     # Priority recs from 5 commits ago

# Compare changes
bv --diff-since HEAD~5          # Changes in last 5 commits
bv --diff-since v1.0.0          # Changes since release
bv --diff-since 2024-01-01      # Changes since date

# JSON diff output (combines --as-of for "to" snapshot)
bv --diff-since HEAD~10 --robot-diff                # From HEAD~10 to current
bv --diff-since HEAD~10 --as-of HEAD~5 --robot-diff # From HEAD~10 to HEAD~5

When using --as-of with robot commands, the JSON output includes additional metadata:

  • as_of: The ref you specified (e.g., "HEAD~30", "v1.0.0")
  • as_of_commit: The resolved commit SHA for reproducibility

Recipe Commands

# List available recipes
bv --robot-recipes

# Apply built-in recipes
bv --recipe actionable          # Ready to work
bv --recipe high-impact         # Top PageRank scores
bv --recipe stale               # Untouched 30+ days
bv --recipe blocked             # Waiting on dependencies
bv -r recent                    # Short flag, updated in 7 days

# Apply custom recipe
bv --recipe .beads/recipes/sprint.yaml

Export Commands

# Generate Markdown report with Mermaid diagrams
bv --export-md report.md

# Export priority brief (focused summary)
bv --priority-brief brief.md

# Export complete agent brief bundle
bv --agent-brief ./agent-bundle/
# Creates: triage.json, insights.json, brief.md, helpers.md

ETA Forecasting & Capacity Planning

# Forecast completion ETA for a specific issue
bv --robot-forecast bv-123

# Forecast all open issues with filtering
bv --robot-forecast all --forecast-label=backend
bv --robot-forecast all --forecast-sprint=sprint-1
bv --robot-forecast all --forecast-agents=2     # Multi-agent parallelism

# Capacity simulation: when will everything be done?
bv --robot-capacity                              # Default: 1 agent
bv --robot-capacity --agents=3                   # 3 parallel agents
bv --robot-capacity --capacity-label=frontend    # Scoped to label

Alerts & Health Monitoring

# Get all alerts (drift warnings + proactive health checks)
bv --robot-alerts

# Filter by severity
bv --robot-alerts --severity=critical
bv --robot-alerts --severity=warning

# Filter by alert type
bv --robot-alerts --alert-type=stale_issue
bv --robot-alerts --alert-type=blocking_cascade

# Filter by label scope
bv --robot-alerts --alert-label=backend

Triage Grouping (Multi-Agent Coordination)

# Group recommendations by execution track (parallel work streams)
bv --robot-triage --robot-triage-by-track

# Group recommendations by label (domain-focused agents)
bv --robot-triage --robot-triage-by-label

Shell Script Emission

Generate executable shell scripts from recommendations for automated workflows:

# Emit bash script for top 5 recommendations
bv --robot-triage --emit-script --script-limit=5

# Different shell formats
bv --robot-triage --emit-script --script-format=fish
bv --robot-triage --emit-script --script-format=zsh

Feedback System (Adaptive Recommendations)

The feedback system learns from your accept/ignore decisions to tune recommendation weights:

# Record positive feedback (you worked on this recommendation)
bv --feedback-accept bv-123

# Record negative feedback (you skipped this recommendation)
bv --feedback-ignore bv-456

# View current feedback state and weight adjustments
bv --feedback-show

# Reset feedback to defaults
bv --feedback-reset

Baseline & Drift Detection

# Save current state as baseline
bv --save-baseline "Pre-release v2.0"

# Show baseline information
bv --baseline-info

# Check for drift from baseline
bv --check-drift                    # Exit codes: 0=OK, 1=critical, 2=warning
bv --check-drift --robot-drift      # JSON output
# Semantic vector search over titles/descriptions
bv --search "login oauth"

# JSON output for automation
bv --search "login oauth" --robot-search

# Hybrid search (text + graph metrics)
bv --search "login oauth" --search-mode hybrid --search-preset impact-first

# Hybrid with custom weights
bv --search "login oauth" --search-mode hybrid \
  --search-weights '{"text":0.4,"pagerank":0.2,"status":0.15,"impact":0.1,"priority":0.1,"recency":0.05}'

Semantic search builds a lightweight vector index from a weighted issue document (ID and title repeated, labels and description included). This keeps lookup fast while still behaving like a human-readable search.

Hybrid mode is a two-stage pipeline: it first retrieves the top candidates by semantic similarity, then re-ranks those candidates using graph-aware signals (PageRank, status, impact, priority, recency). That keeps results anchored to your query while surfacing items that matter most in the dependency graphโ€”a good fit for bvโ€™s goal of making the โ€œwhy this mattersโ€ visible.

Short, intent-heavy queries (e.g., โ€œbenchmarksโ€, โ€œoauthโ€) are treated differently on purpose. bv widens the candidate pool, boosts literal matches, and raises the text weight so quick lookups behave like a precise search. Longer, descriptive queries lean more on graph signals for smart tieโ€‘breaking and prioritization.

Hybrid defaults can be set via:

  • BV_SEARCH_MODE (text|hybrid)
  • BV_SEARCH_PRESET (default|bug-hunting|sprint-planning|impact-first|text-only)
  • BV_SEARCH_WEIGHTS (JSON string, overrides preset)

In --robot-search JSON, hybrid results include mode, preset, weights, plus per-result text_score and component_scores.

Example: AI Agent Workflow

#!/bin/bash
# agent-workflow.sh - Autonomous task selection

# 1. Get the execution plan
PLAN=$(bv --robot-plan)

# 2. Extract highest-impact actionable task
TASK=$(echo "$PLAN" | jq -r '.plan.summary.highest_impact')

# 3. Get full insights for context
INSIGHTS=$(bv --robot-insights)

# 4. Check if completing this introduces regressions
BASELINE=$(bv --diff-since HEAD~1 --robot-diff)

echo "Working on: $TASK"
echo "Unblocks: $(echo "$PLAN" | jq '.plan.summary.unblocks_count') tasks"

Output Examples

--robot-priority Output:

{
  "generated_at": "2025-01-15T10:30:00Z",
  "recommendations": [
    {
      "issue_id": "CORE-123",
      "current_priority": 3,
      "suggested_priority": 1,
      "confidence": 0.87,
      "direction": "increase",
      "reasoning": "High PageRank (0.15) + High Betweenness (0.45) indicates foundational blocker"
    }
  ],
  "summary": {
    "total_issues": 58,
    "recommendations": 12,
    "high_confidence": 5
  }
}

--robot-recipes Output:

{
  "recipes": [
    { "name": "actionable", "description": "Ready to work (no blockers)", "source": "builtin" },
    { "name": "high-impact", "description": "Top PageRank scores", "source": "builtin" },
    { "name": "sprint-review", "description": "Current sprint issues", "source": "project" }
  ]
}

๐Ÿข Multi-Repository Workspace Support

For monorepo and multi-package architectures, bv provides workspace configuration that unifies issues across multiple repositories into a single coherent view.

Workspace Configuration (.bv/workspace.yaml)

# .bv/workspace.yaml - Multi-repo workspace definition
name: my-workspace

repos:
  - name: api
    path: services/api
    prefix: "api-"        # Issues become api-AUTH-123
    beads_path: .beads    # Optional per-repo override (defaults to .beads)

  - name: web
    path: apps/web
    prefix: "web-"        # Issues become web-UI-456

  - name: shared
    path: packages/shared
    prefix: "lib-"        # Issues become lib-UTIL-789

discovery:
  enabled: true
  patterns:
    - "*"                 # Direct children
    - "packages/*"        # npm/pnpm workspaces
    - "apps/*"            # Next.js/Turborepo
    - "services/*"        # Microservices
    - "libs/*"            # Library packages
  exclude:
    - node_modules
    - vendor
    - .git
  max_depth: 2

defaults:
  beads_path: .beads      # Where to find beads.jsonl in each repo

ID Namespacing

When working across repositories, issues are automatically namespaced:

Local IDRepo PrefixNamespaced ID
AUTH-123api-api-AUTH-123
UI-456web-web-UI-456
UTIL-789lib-lib-UTIL-789

Cross-Repository Dependencies

The workspace system enables cross-repo blocking relationships:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  web-UI-456 (apps/web)                                  โ”‚
โ”‚  "Implement OAuth login page"                           โ”‚
โ”‚                                                         โ”‚
โ”‚  blocks: api-AUTH-123, lib-UTIL-789                     โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
         โ”‚                      โ”‚
         โ–ผ                      โ–ผ
โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”    โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚ api-AUTH-123    โ”‚    โ”‚ lib-UTIL-789    โ”‚
โ”‚ (services/api)  โ”‚    โ”‚ (packages/lib)  โ”‚
โ”‚ "Auth endpoint" โ”‚    โ”‚ "Token utils"   โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜    โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Filtering Within a Workspace

Use --repo to scope the view (and robot outputs) to a specific repository prefix. Matching is case-insensitive and accepts common separators (-, :, _); it also honors the source_repo field when present.

Supported Monorepo Layouts

LayoutPatternExample Projects
npm/pnpm workspacespackages/*Lerna, Turborepo
Next.js appsapps/*Vercel monorepos
Microservicesservices/*Backend platforms
Go modulesmodules/*Multi-module Go
Flat*Simple monorepos

ID Resolution

The IDResolver handles cross-repo references intelligently:

resolver := NewIDResolver(config, "api")

// From api repo context:
resolver.Resolve("AUTH-123")      // โ†’ {Namespace: "api-", LocalID: "AUTH-123"}
resolver.Resolve("web-UI-456")    // โ†’ {Namespace: "web-", LocalID: "UI-456"}
resolver.IsCrossRepo("web-UI-456") // โ†’ true
resolver.DisplayID("api-AUTH-123") // โ†’ "AUTH-123" (local, strip prefix)
resolver.DisplayID("web-UI-456")   // โ†’ "web-UI-456" (cross-repo, keep prefix)

โฐ Interactive Time-Travel Mode

Beyond CLI diff commands, bv supports interactive time-travel within the TUI itself. This mode overlays diff badges on your issue list, letting you visually explore what changed.

Activating Time-Travel Mode

Press t in the main list view to enter time-travel mode with a custom revision prompt:

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  โฑ๏ธ  Time-Travel Mode                    โ”‚
โ”‚                                          โ”‚
โ”‚  Compare current state with a            โ”‚
โ”‚  historical revision                     โ”‚
โ”‚                                          โ”‚
โ”‚  โฑ๏ธ  Revision: HEAD~5โ–ˆ                   โ”‚
โ”‚                                          โ”‚
โ”‚  Examples: HEAD~5, main, v1.0.0,         โ”‚
โ”‚           2024-01-01, abc123             โ”‚
โ”‚                                          โ”‚
โ”‚  Press Enter to compare, Esc to cancel   โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

For quick access, press T (uppercase) to instantly compare against HEAD~5 without the prompt.

Diff Badges

Once activated, issues display visual badges indicating their diff status:

BadgeMeaningColor
[NEW]Issue created since baselineGreen
[CLOSED]Issue closed since baselineGray
[MODIFIED]Issue fields changedYellow
[REOPENED]Issue reopened since baselineOrange

Visual Example

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  ๐Ÿ“‹ ISSUES (since HEAD~5)                          58 total โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚  [NEW]      โœจ FEAT-789  Add dark mode toggle      P2  ๐ŸŸข  โ”‚
โ”‚  [NEW]      ๐Ÿ› BUG-456   Fix login race condition  P1  ๐ŸŸข  โ”‚
โ”‚  [MODIFIED] ๐Ÿ“ TASK-123  Update documentation     P3  ๐ŸŸก  โ”‚
โ”‚             โœจ FEAT-100  OAuth integration        P1  ๐ŸŸข  โ”‚
โ”‚  [CLOSED]   ๐Ÿ› BUG-001   Memory leak in parser    P0  โšซ  โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Time-Travel Summary Panel

The footer shows aggregate statistics:

โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
๐Ÿ“Š Changes: +3 new  โœ“2 closed  ~1 modified  โ†บ0 reopened
Health: โ†‘ improving (density: -0.02, cycles: -1)
โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€

Time-Travel Navigation

KeyAction
tEnter time-travel (custom revision prompt)
TQuick time-travel (HEAD~5)
t (while in time-travel)Exit time-travel mode
nJump to next changed issue
NJump to previous changed issue

๐Ÿงช Quality Assurance & Robustness

Trust is earned. bv employs a rigorous testing strategy to ensure it can handle the messy reality of real-world repositories.

1. Synthetic Data Fuzzing

We don't just test on "happy path" data. The test suite (pkg/loader/synthetic_test.go) generates Synthetic Complex Graphsโ€”large JSONL files with thousands of nodes, intricate dependency cycles, and edge-case UTF-8 charactersโ€”to verify that the graph engine and rendering logic never panic under load.

2. Robustness Against Corruption

In a git-based workflow, merge conflicts and partial writes happen. The TestLoadIssuesRobustness suite explicitly injects garbage lines and corrupted JSON into the data stream.

  • Result: bv detects corruption, logs a warning to stderr, and continues loading the valid data. It never crashes the user session due to a single bad line.

Contributing Tests

For contributors writing tests, see the comprehensive Testing Guide which covers:

  • Test philosophy (no mocks, table-driven tests, golden files)
  • Using the testutil package for fixture generation
  • Running tests, coverage, and benchmarks
  • E2E test patterns and CI integration

๐Ÿ”„ The Zero-Friction Update Engine

bv includes a proactive, non-intrusive update check to ensure you never miss a feature. We believe tools should maintain themselves without interrupting your flow.

Design & Implementation

The updater (pkg/updater/updater.go) is architected for silence and safety:

  1. Non-Blocking Concurrency: The check runs in a detached goroutine with a strict 2-second timeout. It never delays your startup time or UI interactivity.
  2. Semantic Versioning: It doesn't just match strings. A custom SemVer comparator ensures you are only notified about strictly newer releases, handling complex edge cases like release candidates vs. stable builds.
  3. Resilience: It gracefully handles network partitions, GitHub API rate limits (403/429), and timeouts by silently failing. You will never see a crash or error log due to an update check.
  4. Unobtrusive Notification: When an update is found, bv doesn't pop a modal. It simply renders a subtle Update Available indicator (โญ) in the footer, letting you choose when to upgrade.

๐Ÿ—‚๏ธ Data Loading & Self-Healing

Reliability is key. bv doesn't assume a perfect environment; it actively handles common file system inconsistencies.

1. Intelligent Path Discovery

The loader (pkg/loader/loader.go) doesn't just blindly open .beads/beads.jsonl. It employs a priority-based discovery algorithm:

  1. Canonical: Checks for issues.jsonl (preferred by beads upstream).
  2. Legacy: Fallback to beads.jsonl for backward compatibility.
  3. Base: Checks beads.base.jsonl (used by br in daemon mode).
  4. Validation: It skips temporary files like *.backup or deletions.jsonl to prevent displaying corrupted state.

2. Robust Parsing

The JSONL parser is designed to be Lossy-Tolerant.

  • It uses a buffered scanner (bufio.NewScanner) with a generous 10MB line limit to handle massive description blobs.
  • Malformed lines (e.g., from a merge conflict) are skipped with a warning rather than crashing the application, ensuring you can still view the readable parts of your project even during a bad git merge.

๐Ÿงฉ Design Philosophy: Why Graphs?

Traditional issue trackers (Jira, GitHub Issues, Trello) model work as Buckets: "To Do", "In Progress", "Done". This is fine for simple task lists, but it fails at scale because it ignores Structure.

In complex software projects, tasks are not isolated. They are deeply interconnected. A "simple" frontend task might depend on a backend endpoint, which depends on a schema change, which depends on a migration script.

bv adopts a Graph-First philosophy:

  1. Structure is Reality: The dependency graph is the project. The list view is just a projection of that graph.
  2. Explicit Blocking: We don't just "relate" tasks; we define strict "blocks". If A blocks B, you literally cannot mark B as "Ready" in bv until A is Closed.
  3. Local-First, Text-Based: Your project data lives in your repo (.beads/beads.jsonl), not on a remote server. It travels with your code, branches with your git, and merges with your PRs.

โšก Performance Specs

bv is engineered for speed. We believe that latency is the enemy of flow.

  • Startup Time: < 50ms for typical repos (< 1000 issues).
  • Rendering: 60 FPS UI updates using Bubble Tea.
  • Virtualization: List views and Markdown renderers are fully windowed. bv can handle repositories with 10,000+ issues without UI lag, consuming minimal RAM.
  • Graph Compute: A two-phase analyzer computes topo/degree/density instantly, then PageRank/Betweenness/HITS/Critical Path/Cycles asynchronously with size-aware timeouts.
  • Caching: Repeated analyses reuse hashed results automatically, avoiding recomputation when the bead graph hasnโ€™t changed.

Performance Benchmarking

bv includes a comprehensive benchmark suite for performance validation:

# Run all benchmarks
./scripts/benchmark.sh

# Save current performance as baseline
./scripts/benchmark.sh baseline

# Compare against baseline (requires benchstat)
./scripts/benchmark.sh compare

# Quick benchmarks (CI mode)
./scripts/benchmark.sh quick

Benchmark Categories:

  • Full Analysis: End-to-end Analyze() pipeline at various scales
  • Individual Algorithms: PageRank, Betweenness, HITS, TopoSort isolation
  • Pathological Graphs: Stress tests for timeout protection (many cycles, complete graphs)
  • Timeout Verification: Ensures large graphs don't hang

Timeout Protection: All expensive algorithms (Betweenness, PageRank, HITS, Cycle detection) have 500ms timeouts to prevent blocking on large or pathological graphs.

Detailed Tuning Guide: For comprehensive performance documentation including troubleshooting, size-based algorithm selection, and tuning options, see docs/performance.md.

Graph Engine Optimization

The analysis engine uses a compact adjacency-list graph (compactDirectedGraph) instead of the standard Gonum map-backed implementation. This optimization delivers significant performance improvements:

Benchmark (696 issues)BeforeAfterImprovement
Full Triage67ms1.3ms52ร— faster
Full Analysis46ms477ฮผs96ร— faster
Graph Build1.2ms323ฮผs3.7ร— faster
Memory (Graph Build)735KB444KB40% less
Allocations4,6472,51246% fewer

Why it matters: The default Gonum DirectedGraph uses map-backed edge sets, which cause heavy allocations during graph construction. Our compact implementation:

  • Pre-allocates node arrays at known size
  • Uses []int64 adjacency lists instead of map[int64]set
  • Eliminates map grow/rehash overhead entirely

Real-data benchmarks: Run go test -bench=BenchmarkRealData ./pkg/analysis/... to validate performance against your project's actual .beads/issues.jsonl data.


โ“ Troubleshooting & FAQ

Q: My icons look weird / text is misaligned.

  • bv requires a terminal with TrueColor support and a Nerd Font installed.
  • Recommended: Nerd Fonts (e.g., "JetBrains Mono Nerd Font" or "Hack Nerd Font").
  • Terminals: Windows Terminal, iTerm2, Alacritty, Kitty, WezTerm.

Q: Live reload isnโ€™t updating (especially on NFS/SMB/SSHFS/FUSE).

  • Some filesystems donโ€™t reliably deliver filesystem events. bv will try to auto-detect this and switch to polling.
  • If it still misbehaves, force polling:
    BV_FORCE_POLLING=1 bv
    # or
    BV_FORCE_POLL=1 bv
    

Q: I see polling โ€ฆ in the footer. Is that bad? No โ€” it just means bv is using polling instead of filesystem events for live reload (common on remote filesystems). Polling can add a small delay before updates appear.

Q: I see โš  STALE / โœ— bg โ€ฆ / โš  worker unresponsive / โ†ป recovered in the footer. These indicators mean the background worker hasnโ€™t produced a fresh snapshot recently (or needed to self-heal). Try Ctrl+R/F5, check filesystem permissions/health, or temporarily disable background mode (BV_BACKGROUND_MODE=0) to fall back to synchronous reload.

Q: I see "Cycles Detected" in the dashboard. What now? A: A cycle (e.g., A โ†’ B โ†’ A) means your project logic is broken; no task can be finished first. Use the Insights Dashboard (i) to find the specific cycle members, then use br to remove one of the dependency links (e.g., br unblock A --from B).

Q: Does this work with Jira/GitHub? A: bv is data-agnostic. The Beads data schema supports an external_ref field. If you populate your .beads/beads.jsonl file with issues from external trackers (e.g., using a custom script or sync tool), bv will render them alongside your local tasks. Future versions of the br CLI may support native syncing, but bv is ready for that data today.

Q: What's the difference between "bead" and "issue"? A: They're the same thing! In the Beads ecosystem, the unit of work is called a "bead" (hence the name). However, bv uses "issue" in many places since that's the more familiar term for most developers. The CLI flags use both interchangeably: --robot-file-beads, --pages-include-closed (issues), etc. Think of "bead" as the Beads-specific term and "issue" as the general concept.


๐Ÿ“ฆ Installation

One-Line Install (Linux/macOS)

The fastest way to get started. Detects your OS and architecture automatically.

curl -fsSL "https://raw.githubusercontent.com/Dicklesworthstone/beads_viewer/main/install.sh?$(date +%s)" | bash

One-Line Install (Windows)

For Windows users using PowerShell:

irm "https://raw.githubusercontent.com/Dicklesworthstone/beads_viewer/main/install.ps1" | iex

Requirements:

Build from Source

Requires Go 1.21+.

git clone https://github.com/Dicklesworthstone/beads_viewer.git
cd beads_viewer
go install ./cmd/bv

Nix Flake

For Nix users, bv provides a flake for reproducible builds and development environments.

# Run directly
nix run github:Dicklesworthstone/beads_viewer

# Install to profile
nix profile install github:Dicklesworthstone/beads_viewer

# Development shell with Go toolchain
nix develop github:Dicklesworthstone/beads_viewer

Or add to your flake inputs:

{
  inputs.bv.url = "github:Dicklesworthstone/beads_viewer";
  # Use: bv.packages.${system}.default
}

๐Ÿš€ Usage Guide

Navigate to any project initialized with br init and run:

bv

๐ŸŽ“ Getting Help

bv has a comprehensive built-in help system:

Quick Reference (?) - Press anywhere to see keyboard shortcuts for your current view. From here, press Space to jump directly to the full tutorial.

Interactive Tutorial (` backtick) - A multi-page walkthrough covering all features:

  • Concepts: beads, dependencies, labels, priorities
  • Views: list, board, graph, tree, insights, history
  • Workflows: AI agent integration, triage, planning
  • Progress is automatically savedโ€”resume where you left off

Keyboard Control Map

ContextKeyAction
Global Navigationj / kNext / Previous Item
g / GJump to Top / Bottom
Ctrl+D / Ctrl+UPage Down / Up
TabSwitch Focus (List โ†” Details)
EnterOpen / Focus Selection
q / EscQuit / Back
FiltersoShow Open Issues
rShow Ready (Unblocked)
cShow Closed Issues
aShow All Issues
/Search (Fuzzy)
Ctrl+SToggle Search Mode (Semantic โ†” Fuzzy)
lLabel Picker (quick filter by label)
List SortingsCycle Sort Mode (Default โ†’ Created โ†‘ โ†’ Created โ†“ โ†’ Priority โ†’ Updated)
ViewsbToggle Kanban Board
iToggle Insights Dashboard
gToggle Graph Visualizer
EToggle Tree View (parent-child hierarchy)
aToggle Actionable Plan
hToggle History View (bead-to-commit correlation)
fToggle Flow Matrix (cross-label dependencies)
[Toggle Label Dashboard (label health analytics)
]Toggle Attention View (label attention scores)
Kanban Boardh / lMove Between Columns
j / kMove Within Column
Insights DashboardTabNext Panel
Shift+TabPrevious Panel
eToggle Explanations
xToggle Calculation Proof
mToggle Heatmap Overlay
Graph ViewH / LScroll Left / Right
Ctrl+D / Ctrl+UPage Down / Up
Tree Viewj / kMove cursor down / up
h / lCollapse/parent or Expand/child
Enter / SpaceToggle expand/collapse
o / OExpand all / Collapse all
g / GJump to top / bottom
Time-Travel & AnalysistTime-Travel Mode (custom revision)
TQuick Time-Travel (HEAD~5)
pToggle Priority Hints Overlay
ActionsxExport to Markdown File
CCopy Issue to Clipboard
OOpen in Editor
Help & Learning?Toggle Help Overlay (keyboard shortcuts)
`Open Interactive Tutorial (progress saved)
Global;Toggle Shortcuts Sidebar
!Toggle Alerts Panel (proactive warnings)
'Recipe Picker
wRepo Picker (workspace mode)

๐Ÿ› ๏ธ Configuration

bv automatically detects your terminal capabilities to render the best possible UI. It looks for .beads/beads.jsonl in your current directory.

Environment Variables

VariableDescriptionDefault
BEADS_DIRCustom beads directory path. When set, overrides the default .beads directory lookup..beads in cwd
BV_BACKGROUND_MODEExperimental: enable background snapshot loading for live reload in the TUI (1/0).(disabled)
BV_FORCE_POLLINGForce polling-based live reload (useful on NFS/SMB/SSHFS/FUSE or any setup where filesystem events are unreliable) (1/0).(auto)
BV_FORCE_POLLAlias for BV_FORCE_POLLING.(auto)
BV_DEBOUNCE_MSDebounce window (milliseconds) for live reload events in background mode.200
BV_CHANNEL_BUFFERBackground worker message buffer size (worker โ†’ UI).8
BV_HEARTBEAT_INTERVAL_SBackground worker heartbeat interval (seconds).5
BV_WATCHDOG_INTERVAL_SBackground worker watchdog interval (seconds).10
BV_FRESHNESS_WARN_SSnapshot staleness warning threshold (seconds).30
BV_FRESHNESS_STALE_SSnapshot staleness critical threshold (seconds).120
BV_MAX_LINE_SIZE_MBMax JSONL line size in MB (lines larger than this are skipped with a warning).10
BV_SKIP_PHASE2Skip Phase 2 graph metrics (centrality, cycles, critical path) (1/0).(disabled)
BV_PHASE2_TIMEOUT_SOverride per-metric Phase 2 timeouts (seconds).(size-based)
BV_SEMANTIC_EMBEDDERSemantic embedding provider for bv --search and TUI semantic mode.hash
BV_SEMANTIC_DIMEmbedding dimension for semantic search index.384
BV_SEMANTIC_MODELProvider-specific model name for semantic search (optional).(empty)

Use cases for BEADS_DIR:

  • Monorepos: Single beads directory shared across multiple packages
  • Non-standard layouts: Projects where .beads isn't in the working directory
  • Testing: Point to test fixtures without changing directory
  • Cross-directory access: View beads from anywhere on the filesystem
# Example: Point to a different beads directory
BEADS_DIR=/path/to/shared/beads bv

# Example: Use in monorepo
export BEADS_DIR=$(git rev-parse --show-toplevel)/.beads

Experimental: Background Mode (Live Reload)

The TUI can run live reload using an experimental background snapshot worker (moves file I/O + analysis off the UI thread).

Enable (opt-in):

BV_BACKGROUND_MODE=1 bv
bv --background-mode

Disable / rollback:

BV_BACKGROUND_MODE=0 bv
bv --no-background-mode

User config file (when neither CLI flags nor BV_BACKGROUND_MODE are set):

# ~/.config/bv/config.yaml
experimental:
  background_mode: true

Precedence: CLI flags โ†’ BV_BACKGROUND_MODE โ†’ ~/.config/bv/config.yaml.

Migration plan (high level):

  • Phase A (now): opt-in background mode, sync remains default.
  • Phase B: broaden rollout; keep explicit rollback (--no-background-mode / BV_BACKGROUND_MODE=0).
  • Phase C: flip default when stable; keep sync as fallback for a period.
  • Phase D: remove legacy sync reload path after deprecation window.

Monitoring plan: no automatic telemetry today; rely on CI + regression tests and user reports during Phase A/B.

Status Indicators (Background Mode + Live Reload)

When background mode or live reload is enabled, the footer may display these indicators:

  • โ—Œ metricsโ€ฆ โ€” Phase 2 metrics are still computing; the UI renders immediately with Phase 1 data.
  • โš  45s ago โ€” snapshot age warning (data is getting stale).
  • โš  STALE: 3m ago โ€” snapshot is stale.
  • โœ— bg <phase> (3x) โ€” background worker hit repeated errors building snapshots (phase shown; retry count in parentheses).
  • โ†ป recovered xN โ€” watchdog recovered the background worker N times (transient failures/self-healing).
  • โš  worker unresponsive โ€” watchdog detected the worker is stuck and is recovering.
  • polling โ€ฆ โ€” live reload is using polling instead of filesystem events (common on remote filesystems); changes may appear with a small delay.

Tip: Ctrl+R (or F5) forces a refresh.

Visual Theme

The UI uses a visually distinct, high-contrast theme inspired by Dracula Principles to ensure readability.

  • Primary: #BD93F9 (Purple)
  • Status Open: #50FA7B (Green)
  • Status Blocked: #FF5555 (Red)

๐Ÿ“„ License

MIT License (with OpenAI/Anthropic Rider). See LICENSE.

Copyright (c) 2025 Jeffrey Emanuel


๐Ÿค– Why Robots Love bv

  • Deterministic JSON contracts: robot commands emit stable field names, stable ordering (ties broken by ID), and include data_hash, analysis_config, and computed_at so multiple calls can be correlated safely.
  • Health flags: every expensive metric reports status (computed, approx, timeout, skipped) plus elapsed ms and (when sampled) the sample size used.
  • Consistent cache: robot subcommands share the same analyzer/cache keyed by the issue data hash, avoiding divergent outputs across --robot-insights, --robot-plan, and --robot-priority.
  • Instant + eventual completeness: Phase 1 metrics are available immediately; Phase 2 fills in and the status flags tell you when it is done or if it degraded.

๐Ÿงญ Data Flow at a Glance

.beads/beads.jsonl
   โ†“ tolerant loader (BOM strip, 10MB lines, skip malformed)
   โ†“ graph builder (blocking deps only)
   โ†“ analyzer (Phase 1 fast; Phase 2 centralities with timeouts)
   โ†“ cache (hash-keyed)
   โ†“ outputs: TUI | robot JSON | exports/hooks
  • Hash and config travel with every robot payload so downstream consumers can verify consistency.

๐Ÿ“ Graph Analysis Algorithms (plain English)

  • PageRank: โ€œblocking authorityโ€ โ€” foundational tasks with many (or important) dependents.
  • Betweenness: โ€œbridgesโ€ โ€” nodes on many shortest paths; bottlenecks between clusters.
  • HITS: hubs (aggregators) vs authorities (prerequisites).
  • Critical-path depth: longest downstream chain length; zero slack keystones.
  • Eigenvector: influence via influential neighbors.
  • Density, degree, topo sort: structural backbone.
  • Cycles: detected via Tarjan SCC + DirectedCyclesIn; capped with timeouts and stored count.
  • Each appears in robot insights with its status flag and, when ready, per-issue scores.

โšก Phase 1 vs Phase 2

  • Phase 1 (instant): degree, topo sort, density; always present.
  • Phase 2 (async): PageRank, Betweenness, HITS, Eigenvector, Critical Path, Cycles; 500ms defaults with size-based adjustments. Status flag reflects computed/approx/timeout/skipped.

โฑ๏ธ Timeout & Approximation Semantics

  • Per-metric status: computed (full), approx (e.g., sampled betweenness), timeout (fallback), skipped (size/density guard).
  • Payload example:
    {
      "status": {
        "pagerank": {"state":"computed","ms":142},
        "betweenness": {"state":"approx","ms":480,"sample":120},
        "cycles": {"state":"timeout","ms":500,"reason":"deadline"}
      }
    }
    

๐Ÿงฎ Execution Plan Logic

  • Actionable set: open/in-progress issues with no open blocking dependencies.
  • Unblocks: for each actionable, list of issues that would become actionable if it closed (no other open blockers).
  • Tracks: undirected connected components group actionable items into parallelizable streams.
  • Summary: highest-impact item = max unblocks, then priority, then ID for determinism.

๐ŸŽฏ Priority Recommendation Model

  • Composite score weights: PageRank 30%, Betweenness 30%, blocker ratio 20%, staleness 10%, priority boost 10%.
  • Thresholds: high PR >0.30, high BW >0.50, staleness ~14 days, min confidence 0.30 by default.
  • Direction: โ€œincreaseโ€ or โ€œdecreaseโ€ priority derived from score vs current priority; confidence blends signal count, strength, and score delta.

๐Ÿ” Diff & Time-Travel Safety Notes

  • When stdout is non-TTY or BV_ROBOT=1, --diff-since auto-emits JSON (or requires --robot-diff in strict setups); resolved revision is echoed in the payload.
  • TUI time-travel badges: [NEW], [CLOSED], [MODIFIED], [REOPENED], matching the robot diff summary.

๐Ÿ›ก๏ธ Performance Guardrails

  • Two-phase analysis with size-aware configs (approx betweenness on large sparse graphs, cycle caps, HITS skipped on dense XL graphs).
  • 500ms default timeouts per expensive metric; results marked with status.
  • Cache TTL keeps repeated robot calls fast on unchanged data; hash mismatch triggers recompute.
  • Bench quick check: ./scripts/benchmark.sh quick or diagnostics via bv --profile-startup.

๐Ÿงท Robustness & Self-Healing

  • Loader skips malformed lines with warnings, strips UTF-8 BOM, tolerates large lines (10MB).
  • Beads file discovery order: issues.jsonl โ†’ beads.jsonl โ†’ beads.base.jsonl; skips backups/merge artifacts/deletions manifests.
  • Live reload is debounced; update check is non-blocking with graceful failure on network issues.

๐Ÿ”— Integrating with CI & Agents

  • Typical pipeline:
    bv --robot-insights > insights.json
    bv --robot-plan | jq '.plan.summary'
    bv --robot-priority | jq '.recommendations[0]'
    bv --check-drift --robot-drift --diff-since HEAD~5 > drift.json
    
  • Use data_hash to ensure all artifacts come from the same analysis run; fail CI if hashes diverge.
  • Exit codes: drift check (0 ok, 1 critical, 2 warning).

๐Ÿฉบ Troubleshooting Matrix (robot mode)

  • Empty metric maps โ†’ Phase 2 still running or timed out; check status flags.
  • Large payloads โ†’ use jq to slice top items; re-run after filtering via recipes.
  • Missing cycles โ†’ likely skipped/timeout; see status.cycles.
  • Inconsistent outputs between commands โ†’ compare data_hash; rerun if different.

๐Ÿ”’ Security & Privacy Notes

  • Local-first: all analysis happens on your repo's JSONL; no network required for robots.
  • Hooks and exports are opt-in; update checks are silent and tolerate network failures without impacting startup.

๐Ÿ™ Acknowledgments & Credits

bv stands on the shoulders of giants. We're deeply grateful to the maintainers and contributors of these exceptional open source projects:

Foundation

ProjectAuthorDescription
BeadsSteve YeggeThe elegant git-native issue tracking system that bv was built to complement

Go Libraries (TUI & CLI)

LibraryAuthorWhat We Use It For
Bubble TeaCharmThe Elm-inspired TUI framework powering all interactive views
Lip GlossCharmBeautiful terminal stylingโ€”colors, borders, layouts
BubblesCharmReady-made components: lists, text inputs, spinners, viewports
HuhCharmInteractive forms and prompts for the deployment wizard
GlamourCharmMarkdown rendering with syntax highlighting in terminal
modernc.org/sqlitemodernc.orgPure-Go SQLite with FTS5 full-text search for static site export
GonumGonum AuthorsGraph algorithms: PageRank, betweenness centrality, SCC
fsnotifyfsnotifyFile system watching for live reload
clipboardatottoCross-platform clipboard for copy-to-clipboard features

JavaScript Libraries (Static Viewer)

LibraryAuthorWhat We Use It For
force-graphVasco AsturianoBeautiful interactive force-directed graph visualization
D3.jsMike Bostock / ObservableData visualization foundation and graph physics
Alpine.jsCaleb PorzioLightweight reactive UI framework
sql.jssql.js contributorsSQLite compiled to WebAssembly for client-side queries
Chart.jsChart.js contributorsInteractive charts: burndown, priority distribution, heatmaps
MermaidKnut SveidqvistDependency graph diagrams in Markdown
DOMPurifycure53XSS-safe HTML sanitization
Markedmarked contributorsFast Markdown parsing
Tailwind CSSTailwind LabsUtility-first CSS framework

Special Thanks

  • The entire Charm team for creating the most delightful terminal UI ecosystem in existence. Their libraries make building beautiful CLI tools a joy.
  • Vasco Asturiano for the incredible force-graph library and the broader ecosystem of visualization tools.
  • Steve Yegge for the vision behind Beadsโ€”a refreshingly simple approach to issue tracking that respects developers' workflows.

About Contributions: Please don't take this the wrong way, but I do not accept outside contributions for any of my projects. I simply don't have the mental bandwidth to review anything, and it's my name on the thing, so I'm responsible for any problems it causes; thus, the risk-reward is highly asymmetric from my perspective. I'd also have to worry about other "stakeholders," which seems unwise for tools I mostly make for myself for free. Feel free to submit issues, and even PRs if you want to illustrate a proposed fix, but know I won't merge them directly. Instead, I'll have Claude or Codex review submissions via gh and independently decide whether and how to address them. Bug reports in particular are welcome. Sorry if this offends, but I want to avoid wasted time and hurt feelings. I understand this isn't in sync with the prevailing open-source ethos that seeks community contributions, but it's the only way I can move at this velocity and keep my sanity.


๐Ÿ“„ License

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

๐Ÿค– Robot JSON contract โ€” quick cheat sheet

Shared across all robots

  • data_hash: hash of the beads file driving the response (use to correlate multiple calls).
  • analysis_config: exact analysis settings (timeouts, modes, cycle caps) for reproducibility.
  • status: per-metric state computed|approx|timeout|skipped with elapsed ms/reason; always check before trusting heavy metrics like PageRank/Betweenness/HITS.
  • as_of / as_of_commit: present when using --as-of; contains the ref you specified and the resolved commit SHA for reproducibility.

Schemas in 5 seconds (jq-friendly)

  • bv --robot-insights โ†’ .status, .analysis_config, metric maps (capped by BV_INSIGHTS_MAP_LIMIT), Bottlenecks, CriticalPath, Cycles, plus advanced signals: Cores (k-core), Articulation (cut vertices), Slack (longest-path slack).
  • bv --robot-plan โ†’ .plan.tracks[].items[].{id,unblocks} for downstream unlocks; .plan.summary.highest_impact.
  • bv --robot-priority โ†’ .recommendations[].{id,current_priority,suggested_priority,confidence,reasoning}.
  • bv --robot-suggest โ†’ .suggestions.suggestions[] (ranked suggestions) + .suggestions.stats (counts) + .usage_hints.
  • bv --robot-diff --diff-since <ref> โ†’ {from_data_hash,to_data_hash,diff.summary,diff.new_issues,diff.cycle_*}.
  • bv --robot-history โ†’ .histories[ID].events + .commit_index for reverse lookup; .stats.method_distribution shows how correlations were inferred.

Copy/paste guardrails

# Ensure metrics are ready
bv --robot-insights | jq '.status'

# Top unblockers from plan
bv --robot-plan | jq '.plan.tracks[].items[] | {id, unblocks}'

# High-confidence priority fixes
bv --robot-priority | jq '.recommendations[] | select(.confidence > 0.6)'

# Structural strength and parallelism
bv --robot-insights | jq '.full_stats.core_number | to_entries | sort_by(-.value)[:5]'
bv --robot-insights | jq '.Articulation'
bv --robot-insights | jq '.Slack[:5]'

# Verify diff hashes match expectations
bv --robot-diff --diff-since HEAD~1 | jq '{from: .from_data_hash, to: .to_data_hash}'

# Historical analysis (verify as_of metadata)
bv --robot-insights --as-of HEAD~30 | jq '{as_of, as_of_commit, data_hash}'