From 47713241ebf5bac9a2cc9b2fc91b5ebd9870832d Mon Sep 17 00:00:00 2001 From: ronso0 Date: Wed, 12 Jan 2022 01:57:12 +0100 Subject: [PATCH] WBeatSpinBox/AutoDJ spinbox: Enter & Esc also move focus to library --- src/library/autodj/dlgautodj.cpp | 22 ++++++++++++++-------- src/library/autodj/dlgautodj.h | 1 + src/widget/wbeatspinbox.cpp | 13 ++++++++----- 3 files changed, 23 insertions(+), 13 deletions(-) diff --git a/src/library/autodj/dlgautodj.cpp b/src/library/autodj/dlgautodj.cpp index adfe89852ac..4cc452a87ee 100644 --- a/src/library/autodj/dlgautodj.cpp +++ b/src/library/autodj/dlgautodj.cpp @@ -79,8 +79,6 @@ DlgAutoDJ::DlgAutoDJ(WLibrary* parent, m_pAutoDJTableModel = m_pAutoDJProcessor->getTableModel(); m_pTrackTableView->loadTrackModel(m_pAutoDJTableModel); - // Override some playlist-view properties: - // Do not set this because it disables auto-scrolling //m_pTrackTableView->setDragDropMode(QAbstractItemView::InternalMove); @@ -163,12 +161,8 @@ DlgAutoDJ::DlgAutoDJ(WLibrary* parent, // work around QLineEdit being protected QLineEdit* lineEditTransition(spinBoxTransition->findChild()); lineEditTransition->setFocusPolicy(Qt::ClickFocus); - // Catch any Return keypress to pass focus to tracks table - connect(lineEditTransition, - &QLineEdit::returnPressed, - this, - // Move focus to tracks table to immediately allow keyboard shortcuts again. - &DlgAutoDJ::setFocus); + // Needed to catch Enter, Return and Escape keypresses + lineEditTransition->installEventFilter(this); connect(spinBoxTransition, QOverload::of(&QSpinBox::valueChanged), @@ -386,6 +380,18 @@ void DlgAutoDJ::setFocus() { m_pTrackTableView->setFocus(); } +void DlgAutoDJ::keyPressEvent(QKeyEvent* pEvent) { + // Return, Enter and Escape key move focus to the AutoDJ queue to immediately + // allow keyboard shortcuts again. + if (pEvent->key() == Qt::Key_Return || + pEvent->key() == Qt::Key_Enter || + pEvent->key() == Qt::Key_Escape) { + setFocus(); + return; + } + return QWidget::keyPressEvent(pEvent); +} + void DlgAutoDJ::saveCurrentViewState() { m_pTrackTableView->saveCurrentViewState(); } diff --git a/src/library/autodj/dlgautodj.h b/src/library/autodj/dlgautodj.h index d0976f2d3c7..163146e6bc8 100644 --- a/src/library/autodj/dlgautodj.h +++ b/src/library/autodj/dlgautodj.h @@ -59,6 +59,7 @@ class DlgAutoDJ : public QWidget, public Ui::DlgAutoDJ, public LibraryView { void setupActionButton(QPushButton* pButton, void (DlgAutoDJ::*pSlot)(bool), const QString& fallbackText); + void keyPressEvent(QKeyEvent* pEvent) override; const UserSettingsPointer m_pConfig; diff --git a/src/widget/wbeatspinbox.cpp b/src/widget/wbeatspinbox.cpp index ded403b4a59..81e16d70845 100644 --- a/src/widget/wbeatspinbox.cpp +++ b/src/widget/wbeatspinbox.cpp @@ -297,12 +297,15 @@ bool WBeatSpinBox::event(QEvent* pEvent) { } void WBeatSpinBox::keyPressEvent(QKeyEvent* pEvent) { - // Return key applies current value and sends a Shift+Tab event in order - // to focus a library widget. In official skins this would be the tracks table. - if (pEvent->key() == Qt::Key_Return) { + // Return & Enter keys apply current value. + // Return, Enter and Escape send a Shift+Tab event in order to move focus + // to a library widget. In official skins this would be the tracks table. + if (pEvent->key() == Qt::Key_Return || + pEvent->key() == Qt::Key_Enter || + pEvent->key() == Qt::Key_Escape) { QDoubleSpinBox::keyPressEvent(pEvent); - QKeyEvent returnKeyEvent = QKeyEvent{QEvent::KeyPress, Qt::Key_Tab, Qt::ShiftModifier}; - QApplication::sendEvent(this, &returnKeyEvent); + QKeyEvent shiftTabKeyEvent = QKeyEvent{QEvent::KeyPress, Qt::Key_Tab, Qt::ShiftModifier}; + QApplication::sendEvent(this, &shiftTabKeyEvent); return; } return QDoubleSpinBox::keyPressEvent(pEvent);