X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=9dbc60afb05b54fe5939ffeff373d2d7ca9b4dee;hb=f033a6c23d48561d064eeb6aaeb6eea1190cc4af;hp=0a2de598bd189d44717f05f4e5dbf30010088e1c;hpb=901cf3dc46cb72c79a1f479f50c4cba0023530f6;p=quassel.git diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 0a2de598..9dbc60af 100644 --- a/src/qtui/qtui.cpp +++ b/src/qtui/qtui.cpp @@ -28,6 +28,7 @@ #include "qtuimessageprocessor.h" #include "qtuisettings.h" #include "qtuistyle.h" +#include "systemtray.h" #include "toolbaractionprovider.h" #include "types.h" #include "util.h" @@ -70,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) { @@ -88,6 +93,38 @@ 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() { + 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) { if(!_notificationBackends.contains(backend)) { _notificationBackends.append(backend); @@ -158,5 +195,5 @@ void QtUi::notificationActivated(uint notificationId) { } closeNotification(notificationId); - mainWindow()->forceActivated(); + activateMainWidget(); }