Every Claude Code extension I've seen shows the same thing: token counts, API costs, model info. Useful, but it doesn't answer the question I actually care about mid-session — how much of the work is done.
So I built task-progress-bar. It reads Claude Code's native task list from disk and renders a live ASCII progress bar with time estimates. It runs as a PostToolUse hook, which means it consumes zero tokens — it's a subprocess that Claude never sees.
Tasks [████████░░] 8/10 (~3m left) | ✓8 ⟳1 ○1
How it works
Claude Code persists tasks as JSON files in ~/.claude/tasks/. The plugin watches for TodoWrite, TodoRead, TaskCreate, and TaskUpdate tool calls via the PostToolUse hook, then:
- Parses every JSON file in the tasks directory
- Counts completed, in-progress, and pending tasks
- Computes a time estimate using an exponential moving average (EMA)
- Outputs a single status line to Claude Code's statusLine renderer
The time estimation is straightforward. Each time a task moves to completed, the timestamp is logged. The interval between consecutive completions feeds into an EMA with α=0.3:
EMA_new = 0.3 × latest_interval + 0.7 × EMA_old
estimated_remaining = EMA × tasks_left
Intervals over 1 hour are clamped to avoid skew from session breaks. The first 3 completions show "calculating..." until there's enough data.
The entire plugin is a single Python file — stdlib only, no pip dependencies. It uses json, pathlib, time, and sys. Nothing else.
Install
curl -fsSL https://raw.githubusercontent.com/PRAFULREDDYM/task-progress-bar/main/install.sh | bash
The installer checks for Python 3.8+, copies the script to ~/.claude/, and patches settings.json with the hook configuration. There's a matching uninstall.sh for clean removal.
What it looks like
The progress bar color-codes by completion percentage — red below 33%, yellow from 33–66%, green above 66%. When all tasks finish, it shows ✅ All done! for 30 seconds and then hides.
If you run it standalone (python3 task_progress_bar.py), you get a full multi-line colored view with a task breakdown and per-task average.
Links
- GitHub: github.com/PRAFULREDDYM/task-progress-bar
- Requirements: Python 3.8+, Claude Code v2.1+
- License: MIT
Top comments (0)