From a5f3b2a94902d10cfda6549e8a79cc638d2e2b08 Mon Sep 17 00:00:00 2001 From: Ivan Molodetskikh Date: Fri, 3 Jan 2025 16:59:53 +0300 Subject: Clear on-demand layer-shell focus in more cases --- src/handlers/compositor.rs | 2 ++ src/handlers/mod.rs | 1 + 2 files changed, 3 insertions(+) (limited to 'src/handlers') diff --git a/src/handlers/compositor.rs b/src/handlers/compositor.rs index dec86929..4b080cd8 100644 --- a/src/handlers/compositor.rs +++ b/src/handlers/compositor.rs @@ -201,7 +201,9 @@ impl CompositorHandler for State { let new_focus = self.niri.layout.focus().map(|m| &m.window); if new_focus == Some(&window) { + // We activated the newly opened window. self.maybe_warp_cursor_to_focus(); + self.niri.layer_shell_on_demand_focus = None; } self.niri.queue_redraw(&output); diff --git a/src/handlers/mod.rs b/src/handlers/mod.rs index 5b59ec45..f8cf1832 100644 --- a/src/handlers/mod.rs +++ b/src/handlers/mod.rs @@ -317,6 +317,7 @@ impl ClientDndGrabHandler for State { if let Some((mapped, _)) = self.niri.layout.find_window_and_output(root) { let window = mapped.window.clone(); self.niri.layout.activate_window(&window); + self.niri.layer_shell_on_demand_focus = None; activate_output = false; } } -- cgit