diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/handlers/xdg_shell.rs | 14 | ||||
| -rw-r--r-- | src/layout/workspace.rs | 17 |
2 files changed, 29 insertions, 2 deletions
diff --git a/src/handlers/xdg_shell.rs b/src/handlers/xdg_shell.rs index a8023a69..2a1b1d0b 100644 --- a/src/handlers/xdg_shell.rs +++ b/src/handlers/xdg_shell.rs @@ -230,6 +230,13 @@ impl XdgShellHandler for State { } self.niri.layout.set_fullscreen(&window, true); + } else if let Some(window) = self.niri.unmapped_windows.get(surface.wl_surface()) { + if let Some(ws) = self.niri.layout.active_workspace() { + window.toplevel().with_pending_state(|state| { + state.size = Some(ws.view_size()); + state.states.set(xdg_toplevel::State::Fullscreen); + }); + } } } @@ -246,6 +253,13 @@ impl XdgShellHandler for State { { let window = window.clone(); self.niri.layout.set_fullscreen(&window, false); + } else if let Some(window) = self.niri.unmapped_windows.get(surface.wl_surface()) { + if let Some(ws) = self.niri.layout.active_workspace() { + window.toplevel().with_pending_state(|state| { + state.size = Some(ws.new_window_size()); + state.states.unset(xdg_toplevel::State::Fullscreen); + }); + } } } diff --git a/src/layout/workspace.rs b/src/layout/workspace.rs index 7324e93e..73a87376 100644 --- a/src/layout/workspace.rs +++ b/src/layout/workspace.rs @@ -330,6 +330,10 @@ impl<W: LayoutElement> Workspace<W> { } } + pub fn view_size(&self) -> Size<i32, Logical> { + self.view_size + } + pub fn update_output_scale_transform(&mut self) { let Some(output) = self.output.as_ref() else { return; @@ -351,7 +355,7 @@ impl<W: LayoutElement> Workspace<W> { )) } - pub fn configure_new_window(&self, window: &Window) { + pub fn new_window_size(&self) -> Size<i32, Logical> { let width = if let Some(width) = self.options.default_width { let mut width = width.resolve(&self.options, self.working_area.size.w); if !self.options.border.off { @@ -367,8 +371,11 @@ impl<W: LayoutElement> Workspace<W> { height -= self.options.border.width as i32 * 2; } - let size = Size::from((width, max(height, 1))); + Size::from((width, max(height, 1))) + } + pub fn configure_new_window(&self, window: &Window) { + let size = self.new_window_size(); let bounds = self.toplevel_bounds(); if let Some(output) = self.output.as_ref() { @@ -1151,8 +1158,14 @@ impl<W: LayoutElement> Column<W> { options, }; + let is_pending_fullscreen = window.is_pending_fullscreen(); + rv.add_window(window); + if is_pending_fullscreen { + rv.set_fullscreen(true); + } + rv } |
