mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-12 05:15:00 +00:00
Toggle sidebar items on mouse down instead of on click
This commit is contained in:
parent
1d697df1bc
commit
38dc023942
2 changed files with 12 additions and 1 deletions
|
@ -12,6 +12,7 @@ pub struct MouseEventHandler {
|
||||||
state: ElementStateHandle<MouseState>,
|
state: ElementStateHandle<MouseState>,
|
||||||
child: ElementBox,
|
child: ElementBox,
|
||||||
cursor_style: Option<CursorStyle>,
|
cursor_style: Option<CursorStyle>,
|
||||||
|
mouse_down_handler: Option<Box<dyn FnMut(&mut EventContext)>>,
|
||||||
click_handler: Option<Box<dyn FnMut(&mut EventContext)>>,
|
click_handler: Option<Box<dyn FnMut(&mut EventContext)>>,
|
||||||
drag_handler: Option<Box<dyn FnMut(Vector2F, &mut EventContext)>>,
|
drag_handler: Option<Box<dyn FnMut(Vector2F, &mut EventContext)>>,
|
||||||
}
|
}
|
||||||
|
@ -38,6 +39,7 @@ impl MouseEventHandler {
|
||||||
state: state_handle,
|
state: state_handle,
|
||||||
child,
|
child,
|
||||||
cursor_style: None,
|
cursor_style: None,
|
||||||
|
mouse_down_handler: None,
|
||||||
click_handler: None,
|
click_handler: None,
|
||||||
drag_handler: None,
|
drag_handler: None,
|
||||||
}
|
}
|
||||||
|
@ -48,6 +50,11 @@ impl MouseEventHandler {
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn on_mouse_down(mut self, handler: impl FnMut(&mut EventContext) + 'static) -> Self {
|
||||||
|
self.mouse_down_handler = Some(Box::new(handler));
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
pub fn on_click(mut self, handler: impl FnMut(&mut EventContext) + 'static) -> Self {
|
pub fn on_click(mut self, handler: impl FnMut(&mut EventContext) + 'static) -> Self {
|
||||||
self.click_handler = Some(Box::new(handler));
|
self.click_handler = Some(Box::new(handler));
|
||||||
self
|
self
|
||||||
|
@ -89,6 +96,7 @@ impl Element for MouseEventHandler {
|
||||||
cx: &mut EventContext,
|
cx: &mut EventContext,
|
||||||
) -> bool {
|
) -> bool {
|
||||||
let cursor_style = self.cursor_style;
|
let cursor_style = self.cursor_style;
|
||||||
|
let mouse_down_handler = self.mouse_down_handler.as_mut();
|
||||||
let click_handler = self.click_handler.as_mut();
|
let click_handler = self.click_handler.as_mut();
|
||||||
let drag_handler = self.drag_handler.as_mut();
|
let drag_handler = self.drag_handler.as_mut();
|
||||||
|
|
||||||
|
@ -124,6 +132,9 @@ impl Element for MouseEventHandler {
|
||||||
state.clicked = true;
|
state.clicked = true;
|
||||||
state.prev_drag_position = Some(*position);
|
state.prev_drag_position = Some(*position);
|
||||||
cx.notify();
|
cx.notify();
|
||||||
|
if let Some(handler) = mouse_down_handler {
|
||||||
|
handler(cx);
|
||||||
|
}
|
||||||
true
|
true
|
||||||
} else {
|
} else {
|
||||||
handled_in_child
|
handled_in_child
|
||||||
|
|
|
@ -91,7 +91,7 @@ impl Sidebar {
|
||||||
.boxed()
|
.boxed()
|
||||||
})
|
})
|
||||||
.with_cursor_style(CursorStyle::PointingHand)
|
.with_cursor_style(CursorStyle::PointingHand)
|
||||||
.on_click(move |cx| {
|
.on_mouse_down(move |cx| {
|
||||||
cx.dispatch_action(ToggleSidebarItem(ToggleArg { side, item_index }))
|
cx.dispatch_action(ToggleSidebarItem(ToggleArg { side, item_index }))
|
||||||
})
|
})
|
||||||
.boxed()
|
.boxed()
|
||||||
|
|
Loading…
Reference in a new issue