From 6a40ca0b559ccac3862eb2f0f8bb5b768eedba3a Mon Sep 17 00:00:00 2001 From: Colomban Wendling Date: Wed, 15 Jun 2016 23:10:11 +0200 Subject: [PATCH] refactor(capslockindicator): expose as a QAction to simplify API --- src/widget/capslockindicator.cpp | 15 ++++++++------- src/widget/capslockindicator.h | 8 +++----- src/widget/loginscreen.cpp | 6 ++---- src/widget/loginscreen.h | 2 -- 4 files changed, 13 insertions(+), 18 deletions(-) diff --git a/src/widget/capslockindicator.cpp b/src/widget/capslockindicator.cpp index bf5fc2e97..521ac8bcc 100644 --- a/src/widget/capslockindicator.cpp +++ b/src/widget/capslockindicator.cpp @@ -4,9 +4,8 @@ #endif #include -CapsLockIndicator::CapsLockIndicator(QLineEdit *parent) : - QAction(parent), - parent(parent) +CapsLockIndicator::CapsLockIndicator(QObject* parent) : + QAction(parent) { setIcon(QIcon(":img/caps_lock.svg")); setToolTip(tr("CAPS-LOCK ENABLED")); @@ -14,6 +13,11 @@ CapsLockIndicator::CapsLockIndicator(QLineEdit *parent) : QCoreApplication::instance()->installEventFilter(this); } +CapsLockIndicator::~CapsLockIndicator() +{ + QCoreApplication::instance()->removeEventFilter(this); +} + void CapsLockIndicator::updateIndicator() { bool caps = false; @@ -22,10 +26,7 @@ void CapsLockIndicator::updateIndicator() caps = Platform::capsLockEnabled(); #endif - if (caps) - parent->addAction(this, QLineEdit::TrailingPosition); - else - parent->removeAction(this); + setVisible(caps); } bool CapsLockIndicator::eventFilter(QObject *obj, QEvent *event) diff --git a/src/widget/capslockindicator.h b/src/widget/capslockindicator.h index 01bd974f8..e5477ac42 100644 --- a/src/widget/capslockindicator.h +++ b/src/widget/capslockindicator.h @@ -4,18 +4,16 @@ #include #include -class CapsLockIndicator : QAction +class CapsLockIndicator : public QAction { public: - CapsLockIndicator(QLineEdit *widget); + CapsLockIndicator(QObject *parent); + ~CapsLockIndicator(); protected: bool eventFilter(QObject *obj, QEvent *event); private: void updateIndicator(); - -private: - QLineEdit *parent; }; #endif // CAPSLOCKINDICATOR_H diff --git a/src/widget/loginscreen.cpp b/src/widget/loginscreen.cpp index b9fd5fec8..7fbe18f71 100644 --- a/src/widget/loginscreen.cpp +++ b/src/widget/loginscreen.cpp @@ -58,8 +58,8 @@ LoginScreen::LoginScreen(QWidget *parent) : connect(ui->autoLoginCB, &QCheckBox::stateChanged, this, &LoginScreen::onAutoLoginToggled); connect(ui->importButton, &QPushButton::clicked, this, &LoginScreen::onImportProfile); - capsIndicator = new CapsLockIndicator(ui->newPass); - confimCapsIndicator = new CapsLockIndicator(ui->newPassConfirm); + ui->newPass->addAction(new CapsLockIndicator(this), QLineEdit::TrailingPosition); + ui->newPassConfirm->addAction(new CapsLockIndicator(this), QLineEdit::TrailingPosition); reset(); this->setStyleSheet(Style::getStylesheet(":/ui/loginScreen/loginScreen.css")); @@ -72,8 +72,6 @@ LoginScreen::~LoginScreen() { Translator::unregister(this); delete ui; - delete capsIndicator; - delete confimCapsIndicator; } void LoginScreen::reset() diff --git a/src/widget/loginscreen.h b/src/widget/loginscreen.h index 2f958583d..f1548d4fa 100644 --- a/src/widget/loginscreen.h +++ b/src/widget/loginscreen.h @@ -67,8 +67,6 @@ private: private: Ui::LoginScreen *ui; QShortcut quitShortcut; - CapsLockIndicator *capsIndicator; - CapsLockIndicator *confimCapsIndicator; }; #endif // LOGINSCREEN_H