36b103525c
The logic that decides whether we should shift the window up when the cursor rectangle overlaps with the keyboard rectangle doesn't work properly right now, we want it to work like this: - If the currently focused window is shifted up, keep it shifted up until the cursor rect no longer overlaps the keyboard rect. To do that comparison correctly, we need to adjust for the height the cursor rect is shifted up by (keyboardHeight) and temporarily shift it down again. - If the currently focused is not shifted up, we want to shift it up as soon as the focus rect overlaps the keyboard rect. If that's not the case, want still want to call _setFocusWindow(null) in order to shift the previously focused window back down. This fixes two issues: 1) We're currently shifting windows back down at the wrong position of the cursor (that is y < keyboardHeight). 2) We're not shifting down previously focused windows when focusing a different window with the new focus in a specific region (y >= keyboardHeight && y + h < monitor.y + monitor.height - keyboardHeight). Part-of: <https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/1760>