┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
path: root/src/filterbar/filterbar.cpp
diff options
context:
space:
mode:
authorMéven Car <[email protected]>2023-05-08 17:46:51 +0200
committerMéven Car <[email protected]>2023-05-08 17:46:51 +0200
commit863ee3a87cee8b1f22a311d6a6a62e56714b5eae (patch)
tree728a2f70486e1835053e5c3431e72c62eb69ff82 /src/filterbar/filterbar.cpp
parent69f6b9b78b71f8369dc0ab9b9f9aecfd928d3eb1 (diff)
parent26808a188ccb5e35a05b37709e4fe61263c46032 (diff)
Merge branch 'master' into kf6
Diffstat (limited to 'src/filterbar/filterbar.cpp')
-rw-r--r--src/filterbar/filterbar.cpp26
1 files changed, 21 insertions, 5 deletions
diff --git a/src/filterbar/filterbar.cpp b/src/filterbar/filterbar.cpp
index 76e23d420..e24025c5b 100644
--- a/src/filterbar/filterbar.cpp
+++ b/src/filterbar/filterbar.cpp
@@ -10,6 +10,7 @@
#include <KLocalizedString>
+#include <QApplication>
#include <QHBoxLayout>
#include <QKeyEvent>
#include <QLineEdit>
@@ -47,6 +48,9 @@ FilterBar::FilterBar(QWidget *parent)
hLayout->addWidget(m_lockButton);
hLayout->addWidget(m_filterInput);
hLayout->addWidget(closeButton);
+
+ setTabOrder(m_lockButton, closeButton);
+ setTabOrder(closeButton, m_filterInput);
}
FilterBar::~FilterBar()
@@ -96,10 +100,8 @@ void FilterBar::showEvent(QShowEvent *event)
}
}
-void FilterBar::keyReleaseEvent(QKeyEvent *event)
+void FilterBar::keyPressEvent(QKeyEvent *event)
{
- QWidget::keyReleaseEvent(event);
-
switch (event->key()) {
case Qt::Key_Escape:
if (m_filterInput->text().isEmpty()) {
@@ -107,14 +109,28 @@ void FilterBar::keyReleaseEvent(QKeyEvent *event)
} else {
m_filterInput->clear();
}
- break;
+ return;
case Qt::Key_Enter:
case Qt::Key_Return:
Q_EMIT focusViewRequest();
- break;
+ return;
+
+ case Qt::Key_Down:
+ case Qt::Key_PageDown:
+ case Qt::Key_Up:
+ case Qt::Key_PageUp: {
+ Q_EMIT focusViewRequest();
+ QWidget *focusWidget = QApplication::focusWidget();
+ if (focusWidget && focusWidget != this) {
+ QApplication::sendEvent(focusWidget, event);
+ }
+ return;
+ }
default:
break;
}
+
+ QWidget::keyPressEvent(event);
}