- Add i18next internationalization with Chinese/English support - Add Claude plugin sync alongside VS Code integration - Extend provider presets with new models (DeepSeek-V3.2-Exp, Qwen3-Max, GLM-4.6) - Support portable mode and single instance enforcement - Add tray minimize and macOS Dock visibility management - Improve Settings UI with scrollable layout and save icon - Fix layout shifts and provider toggle consistency - Remove unnecessary OpenAI auth requirement - Update Windows MSI installer to target per-user LocalAppData
176 lines
7.6 KiB
Markdown
176 lines
7.6 KiB
Markdown
# Changelog
|
|
|
|
All notable changes to CC Switch will be documented in this file.
|
|
|
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
|
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
|
|
|
## [3.4.0] - 2025-10-01
|
|
|
|
### ✨ Features
|
|
- Enable internationalization via i18next with a Chinese default and English fallback, plus an in-app language switcher
|
|
- Add Claude plugin sync alongside the existing VS Code integration controls
|
|
- Extend provider presets with optional API key URLs and updated models, including DeepSeek-V3.1-Terminus and Qwen3-Max
|
|
- Support portable mode launches and enforce a single running instance to avoid conflicts
|
|
|
|
### 🔧 Improvements
|
|
- Allow minimizing the window to the system tray and add macOS Dock visibility management for tray workflows
|
|
- Refresh the Settings modal with a scrollable layout, save icon, and cleaner language section
|
|
- Smooth provider toggle states with consistent button widths/icons and prevent layout shifts when switching between Claude and Codex
|
|
- Adjust the Windows MSI installer to target per-user LocalAppData and improve component tracking reliability
|
|
|
|
### 🐛 Fixes
|
|
- Remove the unnecessary OpenAI auth requirement from third-party provider configurations
|
|
- Fix layout shifts while switching app types with Claude plugin sync enabled
|
|
- Align Enable/In Use button states to avoid visual jank across VS Code and Codex views
|
|
|
|
## [3.3.0] - 2025-09-22
|
|
|
|
### ✨ Features
|
|
- Add “Apply to VS Code / Remove from VS Code” actions on provider cards, writing settings for Code/Insiders/VSCodium variants
|
|
- Enable VS Code auto-sync by default with window broadcast and tray hooks so Codex switches sync silently
|
|
- Extend the Codex provider wizard with display name, dedicated API key URL, and clearer guidance
|
|
- Introduce shared common config snippets with JSON/TOML reuse, validation, and consistent error surfaces
|
|
|
|
### 🔧 Improvements
|
|
- Keep the tray menu responsive when the window is hidden and standardize button styling and copy
|
|
- Disable modal backdrop blur on Linux (WebKitGTK/Wayland) to avoid freezes; restore the window when clicking the macOS Dock icon
|
|
- Support overriding config directories on WSL, refine placeholders/descriptions, and fix VS Code button wrapping on Windows
|
|
- Add a `created_at` timestamp to provider records for future sorting and analytics
|
|
|
|
### 🐛 Fixes
|
|
- Correct regex escapes and common snippet trimming in the Codex wizard to prevent validation issues
|
|
- Harden the VS Code sync flow with more reliable TOML/JSON parsing while reducing layout jank
|
|
- Bundle `@codemirror/lint` to reinstate live linting in config editors
|
|
|
|
## [3.2.0] - 2025-09-13
|
|
|
|
### ✨ New Features
|
|
- System tray provider switching with dynamic menu for Claude/Codex
|
|
- Frontend receives `provider-switched` events and refreshes active app
|
|
- Built-in update flow via Tauri Updater plugin with dismissible UpdateBadge
|
|
|
|
### 🔧 Improvements
|
|
- Single source of truth for provider configs; no duplicate copy files
|
|
- One-time migration imports existing copies into `config.json` and archives originals
|
|
- Duplicate provider de-duplication by name + API key at startup
|
|
- Atomic writes for Codex `auth.json` + `config.toml` with rollback on failure
|
|
- Logging standardized (Rust): use `log::{info,warn,error}` instead of stdout prints
|
|
- Tailwind v4 integration and refined dark mode handling
|
|
|
|
### 🐛 Fixes
|
|
- Remove/minimize debug console logs in production builds
|
|
- Fix CSS minifier warnings for scrollbar pseudo-elements
|
|
- Prettier formatting across codebase for consistent style
|
|
|
|
### 📦 Dependencies
|
|
- Tauri: 2.8.x (core, updater, process, opener, log plugins)
|
|
- React: 18.2.x · TypeScript: 5.3.x · Vite: 5.x
|
|
|
|
### 🔄 Notes
|
|
- `connect-src` CSP remains permissive for compatibility; can be tightened later as needed
|
|
|
|
## [3.1.1] - 2025-09-03
|
|
|
|
### 🐛 Bug Fixes
|
|
- Fixed the default codex config.toml to match the latest modifications
|
|
- Improved provider configuration UX with custom option
|
|
|
|
### 📝 Documentation
|
|
- Updated README with latest information
|
|
|
|
## [3.1.0] - 2025-09-01
|
|
|
|
### ✨ New Features
|
|
- **Added Codex application support** - Now supports both Claude Code and Codex configuration management
|
|
- Manage auth.json and config.toml for Codex
|
|
- Support for backup and restore operations
|
|
- Preset providers for Codex (Official, PackyCode)
|
|
- API Key auto-write to auth.json when using presets
|
|
- **New UI components**
|
|
- App switcher with segmented control design
|
|
- Dual editor form for Codex configuration
|
|
- Pills-style app switcher with consistent button widths
|
|
- **Enhanced configuration management**
|
|
- Multi-app config v2 structure (claude/codex)
|
|
- Automatic v1→v2 migration with backup
|
|
- OPENAI_API_KEY validation for non-official presets
|
|
- TOML syntax validation for config.toml
|
|
|
|
### 🔧 Technical Improvements
|
|
- Unified Tauri command API with app_type parameter
|
|
- Backward compatibility for app/appType parameters
|
|
- Added get_config_status/open_config_folder/open_external commands
|
|
- Improved error handling for empty config.toml
|
|
|
|
### 🐛 Bug Fixes
|
|
- Fixed config path reporting and folder opening for Codex
|
|
- Corrected default import behavior when main config is missing
|
|
- Fixed non_snake_case warnings in commands.rs
|
|
|
|
## [3.0.0] - 2025-08-27
|
|
|
|
### 🚀 Major Changes
|
|
- **Complete migration from Electron to Tauri 2.0** - The application has been completely rewritten using Tauri, resulting in:
|
|
- **90% reduction in bundle size** (from ~150MB to ~15MB)
|
|
- **Significantly improved startup performance**
|
|
- **Native system integration** without Chromium overhead
|
|
- **Enhanced security** with Rust backend
|
|
|
|
### ✨ New Features
|
|
- **Native window controls** with transparent title bar on macOS
|
|
- **Improved file system operations** using Rust for better performance
|
|
- **Enhanced security model** with explicit permission declarations
|
|
- **Better platform detection** using Tauri's native APIs
|
|
|
|
### 🔧 Technical Improvements
|
|
- Migrated from Electron IPC to Tauri command system
|
|
- Replaced Node.js file operations with Rust implementations
|
|
- Implemented proper CSP (Content Security Policy) for enhanced security
|
|
- Added TypeScript strict mode for better type safety
|
|
- Integrated Rust cargo fmt and clippy for code quality
|
|
|
|
### 🐛 Bug Fixes
|
|
- Fixed bundle identifier conflict on macOS (changed from .app to .desktop)
|
|
- Resolved platform detection issues
|
|
- Improved error handling in configuration management
|
|
|
|
### 📦 Dependencies
|
|
- **Tauri**: 2.8.2
|
|
- **React**: 18.2.0
|
|
- **TypeScript**: 5.3.0
|
|
- **Vite**: 5.0.0
|
|
|
|
### 🔄 Migration Notes
|
|
For users upgrading from v2.x (Electron version):
|
|
- Configuration files remain compatible - no action required
|
|
- The app will automatically migrate your existing provider configurations
|
|
- Window position and size preferences have been reset to defaults
|
|
|
|
#### Backup on v1→v2 Migration (cc-switch internal config)
|
|
- When the app detects an old v1 config structure at `~/.cc-switch/config.json`, it now creates a timestamped backup before writing the new v2 structure.
|
|
- Backup location: `~/.cc-switch/config.v1.backup.<timestamp>.json`
|
|
- This only concerns cc-switch's own metadata file; your actual provider files under `~/.claude/` and `~/.codex/` are untouched.
|
|
|
|
### 🛠️ Development
|
|
- Added `pnpm typecheck` command for TypeScript validation
|
|
- Added `pnpm format` and `pnpm format:check` for code formatting
|
|
- Rust code now uses cargo fmt for consistent formatting
|
|
|
|
## [2.0.0] - Previous Electron Release
|
|
|
|
### Features
|
|
- Multi-provider configuration management
|
|
- Quick provider switching
|
|
- Import/export configurations
|
|
- Preset provider templates
|
|
|
|
---
|
|
|
|
## [1.0.0] - Initial Release
|
|
|
|
### Features
|
|
- Basic provider management
|
|
- Claude Code integration
|
|
- Configuration file handling
|