mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-12 21:32:40 +00:00
Fix focus and re-focus of project-wide search (#4121)
This fixes the issue of `Cmd-shift-f` not refocusing the search bar when a project-wide search already exists. It also fixes the handlers for "search in new" and "new search". Release Notes: - N/A
This commit is contained in:
commit
87046eff3c
1 changed files with 24 additions and 26 deletions
|
@ -94,31 +94,29 @@ pub fn init(cx: &mut AppContext) {
|
|||
search_bar.select_next_match(action, cx)
|
||||
},
|
||||
);
|
||||
register_workspace_action(
|
||||
workspace,
|
||||
move |search_bar, action: &SelectPrevMatch, cx| {
|
||||
search_bar.select_prev_match(action, cx)
|
||||
},
|
||||
);
|
||||
|
||||
register_workspace_action_for_dismissed_search(
|
||||
workspace,
|
||||
move |workspace, action: &NewSearch, cx| {
|
||||
ProjectSearchView::new_search(workspace, action, cx)
|
||||
},
|
||||
);
|
||||
register_workspace_action_for_dismissed_search(
|
||||
workspace,
|
||||
move |workspace, action: &DeploySearch, cx| {
|
||||
ProjectSearchView::deploy_search(workspace, action, cx)
|
||||
},
|
||||
);
|
||||
register_workspace_action_for_dismissed_search(
|
||||
workspace,
|
||||
move |workspace, action: &SearchInNew, cx| {
|
||||
ProjectSearchView::search_in_new(workspace, action, cx)
|
||||
},
|
||||
);
|
||||
// Only handle search_in_new if there is a search present
|
||||
register_workspace_action_for_present_search(workspace, |workspace, action, cx| {
|
||||
ProjectSearchView::search_in_new(workspace, action, cx)
|
||||
});
|
||||
|
||||
// Both on present and dismissed search, we need to unconditionally handle those actions to focus from the editor.
|
||||
workspace.register_action(move |workspace, action: &DeploySearch, cx| {
|
||||
if workspace.has_active_modal(cx) {
|
||||
cx.propagate();
|
||||
return;
|
||||
}
|
||||
ProjectSearchView::deploy_search(workspace, action, cx);
|
||||
cx.notify();
|
||||
});
|
||||
workspace.register_action(move |workspace, action: &NewSearch, cx| {
|
||||
if workspace.has_active_modal(cx) {
|
||||
cx.propagate();
|
||||
return;
|
||||
}
|
||||
ProjectSearchView::new_search(workspace, action, cx);
|
||||
cx.notify();
|
||||
});
|
||||
})
|
||||
.detach();
|
||||
}
|
||||
|
@ -2057,7 +2055,7 @@ fn register_workspace_action<A: Action>(
|
|||
});
|
||||
}
|
||||
|
||||
fn register_workspace_action_for_dismissed_search<A: Action>(
|
||||
fn register_workspace_action_for_present_search<A: Action>(
|
||||
workspace: &mut Workspace,
|
||||
callback: fn(&mut Workspace, &A, &mut ViewContext<Workspace>),
|
||||
) {
|
||||
|
@ -2073,7 +2071,7 @@ fn register_workspace_action_for_dismissed_search<A: Action>(
|
|||
.toolbar()
|
||||
.read(cx)
|
||||
.item_of_type::<ProjectSearchBar>()
|
||||
.map(|search_bar| search_bar.read(cx).active_project_search.is_none())
|
||||
.map(|search_bar| search_bar.read(cx).active_project_search.is_some())
|
||||
.unwrap_or(false);
|
||||
if should_notify {
|
||||
callback(workspace, action, cx);
|
||||
|
|
Loading…
Reference in a new issue