X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=9c7cbbf884a7adf51f40247cd64e0ea6991d31c0;hp=4623142ccbbc1961714edde6133fbe9425496313;hb=f04db2cb802b1296ca739c823495930c71d3b4ab;hpb=5941801a1a5a61dc6d3e409ba33ab413adc9005f diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 4623142c..9c7cbbf8 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-2013 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -15,7 +15,7 @@ * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ #include "qtui.h" @@ -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,144 +37,218 @@ # include #endif -QPointer QtUi::_instance = 0; -QPointer QtUi::_mainWin = 0; +QtUi *QtUi::_instance = 0; +MainWin *QtUi::_mainWin = 0; QList QtUi::_notificationBackends; QList QtUi::_notifications; -QtUiStyle *QtUi::_style = 0; -QtUi::QtUi() : GraphicalUi() { - if(_instance != 0) { - qWarning() << "QtUi has been instantiated again!"; - return; - } - _instance = this; +QtUi::QtUi() : GraphicalUi() +{ + if (_instance != 0) { + qWarning() << "QtUi has been instantiated again!"; + return; + } + _instance = 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(); + + setMainWidget(_mainWin); + + connect(_mainWin, SIGNAL(connectToCore(const QVariantMap &)), this, SIGNAL(connectToCore(const QVariantMap &))); + connect(_mainWin, SIGNAL(disconnectFromCore()), this, SIGNAL(disconnectFromCore())); + connect(Client::instance(), SIGNAL(bufferMarkedAsRead(BufferId)), SLOT(closeNotifications(BufferId))); +} - setContextMenuActionProvider(new ContextMenuActionProvider(this)); - setToolBarActionProvider(new ToolBarActionProvider(this)); - QtUiSettings uiSettings; - Quassel::loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); +QtUi::~QtUi() +{ + unregisterAllNotificationBackends(); + delete _mainWin; + _mainWin = 0; + _instance = 0; +} - _mainWin = new MainWin(); - _style = new QtUiStyle; - setMainWidget(_mainWin); +void QtUi::init() +{ + _mainWin->init(); + QtUiSettings uiSettings; + uiSettings.initAndNotify("UseSystemTrayIcon", this, SLOT(useSystemTrayChanged(QVariant)), true); - connect(_mainWin, SIGNAL(connectToCore(const QVariantMap &)), this, SIGNAL(connectToCore(const QVariantMap &))); - connect(_mainWin, SIGNAL(disconnectFromCore()), this, SIGNAL(disconnectFromCore())); + GraphicalUi::init(); // needs to be called after the mainWin is initialized } -QtUi::~QtUi() { - unregisterAllNotificationBackends(); - delete _style; - delete _mainWin; + +MessageModel *QtUi::createMessageModel(QObject *parent) +{ + return new ChatLineModel(parent); } -void QtUi::init() { - _mainWin->init(); + +AbstractMessageProcessor *QtUi::createMessageProcessor(QObject *parent) +{ + return new QtUiMessageProcessor(parent); } -MessageModel *QtUi::createMessageModel(QObject *parent) { - return new ChatLineModel(parent); + +void QtUi::connectedToCore() +{ + _mainWin->connectedToCore(); } -AbstractMessageProcessor *QtUi::createMessageProcessor(QObject *parent) { - return new QtUiMessageProcessor(parent); + +void QtUi::disconnectedFromCore() +{ + _mainWin->disconnectedFromCore(); + GraphicalUi::disconnectedFromCore(); } -void QtUi::connectedToCore() { - _mainWin->connectedToCore(); + +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); + } } -void QtUi::disconnectedFromCore() { - _mainWin->disconnectedFromCore(); + +bool QtUi::haveSystemTray() +{ + return mainWindow()->systemTray()->isSystemTrayAvailable() && instance()->_useSystemTray; } -void QtUi::registerNotificationBackend(AbstractNotificationBackend *backend) { - if(!_notificationBackends.contains(backend)) { - _notificationBackends.append(backend); - instance()->connect(backend, SIGNAL(activated(uint)), SLOT(notificationActivated(uint))); - } + +bool QtUi::isHidingMainWidgetAllowed() const +{ + return haveSystemTray(); } -void QtUi::unregisterNotificationBackend(AbstractNotificationBackend *backend) { - _notificationBackends.removeAll(backend); + +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::unregisterAllNotificationBackends() { - _notificationBackends.clear(); + +void QtUi::registerNotificationBackend(AbstractNotificationBackend *backend) +{ + if (!_notificationBackends.contains(backend)) { + _notificationBackends.append(backend); + instance()->connect(backend, SIGNAL(activated(uint)), SLOT(notificationActivated(uint))); + } } -const QList &QtUi::notificationBackends() { - return _notificationBackends; + +void QtUi::unregisterNotificationBackend(AbstractNotificationBackend *backend) +{ + _notificationBackends.removeAll(backend); } -uint QtUi::invokeNotification(BufferId bufId, const QString &sender, const QString &text) { - static int notificationId = 0; - //notificationId++; - AbstractNotificationBackend::Notification notification(++notificationId, bufId, sender, text); - _notifications.append(notification); - foreach(AbstractNotificationBackend *backend, _notificationBackends) + +void QtUi::unregisterAllNotificationBackends() +{ + _notificationBackends.clear(); +} + + +const QList &QtUi::notificationBackends() +{ + return _notificationBackends; +} + + +uint QtUi::invokeNotification(BufferId bufId, AbstractNotificationBackend::NotificationType type, const QString &sender, const QString &text) +{ + static int notificationId = 0; + + AbstractNotificationBackend::Notification notification(++notificationId, bufId, type, sender, text); + _notifications.append(notification); + foreach(AbstractNotificationBackend *backend, _notificationBackends) backend->notify(notification); - return notificationId; -} - -void QtUi::closeNotification(uint notificationId) { - QList::iterator i = _notifications.begin(); - while(i != _notifications.end()) { - if((*i).notificationId == notificationId) { - foreach(AbstractNotificationBackend *backend, _notificationBackends) - backend->close(notificationId); - i = _notifications.erase(i); - break; - } else { - ++i; + return notificationId; +} + + +void QtUi::closeNotification(uint notificationId) +{ + QList::iterator i = _notifications.begin(); + while (i != _notifications.end()) { + if (i->notificationId == notificationId) { + foreach(AbstractNotificationBackend *backend, _notificationBackends) + backend->close(notificationId); + i = _notifications.erase(i); + } + else ++i; } - } -} - -void QtUi::closeNotifications(BufferId bufferId) { - QList::iterator i = _notifications.begin(); - while(i != _notifications.end()) { - if(!bufferId.isValid() || (*i).bufferId == bufferId) { - foreach(AbstractNotificationBackend *backend, _notificationBackends) - backend->close((*i).notificationId); - i = _notifications.erase(i); - } else { - ++i; +} + + +void QtUi::closeNotifications(BufferId bufferId) +{ + QList::iterator i = _notifications.begin(); + while (i != _notifications.end()) { + if (!bufferId.isValid() || i->bufferId == bufferId) { + foreach(AbstractNotificationBackend *backend, _notificationBackends) + backend->close(i->notificationId); + i = _notifications.erase(i); + } + else ++i; } - } } -const QList &QtUi::activeNotifications() { - return _notifications; + +const QList &QtUi::activeNotifications() +{ + return _notifications; } -void QtUi::notificationActivated(uint notificationId) { - if(notificationId != 0) { - QList::iterator i = _notifications.begin(); - while(i != _notifications.end()) { - if((*i).notificationId == notificationId) { - BufferId bufId = (*i).bufferId; - if(bufId.isValid()) - Client::bufferModel()->switchToBuffer(bufId); - _notifications.erase(i); - break; - } + +void QtUi::notificationActivated(uint notificationId) +{ + if (notificationId != 0) { + QList::iterator i = _notifications.begin(); + while (i != _notifications.end()) { + if (i->notificationId == notificationId) { + BufferId bufId = i->bufferId; + if (bufId.isValid()) + Client::bufferModel()->switchToBuffer(bufId); + break; + } + ++i; + } } - } + closeNotification(notificationId); -#ifdef Q_WS_X11 - // Bypass focus stealing prevention - QX11Info::setAppUserTime(QX11Info::appTime()); -#endif + activateMainWidget(); +} - if(_mainWin->windowState() & Qt::WindowMinimized) { - // restore - _mainWin->setWindowState((_mainWin->windowState() & ~Qt::WindowMinimized) | Qt::WindowActive); - _mainWin->show(); - } - _mainWin->raise(); - _mainWin->activateWindow(); + +void QtUi::bufferMarkedAsRead(BufferId bufferId) +{ + if (bufferId.isValid()) { + closeNotifications(bufferId); + } }