5a7c099
sidebar: `ProjectGroup` -> `Project` rename (#53364)
Cameron Mcloughlin created
5a7c099
sidebar: `ProjectGroup` -> `Project` rename (#53364)
Cameron Mcloughlin created
d2f0452
collab: Remove incoming invite badge count from panel icon (#53363)
Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Release Notes: - N/A or Added/Fixed/Improved ...
Anthony Eid created
4a5826b
Make deserialization a bit more resilient to data changes (#53362)
This PR makes sidebar deserialization enforce the invariants that the multiworkspace is supposed to enforce. Also, this PR makes it so that failing to deserialize the active workspace no longer totally fails to deserialize the multiworkspace. Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Release Notes: - N/A
Mikayla Maki created
a43ee6b
Inherit parent thread settings when spawning subagents (#53328)
When a subagent was spawned while the parent had runtime-modified settings (fast mode, thinking, etc.), the subagent would start with defaults from `AgentSettings` instead of inheriting the parent's current values. This adds `inherit_parent_settings` as a single place in `Thread::new_subagent` that copies all runtime-mutable settings from the parent: - `speed` - `thinking_enabled` - `thinking_effort` - `summarization_model` - `profile_id` These are the same properties that `set_*` methods already propagate to `running_subagents` — this fix ensures they're also inherited at creation time. cc @benbrandt Release Notes: - N/A
Nathan Sobo created
871a342
agent_panel: Add some UI fixes post max-width introduction (#53352)
Quick follow up to https://github.com/zed-industries/zed/pull/52730 with some adjustments. Ended up cleaning some unused UI elements already (i.e., the "Recent" history items in the agent panel's empty state). Release Notes: - N/A
Danilo Leal created
ac6117a
Fix shell escaping in getting current env (#53335)
Credit to Dario Weißer for bringing this to our attention. Self-Review Checklist: - [ ] I've reviewed my own diff for quality, security, and reliability - [ ] Unsafe blocks (if any) have justifying comments - [ ] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [ ] Tests cover the new/changed behavior - [ ] Performance impact has been considered and is acceptable Closes #ISSUE Release Notes: - Fixed a bug where a cleverly crafted directory name could lead to remote code execution
Conrad Irwin created
30e7e8b
Adjust worktree name display in agent panel and git picker (#53351)
This PR adjust the name of the worktree within the agent panel: we display `main` if you're in the main worktree and then the worktree name when in a linked one. Additionally, I also took the opportunity to fix something that confused me in the general worktree picker: for the list item that represented the main worktree, we were using the current checked out branch name for that item's name. I think that's a bit incorrect, given the _name_ of that worktree isn't the name of the branch you have active at that moment. For now, I'm using simply `main` as the worktree name. Lastly, also added a little blue check icon in the worktree _and branch_ picker to highlight which worktree/branch is currently active. | main worktree | linked worktree | main worktree in picker | |--------|--------|--------| | <img width="802" height="338" alt="Screenshot 2026-04-07 at 10 32 2@2x" src="https://github.com/user-attachments/assets/aad993e6-adc3-4c8d-b01a-abb2597182e7" /> | <img width="804" height="332" alt="Screenshot 2026-04-07 at 10 32@2x" src="https://github.com/user-attachments/assets/e59c5b86-8cee-476c-ab7b-32ae87249c1a" /> | <img width="804" height="856" alt="Screenshot 2026-04-07 at 10 36@2x" src="https://github.com/user-attachments/assets/282d89a8-570e-4e62-b703-853bed9b21ff" /> | Release Notes: - Git: Fixed display of the main worktree name in the worktree picker.
Danilo Leal created
a5aea73
agent: Fix panel prompt footer layout in full screen (#53349)
### Summary Keep the prompt editor’s max-width centering, but move the footer controls out of the same flexible wrapper as the full-height editor and add `min_h_0()` shrink guards so the editor no longer overlaps the footer in zoomed/full-screen mode. #### Before <img width="1624" height="1061" alt="Screenshot 2026-04-07 at 8 39 03 PM" src="https://github.com/user-attachments/assets/db889fcd-af8a-4297-a1f9-0acb84e6ead3" /> #### After <img width="1624" height="976" alt="Screenshot 2026-04-07 at 9 14 52 PM" src="https://github.com/user-attachments/assets/ddae7fd4-e720-432d-b84d-45f667aa7dce" /> Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Closes #ISSUE Release Notes: - N/A or Added/Fixed/Improved ...
Anthony Eid created
a0d0195
Add onboarding for parallel agents (#52940)
Release Notes: - N/A --------- Co-authored-by: Eric Holk <eric@zed.dev> Co-authored-by: Bennet Bo Fenner <bennetbo@gmx.de> Co-authored-by: Katie Geer <katie@zed.dev>
Danilo Leal , Eric Holk , Bennet Bo Fenner , and Katie Geer created
bf9cea6
agent_panel: Fix bug where worktree picker showed linked tree as main (#53334)
Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Closes #ISSUE Release Notes: - N/A or Added/Fixed/Improved ...
Anthony Eid created
7bcdb12
Remove Agent V2 feature flag (#52792)
It's happening. Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Release Notes: - N/A
Mikayla Maki created
66d2cb2
Adjust `zed -n` behavior (#53346)
When there's already a workspace that matches the paths provided, activate that workspace, otherwise create a new window. This is different from the default behavior of always adding to the sidebar. Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Release Notes: - N/A
Eric Holk created
2d1137c
docs: Update models page with new GPT models and corrected pricing (#53344)
Syncs the models docs page with what `crates/billing/src/plans.rs` and `crates/llm_api/src/features/list_models.rs` actually serve. ## Changes **New models added:** - GPT-5.4 pro (Pro/Business only): $30/$180 input/output, no cache, 400k context - GPT-5.4: $2.50/$15 input/output, $0.025 cached, 400k context - GPT-5.3-Codex: $1.75/$14 input/output, $0.175 cached, 400k context **Pricing corrected:** - GPT-5.2 + GPT-5.2-Codex: input $1.25 → $1.75, output $10 → $14, cached $0.125 → $0.175 - Gemini 3 Flash: input $0.30 → $0.50, output $2.50 → $3.00 **Other fixes:** - Student plan note updated to include GPT-5.4 pro restriction - Grok context windows added to the context window table (128k / 256k for Grok Code Fast 1) - "GPT-5.2 Codex" renamed to "GPT-5.2-Codex" to match `display_name` in code - Removed retired "Gemini 3 Pro" from context window footnote Release Notes: - N/A
morgankrey created
972731c
theme_selector: Preserve selected theme after empty filter (#52461)
When filtering themes with a query that matches nothing (e.g., "zzz"), `show_selected_theme` returned `None` and overwrote `selected_theme`. Clearing the filter then lost track of the previous selection and defaulted to index 0. The fix only updates `selected_theme` when `show_selected_theme` returns `Some`. Same change in both the theme selector and the icon theme selector. ## Context When `update_matches` runs a filter that yields zero results, `show_selected_theme` returns `None`. The old code unconditionally assigned that back to `selected_theme`, wiping out the previous selection. When the user clears the filter, the selector falls into the `query.is_empty() && selected_theme.is_none()` branch and resets to index 0 instead of restoring the original pick. ## Demo ### Before: https://github.com/user-attachments/assets/62b1531b-d059-4f30-b1f4-a830f2d13a09 ### After: https://github.com/user-attachments/assets/72348666-8dbb-4f35-9446-fa2618340b6c ## How to review The fix is the same one-line change in two files: 1. `crates/theme_selector/src/theme_selector.rs` — line 458 2. `crates/theme_selector/src/icon_theme_selector.rs` — line 272 The rest is test infrastructure: 3. `crates/theme/src/registry.rs` — `register_test_themes` / `register_test_icon_themes` helpers 4. Tests in both selector files covering the empty filter → clear filter flow ## Self-review checklist - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable ## Release notes - Fixed theme selector losing the selected theme after filtering with a query that matches nothing and then clearing the filter.
João Soares created
aa81505
multibuffer: Speed up anchor resolution by avoiding an excerpts seek (#53340)
Before, every creation of `AnchorSeekTarget` called `MultiBufferSnapshot::buffer_for_path`, which seeks the excerpts sum tree. Now we avoid that by - looking up the buffer snapshot for the anchor's buffer in the `buffers` map (keyed by `BufferId`) - handling the case where the anchor's buffer doesn't exist at the original path key with a separate `AnchorSeekTarget::Missing` variant We also added a separate optimization to `AnchorSeekTarget::cmp`, to skip the full `PathKey` comparison when the cursor's `PathKeyIndex` is the same as the anchor's. This should help with singleton multibuffers. Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Release Notes: - N/A --------- Co-authored-by: Anthony Eid <hello@anthonyeid.me>
Cole Miller and Anthony Eid created
36a23c2
Reduce agent spinner GPU usage (#51756)
Closes #39532 ## Summary Move the long-running agent "generating" spinner into a dedicated `GeneratingSpinner` view. Previously, the generating state rendered `SpinnerLabel` inline as part of the full thread view. This change keeps the same spinner styling, but isolates it into its own small view so the animation no longer needs to live directly inside the larger thread UI subtree while the agent is running. before: <img width="398" height="448" alt="image" src="https://github.com/user-attachments/assets/8a56c394-f7a6-4835-b877-fbc1500d2d03" /> after: <img width="524" height="597" alt="image" src="https://github.com/user-attachments/assets/bd2e5804-dba8-49c0-a421-7dc5ba600348" /> ## Testing - `cargo run -j 4 ~/Downloads/WorkSpace/zed/` - `cargo check -p agent_ui` Release Notes: - Fixed high GPU usage from the agent panel's generating spinner while an agent is running. --------- Co-authored-by: Anthony Eid <anthony@zed.dev>
PuQing and Anthony Eid created
fd667f6
repl: Add notebook command/edit modes and keybindings (#51194)
- Introducing NotebookMode state and handlers (EnterEditMode, EnterCommandMode, RunAndAdvance). - Wire up UI to switch modes,focus editors appropriately, and advance selection while in command mode. - Update default and vim keymaps to use the new bindings (shift-enter runs+advances, escape enters command mode, and enter/up/down work in command mode). - Reveal and Focus the new Cell when inserted Before you mark this PR as ready for review, make sure that you have: - [x] Added a solid test coverage and/or screenshots from doing manual testing - [x] Done a self-review taking into account security and performance aspects - [x] Aligned any UI changes with the [UI checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) Release Notes: - N/A
MostlyK created
f2ef434
Add ArchivedGitWorktree data model and DB operations (#53214)
Add the persistence layer for tracking archived git worktrees: - `ArchivedGitWorktree` struct with `staged_commit_hash` and `unstaged_commit_hash` fields to precisely identify WIP commits - DB migrations for `archived_git_worktrees` and `thread_archived_worktrees` (join table) tables - CRUD operations: create, link to thread, query by thread, delete, mark as restored - `Column` impl for deserializing `ArchivedGitWorktree` from DB rows - Tests for two-SHA round-trip, create/retrieve, delete, restore flag, multi-thread linking, and multiple worktrees per thread Part 2 of 3 in the persist-worktree stack. Stacked on #53213. This is pure data model — nothing is wired up yet. Release Notes: - N/A --------- Co-authored-by: Anthony Eid <anthony@zed.dev>
Richard Feldman and Anthony Eid created
29c965a
ci: Add workflow dispatch trigger for compliance workflow (#53327)
Also refines the reporting a bit. Release Notes: - N/A
Finn Evers created
e0272ca
sidebar: Restore keyboard affordances (#53312)
Cameron Mcloughlin created
358a796
Appropriately deserialize app_port in devcontainer.json (#53322)
Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Closes #53263 Properly deserializes the app_port field, even if it is an array of strings. Also, removes app_port from consideration when building a docker-compose-based dev container, since the spec specifies that it only applies to non-docker-compose dev containers. Release Notes: - Fixed app_port deserialization in dev container
KyleBarton created
58ef3fa
keymaps: Avoid capturing ctrl-r in the terminal (#53301)
Update macOS and Linux's default keymaps such that, in the `Terminal` context, `ctrl-r` does send the `ctrl-r` keystrokes. This was no longer the case with recent changes to enable `ctrl-r` to map to `projects::OpenRecent` which prevented users to use history search in shells like bash and zsh, for example. Release Notes: - N/A
Dino created
eb78326
agent_panel: Refine git pickers design in the empty thread view (#53324)
Follow-up to https://github.com/zed-industries/zed/pull/52979 with some design refinements. Release Notes: - N/A --------- Co-authored-by: cameron <cameron.studdstreet@gmail.com> Co-authored-by: Anthony Eid <hello@anthonyeid.me>
Danilo Leal , cameron , and Anthony Eid created
082950d
sidebar: Fixes around multi-root projects (#53276)
When a project mixes main repo worktrees (e.g. `extensions`) with linked git worktrees (e.g. `zed4`, a linked worktree of `zed`), two things were broken: 1. **Threads appeared under the wrong sidebar heading.** A thread created in a workspace with both `extensions` and `zed4` would show under the "zed" group instead of the "extensions, zed" group. This happened because `main_worktree_paths` in `ThreadMetadata` was only populated with paths from linked worktrees, omitting regular repos entirely. The fix uses `project_group_key()` to normalize all visible worktrees to their main repo paths — the same normalization the sidebar uses for group headers. 2. **The worktree chip tooltip only showed linked worktree paths**, missing main repo paths like `extensions`. This happened because `worktree_info_from_thread_paths` filtered out main worktree paths entirely. The fix introduces a `WorktreeKind` enum (`Main` / `Linked`) on `ThreadItemWorktreeInfo`, so all worktrees are included in the data model. Chips still only render for `Linked` worktrees (main worktrees are redundant with the group header), but the tooltip now shows all paths. Release Notes: - N/A
Eric Holk created
70d6c2b
git_graph: Show propagated errors from git binary command (#53320)
Based on commit fba49809b39b0f9e58d68e3956f5c24fd47121d7 that I worked with Dino on in PR: #50288 Co-authored-by Dino \<Dino@zed.dev\> Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Closes #ISSUE Release Notes: - N/A or Added/Fixed/Improved ...
Anthony Eid created
4f3e4d2
Stop highlighting selection matches in the search inputs (#53307)
Follow-up of https://github.com/zed-industries/zed/pull/52553 Restores previous search inputs' behavior where no extra highlights were applied. Before: https://github.com/user-attachments/assets/38b6e70c-d5d5-4e06-abec-97d20af44f39 After: https://github.com/user-attachments/assets/6e4b3931-adf0-4c2a-afc3-f3c839fc9add Release Notes: - N/A
Kirill Bulatov created
0de9b55
Save Settings text inputs on blur (#53036)
Co-authored-by: Anthony Eid <hello@anthonyeid.me>
Chris Biscardi and Anthony Eid created
c5845ec
Remove notification panel (#50204)
After chat functionality was removed, this panel became redundant. It only displayed three notification types: incoming contact requests, accepted contact requests, and channel invitations. This PR moves those notifications into the collab experience by adding toast popups and a badge count to the collab panel. It also removes the notification-panel-specific settings, documentation, and Vim command. Before you mark this PR as ready for review, make sure that you have: - [ ] Added a solid test coverage and/or screenshots from doing manual testing - [x] Done a self-review taking into account security and performance aspects - [x] Aligned any UI changes with the [UI checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) Release Notes: - Removed the notification panel from Zed
Anthony Eid created
4386766
Add query and search options to pane::DeploySearch action (#47331)
Extend the DeploySearch action to accept additional parameters for
configuring the project search from keymaps:
- query: prefilled search query string
- regex: enable regex search mode
- case_sensitive: match case exactly
- whole_word: match whole words only
- include_ignored: search in gitignored files
With this change, the following keymap becomes possible:
```json
["pane::DeploySearch", { "query": "TODO|FIXME|NOTE|BUG|HACK|XXX|WARN", "regex": true }],
```
Release Notes:
- Added options to `pane::DeploySearch` for keymap-driven search
initiation
Jozsef Lazar created
833a015
recent_projects: Make the currently active project visible in the picker (#53302)
This PR improves the recent projects picker in the context of multi-workspace: - The currently active project now appears in the "This Window" section with a checkmark indicator. Clicking it simply dismisses the picker, since there's nothing to switch to. This feels like a better UX because it gives you visual confirmation of where you are. - The remove button is hidden for the current project entry, both in the row and the footer, to prevent accidentally removing the workspace you're actively using. - The "Add to Workspace" button now uses a more descriptive icon (`FolderOpenAdd`) and shows a meta tooltip clarifying that it adds the project as a multi-root folder project. The primary click/enter behavior remains unchanged—it opens the selected project in the current window's multi-workspace. The "Open in New Window" action continues to be available via the icon button or shift+enter. Release Notes: - Improved the recent projects picker to show the currently active project in the "This Window" section with a checkmark indicator.
Danilo Leal created
d3a9d5f
sidebar: Drop test cases (#53315)
Cameron Mcloughlin created
98c17ca
language_models: Refactor deps and extract cloud (#53270)
- `language_model` no longer depends on provider-specific crates such as `anthropic` and `open_ai` (inverted dependency) - `language_model_core` was extracted from `language_model` which contains the types for the provider-specific crates to convert to/from. - `gpui::SharedString` has been extracted into its own crate (still exposed by `gpui`), so `language_model_core` and provider API crates don't have to depend on `gpui`. - Removes some unnecessary `&'static str` | `SharedString` -> `String` -> `SharedString` conversions across the codebase. - Extracts the core logic of the cloud `LanguageModelProvider` into its own crate with simpler dependencies. Release Notes: - N/A --------- Co-authored-by: John Tur <john-tur@outlook.com>
Agus Zubiaga and John Tur created
a856093
sidebar: Fix focus movement while toggling it on and off (#53283)
I was testing out the changes in https://github.com/zed-industries/zed/pull/52730 and realized that the agent panel, when full screen, would be auto-dismissed if I toggled the sidebar off. Turns out this happens because we were "hard-coding" the focus back to the center pane, which was automatically dismissing zoomed items. So, in this PR, I essentially am copying the ModalLayer approach of storing whatever was focused before so we can return focus back to it if possible. Release Notes: - N/A
Danilo Leal created
3ed1c32
editor: Fix diagnostic rendering when semantic tokens set to full (#53008)
Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [ ] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Closes #50212 There are two unreasonable coupling account for this issue, the coupling of `use_tree_sitter` with `languge_aware` in https://github.com/zed-industries/zed/blob/7892b932795911516f26f3c1c1c72249ed181ba8/crates/editor/src/element.rs#L3820-L3822 and the coupling of `language_aware` with `diagnostics` in https://github.com/zed-industries/zed/blob/7892b932795911516f26f3c1c1c72249ed181ba8/crates/language/src/buffer.rs#L3736-L3746 Because of these couplings, when the editor stops using Tree-sitter highlighting when `"semantic_tokens"` set to `"full"`, it also accidentally stops fetching diagnostic information. This is why error and warning underlines disappear. I’ve fixed this by adding a separate `use_tree_sitter` parameter to `highlighted_chunks`. This way, we can keep `language_aware` true to get the diagnostic data we need, but still decide whether or not to apply Tree-sitter highlights. I chose to fix this at the `highlighted_chunks` level because I’m worried that changing the logic in the deeper layers of the DisplayMap or Buffer might have too many side effects that are hard to predict. This approach feels like a safer way to solve the problem. Release Notes: - Fixed a bug where diagnostic underlines disappeared when "semantic_tokens" set to "full" --------- Co-authored-by: Kirill Bulatov <kirill@zed.dev>
Xin Zhao and Kirill Bulatov created
8292ab4
collab_panel: Make channel items have a fixed height (#53304)
Follow-up to https://github.com/zed-industries/zed/pull/53290 This PR fixes a mistake I pushed before of making the `ListItem`'s height method take pixels instead of a scalable unit like rems. Now, it takes `DefiniteLength` which can house both values, meaning we should be clear to set an explicit height for all of these items while still preserving font-size scaling. Release Notes: - N/A
Danilo Leal created
0bde509
agent_ui: Set max-width for thread view content (#52730)
This PR adds a configurable max-width to the agent panel. This will be particularly useful when opting into an agentic-first layout where the thread will be at the center of the UI (with the panel most likely full-screen'ed, which is why I'm also adding here the button to make it full screen in the toolbar). The default max-width is 850, which is a bit bigger than the one generally considered as a standard (~66 characters wide, which usually sums up to 750 pixels). Release Notes: - Agent: Added a max-width to the thread view for better readability, particularly when the panel is zoomed in.
Danilo Leal created
eaf14d0
gpui: Fix SVG renderer not rendering text when system fonts are unavailable (#51623)
Closes #51466 Before you mark this PR as ready for review, make sure that you have: - [x] Added a solid test coverage and/or screenshots from doing manual testing - [x] Done a self-review taking into account security and performance aspects - [ ] Aligned any UI changes with the [UI checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) Release Notes: - Fixed mermaid diagrams not showing text in markdown preview by bundling fallback fonts and fixing generic font family resolution in the SVG renderer.
João Soares created
1dc3bb9
Fix pane::RevealInProjectPanel to focus/open project panel for non-project buffers (#51246)
Update how `workspace::pane::Pane` handles the `RevealInProjectPanel` action so as to display a notification when the user attempts to reveal an unsaved buffer or a file that does not belong to any of the open projects. Closes #23967 Release Notes: - Update `pane: reveal in project panel` to display a notification when the user attempts to use it with an unsaved buffer or a file that is not part of the open projects --------- Signed-off-by: Pratik Karki <pratik@prertik.com> Co-authored-by: dino <dinojoaocosta@gmail.com>
Pratik Karki and dino created
9343882
Add fuzzy_nucleo crate for order independent file finder search (#51164)
Closes #14428 Before you mark this PR as ready for review, make sure that you have: - [ ] Added a solid test coverage and/or screenshots from doing manual testing https://github.com/user-attachments/assets/7e0d67ff-cc4e-4609-880d-5c1794c64dcf - [x] Done a self-review taking into account security and performance aspects - [x] Aligned any UI changes with the [UI checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) Release Notes: - Adds a new `fuzzy_nucleo` crate that implements order independent path matching using the `nucleo` library. currently integrated for file finder. --------- Signed-off-by: Bhuminjay <bhuminjaysoni@gmail.com> Signed-off-by: 11happy <soni5happy@gmail.com>
Bhuminjay Soni created
9c73164
bedrock: Add new Bedrock models (NVIDIA, Z.AI, Mistral, MiniMax) (#53043)
Add 9 new models across 3 new providers (NVIDIA, Z.AI) and expanded coverage for existing providers (Mistral, MiniMax): - NVIDIA Nemotron Super 3 120B, Nemotron Nano 3 30B - Mistral Devstral 2 123B, Ministral 14B - MiniMax M2.1, M2.5 - Z.AI GLM 5, GLM 4.7, GLM 4.7 Flash Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Closes #ISSUE Release Notes: - bedrock: Added 9 new models across 3 new providers (NVIDIA, Z.AI) and expanded coverage for existing providers (Mistral, MiniMax)
Shardul Vaidya created
ccb9e60
agent_panel: Add new thread git worktree/branch pickers (#52979)
This PR allows users to create a new thread based off a git worktree that already exists or has a custom name. User's can also choose what branch they want the newly generated worktree to be based off of. The UI still needs some polish, but I'm merging this early to get the team using this before our preview launch. I'll be active today and tomorrow before launch to fix any nits we have with the UI. Functionality of this feature works! And I have a basic test to prevent regressions Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Closes #ISSUE Release Notes: - N/A or Added/Fixed/Improved ... --------- Co-authored-by: cameron <cameron.studdstreet@gmail.com>
Anthony Eid and cameron created
614f67e
markdown_preview: Fix HTML alignment styles not being applied (#53196)
## What This PR Does This PR adds support for HTML alignment styles to be applied to Paragraph and Heading elements and their children. Here is what this looks like before vs after this PR (both images use the same markdown below): ```markdown <p style="text-align: center;"> <a target="_blank" href="https://github.com/"><img width="150" height="150" src="https://upload.wikimedia.org/wikipedia/commons/c/c2/GitHub_Invertocat_Logo.svg"></a> </p> ``` **BEFORE:** <img width="742" height="242" alt="image" src="https://github.com/user-attachments/assets/4ca8b8d9-0606-45f5-8a0e-cafaaac47d97" /> **AFTER:** <img width="1274" height="267" alt="image" src="https://github.com/user-attachments/assets/2c347ce7-75b9-4ef6-9598-b1eda7272ef5" /> ## Notes I used `style="text-align: center|left|right;"` instead of `align="center|right|left"` since `align` has been [deprecated in HTML5](https://www.w3.org/TR/2011/WD-html5-author-20110809/obsolete.html) for block-level elements. The issue this PR solves mentioned that github supports the `align="center|right|left"` attribute, so I'm unsure if the Zed team would want to have parity there. Feel free to let me know if that would be something that should be added, however for now I've decided to follow the HTML5 standard. Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Closes https://github.com/zed-industries/zed/issues/51062 Release Notes: - Fixed HTML alignment styles not being applied in markdown previews --------- Co-authored-by: Smit Barmase <heysmitbarmase@gmail.com>
Angel P. and Smit Barmase created
ee6495d
collab: Fix UI font size scaling (#53290)
Cameron Mcloughlin created
818991d
tasks_ui: Fix previously used task tooltip (#53104)
Closes #52941 ## Summary - update the task picker delete button tooltip to describe the recently used task entry it removes - keep the change scoped to the inaccurate user-facing copy in the tasks modal ## Testing - cargo test -p tasks_ui Release Notes: - N/A
Saketh created
6f7fab1
http_client: Fix GitHub download unpack failures on some filesystems (#53286)
Disable mtime preservation when unpacking tar archives, as some filesystems error when asked to set it. Follows how [cargo](https://github.com/rust-lang/cargo/blob/1ad92f77a819953bcef75a24019b66681ff28b1c/src/cargo/ops/cargo_package/verify.rs#L59 ) and [uv](https://github.com/astral-sh/uv/blob/0da0cd8b4310d3ac4be96223bd1e24ada109af9e/crates/uv-extract/src/stream.rs#L658) handle it. > Caused by: 0: extracting https://github.com/microsoft/vscode-eslint/archive/refs/tags/release%2F3.0.24.tar.gz to "/Users/user-name-here/Library/Application Support/Zed/languages/eslint/.tmp-github-download-pYkrYP" 1: failed to unpack `/Users/user-name-here/Library/Application Support/Zed/languages/eslint/.tmp-github-download-pYkrYP/vscode-eslint-release-3.0.24/package-lock.json` 2: failed to set mtime for `/Users/user-name-here/Library/Application Support/Zed/languages/eslint/.tmp-github-download-pYkrYP/vscode-eslint-release-3.0.24/package-lock.json` 3: No such file or directory (os error 2) Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Release Notes: - N/A
Smit Barmase created
24a6008
repl: Improve iopub connection error messages (#53014)
Coming from #51834, these would be more helpful than just that it failed! Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Release Notes: - N/A
MostlyK created
2aa1559
agent_ui: Add padding to markdown output in card layout (#53194)
Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [x] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Closes #53191 Release Notes: - Added padding to markdown output when rendered in card layout. Before: <img width="627" height="437" alt="Screenshot 2026-04-01 at 3 32" src="https://github.com/user-attachments/assets/6fbd31f0-80b5-4c63-b9a4-d151bd28cf31" /> After: <img width="666" height="400" alt="Screenshot 2026-04-05 at 4 47 38 PM" src="https://github.com/user-attachments/assets/3128532a-bfcf-4308-aec5-3981201001ab" />
Markos Narinian created
092c705
vim: Fix % for multiline comments and preprocessor directives (#53148)
Implements: [49806](https://github.com/zed-industries/zed/discussions/49806) Closes: [24820](https://github.com/zed-industries/zed/issues/24820) Zeds impl of `%` didn't handle preprocessor directives and multiline To implement this feature for multiline comment, a tree-sitter query is used to check if we are inside a comment range and then replicate the logic used in brackets. For preprocessor directives using `TextObjects` wasn't a option, so it was implemented through a text based query that searches for the next preprocessor directives. Using text based queries might not be the best for performance, so I'm open to any suggestions. Release Notes: - Fixed vim's matching '%' to handle multiline comments `/* */` and preprocessor directives `#if #else #endif`.
Juan Pablo Briones created
46fc693
vim: Add editor setting for changing regex mode default in vim searches (#53092)
Closes #48007 Release Notes: - Added editor setting for changing regex mode default in vim searches Summary: - Based on the report in #48007 and the discussion here https://github.com/zed-industries/zed/pull/48127#issuecomment-3838678903 - There was feedback mentioning that vim-mode needs to default vim-searches to use regex-mode (even when the editor regex-search setting is disabled). However, it was suggested that a vim search setting could be configured to adjust this behaviour. - In this PR a new vim setting was added to change whether vim-searches will use regex-mode by default, so now users can can configure vim-search to not use regex-mode when typing the `/` character (or using the vim search command). Screen Captures: https://github.com/user-attachments/assets/172669fb-ab78-41a1-9485-c973825543c5
Sean Hagstrom created
9c5f3b1
terminal_view: Reset cursor blink on `SendText` and `SendKeystroke` actions (#53171)
Self-Review Checklist: - [x] I've reviewed my own diff for quality, security, and reliability - [x] Unsafe blocks (if any) have justifying comments - [x] The content is consistent with the [UI/UX checklist](https://github.com/zed-industries/zed/blob/main/CONTRIBUTING.md#uiux-checklist) - [ ] Tests cover the new/changed behavior - [x] Performance impact has been considered and is acceptable Closes #53115 Release Notes: - Fixed terminal cursor blink not resetting when navigating with action-bound keys (e.g., alt+left/right on macOS, alt+b/f on Linux) ## Demo ### Before the fix The cursor stays invisible after word-jumping because the blink cycle keeps going without resetting. https://github.com/user-attachments/assets/00dbdba6-d793-4a23-abcc-37887f4d1262 ### After the fix The cursor shows up at the new position right after each word-jump, then blinks again as expected. https://github.com/user-attachments/assets/48d5906c-4899-4f4a-adbd-5908ebea0cfb
João Soares created