πβ¨ Merry Christmas Eve, everyone! β¨π
Wishing warmth, joy, and peace to all who celebrate. May your holidays be filled with love and laughter.
Time to slow down, enjoy the magic, and celebrate with the people who matter most.
However you spend tonight - we hope it's filled with joy π
May your code be bug-free, your quotas stay green, and your builds always succeed! π
(P.S. Check ClaudeBar for a snowy surprise βοΈ)
Happy Holidays! β€οΈπ
A macOS menu bar application that monitors AI coding assistant usage quotas. Keep track of your Claude, Codex, Gemini, GitHub Copilot, and Antigravity usage at a glance.
Dark Mode Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Β Light Mode
Festive holiday theme with snowfall animation - automatically enabled during the Christmas season!
- Multi-Provider Support - Monitor Claude, Codex, Gemini, GitHub Copilot, and Antigravity quotas in one place
- Real-Time Quota Tracking - View Session, Weekly, and Model-specific usage percentages
- Light & Dark Themes - Automatically adapts to your system appearance
- Seasonal Themes - Festive Christmas theme with snowfall animation, auto-enabled during the holiday season
- Visual Status Indicators - Color-coded progress bars (green/yellow/red) show quota health
- System Notifications - Get alerted when quota status changes to warning or critical
- Auto-Refresh - Automatically updates quotas at configurable intervals
- Keyboard Shortcuts - Quick access with
βD(Dashboard) andβR(Refresh)
| Remaining | Status | Color |
|---|---|---|
| > 50% | Healthy | Green |
| 20-50% | Warning | Yellow |
| < 20% | Critical | Red |
| 0% | Depleted | Gray |
- macOS 15+
- Swift 6.2+
- CLI tools installed for providers you want to monitor:
- Claude CLI (
claude) - Codex CLI (
codex) - Gemini CLI (
gemini) - GitHub Copilot - Configure credentials in Settings
- Antigravity - Auto-detected when running locally
- Claude CLI (
Download the latest release from GitHub Releases:
- DMG: Open and drag ClaudeBar.app to Applications
- ZIP: Unzip and move ClaudeBar.app to Applications
Both are code-signed and notarized for Gatekeeper.
git clone https://github.com/tddworks/ClaudeBar.git
cd ClaudeBar
swift build -c releaseswift run ClaudeBarThe app will appear in your menu bar. Click to view quota details for each provider.
# Build the project
swift build
# Run all tests
swift test
# Run tests with coverage
swift test --enable-code-coverage
# Run a specific test
swift test --filter "QuotaMonitorTests"The project uses Tuist to generate Xcode projects with ENABLE_DEBUG_DYLIB for SwiftUI previews.
# Install Tuist (if not installed)
brew install tuist
# Generate Xcode project
tuist generate
# Open in Xcode
open ClaudeBar.xcworkspaceAfter opening in Xcode, SwiftUI previews will work with Cmd+Option+Return.
ClaudeBar uses a layered architecture with protocol-based dependency injection:
βββββββββββββββββββββββββββββββββββββββββββββββββββ
β App Layer β
β SwiftUI Views + @Observable AppState β
βββββββββββββββββββββββββββββββββββββββββββββββββββ
β
βΌ
βββββββββββββββββββββββββββββββββββββββββββββββββββ
β Domain Layer β
β Models: UsageQuota, UsageSnapshot, QuotaStatus β
β Protocols: UsageProbe, StatusChangeObserver β
β Services: QuotaMonitor (Actor) β
βββββββββββββββββββββββββββββββββββββββββββββββββββ
β
βΌ
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
β Infrastructure Layer β
β Probes: Claude, Codex, Gemini, Copilot, Antigravity β
β Adapters: Pure 3rd-party wrappers (no coverage) β
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
- Rich Domain Models - Business logic lives in domain models, not ViewModels
- Actor-Based Concurrency - Thread-safe state management with Swift actors
- Protocol-Based DI -
@Mockableprotocols enable testability without real CLI/network - Adapters Folder - Pure 3rd-party wrappers excluded from code coverage
- No ViewModel Layer - SwiftUI views directly consume domain models
Use the add-provider skill to guide you through adding new providers with TDD:
Tell Claude Code: "I want to add a new provider for [ProviderName]"
The skill guides you through: Parsing Tests β Probe Tests β Implementation β Registration.
See .claude/skills/add-provider/SKILL.md for details and AntigravityUsageProbe as a reference implementation.
- Sparkle - Auto-update framework
- Mockable - Protocol mocking for tests
- Tuist - Xcode project generation (for SwiftUI previews)
Releases are automated via GitHub Actions. Push a version tag to create a new release.
For detailed setup instructions, see docs/RELEASE_SETUP.md.
The workflow uses Tuist to generate the Xcode project:
Tag v1.0.0 β Update Info.plist β tuist generate β xcodebuild β Sign & Notarize β GitHub Release
Version is set in Sources/App/Info.plist and flows through to Sparkle auto-updates.
-
Configure GitHub Secrets (see full guide):
Secret Description APPLE_CERTIFICATE_P12Developer ID certificate (base64) APPLE_CERTIFICATE_PASSWORDPassword for .p12 APP_STORE_CONNECT_API_KEY_P8API key (base64) APP_STORE_CONNECT_KEY_IDKey ID APP_STORE_CONNECT_ISSUER_IDIssuer ID -
Verify your certificate:
./scripts/verify-p12.sh /path/to/certificate.p12
-
Create a release:
git tag v1.0.0 git push origin v1.0.0
The workflow will automatically build, sign, notarize, and publish to GitHub Releases.
MIT


