You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
* Follow symlinks in rooignore checks (RooCodeInc#7405)
* Sonic -> Grok Code Fast (RooCodeInc#7426)
* chore: add changeset for v3.26.0 (RooCodeInc#7428)
* Changeset version bump (RooCodeInc#7429)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Matt Rubens <[email protected]>
* feat: Add Vercel AI Gateway provider integration (RooCodeInc#7396)
Co-authored-by: daniel-lxs <[email protected]>
Co-authored-by: cte <[email protected]>
* feat: Enable on-disk storage for Qdrant vectors and HNSW index (RooCodeInc#7182)
* fix: use anthropic protocol for token counting when using anthropic models via Vercel AI Gateway (RooCodeInc#7433)
- Added condition in getApiProtocol to return 'anthropic' for vercel-ai-gateway when modelId starts with 'anthropic/'
- Added tests for Vercel AI Gateway provider protocol detection
This ensures proper token counting for Anthropic models accessed through Vercel AI Gateway, as Anthropic and OpenAI count tokens differently (Anthropic excludes cache tokens from input count, OpenAI includes them).
* fix: remove duplicate cache display in task header (RooCodeInc#7443)
* Random chat text area cleanup (RooCodeInc#7436)
* Update @roo-code/cloud to enable roomote control for cloud agents (RooCodeInc#7446)
Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com>
* Always set remoteControlEnabled to true for cloud agents (RooCodeInc#7448)
* chore: add changeset for v3.26.1 (RooCodeInc#7459)
* feat: show model ID in API configuration dropdown (RooCodeInc#7423)
* feat: update tooltip component to match native VSCode tooltip shadow styling (RooCodeInc#7457)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: cte <[email protected]>
* Add support for Vercel embeddings (RooCodeInc#7445)
Co-authored-by: daniel-lxs <[email protected]>
* Remove dot before model display (RooCodeInc#7461)
* Update contributors list (RooCodeInc#7109)
Co-authored-by: mrubens <[email protected]>
* Update 3.26.1 changeset (RooCodeInc#7463)
* Changeset version bump (RooCodeInc#7460)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Matt Rubens <[email protected]>
* Add type for RooCodeEventName.TaskSpawned (RooCodeInc#7465)
* fix: hide .rooignore'd files from environment details by default (RooCodeInc#7369)
* fix: change default showRooIgnoredFiles to false to hide ignored files
- Changed default value from true to false across all files
- Updated tests to reflect the new default behavior
- This prevents ignored files from appearing in environment details
FixesRooCodeInc#7368
* fix: update tests to match new showRooIgnoredFiles default
* fix: update test expectation to match new showRooIgnoredFiles default value
The PR changed the default value of showRooIgnoredFiles from true to false,
so the test needs to expect false instead of true when calling formatFilesList.
---------
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: daniel-lxs <[email protected]>
* fix: exclude browser scroll actions from repetition detection (RooCodeInc#7471)
- Modified ToolRepetitionDetector to skip repetition detection for browser_action scroll_down and scroll_up actions
- Added isBrowserScrollAction() helper method to identify scroll actions
- Added comprehensive tests for the new behavior
- Fixes issue where multiple scroll actions were incorrectly flagged as being stuck in a loop
Resolves: RooCodeInc#7470
Co-authored-by: Roo Code <[email protected]>
* Fix GPT-5 Responses API issues with condensing and image support (RooCodeInc#7067)
Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com>
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Hannes Rudolph <[email protected]>
* Bump cloud to 0.25.0 (RooCodeInc#7475)
* feat: add image generation tool with OpenRouter integration (RooCodeInc#7474)
Co-authored-by: Matt Rubens <[email protected]>
Co-authored-by: cte <[email protected]>
* Make the default image filename more generic (RooCodeInc#7479)
* Release v3.26.2 (RooCodeInc#7490)
* Support free imagegen (RooCodeInc#7493)
* feat: update OpenRouter API to support input/output modalities and filter image generation models (RooCodeInc#7492)
* Add padding to image model picker (RooCodeInc#7494)
* fix: prevent dirty state on initial mount in ImageGenerationSettings (RooCodeInc#7495)
* Changeset version bump (RooCodeInc#7491)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Matt Rubens <[email protected]>
* Show console logging in vitests when the --no-silent flag is set (RooCodeInc#7467)
By default, all of the tests run in silent mode with monkey-patched the console logging so no console logging will ever appear in test output.
This confuses the agent- sometimes it will add console logging to help it debug things, and it won't see the logs that it expects.
Adds src/utils/vitest-verbosity.ts to handle verbosity resolution and console logging.
Modifies src/vitest.config.ts and webview-ui/vitest.config.ts to integrate the new verbosity control.
Removes manual console suppression from src/vitest.setup.ts and webview-ui/vitest.setup.ts as it's now handled dynamically.
Co-authored-by: Chris Hasson <[email protected]>
* Move @roo-code/cloud to the Roo-Code repo (RooCodeInc#7503)
* Refactor the extension bridge (RooCodeInc#7515)
* Implement deferred task subscriptions (RooCodeInc#7517)
* feat: add optional input image parameter to image generation tool (RooCodeInc#7525)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Daniel Riccio <[email protected]>
* feat: sync extension bridge settings with cloud (RooCodeInc#7535)
- Use CloudService.getUserSettings() for remoteControlEnabled instead of global state
- Update CloudService.updateUserSettings when toggling remote control
- Add BridgeOrchestrator.connectOrDisconnect handling in settings update handler
- Remove dependency on contentProxy/globalSettings for remote control state
---------
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: John Richmond <[email protected]>
* refactor: flatten image generation settings structure (RooCodeInc#7536)
* chore: add changeset for v3.26.3 (RooCodeInc#7541)
* Changeset version bump (RooCodeInc#7542)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Matt Rubens <[email protected]>
* Mode and provider profile selector (RooCodeInc#7545)
* Putting the Roo in Roo-leases (RooCodeInc#7546)
* Fix evals (RooCodeInc#7547)
* fix: special tokens should not break task processing (RooCodeInc#7540)
* docs: update PR template branding from Roo Code to Costrict
* feat: optimize memory usage for image handling in webview (RooCodeInc#7556)
* feat: optimize memory usage for image handling in webview
- Replace base64 image data with webview URIs to reduce memory footprint
- Add proper resource roots to webview for workspace file access
- Implement convertToWebviewUri method for safe file-to-URI conversion
- Update ImageViewer to handle both webview URIs and file paths separately
- Add image message type for proper image rendering in chat
- Improve error handling and display for failed image loads
- Add comprehensive tests for ImageViewer component
- Format display paths as relative for better readability
This change significantly reduces memory usage by avoiding base64 encoding
of images and instead using VSCode's webview URI system for direct file
access. Images are now loaded on-demand from disk rather than being held
in memory as base64 strings.
* fix: address PR review comments
- Use safeJsonParse instead of JSON.parse in ChatRow.tsx
- Add type definition for parsed image info
- Add more specific error types in ClineProvider.ts
- Add comprehensive JSDoc comments to ImageBlock.tsx
- Improve error handling and type safety
* fix: address MrUbens' review comments
- Remove hardcoded 'rc1' pattern in formatDisplayPath, use generic workspace detection
- Internationalize 'No image data' text using i18n system
* chore: remove useless comment
* chore(i18n): add image.noData to all locales to fix translation check
* test: update ImageViewer.spec to align with i18n key and flexible path formatting
* feat: rename Account tab to Cloud tab (RooCodeInc#7558)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Matt Rubens <[email protected]>
* feat: add Ollama API key support for Turbo mode (RooCodeInc#7425)
* feat: add Ollama API key support for Turbo mode
- Add ollamaApiKey field to ProviderSettings schema
- Add ollamaApiKey to SECRET_STATE_KEYS for secure storage
- Update Ollama and NativeOllama providers to use API key for authentication
- Add UI field for Ollama API key (shown when custom base URL is provided)
- Add test coverage for API key functionality
This enables users to use Ollama Turbo with datacenter-grade hardware by providing an API key for authenticated Ollama instances or cloud services.
* fix: use VSCodeTextField for Ollama API key field
Remove non-existent ApiKeyField import and use standard VSCodeTextField with password type, matching other provider implementations
* Add missing translation keys for Ollama API key support
- Add providers.ollama.apiKey and providers.ollama.apiKeyHelp to all 18 language files
- Support for authenticated Ollama instances and cloud services
- Relates to PR RooCodeInc#7425
* refactor: improve type safety for Ollama client configuration
- Replace 'any' type with proper OllamaOptions (Config) type
- Import Config type from ollama package for better type checking
---------
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Daniel Riccio <[email protected]>
* Disconnect extension bridge on logout (RooCodeInc#7563)
* Disconnect extension bridge on logout
* Remove bad test
* Cleanup
* Fix claudeCode.notFound translation key (RooCodeInc#7571)
I think I saw someone post a screenshot where "errors.claudeCode.notFound" was shown untranslated.
* v3.26.4 (RooCodeInc#7579)
* Update contributors list (RooCodeInc#7462)
Co-authored-by: mrubens <[email protected]>
* Changeset version bump (RooCodeInc#7580)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Matt Rubens <[email protected]>
* feat: add configurable embedding batch size for code indexing (RooCodeInc#7464)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Daniel Riccio <[email protected]>
* Shows a pill with the base Roo Code Cloud URL when not pointing to pr… (RooCodeInc#7555)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Matt Rubens <[email protected]>
Co-authored-by: roomote[bot] <219738659+roomote[bot]@users.noreply.github.com>
* Cloud: fix provider syncing (RooCodeInc#7603)
ClineProvider creation was moved before CloudService which broke
the old way of doing things.
* fix: add cache reporting support for OpenAI-Native provider (RooCodeInc#7602)
* fix: add cache reporting support for OpenAI-Native provider
- Add normalizeUsage method to properly extract cache tokens from Responses API
- Support both detailed token shapes (input_tokens_details) and legacy fields
- Calculate cache read/write tokens with proper fallbacks
- Include reasoning tokens when available in output_tokens_details
- Ensure accurate cost calculation using uncached input tokens
This fixes the issue where caching information was not being reported
when using the OpenAI-Native provider with the Responses API.
* fix: improve cache token normalization and add comprehensive tests
- Add fallback to derive total input tokens from details when totals are missing
- Remove unused convertToOpenAiMessages import
- Add comment explaining cost calculation alignment with Gemini provider
- Add comprehensive test coverage for normalizeUsage method covering:
- Detailed token shapes with cached/miss tokens
- Legacy field names and SSE-only events
- Edge cases including missing totals with details-only
- Cost calculation with uncached input tokens
* fix: address PR review comments
- Remove incorrect fallback to missFromDetails for cache write tokens
- Fix cost calculation to pass total input tokens (calculateApiCostOpenAI handles subtraction)
- Improve readability by extracting cache detail checks to intermediate variables
- Remove redundant ?? undefined
- Update tests to reflect correct behavior (miss tokens are not cache writes)
- Add clarifying comments about cache miss vs cache write tokens
* feat: add auto-approve support for MCP access_resource tool (RooCodeInc#7606)
* Move message queue to the extension host (RooCodeInc#7604)
Co-authored-by: roomote[bot] <219738659+roomote[bot]@users.noreply.github.com>
* Send custom modes to the extension bridge (RooCodeInc#7612)
* Never give up in socket transport (RooCodeInc#7616)
* Fix socket-io client event handling (RooCodeInc#7618)
* More socket-io client fixes from PR feedback (RooCodeInc#7619)
* More socket-io client logging improvements (RooCodeInc#7620)
* Publish subtask events (RooCodeInc#7626)
* Update chutes.ts to add Qwen3 235B A22B Thinking 2507 model (RooCodeInc#7578)
Co-authored-by: Matt Rubens <[email protected]>
* chore: add changeset for v3.26.5 (RooCodeInc#7628)
* Update contributors list (RooCodeInc#7629)
Co-authored-by: mrubens <[email protected]>
* Changeset version bump (RooCodeInc#7630)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Matt Rubens <[email protected]>
* feat: add run_slash_command tool for executing slash commands (RooCodeInc#7473)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Matt Rubens <[email protected]>
Co-authored-by: Daniel Riccio <[email protected]>
* Focus the extension when receiving bridge commands (RooCodeInc#7633)
* Release: v1.73.0 (RooCodeInc#7636)
* Cloud: remove extension_bridge_enabled for personal users (RooCodeInc#7638)
* Publish token usage metrics (RooCodeInc#7637)
* fix: preserve scroll position when switching tabs in settings (RooCodeInc#7587)
* fix: preserve scroll position when switching tabs in settings
* ui(settings): restore scroll synchronously to prevent flicker; dx(ui): name TabContent for clearer DevTools
---------
Co-authored-by: Daniel Riccio <[email protected]>
* feat: add Kimi K2 Turbo model configuration to moonshotModels (RooCodeInc#7593)
* feat: add Kimi K2 Turbo model configuration to moonshotModels
* feat: update Kimi K2 Turbo pricing and cache read prices
* fix: use askApproval wrapper in insert_content and search_and_replace tools (RooCodeInc#7649)
Fixes issue where isWriteProtected was incorrectly passed as the partial flag
to task.ask(), causing "Current ask promise was ignored (#1)" error.
Both tools now use the askApproval wrapper function which correctly handles
the parameter ordering, passing undefined for progressStatus and isWriteProtected
as the fourth parameter.
FixesRooCodeInc#7648
Co-authored-by: Roo Code <[email protected]>
* Release v3.26.6 (RooCodeInc#7650)
* Changeset version bump (RooCodeInc#7651)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Matt Rubens <[email protected]>
* Delete .github/workflows/discord-pr-notify.yml
* Remove unused slack notif (RooCodeInc#7655)
* Handle zsh process substitution correctly (RooCodeInc#7658)
* Handle zsh glob qualifiers correctly (RooCodeInc#7667)
* Minor zh-TW Traditional Chinese locale typo fix (RooCodeInc#7672)
* feat: Add DeepInfra as a model provider in Roo Code (RooCodeInc#7677)
* fix: validate MCP tool exists before execution (RooCodeInc#7632)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Daniel Riccio <[email protected]>
* fix: add error transform to cryptic openAI SDK errors when API key is invalid (RooCodeInc#7586)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Daniel Riccio <[email protected]>
* feat: OpenAI Responses API service tiers (flex/priority) — UI selector, pricing, and tests (RooCodeInc#7646)
Co-authored-by: Daniel Riccio <[email protected]>
* fix: prevent countdown timer from showing in history for answered follow-up questions (RooCodeInc#7686)
* fix: Fix the issue of Moonshot's maximum return token count being limited to 1024 (RooCodeInc#7673)
Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com>
Co-authored-by: roomote[bot] <219738659+roomote[bot]@users.noreply.github.com>
* feat: update kimi-k2-0905-preview and kimi-k2-turbo-preview (RooCodeInc#7663)
* Fix test
* Release v3.26.7 (RooCodeInc#7691)
* Delete .changeset/petite-rats-admire.md
* feat: Add Kimi K2 0905 model to Groq, Moonshot, and Fireworks providers (RooCodeInc#7693)
* Use an allowlist to keep the prompt default shell sane (RooCodeInc#7681)
* Changeset version bump (RooCodeInc#7690)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Matt Rubens <[email protected]>
* Fix: Improve WelcomeView styling and readability (RooCodeInc#7682)
* fix: improve WelcomeView styling and readability
- Reduced excessive padding from p-16 to p-6
- Removed excessive bold text throughout
- Made provider cards more compact with smaller icons (32x32px)
- Increased introduction text size from text-sm to text-base for better visibility
- Centered the main greeting title
- Improved visual hierarchy with proper text sizing and spacing
- Added subtle borders and improved color contrast
* fix: remove undefined color class from incentive text
Removed the text-vscode-warningForeground class as it wasn't defined in index.css. The incentive text now uses default color which looks good.
* feat: add Kimi K2-0905 model to Chutes provider (RooCodeInc#7701)
Co-authored-by: Roo Code <[email protected]>
* fix: handle array paths from VSCode terminal profiles (RooCodeInc#7697)
* fix: handle array paths from VSCode terminal profiles
- Updated terminal profile interfaces to support string | string[] for path property
- Added normalizeShellPath helper to safely extract first element from array paths
- Modified isShellAllowed to handle both string and array inputs
- Updated getWindowsShellFromVSCode, getMacShellFromVSCode, and getLinuxShellFromVSCode to use normalizeShellPath
- Added comprehensive tests for array path handling
FixesRooCodeInc#7695
* feat: add validateShellPath export for robust shell validation
- Created validateShellPath as a public API for shell path validation
- Refactored internal validation logic into isShellAllowedInternal
- Added comprehensive test coverage for all edge cases
- Maintains backward compatibility with deprecated isShellAllowed
- Handles arrays, strings, null, undefined, and nested arrays gracefully
* Simplify roomote's work a little
---------
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: John Richmond <[email protected]>
* Edit/Delete User Message (RooCodeInc#7447)
* fix: prevent stack overflow in codebase indexing for large projects (RooCodeInc#7712)
* fix: identify mcp and slash command config path in multiple folder workspace (RooCodeInc#6904)
* fix: resolve CI e2e test ETIMEDOUT errors when downloading VS Code (RooCodeInc#7583)
* fix: Tackling Race/State condition issue by Changing the Code Design for Gemini Grounding Sources (RooCodeInc#7434)
Co-authored-by: daniel-lxs <[email protected]>
Co-authored-by: Matt Rubens <[email protected]>
* fix: preserve context by retrying with full conversation on invalid previous_response_id (RooCodeInc#7714)
* chore: add changeset for v3.26.8 (RooCodeInc#7715)
* feat(checkpoints): create checkpoint when user sends a message (RooCodeInc#7713)
* feat(checkpoints): create checkpoint on user message send
* fix(checkpoints): suppress implicit user-message checkpoint row; keep current checkpoint updated without a chat row
* Fix checkpoint suppression for user messages
- Propagate suppressMessage flag through event chain properly
- Update ChatView to check checkpoint metadata for suppressMessage flag
- Ensure checkpoint messages are created but not rendered when suppressed
- Fix bug where checkpointSave(false) should have been checkpointSave(true)
* fix: only create checkpoint on user message when files have changed
- Changed allowEmpty from true to false in checkpointSave call
- Checkpoints will now only be created when there are actual file changes
- This avoids creating empty commits in the shadow git repository
* test: update checkpoint test to include suppressMessage parameter
- Fixed test expectation to match the new function signature
- saveCheckpoint now expects both allowEmpty and suppressMessage parameters
---------
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Hannes Rudolph <[email protected]>
Co-authored-by: Daniel Riccio <[email protected]>
* Bump to 3.27.0 (RooCodeInc#7719)
* Changeset version bump (RooCodeInc#7716)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Matt Rubens <[email protected]>
* fix: update DeepSeek pricing to new unified rates effective Sept 5, 2025 (RooCodeInc#7687)
- Updated deepseek-chat pricing: $0.56 input (cache miss), $0.07 (cache hit), $1.68 output
- Updated deepseek-reasoner pricing: same unified rates as deepseek-chat
- Both models now have identical pricing as per DeepSeek announcement
- Pricing takes effect at 16:00 UTC, Sept 5th, 2025
FixesRooCodeInc#7685
Co-authored-by: Roo Code <[email protected]>
* feat: replace cloud waitlist ad with direct Cloud link in navigation (RooCodeInc#7742)
Co-authored-by: Roo Code <[email protected]>
* feat: show dash instead of zero for missing data on evals page (RooCodeInc#7748)
Co-authored-by: Roo Code <[email protected]>
* Feature/update vertex ai models and regions (RooCodeInc#7727)
* Add model info to eval runs table (RooCodeInc#7749)
* chore(deps): update dependency eslint-config-prettier to v10.1.8 (RooCodeInc#6464)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
* chore(deps): update dependency esbuild to v0.25.9 (RooCodeInc#5455)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
* chore(deps): update dependency @changesets/cli to v2.29.6 (RooCodeInc#7376)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
* chore(deps): update dependency nock to v14.0.10 (RooCodeInc#6465)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
* chore(deps): update dependency eslint-plugin-turbo to v2.5.6 (RooCodeInc#7764)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
* refactor(utils): simplify shell detection logic
* Merge remote-tracking branch 'upstream/main' into roo-to-main
* test: update shell detection test expectation and mocks
* test: add mock cleanup in shell detection tests
* test: update shell detection tests to prioritize PowerShell 7
* fix(workspace-event-monitor): increase max retries and improve retry logic
* refactor(codebase): improve error handling and workspace validation
* Revert PR RooCodeInc#7188 - Restore temperature parameter to fix TabbyApi/ExLlamaV2 crashes (RooCodeInc#7594)
* fix: reduce CodeBlock button z-index to prevent overlap with popovers (RooCodeInc#7783)
FixesRooCodeInc#7703 - CodeBlock language dropdown and copy button were appearing above popovers due to z-index: 100. Reduced to z-index: 40 to maintain proper layering hierarchy while keeping buttons functional.
* Make ollama models info transport work like lmstudio (RooCodeInc#7679)
* feat: add click-to-edit, ESC-to-cancel, and fix padding consistency for chat messages (RooCodeInc#7790)
* feat: add click-to-edit, ESC-to-cancel, and fix padding consistency
- Enable click-to-edit for past messages by making message text clickable
- Add ESC key handler to cancel edit mode in ChatTextArea
- Fix padding consistency between past and queued message editors
- Adjust right padding for edit mode to accommodate cancel button
FixesRooCodeInc#7788
* fix: adjust padding and layout for ChatTextArea in edit mode
* refactor: replace hardcoded pr-[72px] with standard Tailwind pr-20 class
---------
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Hannes Rudolph <[email protected]>
Co-authored-by: daniel-lxs <[email protected]>
* Let people paste in the auth redirect url (RooCodeInc#7805)
Co-authored-by: roomote[bot] <219738659+roomote[bot]@users.noreply.github.com>
Co-authored-by: Bruno Bergher <[email protected]>
* test: change console.error to console.warn in tests
* fix: resolve chat message edit/delete duplication issues (RooCodeInc#7793)
* fix: add GIT_EDITOR env var to merge-resolver mode for non-interactive rebase (RooCodeInc#7819)
* UI: Render reasoning as plain italic (match <thinking>) (RooCodeInc#7752)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Hannes Rudolph <[email protected]>
Co-authored-by: daniel-lxs <[email protected]>
* Add taskSyncEnabled to userSettingsConfigSchema (RooCodeInc#7827)
feat: add taskSyncEnabled to userSettingsConfigSchema
Co-authored-by: Roo Code <[email protected]>
* Release: v1.75.0 (RooCodeInc#7829)
chore: bump version to v1.75.0
* fix: prevent negative cost values and improve label visibility in evals chart (RooCodeInc#7830)
Co-authored-by: Roo Code <[email protected]>
* Fix Groq context window display (RooCodeInc#7839)
* test: enhance vscode mock implementations and error handling
* feat(chat): replace edit button with copy functionality
* refactor(core): enhance binary file detection and encoding handling
* separate task sync roomote control (RooCodeInc#7799)
* feat: separate Task Sync and Roomote Control settings
- Add new taskSyncEnabled setting to control task content syncing
- Keep remoteControlEnabled for Roomote Control functionality
- Task Sync controls whether task content is sent to cloud
- Roomote Control controls whether cloud can send instructions back
- Roomote Control now depends on Task Sync being enabled
- Usage metrics (tokens, cost) always reported regardless of settings
- Update UI with two separate toggles and clear descriptions
- Add info text explaining usage metrics are always reported
* feat: add missing translations for Task Sync and Roomote Control settings
- Added taskSync, taskSyncDescription, remoteControlRequiresTaskSync, and usageMetricsAlwaysReported keys to all non-English cloud.json files
- Updated cloudBenefit keys to match English structure
- Ensured all languages have consistent translation keys for the new Task Sync and Roomote Control features
* Cloud: cleanup taskSyncEnabled additions
* fix: correct indentation localization files
---------
Co-authored-by: Roo Code <[email protected]>
* feat: In-extension dismissible upsells for Roo Code Cloud (RooCodeInc#7850)
* First pass at separate upsell dialog
* Revert PR RooCodeInc#7188 - Restore temperature parameter to fix TabbyApi/ExLlamaV2 crashes (RooCodeInc#7594)
* fix: reduce CodeBlock button z-index to prevent overlap with popovers (RooCodeInc#7783)
FixesRooCodeInc#7703 - CodeBlock language dropdown and copy button were appearing above popovers due to z-index: 100. Reduced to z-index: 40 to maintain proper layering hierarchy while keeping buttons functional.
* Make ollama models info transport work like lmstudio (RooCodeInc#7679)
* feat: add click-to-edit, ESC-to-cancel, and fix padding consistency for chat messages (RooCodeInc#7790)
* feat: add click-to-edit, ESC-to-cancel, and fix padding consistency
- Enable click-to-edit for past messages by making message text clickable
- Add ESC key handler to cancel edit mode in ChatTextArea
- Fix padding consistency between past and queued message editors
- Adjust right padding for edit mode to accommodate cancel button
FixesRooCodeInc#7788
* fix: adjust padding and layout for ChatTextArea in edit mode
* refactor: replace hardcoded pr-[72px] with standard Tailwind pr-20 class
---------
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Hannes Rudolph <[email protected]>
Co-authored-by: daniel-lxs <[email protected]>
* Let people paste in the auth redirect url (RooCodeInc#7805)
Co-authored-by: roomote[bot] <219738659+roomote[bot]@users.noreply.github.com>
Co-authored-by: Bruno Bergher <[email protected]>
* fix: resolve chat message edit/delete duplication issues (RooCodeInc#7793)
* fix: add GIT_EDITOR env var to merge-resolver mode for non-interactive rebase (RooCodeInc#7819)
* UI: Render reasoning as plain italic (match <thinking>) (RooCodeInc#7752)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Hannes Rudolph <[email protected]>
Co-authored-by: daniel-lxs <[email protected]>
* Add taskSyncEnabled to userSettingsConfigSchema (RooCodeInc#7827)
feat: add taskSyncEnabled to userSettingsConfigSchema
Co-authored-by: Roo Code <[email protected]>
* Release: v1.75.0 (RooCodeInc#7829)
chore: bump version to v1.75.0
* fix: prevent negative cost values and improve label visibility in evals chart (RooCodeInc#7830)
Co-authored-by: Roo Code <[email protected]>
* Fix Groq context window display (RooCodeInc#7839)
* feat: add DismissibleUpsell component for dismissible messages
- Created DismissibleUpsell component with variant support (banner/default)
- Added dismissedUpsells to GlobalState for persistence
- Implemented message handlers for dismissing and retrieving dismissed upsells
- Added comprehensive tests for the component
- Uses VSCode extension globalState for persistent storage
* fix: Apply PR feedback for DismissibleUpsell component
- Changed from className to separate 'id' and 'className' props for better semantics
- Added i18n support for accessibility labels (aria-label and title)
- Fixed memory leak by adding mounted flag to prevent state updates after unmount
- Fixed race condition by sending dismiss message before hiding component
- Fixed inefficient array operations in webviewMessageHandler
- Added comprehensive test coverage for edge cases including:
- Multiple rapid dismissals
- Component unmounting during async operations
- Invalid/malformed message handling
- Proper message sending before unmount
- Added null checks for message data to handle edge cases gracefully
* New Cloud upsell dialog in task share and cloud view, shared component
* Properly working DismissibleUpsell
* Working upsell for long-running tasks
* CTA in AutoApproveMenu
* Home page CTA
* Fixes the autoapprove upsell and some tests
* Visual and copy fixes
* Test fix
* Translations
* Stray className attribute
* Cloud view fixes in a left-aligned layout
* Removes unnecessary test
* Less flaky tests
* Fixes sharebutton behavior and updates associated tests
* Update webview-ui/src/i18n/locales/it/cloud.json
Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com>
* Fix dismissed flicker
* Fix long task upsell
---------
Co-authored-by: Daniel <[email protected]>
Co-authored-by: ItsOnlyBinary <[email protected]>
Co-authored-by: roomote[bot] <219738659+roomote[bot]@users.noreply.github.com>
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Hannes Rudolph <[email protected]>
Co-authored-by: daniel-lxs <[email protected]>
Co-authored-by: Matt Rubens <[email protected]>
Co-authored-by: John Richmond <[email protected]>
Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com>
* v3.28.0 (RooCodeInc#7858)
* Changeset version bump (RooCodeInc#7859)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Matt Rubens <[email protected]>
* feat(chat): add chat search functionality with highlighting
* feat: show notification when the checkpoint initialization fails (RooCodeInc#7766)
Co-authored-by: daniel-lxs <[email protected]>
* Bust cache in generated image preview (RooCodeInc#7860)
Co-authored-by: Roo Code <[email protected]>
* test: disable TaskHeader upsell tests
* test: refactor TaskHeader test file
* feat: Add cloud task button for opening tasks in Roo Code Cloud (RooCodeInc#7572)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Bruno Bergher <[email protected]>
Co-authored-by: Bruno Bergher <[email protected]>
* fix: center active mode in selector dropdown on open (RooCodeInc#7883)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: daniel-lxs <[email protected]>
* Make Posthog telemetry the default (RooCodeInc#7909)
Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com>
* Fix: Preserve first message during conversation condensing (RooCodeInc#7910)
* In-app announcement for Roo Code Cloud (RooCodeInc#7914)
Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com>
* chore: add changeset for v3.28.1 (RooCodeInc#7916)
* Changeset version bump (RooCodeInc#7917)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Matt Rubens <[email protected]>
* Remove Roo Code 3.25 release announcement
Removed the section about Roo Code 3.25 release notes.
* fix: restrict @-mention parsing to line-start or whitespace boundaries (RooCodeInc#7876)
Co-authored-by: Roo Code <[email protected]>
* Fix message queue re-queue loop in Task.ask() (RooCodeInc#7823)
* fix: preserve original first message context during conversation condensing (RooCodeInc#7939)
* Add a little padding to the cloudview (RooCodeInc#7954)
* test: increase test timeout configuration
* test(ci): enable translation check and optimize test workflow
* fix: make nested git repository warning persistent with path info (RooCodeInc#7885)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: daniel-lxs <[email protected]>
* fix: include API key in Ollama /api/tags requests (RooCodeInc#7903)
Co-authored-by: Roo Code <[email protected]>
* feat: add Qwen3 Next 80B A3B models to chutes provider (RooCodeInc#7948)
* ux: Smaller and more subtle auto-approve UI (RooCodeInc#7894)
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Hannes Rudolph <[email protected]>
Co-authored-by: daniel-lxs <[email protected]>
Co-authored-by: roomote[bot] <219738659+roomote[bot]@users.noreply.github.com>
Co-authored-by: Bruno Bergher <[email protected]>
Co-authored-by: Daniel <[email protected]>
Co-authored-by: ItsOnlyBinary <[email protected]>
Co-authored-by: Matt Rubens <[email protected]>
Co-authored-by: John Richmond <[email protected]>
* Disable Roomote Control on logout (RooCodeInc#7976)
* Remove chevrons from chat buttons (RooCodeInc#7970)
* chore: add changeset for v3.28.2 (RooCodeInc#7979)
* Changeset version bump (RooCodeInc#7980)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Matt Rubens <[email protected]>
* ux: Makes text area buttons appear only when there's text (RooCodeInc#7987)
* fix: corrected C# tree-sitter query (RooCodeInc#7813)
* feat: Move slash commands to Settings tab with gear icon for discoverability (RooCodeInc#7988)
Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com>
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: Bruno Bergher <[email protected]>
Co-authored-by: Mubeen Zulfiqar <[email protected]>
Co-authored-by: Matt Rubens <[email protected]>
* Add Z.ai coding plan support (RooCodeInc#8003)
* chore(deps): bump axios from 1.9.0 to 1.12.0 (RooCodeInc#7963)
Bumps [axios](https://github.com/axios/axios) from 1.9.0 to 1.12.0.
- [Release notes](https://github.com/axios/axios/releases)
- [Changelog](https://github.com/axios/axios/blob/v1.x/CHANGELOG.md)
- [Commits](axios/axios@v1.9.0...v1.12.0)
---
updated-dependencies:
- dependency-name: axios
dependency-version: 1.12.0
dependency-type: direct:production
...
Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
* Fix context menu is obscured when edit message. (RooCodeInc#7951)
* feat: add keyboard shortcut for "Add to Context" action (RooCodeInc#7908)
Co-authored-by: daniel-lxs <[email protected]>
Co-authored-by: Matt Rubens <[email protected]>
* fix: handle ByteString conversion errors in OpenAI embedders (RooCodeInc#8008)
* CONTRIBUTING.md tweaks and issue template rewrite (RooCodeInc#8014)
---------
Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: Matt Rubens <[email protected]>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Josh <[email protected]>
Co-authored-by: daniel-lxs <[email protected]>
Co-authored-by: cte <[email protected]>
Co-authored-by: Daniel <[email protected]>
Co-authored-by: ellipsis-dev[bot] <65095814+ellipsis-dev[bot]@users.noreply.github.com>
Co-authored-by: roomote[bot] <219738659+roomote[bot]@users.noreply.github.com>
Co-authored-by: Roo Code <[email protected]>
Co-authored-by: mrubens <[email protected]>
Co-authored-by: Hannes Rudolph <[email protected]>
Co-authored-by: Chris Hasson <[email protected]>
Co-authored-by: Chris Hasson <[email protected]>
Co-authored-by: John Richmond <[email protected]>
Co-authored-by: Piotr Wilkin (ilintar) <[email protected]>
Co-authored-by: Christiaan Arnoldus <[email protected]>
Co-authored-by: Bruno Bergher <[email protected]>
Co-authored-by: Mohammad Danaee nia <[email protected]>
Co-authored-by: 淡草 <[email protected]>
Co-authored-by: WangXiaolong <[email protected]>
Co-authored-by: Peter Dave Hello <[email protected]>
Co-authored-by: Thach Nguyen <[email protected]>
Co-authored-by: CellenLee <[email protected]>
Co-authored-by: NaccOll <[email protected]>
Co-authored-by: Ton Hoang Nguyen (Bill) <[email protected]>
Co-authored-by: ssweens <[email protected]>
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: ItsOnlyBinary <[email protected]>
Co-authored-by: Bruno Bergher <[email protected]>
Co-authored-by: Mubeen Zulfiqar <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
description: Report a specific problem that needs solving in Costrict
3
-
labels: ["proposal", "enhancement"]
1
+
name: Enhancement Request
2
+
description: Propose an improvement in plain language focused on user benefit
3
+
labels: ["enhancement"]
4
+
title: "[ENHANCEMENT] "
4
5
body:
5
6
- type: markdown
6
7
attributes:
7
8
value: |
8
-
**Thank you for submitting a feature request for Costrict!**
9
-
10
-
This template helps you describe problems that need solving. Focus on the problem - the Roo team will work to design solutions unless you want to contribute the implementation yourself.
11
-
12
-
**Quality over speed:** We prefer detailed, clear problem descriptions over quick ones. Vague requests often get closed or require multiple rounds of clarification, which wastes everyone's time.
13
-
14
-
**Before submitting:**
15
-
- Search existing [Issues](https://github.com/zgsm-ai/costrict/issues) and [Discussions](https://github.com/zgsm-ai/costrict/discussions) to avoid duplicates
16
-
- For general ideas, use [GitHub Discussions](https://github.com/zgsm-ai/costrict/discussions/categories/feature-requests) instead of this template.
9
+
Thank you for helping improve Costrict!
10
+
Please focus on the problem and the desired behavior in plain language.
17
11
18
-
- type: markdown
12
+
- type: textarea
13
+
id: problem
19
14
attributes:
20
-
value: |
21
-
## ❌ Common mistakes that lead to request rejection:
22
-
- **Vague problem descriptions:** "UI is bad" -> Should be: "Submit button is invisible on dark theme"
23
-
- **Missing user impact:** "This would be cool" -> Should explain who benefits and how
24
-
- **No specific context:** Describe exactly when and how the problem occurs
25
-
15
+
label: Problem (one or two sentences)
16
+
description: What problem are users facing?
17
+
placeholder: e.g., "Users often click Copy Run by mistake and duplicate runs unintentionally."
18
+
validations:
19
+
required: true
26
20
27
21
- type: textarea
28
-
id: problem-description
22
+
id: context
29
23
attributes:
30
-
label: What specific problem does this solve?
31
-
description: |
32
-
**Be concrete and detailed.** Explain the problem from a user's perspective.
33
-
34
-
✅ **Good examples (specific, clear impact):**
35
-
- "When running large tasks, users wait 5+ minutes because tasks execute sequentially instead of in parallel, blocking productivity"
36
-
- "AI can only read one file per request, forcing users to make multiple requests for multi-file projects, increasing wait time from 30s to 5+ minutes"
37
-
- "Dark theme users can't see the submit button because it uses white text on light grey background"
38
-
39
-
❌ **Poor examples (vague, unclear impact):**
40
-
- "The UI looks weird" -> What specifically looks weird? On which screen? What's the impact?
41
-
- "System prompt is not good" -> What's wrong with it? What behaviour does it cause? What should it do instead?
42
-
- "Performance could be better" -> Where? How slow is it currently? What's the user impact?
43
-
44
-
**Your problem description should answer:**
45
-
- Who is affected? (all users, specific user types, etc.)
46
-
- When does this happen? (specific scenarios/steps)
47
-
- What's the current behaviour vs expected behaviour?
48
-
- What's the impact? (time wasted, errors caused, etc.)
49
-
placeholder: Be specific about the problem, who it affects, and the impact. Avoid generic statements like "it's slow" or "it's confusing."
24
+
label: Context (who is affected and when)
25
+
description: Who encounters this and in what situation?
26
+
placeholder: e.g., "Happens when browsing the Runs list; most visible for new users."
50
27
validations:
51
28
required: true
52
29
30
+
- type: textarea
31
+
id: desired
32
+
attributes:
33
+
label: Desired behavior (conceptual, not technical)
34
+
description: Describe what should happen in simple terms.
35
+
placeholder: e.g., "Ask for confirmation before copying a run."
36
+
validations:
37
+
required: true
53
38
54
39
- type: textarea
55
-
id: additional-context
40
+
id: constraints
56
41
attributes:
57
-
label: Additional context (optional)
58
-
description: Mockups, screenshots, links, user quotes, or other relevant information that supports your proposal.
42
+
label: Constraints / preferences (optional)
43
+
description: Any considerations like performance, accessibility, or UX expectations.
44
+
placeholder: e.g., "Keep it quick and unobtrusive; keyboard accessible."
59
45
60
46
- type: checkboxes
61
47
id: checklist
@@ -64,128 +50,35 @@ body:
64
50
options:
65
51
- label: I've searched existing Issues and Discussions for duplicates
66
52
required: true
67
-
- label: This describes a specific problem with clear impact and context
53
+
- label: This describes a specific problem with clear context and impact
**🎯 Just reporting a problem?** You can click "Submit new issue" right now! The sections below are only needed if you want to contribute a solution via pull request.
78
-
79
-
**⚠️ Only continue if you want to:**
80
-
- Propose a specific solution design
81
-
- Implement the feature yourself via pull request
82
-
- Provide technical analysis to help with implementation
83
-
84
-
**For contributors who continue:**
85
-
- A maintainer (especially @hannesrudolph) will review this proposal. **Do not start implementation until approved and assigned.** We're a small team with limited resources, so every code addition needs careful consideration. We're always happy to receive clear, actionable proposals though!
86
-
- Join [Discord](https://discord.gg/roocode) and DM **Hannes Rudolph** (`hrudolph`) for guidance on implementation
87
-
- Check our [Roadmap](https://github.com/orgs/RooCodeInc/projects/1/views/1?query=sort%3Aupdated-desc+is%3Aopen&filterQuery=is%3Aissue%2Copen%2Cclosed+label%3A%22feature+request%22+status%3A%22Issue+%5BUnassigned%5D%22%2C%22Issue+%5BIn+Progress%5D%22) to see open feature requests ready to be implemented or currently being worked on
88
-
89
-
- type: checkboxes
90
-
id: willingness-to-contribute
91
-
attributes:
92
-
label: Interested in implementing this?
93
-
description: |
94
-
**Important:** If you check "Yes" below, the technical sections become REQUIRED.
95
-
We need detailed technical analysis from contributors to ensure quality implementation.
96
-
options:
97
-
- label: Yes, I'd like to help implement this feature
98
-
required: false
99
-
100
-
- type: checkboxes
101
-
id: implementation-approval
102
-
attributes:
103
-
label: Implementation requirements
104
-
options:
105
-
- label: I understand this needs approval before implementation begins
106
-
required: false
107
-
108
-
- type: textarea
109
-
id: proposed-solution
110
-
attributes:
111
-
label: How should this be solved? (REQUIRED if contributing, optional otherwise)
112
-
description: |
113
-
**If you want to implement this feature, this section is REQUIRED.**
114
-
115
-
**Describe your solution in detail.** Explain not just what to build, but how it should work.
116
-
117
-
✅ **Good examples:**
118
-
- "Add parallel task execution: Allow up to 3 tasks to run simultaneously with a queue system for additional tasks. Show progress for each active task in the UI."
119
-
- "Enable multi-file AI processing: Modify the request handler to accept multiple files in a single request and process them together, reducing round trips."
120
-
- "Fix button contrast: Change submit button to use primary colour on dark theme (white text on blue background) instead of current grey."
121
-
122
-
❌ **Poor examples:**
123
-
- "Make it faster" -> How? What specific changes?
124
-
- "Improve the UI" -> Which part? What specific improvements?
125
-
- "Fix the prompt" -> What should the new prompt do differently?
126
-
127
-
**Your solution should explain:**
128
-
- What exactly will change?
129
-
- How will users interact with it?
130
-
- What will the new behaviour look like?
131
-
placeholder: Describe the specific changes and how they will work. Include user interaction details if relevant.
60
+
Optional (for contributors): You can stop here if you're just proposing the improvement.
132
61
133
62
- type: textarea
134
63
id: acceptance-criteria
135
64
attributes:
136
-
label: How will we know it works? (Acceptance Criteria - REQUIRED if contributing, optional otherwise)
137
-
description: |
138
-
**If you want to implement this feature, this section is REQUIRED.**
139
-
140
-
**This is crucial - don't skip it.** Define what "working" looks like with specific, testable criteria.
141
-
142
-
**Format suggestion:**
143
-
```
144
-
Given [context/situation]
65
+
label: Acceptance criteria (optional)
66
+
description: Define what “working” looks like with specific, testable outcomes.
67
+
placeholder: |
68
+
Given [context]
145
69
When [user action]
146
70
Then [expected result]
147
71
And [additional expectations]
148
72
But [what should NOT happen]
149
-
```
150
-
151
-
**Example:**
152
-
```
153
-
Given I have 5 large tasks to run
154
-
When I start all of them
155
-
Then they execute in parallel (max 3 at once, can be configured)
156
-
And I see progress for each active task
157
-
And queued tasks show "waiting" status
158
-
But the UI doesn't freeze or become unresponsive
159
-
```
160
-
placeholder: |
161
-
Define specific, testable criteria. What should users be able to do? What should happen? What should NOT happen?
162
-
Use the Given/When/Then format above or your own clear structure.
163
73
164
74
- type: textarea
165
-
id: technical-considerations
75
+
id: proposed-solution
166
76
attributes:
167
-
label: Technical considerations (REQUIRED if contributing, optional otherwise)
168
-
description: |
169
-
**If you want to implement this feature, this section is REQUIRED.**
170
-
171
-
Share technical insights that could help planning:
172
-
- Implementation approach or architecture changes
173
-
- Performance implications
174
-
- Compatibility concerns
175
-
- Systems that might be affected
176
-
- Potential blockers you can foresee
177
-
placeholder: e.g., "Will need to refactor task manager", "Could impact memory usage on large files", "Requires a large portion of code to be rewritten"
77
+
label: Proposed approach (optional)
78
+
description: If you have an idea, describe it briefly in plain language.
178
79
179
80
- type: textarea
180
-
id: trade-offs-and-risks
81
+
id: risks
181
82
attributes:
182
-
label: Trade-offs and risks (REQUIRED if contributing, optional otherwise)
183
-
description: |
184
-
**If you want to implement this feature, this section is REQUIRED.**
185
-
186
-
What could go wrong or what alternatives did you consider?
187
-
- Alternative approaches and why you chose this one
0 commit comments