From b23dd4b800285f120ad556d77c2357b17c1ea6a2 Mon Sep 17 00:00:00 2001 From: Ivan Molodetskikh Date: Sat, 3 Feb 2024 09:00:08 +0400 Subject: Respect natural-scroll for workspace switch gesture --- src/input.rs | 19 ++++++++++++++----- src/layout/mod.rs | 2 +- 2 files changed, 15 insertions(+), 6 deletions(-) (limited to 'src') diff --git a/src/input.rs b/src/input.rs index a357eac1..f06f6142 100644 --- a/src/input.rs +++ b/src/input.rs @@ -1156,11 +1156,20 @@ impl State { ); } - fn on_gesture_swipe_update(&mut self, event: I::GestureSwipeUpdateEvent) { - let res = self - .niri - .layout - .workspace_switch_gesture_update(event.delta_y()); + fn on_gesture_swipe_update(&mut self, event: I::GestureSwipeUpdateEvent) + where + I::Device: 'static, + { + let mut delta_y = event.delta_y(); + + let device = event.device(); + if let Some(device) = (&device as &dyn Any).downcast_ref::() { + if device.config_scroll_natural_scroll_enabled() { + delta_y = -delta_y; + } + } + + let res = self.niri.layout.workspace_switch_gesture_update(delta_y); if let Some(output) = res { if let Some(output) = output { self.niri.queue_redraw(output); diff --git a/src/layout/mod.rs b/src/layout/mod.rs index 3dc47561..e50c52a2 100644 --- a/src/layout/mod.rs +++ b/src/layout/mod.rs @@ -1462,7 +1462,7 @@ impl Layout { for monitor in monitors { if let Some(WorkspaceSwitch::Gesture(gesture)) = &mut monitor.workspace_switch { // Normalize like GNOME Shell's workspace switching. - let delta_y = -delta_y / 400.; + let delta_y = delta_y / 400.; let min = gesture.center_idx.saturating_sub(1) as f64; let max = (gesture.center_idx + 1).min(monitor.workspaces.len() - 1) as f64; -- cgit