Claude-skill-registry claude-code-statusline-development
This skill should be used when the user asks to "create a statusline", "customize the status line", "add a custom prompt", or mentions Claude Code statusline. Also suggest when the user wants to display git branch, context usage, model name, or session costs at the bottom of Claude Code.
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/claude-code-statusline-development" ~/.claude/skills/majiayu000-claude-skill-registry-claude-code-statusline-development && rm -rf "$T"
manifest:
skills/data/claude-code-statusline-development/SKILL.mdsource content
Claude Code Statusline Development
Create custom status lines that display contextual information at the bottom of Claude Code.
Quick Reference
You MUST read the reference files for detailed schemas and examples:
- JSON Schema - Complete input structure documentation
- Example: Simple - Basic bash statusline
- Example: Git-Aware - Git branch and status
- Example: Context Usage - Context window percentage
- Example: Cost Tracking - Session costs and tokens
Configuration
Add to
.claude/settings.json:
{ "statusLine": { "type": "command", "command": "~/.claude/statusline.sh", "padding": 0 } }
How It Works
- Status line updates when conversation messages change
- Updates run at most every 300ms
- First line of stdout becomes the status line text
- ANSI color codes supported
- JSON context passed via stdin
JSON Input (Quick Reference)
| Field | Description |
|---|---|
| Model name (e.g., "Opus") |
| Current working directory |
| Original project directory |
| Session cost in USD |
| Lines added this session |
| Lines removed this session |
| Max context tokens |
| Current token usage object |
See JSON Schema for complete structure.
Script Template
#!/bin/bash input=$(cat) # Extract values using jq model=$(echo "$input" | jq -r '.model.display_name') dir=$(echo "$input" | jq -r '.workspace.current_dir') # Colors via tput blue=$(tput setaf 4) reset=$(tput sgr0) echo "${blue}[$model]${reset} ${dir##*/}"
Make executable:
chmod +x ~/.claude/statusline.sh
Tips
- Keep output concise - single line only
- Use
for portable ANSI colorstput - Test with mock JSON:
echo '{"model":{"display_name":"Test"}}' | ./statusline.sh - Cache expensive operations (git status) if needed
Important
After creating or modifying statuslines, inform the user:
No restart needed. Statusline changes take effect immediately - Claude Code reads settings fresh on each update.
Attribution
Based on Claude Code Status Line Configuration.