X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=9dbc60afb05b54fe5939ffeff373d2d7ca9b4dee;hb=25e93f53be9b25f376c4f782f5e77d8e59b6cf10;hp=5495758875f3491e2413e36f44fe441894d817cc;hpb=d76bb125c8dd275095409edd3426700a98d89f3a;p=quassel.git diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 54957588..9dbc60af 100644 --- a/src/qtui/qtui.cpp +++ b/src/qtui/qtui.cpp @@ -71,6 +71,10 @@ QtUi::~QtUi() { void QtUi::init() { _mainWin->init(); + QtUiSettings uiSettings; + uiSettings.initAndNotify("UseSystemTrayIcon", this, SLOT(useSystemTrayChanged(QVariant)), true); + + GraphicalUi::init(); // needs to be called after the mainWin is initialized } MessageModel *QtUi::createMessageModel(QObject *parent) { @@ -89,12 +93,36 @@ void QtUi::disconnectedFromCore() { _mainWin->disconnectedFromCore(); } +void QtUi::useSystemTrayChanged(const QVariant &v) { + _useSystemTray = v.toBool(); + SystemTray *tray = mainWindow()->systemTray(); + if(_useSystemTray) { + if(tray->isSystemTrayAvailable()) + tray->setVisible(true); + } else { + if(tray->isSystemTrayAvailable() && mainWindow()->isVisible()) + tray->setVisible(false); + } +} + bool QtUi::haveSystemTray() { -#ifdef QT_NO_SYSTEMTRAYICON - return false; -#else - return mainWindow()->systemTray()->isSystemTrayAvailable(); -#endif + return mainWindow()->systemTray()->isSystemTrayAvailable() && instance()->_useSystemTray; +} + +bool QtUi::isHidingMainWidgetAllowed() const { + return haveSystemTray(); +} + +void QtUi::minimizeRestore(bool show) { + SystemTray *tray = mainWindow()->systemTray(); + if(show) { + if(tray && !_useSystemTray) + tray->setVisible(false); + } else { + if(tray && _useSystemTray) + tray->setVisible(true); + } + GraphicalUi::minimizeRestore(show); } void QtUi::registerNotificationBackend(AbstractNotificationBackend *backend) { @@ -167,5 +195,5 @@ void QtUi::notificationActivated(uint notificationId) { } closeNotification(notificationId); - mainWindow()->forceActivated(); + activateMainWidget(); }