[TabBox] Fix Arrow Key / Keyboard Events in QML Alt+Tab Skins
Summary:
KWin used to do a quirky trick to send key events to the topmost QQuickItem
rather than things going to the activeFocus item.
Sending it to the window previously would have failed as the window
didn't think it was active.
Since 66986d4afd
we can just let the
window process the events in a normal QtQuick manner.
BUG: 370185
Fixed-in: 5.15.0
It will require tabboxes to set focus correctly.
The ones I tested did.
Most analysis for this patch was done by Chris Holland.
Test Plan:
Held+alt tab with the "Text" tabbox switcher
pressed up and down
Reviewers: #kwin, graesslin
Reviewed By: #kwin, graesslin
Subscribers: graesslin, kwin, Zren
Tags: #kwin
Differential Revision: https://phabricator.kde.org/D16693
This commit is contained in:
parent
7221864cd2
commit
c42d160742
1 changed files with 1 additions and 7 deletions
|
@ -528,13 +528,7 @@ void TabBoxHandler::grabbedKeyEvent(QKeyEvent* event) const
|
|||
if (!d->m_mainItem || !d->window()) {
|
||||
return;
|
||||
}
|
||||
const QList<QQuickItem*> items = d->window()->contentItem()->findChildren<QQuickItem*>(QString(), Qt::FindDirectChildrenOnly);
|
||||
for (QQuickItem *item : items) {
|
||||
d->window()->sendEvent(item, event);
|
||||
if (event->isAccepted()) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
QCoreApplication::sendEvent(d->window(), event);
|
||||
}
|
||||
|
||||
bool TabBoxHandler::containsPos(const QPoint& pos) const
|
||||
|
|
Loading…
Reference in a new issue