diff --git a/crates/gpui/src/platform/linux/wayland/client.rs b/crates/gpui/src/platform/linux/wayland/client.rs index 1579a5098b..2e341dabac 100644 --- a/crates/gpui/src/platform/linux/wayland/client.rs +++ b/crates/gpui/src/platform/linux/wayland/client.rs @@ -421,12 +421,29 @@ impl Dispatch for WaylandClientState { state.keymap_state = Some(xkb::State::new(&keymap)); } wl_keyboard::Event::Enter { surface, .. } => { - for window in &state.windows { - if window.1.surface.id() == surface.id() { - state.keyboard_focused_window = Some(Rc::clone(&window.1)); - } + state.keyboard_focused_window = state + .windows + .iter() + .find(|&w| w.1.surface.id() == surface.id()) + .map(|w| w.1.clone()); + + if let Some(window) = &state.keyboard_focused_window { + window.set_focused(true); } } + wl_keyboard::Event::Leave { surface, .. } => { + let keyboard_focused_window = state + .windows + .iter() + .find(|&w| w.1.surface.id() == surface.id()) + .map(|w| w.1.clone()); + + if let Some(window) = keyboard_focused_window { + window.set_focused(false); + } + + state.keyboard_focused_window = None; + } wl_keyboard::Event::Modifiers { mods_depressed, mods_latched, @@ -479,7 +496,6 @@ impl Dispatch for WaylandClientState { } } } - wl_keyboard::Event::Leave { .. } => {} _ => {} } } diff --git a/crates/gpui/src/platform/linux/wayland/window.rs b/crates/gpui/src/platform/linux/wayland/window.rs index 5f0b64cff7..3a0c82cd16 100644 --- a/crates/gpui/src/platform/linux/wayland/window.rs +++ b/crates/gpui/src/platform/linux/wayland/window.rs @@ -228,6 +228,12 @@ impl WaylandWindowState { } } } + + pub fn set_focused(&self, focus: bool) { + if let Some(ref mut fun) = self.callbacks.lock().active_status_change { + fun(focus); + } + } } #[derive(Clone)] @@ -349,7 +355,7 @@ impl PlatformWindow for WaylandWindow { } fn on_active_status_change(&self, callback: Box) { - //todo!(linux) + self.0.callbacks.lock().active_status_change = Some(callback); } fn on_resize(&self, callback: Box, f32)>) {