X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=bcf8c0246f321e2bfa0a2517b619b78694960391;hp=0ae5ceea1ffc7e12e5986b6aa9a105826185bf57;hb=fe155e87ffa75bf4c13ae40311b029adba706816;hpb=4ef342acedf6a7a2176165c741e05d88c6a253de diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 0ae5ceea..bcf8c024 100644 --- a/src/qtui/qtui.cpp +++ b/src/qtui/qtui.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2010 by the Quassel Project * + * Copyright (C) 2005-2016 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" @@ -33,169 +33,218 @@ #include "types.h" #include "util.h" -#ifdef Q_WS_X11 -# include -#endif - QtUi *QtUi::_instance = 0; MainWin *QtUi::_mainWin = 0; QList QtUi::_notificationBackends; QList QtUi::_notifications; -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()); + QtUiSettings uiSettings; + Quassel::loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); - setContextMenuActionProvider(new ContextMenuActionProvider(this)); - setToolBarActionProvider(new ToolBarActionProvider(this)); + setContextMenuActionProvider(new ContextMenuActionProvider(this)); + setToolBarActionProvider(new ToolBarActionProvider(this)); - setUiStyle(new QtUiStyle(this)); - _mainWin = new MainWin(); + setUiStyle(new QtUiStyle(this)); + _mainWin = new MainWin(); - setMainWidget(_mainWin); + setMainWidget(_mainWin); - connect(_mainWin, SIGNAL(connectToCore(const QVariantMap &)), this, SIGNAL(connectToCore(const QVariantMap &))); - connect(_mainWin, SIGNAL(disconnectFromCore()), this, SIGNAL(disconnectFromCore())); + 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))); } -QtUi::~QtUi() { - unregisterAllNotificationBackends(); - delete _mainWin; - _mainWin = 0; - _instance = 0; + +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 +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) { - return new ChatLineModel(parent); + +MessageModel *QtUi::createMessageModel(QObject *parent) +{ + return new ChatLineModel(parent); } -AbstractMessageProcessor *QtUi::createMessageProcessor(QObject *parent) { - return new QtUiMessageProcessor(parent); + +AbstractMessageProcessor *QtUi::createMessageProcessor(QObject *parent) +{ + return new QtUiMessageProcessor(parent); } -void QtUi::connectedToCore() { - _mainWin->connectedToCore(); + +void QtUi::connectedToCore() +{ + _mainWin->connectedToCore(); } -void QtUi::disconnectedFromCore() { - _mainWin->disconnectedFromCore(); + +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); - } + +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::haveSystemTray() +{ + return mainWindow()->systemTray()->isSystemTrayAvailable() && instance()->_useSystemTray; } -bool QtUi::isHidingMainWidgetAllowed() const { - return haveSystemTray(); + +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::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); - instance()->connect(backend, SIGNAL(activated(uint)), SLOT(notificationActivated(uint))); - } + +void QtUi::registerNotificationBackend(AbstractNotificationBackend *backend) +{ + if (!_notificationBackends.contains(backend)) { + _notificationBackends.append(backend); + instance()->connect(backend, SIGNAL(activated(uint)), SLOT(notificationActivated(uint))); + } } -void QtUi::unregisterNotificationBackend(AbstractNotificationBackend *backend) { - _notificationBackends.removeAll(backend); + +void QtUi::unregisterNotificationBackend(AbstractNotificationBackend *backend) +{ + _notificationBackends.removeAll(backend); } -void QtUi::unregisterAllNotificationBackends() { - _notificationBackends.clear(); + +void QtUi::unregisterAllNotificationBackends() +{ + _notificationBackends.clear(); } -const QList &QtUi::notificationBackends() { - return _notificationBackends; + +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) +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; + 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::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); - break; - } - ++i; + +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); + closeNotification(notificationId); - activateMainWidget(); + activateMainWidget(); +} + + +void QtUi::bufferMarkedAsRead(BufferId bufferId) +{ + if (bufferId.isValid()) { + closeNotifications(bufferId); + } }