mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-08 05:47:27 +03:00
Display active match and allow going to next or previous match
We still need to write a unit test for this, as well as add a keybinding.
This commit is contained in:
parent
5c7cea5a3e
commit
1d55872e7a
@ -1,7 +1,7 @@
|
|||||||
use aho_corasick::AhoCorasickBuilder;
|
use aho_corasick::AhoCorasickBuilder;
|
||||||
use anyhow::Result;
|
use anyhow::Result;
|
||||||
use collections::HashSet;
|
use collections::HashSet;
|
||||||
use editor::{char_kind, Anchor, Editor, EditorSettings, MultiBufferSnapshot};
|
use editor::{char_kind, Anchor, Autoscroll, Editor, EditorSettings, MultiBufferSnapshot};
|
||||||
use gpui::{
|
use gpui::{
|
||||||
action, elements::*, keymap::Binding, Entity, MutableAppContext, RenderContext, Subscription,
|
action, elements::*, keymap::Binding, Entity, MutableAppContext, RenderContext, Subscription,
|
||||||
Task, View, ViewContext, ViewHandle, WeakViewHandle,
|
Task, View, ViewContext, ViewHandle, WeakViewHandle,
|
||||||
@ -9,7 +9,11 @@ use gpui::{
|
|||||||
use postage::watch;
|
use postage::watch;
|
||||||
use regex::RegexBuilder;
|
use regex::RegexBuilder;
|
||||||
use smol::future::yield_now;
|
use smol::future::yield_now;
|
||||||
use std::{cmp::Ordering, ops::Range, sync::Arc};
|
use std::{
|
||||||
|
cmp::{self, Ordering},
|
||||||
|
ops::Range,
|
||||||
|
sync::Arc,
|
||||||
|
};
|
||||||
use workspace::{ItemViewHandle, Settings, Toolbar, Workspace};
|
use workspace::{ItemViewHandle, Settings, Toolbar, Workspace};
|
||||||
|
|
||||||
action!(Deploy);
|
action!(Deploy);
|
||||||
@ -99,6 +103,20 @@ impl View for FindBar {
|
|||||||
.with_child(self.render_nav_button(">", Direction::Next, theme, cx))
|
.with_child(self.render_nav_button(">", Direction::Next, theme, cx))
|
||||||
.boxed(),
|
.boxed(),
|
||||||
)
|
)
|
||||||
|
.with_children(self.active_editor.as_ref().and_then(|editor| {
|
||||||
|
let (_, highlighted_ranges) =
|
||||||
|
editor.read(cx).highlighted_ranges_for_type::<Self>()?;
|
||||||
|
let match_ix = cmp::min(self.active_match_index? + 1, highlighted_ranges.len());
|
||||||
|
Some(
|
||||||
|
Label::new(
|
||||||
|
format!("{} of {}", match_ix, highlighted_ranges.len()),
|
||||||
|
theme.match_index.text.clone(),
|
||||||
|
)
|
||||||
|
.contained()
|
||||||
|
.with_style(theme.match_index.container)
|
||||||
|
.boxed(),
|
||||||
|
)
|
||||||
|
}))
|
||||||
.contained()
|
.contained()
|
||||||
.with_style(theme.container)
|
.with_style(theme.container)
|
||||||
.boxed()
|
.boxed()
|
||||||
@ -273,12 +291,16 @@ impl FindBar {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
Direction::Next => {
|
Direction::Next => {
|
||||||
index += 1;
|
if index == ranges.len() - 1 {
|
||||||
if index >= ranges.len() {
|
|
||||||
index = 0;
|
index = 0;
|
||||||
|
} else {
|
||||||
|
index += 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let range_to_select = ranges[index].clone();
|
||||||
|
editor.select_ranges([range_to_select], Some(Autoscroll::Fit), cx);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -312,14 +334,13 @@ impl FindBar {
|
|||||||
|
|
||||||
fn on_active_editor_event(
|
fn on_active_editor_event(
|
||||||
&mut self,
|
&mut self,
|
||||||
editor: ViewHandle<Editor>,
|
_: ViewHandle<Editor>,
|
||||||
event: &editor::Event,
|
event: &editor::Event,
|
||||||
cx: &mut ViewContext<Self>,
|
cx: &mut ViewContext<Self>,
|
||||||
) {
|
) {
|
||||||
match event {
|
match event {
|
||||||
editor::Event::Edited => self.update_matches(cx),
|
editor::Event::Edited => self.update_matches(cx),
|
||||||
editor::Event::SelectionsChanged => self.update_match_index(cx),
|
editor::Event::SelectionsChanged => self.update_match_index(cx),
|
||||||
|
|
||||||
_ => {}
|
_ => {}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -329,6 +350,7 @@ impl FindBar {
|
|||||||
self.pending_search.take();
|
self.pending_search.take();
|
||||||
if let Some(editor) = self.active_editor.as_ref() {
|
if let Some(editor) = self.active_editor.as_ref() {
|
||||||
if query.is_empty() {
|
if query.is_empty() {
|
||||||
|
self.active_match_index.take();
|
||||||
editor.update(cx, |editor, cx| editor.clear_highlighted_ranges::<Self>(cx));
|
editor.update(cx, |editor, cx| editor.clear_highlighted_ranges::<Self>(cx));
|
||||||
} else {
|
} else {
|
||||||
let buffer = editor.read(cx).buffer().read(cx).snapshot(cx);
|
let buffer = editor.read(cx).buffer().read(cx).snapshot(cx);
|
||||||
@ -376,6 +398,7 @@ impl FindBar {
|
|||||||
|
|
||||||
fn update_match_index(&mut self, cx: &mut ViewContext<Self>) {
|
fn update_match_index(&mut self, cx: &mut ViewContext<Self>) {
|
||||||
self.active_match_index = self.active_match_index(cx);
|
self.active_match_index = self.active_match_index(cx);
|
||||||
|
cx.notify();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn active_match_index(&mut self, cx: &mut ViewContext<Self>) -> Option<usize> {
|
fn active_match_index(&mut self, cx: &mut ViewContext<Self>) -> Option<usize> {
|
||||||
|
@ -100,6 +100,7 @@ pub struct Find {
|
|||||||
pub hovered_mode_button: ContainedText,
|
pub hovered_mode_button: ContainedText,
|
||||||
pub active_hovered_mode_button: ContainedText,
|
pub active_hovered_mode_button: ContainedText,
|
||||||
pub match_background: Color,
|
pub match_background: Color,
|
||||||
|
pub match_index: ContainedText,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Deserialize, Default)]
|
#[derive(Clone, Deserialize, Default)]
|
||||||
|
@ -342,6 +342,9 @@ background = "$surface.2"
|
|||||||
extends = "$find.mode_button"
|
extends = "$find.mode_button"
|
||||||
background = "$surface.2"
|
background = "$surface.2"
|
||||||
|
|
||||||
|
[find.match_index]
|
||||||
|
extends = "$text.1"
|
||||||
|
|
||||||
[find.editor]
|
[find.editor]
|
||||||
max_width = 400
|
max_width = 400
|
||||||
background = "$surface.0"
|
background = "$surface.0"
|
||||||
|
Loading…
Reference in New Issue
Block a user