mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-11 21:13:02 +00:00
Render a magnifier icon and the query in project search tab
Also: Wire up events so the modified status updates correctly.
This commit is contained in:
parent
a78fe4ef6a
commit
ae1a46a4e4
4 changed files with 56 additions and 14 deletions
|
@ -39,6 +39,7 @@ struct ProjectFind {
|
||||||
excerpts: ModelHandle<MultiBuffer>,
|
excerpts: ModelHandle<MultiBuffer>,
|
||||||
pending_search: Option<Task<Option<()>>>,
|
pending_search: Option<Task<Option<()>>>,
|
||||||
highlighted_ranges: Vec<Range<Anchor>>,
|
highlighted_ranges: Vec<Range<Anchor>>,
|
||||||
|
active_query: Option<SearchQuery>,
|
||||||
}
|
}
|
||||||
|
|
||||||
struct ProjectFindView {
|
struct ProjectFindView {
|
||||||
|
@ -64,6 +65,7 @@ impl ProjectFind {
|
||||||
excerpts: cx.add_model(|_| MultiBuffer::new(replica_id)),
|
excerpts: cx.add_model(|_| MultiBuffer::new(replica_id)),
|
||||||
pending_search: Default::default(),
|
pending_search: Default::default(),
|
||||||
highlighted_ranges: Default::default(),
|
highlighted_ranges: Default::default(),
|
||||||
|
active_query: None,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -75,6 +77,7 @@ impl ProjectFind {
|
||||||
.update(new_cx, |excerpts, cx| cx.add_model(|cx| excerpts.clone(cx))),
|
.update(new_cx, |excerpts, cx| cx.add_model(|cx| excerpts.clone(cx))),
|
||||||
pending_search: Default::default(),
|
pending_search: Default::default(),
|
||||||
highlighted_ranges: self.highlighted_ranges.clone(),
|
highlighted_ranges: self.highlighted_ranges.clone(),
|
||||||
|
active_query: self.active_query.clone(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -104,6 +107,7 @@ impl ProjectFind {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
this.pending_search.take();
|
this.pending_search.take();
|
||||||
|
this.active_query = Some(query);
|
||||||
cx.notify();
|
cx.notify();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -124,8 +128,22 @@ impl Item for ProjectFind {
|
||||||
) -> Self::View {
|
) -> Self::View {
|
||||||
let settings = workspace.settings();
|
let settings = workspace.settings();
|
||||||
let excerpts = model.read(cx).excerpts.clone();
|
let excerpts = model.read(cx).excerpts.clone();
|
||||||
|
let results_editor = cx.add_view(|cx| {
|
||||||
|
let mut editor = Editor::for_buffer(
|
||||||
|
excerpts,
|
||||||
|
Some(workspace.project().clone()),
|
||||||
|
settings.clone(),
|
||||||
|
cx,
|
||||||
|
);
|
||||||
|
editor.set_searchable(false);
|
||||||
|
editor.set_nav_history(Some(nav_history));
|
||||||
|
editor
|
||||||
|
});
|
||||||
|
cx.observe(&results_editor, |_, _, cx| cx.emit(ViewEvent::UpdateTab))
|
||||||
|
.detach();
|
||||||
cx.observe(&model, |this, _, cx| this.model_changed(true, cx))
|
cx.observe(&model, |this, _, cx| this.model_changed(true, cx))
|
||||||
.detach();
|
.detach();
|
||||||
|
|
||||||
ProjectFindView {
|
ProjectFindView {
|
||||||
model,
|
model,
|
||||||
query_editor: cx.add_view(|cx| {
|
query_editor: cx.add_view(|cx| {
|
||||||
|
@ -135,17 +153,7 @@ impl Item for ProjectFind {
|
||||||
cx,
|
cx,
|
||||||
)
|
)
|
||||||
}),
|
}),
|
||||||
results_editor: cx.add_view(|cx| {
|
results_editor,
|
||||||
let mut editor = Editor::for_buffer(
|
|
||||||
excerpts,
|
|
||||||
Some(workspace.project().clone()),
|
|
||||||
settings.clone(),
|
|
||||||
cx,
|
|
||||||
);
|
|
||||||
editor.set_searchable(false);
|
|
||||||
editor.set_nav_history(Some(nav_history));
|
|
||||||
editor
|
|
||||||
}),
|
|
||||||
case_sensitive: false,
|
case_sensitive: false,
|
||||||
whole_word: false,
|
whole_word: false,
|
||||||
regex: false,
|
regex: false,
|
||||||
|
@ -159,8 +167,12 @@ impl Item for ProjectFind {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum ViewEvent {
|
||||||
|
UpdateTab,
|
||||||
|
}
|
||||||
|
|
||||||
impl Entity for ProjectFindView {
|
impl Entity for ProjectFindView {
|
||||||
type Event = ();
|
type Event = ViewEvent;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl View for ProjectFindView {
|
impl View for ProjectFindView {
|
||||||
|
@ -231,8 +243,26 @@ impl ItemView for ProjectFindView {
|
||||||
Box::new(self.model.clone())
|
Box::new(self.model.clone())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn tab_content(&self, style: &theme::Tab, _: &gpui::AppContext) -> ElementBox {
|
fn tab_content(&self, style: &theme::Tab, cx: &gpui::AppContext) -> ElementBox {
|
||||||
Label::new("Project Find".to_string(), style.label.clone()).boxed()
|
let settings = self.settings.borrow();
|
||||||
|
let find_theme = &settings.theme.find;
|
||||||
|
Flex::row()
|
||||||
|
.with_child(
|
||||||
|
Svg::new("icons/magnifier.svg")
|
||||||
|
.with_color(style.label.text.color)
|
||||||
|
.constrained()
|
||||||
|
.with_width(find_theme.tab_icon_width)
|
||||||
|
.aligned()
|
||||||
|
.boxed(),
|
||||||
|
)
|
||||||
|
.with_children(self.model.read(cx).active_query.as_ref().map(|query| {
|
||||||
|
Label::new(query.as_str().to_string(), style.label.clone())
|
||||||
|
.aligned()
|
||||||
|
.contained()
|
||||||
|
.with_margin_left(find_theme.tab_icon_spacing)
|
||||||
|
.boxed()
|
||||||
|
}))
|
||||||
|
.boxed()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn project_path(&self, _: &gpui::AppContext) -> Option<project::ProjectPath> {
|
fn project_path(&self, _: &gpui::AppContext) -> Option<project::ProjectPath> {
|
||||||
|
@ -331,6 +361,10 @@ impl ItemView for ProjectFindView {
|
||||||
self.results_editor
|
self.results_editor
|
||||||
.update(cx, |editor, cx| editor.navigate(data, cx));
|
.update(cx, |editor, cx| editor.navigate(data, cx));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn should_update_tab_on_event(event: &ViewEvent) -> bool {
|
||||||
|
matches!(event, ViewEvent::UpdateTab)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ProjectFindView {
|
impl ProjectFindView {
|
||||||
|
@ -407,6 +441,7 @@ impl ProjectFindView {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cx.emit(ViewEvent::UpdateTab);
|
||||||
cx.notify();
|
cx.notify();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -108,6 +108,8 @@ pub struct Find {
|
||||||
pub match_background: Color,
|
pub match_background: Color,
|
||||||
pub match_index: ContainedText,
|
pub match_index: ContainedText,
|
||||||
pub results_status: TextStyle,
|
pub results_status: TextStyle,
|
||||||
|
pub tab_icon_width: f32,
|
||||||
|
pub tab_icon_spacing: f32,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Deserialize, Default)]
|
#[derive(Clone, Deserialize, Default)]
|
||||||
|
|
3
crates/zed/assets/icons/magnifier.svg
Normal file
3
crates/zed/assets/icons/magnifier.svg
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
<svg width="12" height="12" viewBox="0 0 12 12" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<path d="M11.0893 10.4092L8.34129 7.66113C8.93602 6.93311 9.26414 6.01641 9.26414 5.01562C9.26414 2.65928 7.35425 0.75 4.99851 0.75C2.64278 0.75 0.751343 2.65989 0.751343 5.01562C0.751343 7.37136 2.66103 9.28125 4.99851 9.28125C5.99909 9.28125 6.91702 8.93446 7.64402 8.35758L10.3921 11.1056C10.5069 11.2028 10.6341 11.25 10.7592 11.25C10.8843 11.25 11.011 11.2019 11.1072 11.1058C11.2985 10.9137 11.2985 10.602 11.0893 10.4092ZM1.73572 5.01562C1.73572 3.20643 3.20777 1.73438 5.01697 1.73438C6.82617 1.73438 8.29822 3.20643 8.29822 5.01562C8.29822 6.82482 6.82617 8.29688 5.01697 8.29688C3.20777 8.29688 1.73572 6.82441 1.73572 5.01562Z" fill="white" fill-opacity="0.5"/>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 776 B |
|
@ -352,6 +352,8 @@ tab_summary_spacing = 10
|
||||||
match_background = "$state.highlighted_line"
|
match_background = "$state.highlighted_line"
|
||||||
background = "$surface.1"
|
background = "$surface.1"
|
||||||
results_status = { extends = "$text.0", size = 18 }
|
results_status = { extends = "$text.0", size = 18 }
|
||||||
|
tab_icon_width = 14
|
||||||
|
tab_icon_spacing = 4
|
||||||
|
|
||||||
[find.option_button]
|
[find.option_button]
|
||||||
extends = "$text.1"
|
extends = "$text.1"
|
||||||
|
|
Loading…
Reference in a new issue