Toggle buffer search via quick actions
This commit is contained in:
parent
5c3d563f0f
commit
6a326c1bd8
2 changed files with 32 additions and 17 deletions
|
@ -6,17 +6,17 @@ use gpui::{
|
|||
};
|
||||
|
||||
use search::{buffer_search, BufferSearchBar};
|
||||
use workspace::{item::ItemHandle, ToolbarItemLocation, ToolbarItemView, Workspace};
|
||||
use workspace::{item::ItemHandle, Pane, ToolbarItemLocation, ToolbarItemView};
|
||||
|
||||
pub struct QuickActionBar {
|
||||
workspace: ViewHandle<Workspace>,
|
||||
pane: ViewHandle<Pane>,
|
||||
active_item: Option<Box<dyn ItemHandle>>,
|
||||
}
|
||||
|
||||
impl QuickActionBar {
|
||||
pub fn new(workspace: ViewHandle<Workspace>) -> Self {
|
||||
pub fn new(pane: ViewHandle<Pane>) -> Self {
|
||||
Self {
|
||||
workspace,
|
||||
pane,
|
||||
active_item: None,
|
||||
}
|
||||
}
|
||||
|
@ -60,23 +60,40 @@ impl View for QuickActionBar {
|
|||
));
|
||||
|
||||
if editor.read(cx).buffer().read(cx).is_singleton() {
|
||||
let buffer_search_bar = self
|
||||
.pane
|
||||
.read(cx)
|
||||
.toolbar()
|
||||
.read(cx)
|
||||
.item_of_type::<BufferSearchBar>();
|
||||
let search_bar_shown = buffer_search_bar
|
||||
.as_ref()
|
||||
.map(|bar| !bar.read(cx).is_dismissed())
|
||||
.unwrap_or(false);
|
||||
|
||||
let search_action = buffer_search::Deploy { focus: true };
|
||||
|
||||
// TODO kb: this opens the search bar in a differently focused pane (should be the same) + should be toggleable
|
||||
let pane = self.workspace.read(cx).active_pane().clone();
|
||||
bar = bar.with_child(render_quick_action_bar_button(
|
||||
1,
|
||||
"icons/magnifying_glass_12.svg",
|
||||
false,
|
||||
search_bar_shown,
|
||||
(
|
||||
"Search in buffer".to_string(),
|
||||
"Toggle buffer search".to_string(),
|
||||
Some(Box::new(search_action.clone())),
|
||||
),
|
||||
cx,
|
||||
move |_, cx| {
|
||||
pane.update(cx, |pane, cx| {
|
||||
BufferSearchBar::deploy(pane, &search_action, cx);
|
||||
});
|
||||
move |this, cx| {
|
||||
if search_bar_shown {
|
||||
if let Some(buffer_search_bar) = buffer_search_bar.as_ref() {
|
||||
buffer_search_bar.update(cx, |buffer_search_bar, cx| {
|
||||
buffer_search_bar.dismiss(&buffer_search::Dismiss, cx);
|
||||
});
|
||||
}
|
||||
} else {
|
||||
this.pane.update(cx, |pane, cx| {
|
||||
BufferSearchBar::deploy(pane, &search_action, cx);
|
||||
});
|
||||
}
|
||||
},
|
||||
));
|
||||
}
|
||||
|
@ -130,7 +147,6 @@ impl ToolbarItemView for QuickActionBar {
|
|||
) -> ToolbarItemLocation {
|
||||
match active_pane_item {
|
||||
Some(active_item) => {
|
||||
dbg!("@@@@@@@@@@ TODO kb", active_item.id());
|
||||
self.active_item = Some(active_item.boxed_clone());
|
||||
ToolbarItemLocation::PrimaryRight { flex: None }
|
||||
}
|
||||
|
|
|
@ -258,15 +258,14 @@ pub fn initialize_workspace(
|
|||
workspace_handle.update(&mut cx, |workspace, cx| {
|
||||
let workspace_handle = cx.handle();
|
||||
cx.subscribe(&workspace_handle, {
|
||||
let workspace_handle = workspace_handle.clone();
|
||||
move |workspace, _, event, cx| {
|
||||
if let workspace::Event::PaneAdded(pane) = event {
|
||||
pane.update(cx, |pane, cx| {
|
||||
if let workspace::Event::PaneAdded(pane_handle) = event {
|
||||
pane_handle.update(cx, |pane, cx| {
|
||||
pane.toolbar().update(cx, |toolbar, cx| {
|
||||
let breadcrumbs = cx.add_view(|_| Breadcrumbs::new(workspace));
|
||||
toolbar.add_item(breadcrumbs, cx);
|
||||
let quick_action_bar =
|
||||
cx.add_view(|_| QuickActionBar::new(workspace_handle.clone()));
|
||||
cx.add_view(|_| QuickActionBar::new(pane_handle.clone()));
|
||||
toolbar.add_item(quick_action_bar, cx);
|
||||
let buffer_search_bar = cx.add_view(BufferSearchBar::new);
|
||||
toolbar.add_item(buffer_search_bar, cx);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue