diff --git a/abstract_client.cpp b/abstract_client.cpp index dc145c4dee..260e5fdccf 100644 --- a/abstract_client.cpp +++ b/abstract_client.cpp @@ -792,6 +792,13 @@ bool AbstractClient::performMouseCommand(Options::MouseCommand cmd, const QPoint break; case Options::MouseLower: { workspace()->lowerClient(this); + // used to be activateNextClient(this), then topClientOnDesktop + // since this is a mouseOp it's however safe to use the client under the mouse instead + if (isActive() && options->focusPolicyIsReasonable()) { + AbstractClient *next = workspace()->clientUnderMouse(screen()); + if (next && next != this) + workspace()->requestFocus(next, false); + } break; } case Options::MouseOperationsMenu: diff --git a/useractions.cpp b/useractions.cpp index 95861cceda..eb498f3581 100755 --- a/useractions.cpp +++ b/useractions.cpp @@ -1199,17 +1199,6 @@ bool Client::performMouseCommand(Options::MouseCommand command, const QPoint &gl { bool replay = false; switch(command) { - case Options::MouseLower: { - workspace()->lowerClient(this); - // used to be activateNextClient(this), then topClientOnDesktop - // since this is a mouseOp it's however safe to use the client under the mouse instead - if (isActive() && options->focusPolicyIsReasonable()) { - AbstractClient *next = workspace()->clientUnderMouse(screen()); - if (next && next != this) - workspace()->requestFocus(next, false); - } - break; - } case Options::MouseShade : toggleShade(); cancelShadeHoverTimer();