Keyboard-first kanban for the terminal.
Inspired by lazygit · Built on ratatui
- Zero latency — pure keyboard flow — hjkl, never reach for the mouse
- Your data is a file on your disk — private, offline, always yours
- Git-native — generate branch names and
git checkoutcommands from any card - LLM-native — full MCP server (40 tools) works with Claude Code, Cursor, and any MCP client
- Offline-first — works anywhere; JSON and SQLite backends, atomic writes, live conflict detection
kanban # launch in-memory; pick or skip a file from the startup dialog
kanban boards.json # open or create a JSON board file
kanban boards.sqlite # open or create a SQLite board filePress ? at any time to see context-sensitive help.
export KANBAN_FILE=boards.json # or pass the path as the first argument
kanban board create --name "My Project"
kanban board list
kanban card create --board "My Project" --column TODO --title "Fix the bug" --priority high
kanban card list --board "My Project"
kanban sprint create --board "My Project"
kanban sprint activate yarara-release --duration-days 14
kanban card assign-sprint KAN-5 --sprint yarara-releasekanban init boards.json --board "My Project" # create file + first board, exit
kanban init --board "My Project" # uses KANBAN_FILE or boards.json
kanban init # creates boards.json with "My Board"Every entity argument accepts either a UUID or a human-readable name (sprint
numbers also work for sprints; cards accept their KAN-N identifier). When a
name doesn't match, the error lists what's available.
All commands output JSON. Use kanban --help for full reference.
Claude Code
{
"mcpServers": {
"kanban": {
"command": "kanban-mcp",
"args": ["boards.json"]
}
}
}cargo install kanban-cligit clone https://github.com/fulsomenko/kanban
cd kanban
cargo install --path crates/kanban-clibrew install fulsomenko/tap/kanbannix run github:fulsomenko/kanbanyay -S kanbanFor y/Y clipboard operations to persist after the app exits, you need a clipboard manager:
- Wayland:
wl-clip-persist,cliphist,clipman, or your DE's built-in manager - X11: Most desktop environments include one by default
If your setup is Windows and WSL, and you often switch between them, then it is recommended to install separate binaries for each system to avoid constant recompiles.
Changes are made in an external editor as defined by your EDITOR. Neovim, nano, or some other terminal-based editor is recommended, both for easier switching between edits and browsing, and because editors that leave the terminal may cause issues.
VS Code is known not to work in the current implementation.
kanban is well-tested on supported OSes and is designed to be shell-agnostic. If your EDITOR is not set, it will default to notepad on Windows and vi otherwise.
- Multiple boards, each with custom columns and WIP limits
- Rich cards: title, description, priority (Low/Medium/High/Critical), status (Todo/InProgress/Blocked/Done), story points, due dates
- Card numbering with configurable prefix (e.g.
KAN-42) - Card dependencies: parent/child relationships with cycle detection
- Archive and restore cards
- Full sprint lifecycle: Planning → Active → Completed / Cancelled
- Carry uncompleted cards to the next sprint with one key
- Per-sprint card prefix overrides
- Sprint logs track assignment history per card
- 3 view modes: Flat list / Grouped by column / Kanban board — toggle with
V - Real-time
/search - Sort by priority, points, status, or position
- Filter by sprint, status, or search result
- Multi-select for bulk archive / move / sprint-assign
- Undo/redo (
u/U, up to 100 levels) - External editor for descriptions (respects
$EDITOR) - Clipboard:
ycopies git branch name,Ycopiesgit checkoutcommand - Import/export boards as JSON
- JSON and SQLite storage backends
- Atomic writes (temp file → rename) prevent corruption
- Live file watching: auto-reload when another instance writes
- Conflict detection with user prompt when local edits clash
- TUI — full keyboard-driven terminal UI
- CLI — scriptable; all operations, JSON output, pagination
- MCP server — 40 tools for LLM integration
Press ? in the app to see bindings for the current context.
| Key | Action |
|---|---|
j/↓ |
Navigate down |
k/↑ |
Navigate up |
gg |
Jump to top |
G |
Jump to bottom |
Enter/Space |
Open board detail |
n |
New board |
r |
Rename board |
e |
Edit board |
x |
Export board |
X |
Export all boards |
i |
Import board from file |
u |
Undo |
U |
Redo |
S |
Open settings |
1/2 |
Focus boards/cards panel |
q |
Quit |
? |
Help |
| Key | Action |
|---|---|
j/↓, k/↑ |
Navigate down/up |
gg / G |
Jump to top/bottom |
{ / } |
Half-page up/down |
h/l |
Previous/next column |
H/L |
Move card left/right column |
Enter/Space |
Open card detail |
n |
New card |
e |
Edit card |
c |
Toggle done |
p |
Set priority |
d |
Archive card(s) |
D |
View archived cards |
v |
Toggle card selection |
Ctrl+a |
Select all visible cards |
Esc |
Clear selection |
P |
Set priority (bulk) |
a |
Assign to sprint |
o |
Sort cards |
O |
Toggle sort order |
t |
Toggle sprint filter |
T |
Filter options |
/ |
Search |
s |
Manage child cards |
V |
Toggle view mode |
u / U |
Undo / Redo |
1/2 |
Focus boards/cards panel |
q |
Quit |
? |
Help |
| Key | Action |
|---|---|
1–5 |
Focus Title / Metadata / Description / Parents / Children panel |
e |
Edit current panel |
r |
Manage parent cards |
R |
Manage child cards |
y |
Copy git branch name to clipboard |
Y |
Copy git checkout command to clipboard |
a |
Assign to sprint |
d |
Delete card |
u / U |
Undo / Redo |
q/Esc |
Back |
? |
Help |
| Key | Action |
|---|---|
1–5 |
Focus Name / Description / Settings / Sprints / Columns panel |
e |
Edit current panel |
p |
Set branch prefix |
n |
New sprint (Sprints panel) / New column (Columns panel) |
r |
Rename column (Columns panel) |
d |
Delete column (Columns panel) |
J/K |
Reorder column up/down (Columns panel) |
j/k |
Navigate within panel |
Enter/Space |
Open sprint detail (Sprints panel) |
u / U |
Undo / Redo |
q/Esc |
Back |
? |
Help |
| Key | Action |
|---|---|
h/l |
Switch between uncompleted/completed panels |
j/k |
Navigate cards |
a |
Activate sprint |
c |
Complete sprint |
p |
Set sprint prefix |
C |
Set card prefix override |
o/O |
Sort / Toggle sort order |
v |
Select card(s) |
u / U |
Undo / Redo |
q/Esc |
Back |
? |
Help |
| Key | Action |
|---|---|
j/k |
Navigate |
gg/G |
Jump to top/bottom |
{/} |
Half-page up/down |
r |
Restore card(s) |
x |
Delete card(s) permanently |
v |
Select for bulk operation |
V |
Toggle view mode |
u / U |
Undo / Redo |
q/Esc |
Back |
crates/
├── kanban-core → Shared types, error handling, config, reusable state primitives
├── kanban-domain → Domain models, business logic, filtering & sorting
├── kanban-persistence → Persistence trait layer — pure trait definitions, all I/O lives in backend crates
├── kanban-persistence-json → JSON file storage backend
├── kanban-persistence-sqlite → SQLite storage backend
├── kanban-service → KanbanContext, persistence orchestration, undo/redo
├── kanban-tui → Terminal UI with ratatui
├── kanban-cli → CLI entry point (clap)
└── kanban-mcp → Model Context Protocol server
graph LR
CLI[kanban-cli] --> TUI[kanban-tui]
CLI --> SVC[kanban-service]
MCP[kanban-mcp] --> SVC
TUI --> SVC
SVC --> PER[kanban-persistence]
SVC -.-> JSON[kanban-persistence-json]
SVC -.-> SQL[kanban-persistence-sqlite]
JSON --> PER
SQL --> PER
PER --> DOM[kanban-domain]
DOM --> CORE[kanban-core]
| Crate | Description | README |
|---|---|---|
kanban-core |
Shared types, config, errors, graph, pagination | → |
kanban-domain |
Domain models, business logic | → |
kanban-persistence |
Persistence trait layer | → |
kanban-persistence-json |
JSON file backend | → |
kanban-persistence-sqlite |
SQLite backend | → |
kanban-service |
Service layer, KanbanContext, undo/redo | → |
kanban-tui |
Terminal UI | → |
kanban-cli |
CLI entry point | → |
kanban-mcp |
MCP server | → |
- V2 envelope format:
{ "version": 2, "metadata": {...}, "data": {...} } - Atomic writes: crash-safe — every write is atomic (temp file → rename)
- Debounced saving: 500ms minimum interval between saves
- Default for any plain file path
- WAL mode with foreign key enforcement
- Connection pool: max 2 connections
- Relational schema: boards, columns, cards, archived cards, sprints, sprint logs, dependency graph edges, and more
- Schema versioning with migration skeleton for future upgrades
- File selected by
.sqlite,.sqlite3, or.dbextension
- File watching: detects changes written by other TUI or MCP instances
- Auto-reload: applies external changes automatically when the local state is clean
- Conflict prompt: when local edits clash with an external write, you choose to reload or keep
- Progressive auto-save
- Full CLI interface
- Card dependencies (parent/child)
- Multiple storage backends (JSON + SQLite)
- MCP server for LLM integration
- Full undo/redo
- Sprint planning lifecycle
- Bulk operations
- Configurable keybindings
- Attachments (files on cards)
- Audit log
- HTTP API for remote access
- Collaborative / sync features
See CONTRIBUTING.md for development workflow, code style, and testing guidelines.
Apache 2.0 — see LICENSE.md
