Claude-skill-registry kan
Manage kanban boards using the Kan CLI. Use when working with tasks, cards, boards, columns, or project tracking via the kan command.
install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/kan" ~/.claude/skills/majiayu000-claude-skill-registry-kan && rm -rf "$T"
manifest:
skills/data/kan/SKILL.mdsource content
Kan CLI
Kan is a file-based kanban board CLI. All data lives in
.kan/ as plain files.
Getting Help
Every command supports
--help for detailed usage:
kan --help kan add --help kan column --help
Initialize
kan init # Create .kan/ in current directory kan init -l .kanboard # Custom location kan init -c todo,doing,done # Custom columns kan init -n myboard # Custom board name kan init -p myproject # Custom project name for favicon/title kan init -c a,b,c -n project # Both custom columns and name
| Flag | Description |
|---|---|
| Custom location for .kan directory |
| Comma-separated column names (default: backlog,next,in-progress,done) |
| Board name (default: main) |
| Project name for favicon and page title (default: git repo or directory name) |
Adding Cards
kan add "Fix login bug" # Add card, prompted for details kan add "Fix login bug" -c backlog # Add to specific column kan add "Feature" -b features -c todo # Specify board and column kan add "Title" "Description here" -c backlog # Title + description kan add "Subtask" -p 12 # Add as child of card 12 kan add "Task" -f priority=high -f type=bug # Add with custom fields
| Flag | Description |
|---|---|
| Target board |
| Target column |
| Parent card ID or alias |
| Custom field (key=value, repeatable) |
Listing Cards
kan list # List all cards grouped by column kan list -c done # Filter by column kan list -b myboard # Filter by board
Showing Card Details
kan show 12 # Show card by ID kan show fix # Show card by alias or partial match kan show fix -b myboard # Specify board
Editing Cards
kan edit 12 # Edit interactively kan edit fix -t "New title" # Update title kan edit fix -c done # Move to column kan edit fix -d "New description" # Update description kan edit fix -f priority=low # Update custom field
| Flag | Description |
|---|---|
| Board name |
| Set card title |
| Set card description |
| Move card to column |
| Set parent card |
| Set explicit alias |
| Set custom field (key=value, repeatable) |
Board Management
kan board create features # Create a new board kan board list # List all boards
Column Management
kan column add review # Add column to end kan column add review --color "#9333ea" # With custom color kan column add review --position 2 # Insert at position kan column delete review # Delete column kan column rename review code-review # Rename column kan column edit review --color "#ec4899" # Change column color kan column list # List columns kan column move review --position 1 # Reorder column kan column move review --after backlog # Insert after another
Comments
kan comment add fix-login "Found the issue" # Add comment to card kan comment add fix-login # Add comment (opens editor) kan comment edit c_9kL2x "Updated text" # Edit comment by ID kan comment delete c_9kL2x # Delete comment
| Flag | Description |
|---|---|
| Board name |
Web Interface
kan serve # Start web UI (opens browser) kan serve -p 8080 # Custom port kan serve --no-open # Don't auto-open browser
Migration
kan migrate # Migrate data to current schema kan migrate --dry-run # Preview changes without applying
Global Flags
| Flag | Description |
|---|---|
| Fail instead of prompting for input |
Tips
- Cards are identified by flexible IDs: numeric ID, alias, or partial match
- Use
for scripting to ensure commands fail rather than prompt-I