X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=f3bb9a6df405c474ef1064b053625695d03e33e1;hp=3774acbed891c7f10d83ddaac3f6a68eba3525ab;hb=647215f1dd8ea6fdb6e4fb747c5dc3e19c4ec3fc;hpb=eabf97d25da5af06033807c2697fd687fc48d2e7 diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 3774acbe..f3bb9a6d 100644 --- a/src/qtui/qtui.cpp +++ b/src/qtui/qtui.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-09 by the Quassel Project * + * Copyright (C) 2005-2010 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -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" @@ -36,8 +37,8 @@ # include #endif -QPointer QtUi::_instance = 0; -QPointer QtUi::_mainWin = 0; +QtUi *QtUi::_instance = 0; +MainWin *QtUi::_mainWin = 0; QList QtUi::_notificationBackends; QList QtUi::_notifications; @@ -48,12 +49,12 @@ QtUi::QtUi() : GraphicalUi() { } _instance = this; - setContextMenuActionProvider(new ContextMenuActionProvider(this)); - setToolBarActionProvider(new ToolBarActionProvider(this)); - QtUiSettings uiSettings; Quassel::loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); + setContextMenuActionProvider(new ContextMenuActionProvider(this)); + setToolBarActionProvider(new ToolBarActionProvider(this)); + setUiStyle(new QtUiStyle(this)); _mainWin = new MainWin(); @@ -66,10 +67,16 @@ QtUi::QtUi() : GraphicalUi() { QtUi::~QtUi() { unregisterAllNotificationBackends(); delete _mainWin; + _mainWin = 0; + _instance = 0; } 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) { @@ -86,6 +93,39 @@ void QtUi::connectedToCore() { void QtUi::disconnectedFromCore() { _mainWin->disconnectedFromCore(); + GraphicalUi::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) { @@ -158,5 +198,5 @@ void QtUi::notificationActivated(uint notificationId) { } closeNotification(notificationId); - mainWindow()->forceActivated(); + activateMainWidget(); }