diff --git a/pointer_input.cpp b/pointer_input.cpp index 70cef8f522..0d2dfea0bf 100644 --- a/pointer_input.cpp +++ b/pointer_input.cpp @@ -130,6 +130,7 @@ void PointerInputRedirection::init() connect(m_cursor, &CursorImage::changed, kwinApp()->platform(), &Platform::cursorChanged); emit m_cursor->changed(); connect(workspace(), &Workspace::stackingOrderChanged, this, &PointerInputRedirection::update); + connect(workspace(), &Workspace::clientMinimizedChanged, this, &PointerInputRedirection::update); connect(screens(), &Screens::changed, this, &PointerInputRedirection::updateAfterScreenChange); if (waylandServer()->hasScreenLockerIntegration()) { connect(ScreenLocker::KSldApp::self(), &ScreenLocker::KSldApp::lockStateChanged, this, diff --git a/workspace.cpp b/workspace.cpp index 0a4303482e..be0ec80b46 100644 --- a/workspace.cpp +++ b/workspace.cpp @@ -546,6 +546,7 @@ void Workspace::setupClientConnections(AbstractClient *c) { connect(c, &Toplevel::needsRepaint, m_compositor, &Compositor::scheduleRepaint); connect(c, &AbstractClient::desktopPresenceChanged, this, &Workspace::desktopPresenceChanged); + connect(c, &AbstractClient::minimizedChanged, this, std::bind(&Workspace::clientMinimizedChanged, this, c)); } Client* Workspace::createClient(xcb_window_t w, bool is_mapped) diff --git a/workspace.h b/workspace.h index 7e23807fa8..d856348b8e 100644 --- a/workspace.h +++ b/workspace.h @@ -479,6 +479,7 @@ Q_SIGNALS: void clientRemoved(KWin::AbstractClient*); void clientActivated(KWin::AbstractClient*); void clientDemandsAttentionChanged(KWin::AbstractClient*, bool); + void clientMinimizedChanged(KWin::AbstractClient*); void groupAdded(KWin::Group*); void unmanagedAdded(KWin::Unmanaged*); void unmanagedRemoved(KWin::Unmanaged*);