input: don't remove pinned focus on workspace change (#5486)

modified:   src/helpers/Monitor.cpp
This commit is contained in:
MightyPlaza 2024-04-07 22:13:56 +00:00 committed by GitHub
parent 7d989f2cf0
commit df1a3a978d
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -569,7 +569,8 @@ void CMonitor::changeWorkspace(const PHLWORKSPACE& pWorkspace, bool internal, bo
w->moveToWorkspace(pWorkspace); w->moveToWorkspace(pWorkspace);
} }
if (!noFocus && !g_pCompositor->m_pLastMonitor->activeSpecialWorkspace) { if (!noFocus && !g_pCompositor->m_pLastMonitor->activeSpecialWorkspace &&
!(g_pCompositor->m_pLastWindow && g_pCompositor->m_pLastWindow->m_bPinned && g_pCompositor->m_pLastWindow->m_iMonitorID == ID)) {
static auto PFOLLOWMOUSE = CConfigValue<Hyprlang::INT>("input:follow_mouse"); static auto PFOLLOWMOUSE = CConfigValue<Hyprlang::INT>("input:follow_mouse");
CWindow* pWindow = pWorkspace->getLastFocusedWindow(); CWindow* pWindow = pWorkspace->getLastFocusedWindow();
@ -627,10 +628,12 @@ void CMonitor::setSpecialWorkspace(const PHLWORKSPACE& pWorkspace) {
g_pLayoutManager->getCurrentLayout()->recalculateMonitor(ID); g_pLayoutManager->getCurrentLayout()->recalculateMonitor(ID);
if (const auto PLAST = activeWorkspace->getLastFocusedWindow(); PLAST) if (!(g_pCompositor->m_pLastWindow && g_pCompositor->m_pLastWindow->m_bPinned && g_pCompositor->m_pLastWindow->m_iMonitorID == ID)) {
g_pCompositor->focusWindow(PLAST); if (const auto PLAST = activeWorkspace->getLastFocusedWindow(); PLAST)
else g_pCompositor->focusWindow(PLAST);
g_pInputManager->refocus(); else
g_pInputManager->refocus();
}
g_pCompositor->updateFullscreenFadeOnWorkspace(activeWorkspace); g_pCompositor->updateFullscreenFadeOnWorkspace(activeWorkspace);
@ -693,10 +696,12 @@ void CMonitor::setSpecialWorkspace(const PHLWORKSPACE& pWorkspace) {
g_pLayoutManager->getCurrentLayout()->recalculateMonitor(ID); g_pLayoutManager->getCurrentLayout()->recalculateMonitor(ID);
if (const auto PLAST = pWorkspace->getLastFocusedWindow(); PLAST) if (!(g_pCompositor->m_pLastWindow && g_pCompositor->m_pLastWindow->m_bPinned && g_pCompositor->m_pLastWindow->m_iMonitorID == ID)) {
g_pCompositor->focusWindow(PLAST); if (const auto PLAST = pWorkspace->getLastFocusedWindow(); PLAST)
else g_pCompositor->focusWindow(PLAST);
g_pInputManager->refocus(); else
g_pInputManager->refocus();
}
g_pEventManager->postEvent(SHyprIPCEvent{"activespecial", pWorkspace->m_szName + "," + szName}); g_pEventManager->postEvent(SHyprIPCEvent{"activespecial", pWorkspace->m_szName + "," + szName});