mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-11 21:13:02 +00:00
Merge pull request #1996 from zed-industries/add-close-clean-items-command
Add close clean items command
This commit is contained in:
commit
0f818f2458
2 changed files with 37 additions and 19 deletions
|
@ -21,6 +21,7 @@
|
||||||
"alt-cmd-right": "pane::ActivateNextItem",
|
"alt-cmd-right": "pane::ActivateNextItem",
|
||||||
"cmd-w": "pane::CloseActiveItem",
|
"cmd-w": "pane::CloseActiveItem",
|
||||||
"alt-cmd-t": "pane::CloseInactiveItems",
|
"alt-cmd-t": "pane::CloseInactiveItems",
|
||||||
|
"cmd-k u": "pane::CloseCleanItems",
|
||||||
"cmd-k cmd-w": "pane::CloseAllItems",
|
"cmd-k cmd-w": "pane::CloseAllItems",
|
||||||
"cmd-shift-w": "workspace::CloseWindow",
|
"cmd-shift-w": "workspace::CloseWindow",
|
||||||
"cmd-s": "workspace::Save",
|
"cmd-s": "workspace::Save",
|
||||||
|
|
|
@ -44,6 +44,7 @@ actions!(
|
||||||
ActivateLastItem,
|
ActivateLastItem,
|
||||||
CloseActiveItem,
|
CloseActiveItem,
|
||||||
CloseInactiveItems,
|
CloseInactiveItems,
|
||||||
|
CloseCleanItems,
|
||||||
CloseAllItems,
|
CloseAllItems,
|
||||||
ReopenClosedItem,
|
ReopenClosedItem,
|
||||||
SplitLeft,
|
SplitLeft,
|
||||||
|
@ -123,6 +124,7 @@ pub fn init(cx: &mut MutableAppContext) {
|
||||||
});
|
});
|
||||||
cx.add_async_action(Pane::close_active_item);
|
cx.add_async_action(Pane::close_active_item);
|
||||||
cx.add_async_action(Pane::close_inactive_items);
|
cx.add_async_action(Pane::close_inactive_items);
|
||||||
|
cx.add_async_action(Pane::close_clean_items);
|
||||||
cx.add_async_action(Pane::close_all_items);
|
cx.add_async_action(Pane::close_all_items);
|
||||||
cx.add_async_action(|workspace: &mut Workspace, action: &CloseItem, cx| {
|
cx.add_async_action(|workspace: &mut Workspace, action: &CloseItem, cx| {
|
||||||
let pane = action.pane.upgrade(cx)?;
|
let pane = action.pane.upgrade(cx)?;
|
||||||
|
@ -263,6 +265,7 @@ pub enum ReorderBehavior {
|
||||||
enum ItemType {
|
enum ItemType {
|
||||||
Active,
|
Active,
|
||||||
Inactive,
|
Inactive,
|
||||||
|
Clean,
|
||||||
All,
|
All,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -723,6 +726,14 @@ impl Pane {
|
||||||
Self::close_main(workspace, ItemType::All, cx)
|
Self::close_main(workspace, ItemType::All, cx)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn close_clean_items(
|
||||||
|
workspace: &mut Workspace,
|
||||||
|
_: &CloseCleanItems,
|
||||||
|
cx: &mut ViewContext<Workspace>,
|
||||||
|
) -> Option<Task<Result<()>>> {
|
||||||
|
Self::close_main(workspace, ItemType::Clean, cx)
|
||||||
|
}
|
||||||
|
|
||||||
fn close_main(
|
fn close_main(
|
||||||
workspace: &mut Workspace,
|
workspace: &mut Workspace,
|
||||||
close_item_type: ItemType,
|
close_item_type: ItemType,
|
||||||
|
@ -731,26 +742,32 @@ impl Pane {
|
||||||
let pane_handle = workspace.active_pane().clone();
|
let pane_handle = workspace.active_pane().clone();
|
||||||
let pane = pane_handle.read(cx);
|
let pane = pane_handle.read(cx);
|
||||||
if pane.items.is_empty() {
|
if pane.items.is_empty() {
|
||||||
None
|
return None;
|
||||||
} else {
|
|
||||||
let active_item_id = pane.items[pane.active_item_index].id();
|
|
||||||
let task =
|
|
||||||
Self::close_items(
|
|
||||||
workspace,
|
|
||||||
pane_handle,
|
|
||||||
cx,
|
|
||||||
move |item_id| match close_item_type {
|
|
||||||
ItemType::Active => item_id == active_item_id,
|
|
||||||
ItemType::Inactive => item_id != active_item_id,
|
|
||||||
ItemType::All => true,
|
|
||||||
},
|
|
||||||
);
|
|
||||||
|
|
||||||
Some(cx.foreground().spawn(async move {
|
|
||||||
task.await?;
|
|
||||||
Ok(())
|
|
||||||
}))
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let active_item_id = pane.items[pane.active_item_index].id();
|
||||||
|
let clean_item_ids: Vec<_> = pane
|
||||||
|
.items()
|
||||||
|
.filter(|item| !item.is_dirty(cx))
|
||||||
|
.map(|item| item.id())
|
||||||
|
.collect();
|
||||||
|
let task =
|
||||||
|
Self::close_items(
|
||||||
|
workspace,
|
||||||
|
pane_handle,
|
||||||
|
cx,
|
||||||
|
move |item_id| match close_item_type {
|
||||||
|
ItemType::Active => item_id == active_item_id,
|
||||||
|
ItemType::Inactive => item_id != active_item_id,
|
||||||
|
ItemType::Clean => clean_item_ids.contains(&item_id),
|
||||||
|
ItemType::All => true,
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
||||||
|
Some(cx.foreground().spawn(async move {
|
||||||
|
task.await?;
|
||||||
|
Ok(())
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn close_item(
|
pub fn close_item(
|
||||||
|
|
Loading…
Reference in a new issue