From f815d99c4266cb1c2baf16fd9e0fd0b98bdd12df Mon Sep 17 00:00:00 2001 From: "G. Allen Morris III" Date: Sat, 21 Oct 2023 09:00:32 +0200 Subject: [PATCH] Modify the Quit button on the Main Window to be a Hide button if the Tray is active. --- src/core/ui/mainwindow.cpp | 20 ++++++++++++++++---- src/core/ui/mainwindow.h | 1 + 2 files changed, 17 insertions(+), 4 deletions(-) diff --git a/src/core/ui/mainwindow.cpp b/src/core/ui/mainwindow.cpp index 1e681bab..2b09d1c2 100644 --- a/src/core/ui/mainwindow.cpp +++ b/src/core/ui/mainwindow.cpp @@ -49,6 +49,7 @@ MainWindow::MainWindow(QWidget* parent) : QMainWindow(parent), actHelp = new QAction(QIcon::fromTheme(QStringLiteral("system-help")), tr("Help"), this); actAbout = new QAction(QIcon::fromTheme(QStringLiteral("system-about")), tr("About"), this); actQuit = new QAction(QIcon::fromTheme(QStringLiteral("application-exit")), tr("Quit"), this); + actHideQuit = new QAction(QIcon::fromTheme(QStringLiteral("application-exit")), tr("QuitHide"), this); // connect actions to slots Core *c = Core::instance(); @@ -79,9 +80,9 @@ MainWindow::MainWindow(QWidget* parent) : QMainWindow(parent), QWidget* spacer = new QWidget(); spacer->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding); - _ui->toolBar->addWidget(spacer); + _ui->toolBar->addWidget(spacer); - _ui->toolBar->addAction(actQuit); + _ui->toolBar->addAction(actHideQuit); void (QSpinBox::*delayChange)(int) = &QSpinBox::valueChanged; connect(_ui->delayBox, delayChange, this, &MainWindow::delayBoxChange); @@ -217,14 +218,14 @@ void MainWindow::show() { if (!isVisible() && !_trayed) showNormal(); - if (_trayIcon){ + if (_trayIcon) { if (_conf->getShowTrayIcon()) { _trayIcon->blockSignals(false); _trayIcon->setContextMenu(_trayMenu); } - _trayIcon->setVisible(true); + _trayIcon->setVisible(true); } QMainWindow::show(); } @@ -451,6 +452,17 @@ void MainWindow::updateUI() _ui->checkIncludeCursor->setChecked(_conf->getIncludeCursor()); updateShortcuts(); + Core* c = Core::instance(); + + if (_conf->getShowTrayIcon()) { + disconnect(actHideQuit, &QAction::triggered, c, &Core::coreQuit); + connect(actHideQuit, &QAction::triggered, this, &MainWindow::windowHideShow); + actHideQuit->setText(tr("Hide")); + } else { + disconnect(actHideQuit, &QAction::triggered, this, &MainWindow::windowHideShow); + connect(actHideQuit, &QAction::triggered, c, &Core::coreQuit); + actHideQuit->setText(tr("Quit")); + } // create tray object if (_conf->getShowTrayIcon() && !_trayIcon) diff --git a/src/core/ui/mainwindow.h b/src/core/ui/mainwindow.h index 17cd915d..a1829afc 100644 --- a/src/core/ui/mainwindow.h +++ b/src/core/ui/mainwindow.h @@ -74,6 +74,7 @@ public Q_SLOTS: QAction *actAbout; QAction *actHelp; QAction *actQuit; + QAction *actHideQuit; Config *_conf; QMenu *_trayMenu; QShortcut *_hideWnd;