aboutsummaryrefslogtreecommitdiff
path: root/sway/desktop/layer_shell.c
diff options
context:
space:
mode:
authorBrian Ashworth <bosrsf04@gmail.com>2019-12-26 19:51:06 -0500
committerSimon Ser <contact@emersion.fr>2019-12-27 11:38:56 +0100
commit088b374b1a3e7ead08e1430d3d89649b1cd5a54b (patch)
tree3ac0b3b3c063fb30cf078304733056502868f04f /sway/desktop/layer_shell.c
parentbd42415b5d3254f699a01845a0396e24f0de1a5f (diff)
layer-shell: refocus if keyboard interactive lost
When arranging layer-shell layers, verify that the currently focused layer, if any, for each seat is still keyboard interactive. If the layer is no longer keyboard interactive and there is not a keyboard interactive overlay or top layer to change the focus to, refocus the focus inactive node for the seat.
Diffstat (limited to 'sway/desktop/layer_shell.c')
-rw-r--r--sway/desktop/layer_shell.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/sway/desktop/layer_shell.c b/sway/desktop/layer_shell.c
index b754b1fa..b6dddff6 100644
--- a/sway/desktop/layer_shell.c
+++ b/sway/desktop/layer_shell.c
@@ -215,6 +215,9 @@ void arrange_layers(struct sway_output *output) {
wl_list_for_each(seat, &server.input->seats, link) {
if (topmost != NULL) {
seat_set_focus_layer(seat, topmost->layer_surface);
+ } else if (seat->focused_layer &&
+ !seat->focused_layer->current.keyboard_interactive) {
+ seat_set_focus_layer(seat, NULL);
}
}
}