Open a new file on double-clicking the tab bar (#8431)

Fixes #6818

This is a convenience feature that exists in other editors, allowing
quick creation a new tab by double-clicking the empty space on the tab
bar:
![2024-02-26 14 26
16](https://github.com/zed-industries/zed/assets/601206/55d99a84-2e61-494d-b06c-6e5f15071655)

Release Notes:

- Added the ability to open a new buffer when double-clicking on the tab
bar ([#6818](https://github.com/zed-industries/zed/issues/6818)).
This commit is contained in:
Igal Tabachnik 2024-02-26 21:07:04 +02:00 committed by GitHub
parent 43163a0154
commit 3b2e315ead
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -9,9 +9,9 @@ use collections::{HashMap, HashSet, VecDeque};
use futures::{stream::FuturesUnordered, StreamExt}; use futures::{stream::FuturesUnordered, StreamExt};
use gpui::{ use gpui::{
actions, impl_actions, overlay, prelude::*, Action, AnchorCorner, AnyElement, AppContext, actions, impl_actions, overlay, prelude::*, Action, AnchorCorner, AnyElement, AppContext,
AsyncWindowContext, DismissEvent, Div, DragMoveEvent, EntityId, EventEmitter, ExternalPaths, AsyncWindowContext, ClickEvent, DismissEvent, Div, DragMoveEvent, EntityId, EventEmitter,
FocusHandle, FocusableView, Model, MouseButton, NavigationDirection, Pixels, Point, ExternalPaths, FocusHandle, FocusableView, Model, MouseButton, NavigationDirection, Pixels,
PromptLevel, Render, ScrollHandle, Subscription, Task, View, ViewContext, VisualContext, Point, PromptLevel, Render, ScrollHandle, Subscription, Task, View, ViewContext, VisualContext,
WeakView, WindowContext, WeakView, WindowContext,
}; };
use parking_lot::Mutex; use parking_lot::Mutex;
@ -1505,6 +1505,7 @@ impl Pane {
) )
.child( .child(
div() div()
.id("tab_bar_drop_target")
.min_w_6() .min_w_6()
// HACK: This empty child is currently necessary to force the drop target to appear // HACK: This empty child is currently necessary to force the drop target to appear
// despite us setting a min width above. // despite us setting a min width above.
@ -1528,6 +1529,11 @@ impl Pane {
.on_drop(cx.listener(move |this, paths, cx| { .on_drop(cx.listener(move |this, paths, cx| {
this.drag_split_direction = None; this.drag_split_direction = None;
this.handle_external_paths_drop(paths, cx) this.handle_external_paths_drop(paths, cx)
}))
.on_click(cx.listener(move |_, event: &ClickEvent, cx| {
if event.up.click_count == 2 {
cx.dispatch_action(NewFile.boxed_clone());
}
})), })),
) )
} }