From 889d062df7d89bf8084414c6f8fd87075c3cf85a Mon Sep 17 00:00:00 2001 From: Ivan Molodetskikh Date: Thu, 2 Nov 2023 13:07:01 +0400 Subject: Render top layer under fullscreen surfaces when stationary --- src/layout.rs | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) (limited to 'src/layout.rs') diff --git a/src/layout.rs b/src/layout.rs index 5426af95..663a5fc3 100644 --- a/src/layout.rs +++ b/src/layout.rs @@ -1768,6 +1768,16 @@ impl Monitor { } } } + + pub fn render_above_top_layer(&self) -> bool { + // Render above the top layer only if the view is stationary. + if self.workspace_switch.is_some() { + return false; + } + + let ws = &self.workspaces[self.active_workspace_idx]; + ws.render_above_top_layer() + } } impl Monitor { @@ -2449,6 +2459,19 @@ impl Workspace { let value = !col.is_fullscreen; self.set_fullscreen(window, value); } + + pub fn render_above_top_layer(&self) -> bool { + // Render above the top layer if we're on a fullscreen window and the view is stationary. + if self.columns.is_empty() { + return false; + } + + if self.view_offset_anim.is_some() { + return false; + } + + self.columns[self.active_column_idx].is_fullscreen + } } impl Workspace { -- cgit