aboutsummaryrefslogtreecommitdiff
path: root/src/input
diff options
context:
space:
mode:
Diffstat (limited to 'src/input')
-rw-r--r--src/input/mod.rs28
1 files changed, 28 insertions, 0 deletions
diff --git a/src/input/mod.rs b/src/input/mod.rs
index 6e116d9e..c510a958 100644
--- a/src/input/mod.rs
+++ b/src/input/mod.rs
@@ -1318,6 +1318,34 @@ impl State {
self.niri.queue_redraw_all();
}
}
+ Action::MoveWindowToFloating => {
+ self.niri.layout.set_window_floating(None, true);
+ // FIXME: granular
+ self.niri.queue_redraw_all();
+ }
+ Action::MoveWindowToFloatingById(id) => {
+ let window = self.niri.layout.windows().find(|(_, m)| m.id().get() == id);
+ let window = window.map(|(_, m)| m.window.clone());
+ if let Some(window) = window {
+ self.niri.layout.set_window_floating(Some(&window), true);
+ // FIXME: granular
+ self.niri.queue_redraw_all();
+ }
+ }
+ Action::MoveWindowToTiling => {
+ self.niri.layout.set_window_floating(None, false);
+ // FIXME: granular
+ self.niri.queue_redraw_all();
+ }
+ Action::MoveWindowToTilingById(id) => {
+ let window = self.niri.layout.windows().find(|(_, m)| m.id().get() == id);
+ let window = window.map(|(_, m)| m.window.clone());
+ if let Some(window) = window {
+ self.niri.layout.set_window_floating(Some(&window), false);
+ // FIXME: granular
+ self.niri.queue_redraw_all();
+ }
+ }
Action::SwitchFocusBetweenFloatingAndTiling => {
self.niri.layout.switch_focus_floating_tiling();
// FIXME: granular