From fc9caef79a9b35d776ff91bb1288323e94379068 Mon Sep 17 00:00:00 2001 From: tobtoht Date: Sun, 3 Jul 2022 19:41:08 +0200 Subject: [PATCH] Inactivity lock: hide all interface elements --- src/MainWindow.cpp | 12 +++++++++--- src/MainWindow.h | 2 +- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/src/MainWindow.cpp b/src/MainWindow.cpp index 7de899a..b7790ee 100644 --- a/src/MainWindow.cpp +++ b/src/MainWindow.cpp @@ -1611,10 +1611,10 @@ void MainWindow::updateRecentlyOpenedMenu() { ui->menuRecently_open->addAction(m_clearRecentlyOpenAction); } -bool MainWindow::verifyPassword() { +bool MainWindow::verifyPassword(bool sensitive) { bool incorrectPassword = false; while (true) { - PasswordDialog passwordDialog{this->walletName(), incorrectPassword, true, this}; + PasswordDialog passwordDialog{this->walletName(), incorrectPassword, sensitive, this}; int ret = passwordDialog.exec(); if (ret == QDialog::Rejected) { return false; @@ -1652,7 +1652,10 @@ void MainWindow::checkUserActivity() { if ((m_userLastActive + (config()->get(Config::inactivityLockTimeout).toInt()*60)) < QDateTime::currentSecsSinceEpoch()) { m_checkUserActivity.stop(); qInfo() << "Locking wallet for inactivity"; - if (!this->verifyPassword()) { + ui->tabWidget->hide(); + this->statusBar()->hide(); + this->menuBar()->hide(); + if (!this->verifyPassword(false)) { this->setEnabled(false); this->close(); // This doesn't close the wallet immediately. @@ -1667,6 +1670,9 @@ void MainWindow::checkUserActivity() { } while (QApplication::hasPendingEvents()); #endif } else { + ui->tabWidget->show(); + this->statusBar()->show(); + this->menuBar()->show(); m_checkUserActivity.start(); } } diff --git a/src/MainWindow.h b/src/MainWindow.h index fd25106..6e5b9c3 100644 --- a/src/MainWindow.h +++ b/src/MainWindow.h @@ -215,7 +215,7 @@ private: void addToRecentlyOpened(const QString &filename); void updateRecentlyOpenedMenu(); void updateWidgetIcons(); - bool verifyPassword(); + bool verifyPassword(bool senstive = true); void patchStylesheetMac(); void fillSendTab(const QString &address, const QString &description); void userActivity();