8 production-ready skills for enhanced Claude Code workflows: 1. github-ops - Comprehensive GitHub operations via gh CLI and API - PR/issue management, workflow automation, API interactions 2. markdown-tools - Document conversion to markdown - PDF/Word/PowerPoint/Confluence → Markdown with WSL support 3. mermaid-tools - Mermaid diagram generation - Extract and render diagrams from markdown to PNG/SVG 4. statusline-generator - Claude Code statusline customization - Multi-line layouts, cost tracking, git status, colors 5. teams-channel-post-writer - Microsoft Teams communication - Adaptive Cards, formatted announcements, corporate standards 6. repomix-unmixer - Repomix file extraction - Extract from XML/Markdown/JSON formats with auto-detection 7. skill-creator - Skill development toolkit - Init, validation, packaging scripts with privacy best practices 8. llm-icon-finder - AI/LLM brand icon finder - 100+ AI model icons in SVG/PNG/WEBP formats Features: - Individual skill installation (install only what you need) - Progressive disclosure design (optimized context usage) - Privacy-safe examples (no personal/company information) - Comprehensive documentation with references - Production-tested workflows Installation: /plugin marketplace add daymade/claude-code-skills /plugin marketplace install daymade/claude-code-skills#<skill-name> Version: 1.2.0 License: See individual skill licenses 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
4.1 KiB
ccusage Integration Reference
This reference explains how the statusline integrates with ccusage for cost tracking and troubleshooting.
What is ccusage?
ccusage is a command-line tool that tracks Claude Code usage and costs by reading conversation transcripts. It provides session-based and daily cost reporting.
How Statusline Uses ccusage
The statusline script calls ccusage to display session and daily costs:
session=$(ccusage session --json --offline -o desc 2>/dev/null | jq -r '.sessions[0].totalCost' 2>/dev/null | xargs printf "%.2f")
daily=$(ccusage daily --json --offline -o desc 2>/dev/null | jq -r '.daily[0].totalCost' 2>/dev/null | xargs printf "%.2f")
Key Features
- JSON Output: Uses
--jsonflag for machine-readable output - Offline Mode: Uses
--offlineto avoid fetching pricing data (faster) - Descending Order: Uses
-o descto get most recent data first - Error Suppression: Redirects errors to
/dev/nullto prevent statusline clutter
Caching Strategy
To avoid slowing down the statusline, costs are cached:
- Cache File:
/tmp/claude_cost_cache_YYYYMMDD_HHMM.txt - Cache Duration: 2 minutes (refreshes based on minute timestamp)
- Background Refresh: First run fetches costs in background
- Fallback: Uses previous cache (up to 10 minutes old) while refreshing
Cache Behavior
- First Display: Statusline shows without costs
- 2-5 Seconds Later: Costs appear after background fetch completes
- Next 2 Minutes: Cached costs shown instantly
- After 2 Minutes: New cache generated in background
ccusage JSON Structure
Session Data
{
"sessions": [
{
"sessionId": "conversation-id",
"totalCost": 0.26206769999999996,
"inputTokens": 2065,
"outputTokens": 1313,
"lastActivity": "2025-10-20"
}
]
}
Daily Data
{
"daily": [
{
"date": "2025-10-20",
"totalCost": 25.751092800000013,
"inputTokens": 16796,
"outputTokens": 142657
}
]
}
Troubleshooting
Costs Not Showing
Symptoms: Statusline appears but no [$X.XX/$X.XX] shown
Possible Causes:
- ccusage not installed
- ccusage not in PATH
- No transcript data available yet
- Background fetch still in progress
Solutions:
# Check if ccusage is installed
which ccusage
# Test ccusage manually
ccusage session --json --offline -o desc
# Check cache files
ls -lh /tmp/claude_cost_cache_*.txt
# Wait 5-10 seconds and check again (first fetch runs in background)
Slow Statusline
Symptoms: Statusline takes >1 second to appear
Possible Causes:
- Cache not working (being regenerated too often)
- ccusage taking too long to execute
Solutions:
# Check cache timestamp
ls -lh /tmp/claude_cost_cache_*.txt
# Test ccusage speed
time ccusage session --json --offline -o desc
# If slow, consider disabling cost tracking by commenting out cost section in script
Incorrect Costs
Symptoms: Costs don't match expected values
Possible Causes:
- Cache stale (showing old data)
- ccusage database out of sync
- Multiple Claude sessions confusing costs
Solutions:
# Clear cache to force refresh
rm /tmp/claude_cost_cache_*.txt
# Verify ccusage data
ccusage session -o desc | head -20
ccusage daily -o desc | head -20
# Check ccusage database location
ls -lh ~/.config/ccusage/
Installing ccusage
If ccusage is not installed:
# Using npm (Node.js required)
npm install -g @anthropic-ai/ccusage
# Or check the official ccusage repository for latest installation instructions
Disabling Cost Tracking
To disable costs (e.g., if ccusage not available), comment out the cost section in generate_statusline.sh:
# Cost information using ccusage with caching
cost_info=""
# cache_file="/tmp/claude_cost_cache_$(date +%Y%m%d_%H%M).txt"
# ... rest of cost section commented out
Then update the final printf to remove %s for cost_info:
printf '\033[01;32m%s\033[00m \033[01;36m(%s)\033[00m\n\033[01;37m%s\033[00m\n%s' \
"$username" "$model" "$short_path" "$git_info"