diff --git a/sway/tree/container.c b/sway/tree/container.c index 6880841bd..03eeb11fb 100644 --- a/sway/tree/container.c +++ b/sway/tree/container.c @@ -945,8 +945,6 @@ void container_set_floating(struct sway_container *container, bool enable) { struct sway_seat *seat = input_manager_current_seat(); struct sway_workspace *workspace = container->pending.workspace; - struct sway_container *focus = seat_get_focused_container(seat); - bool set_focus = focus == container; if (enable) { struct sway_container *old_parent = container->pending.parent; @@ -967,10 +965,6 @@ void container_set_floating(struct sway_container *container, bool enable) { container_floating_set_default_size(container); container_floating_resize_and_center(container); if (old_parent) { - if (set_focus) { - seat_set_raw_focus(seat, &old_parent->node); - seat_set_raw_focus(seat, &container->node); - } container_reap_empty(old_parent); } } else { @@ -985,7 +979,13 @@ void container_set_floating(struct sway_container *container, bool enable) { if (reference->view) { container_add_sibling(reference, container, 1); } else { - container_add_child(reference, container); + struct sway_container *sibling = + seat_get_focus_inactive_view(seat, &reference->node); + if (sibling) { + container_add_sibling(sibling, container, 1); + } else { + container_add_child(reference, container); + } } container->pending.width = reference->pending.width; container->pending.height = reference->pending.height;