X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=27cf97151698fbefc8546354ffece1bce5139412;hp=d1c23ca00ead2e740ecbb16457868b169649655c;hb=3af9d3aeccfac1218ad3342434e5fda0c4ad1266;hpb=e1f500a5f5b510d16e9eaf76a24a9aea98fac86c diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index d1c23ca0..27cf9715 100644 --- a/src/qtui/qtui.cpp +++ b/src/qtui/qtui.cpp @@ -20,10 +20,11 @@ #include "qtui.h" +#include "abstractnotificationbackend.h" #include "actioncollection.h" #include "chatlinemodel.h" #include "mainwin.h" -#include "abstractnotificationbackend.h" +#include "networkmodelactionprovider.h" #include "qtuimessageprocessor.h" #include "qtuisettings.h" #include "qtuistyle.h" @@ -31,16 +32,20 @@ #include "util.h" QHash QtUi::_actionCollections; -MainWin *QtUi::_mainWin = 0; +QPointer QtUi::_instance = 0; +QPointer QtUi::_mainWin = 0; QList QtUi::_notificationBackends; QList QtUi::_notifications; QtUiStyle *QtUi::_style = 0; QtUi::QtUi() : AbstractUi() { - if(_style != 0) { + if(_instance != 0) { qWarning() << "QtUi has been instantiated again!"; return; } + _instance = this; + + _actionProvider = new NetworkModelActionProvider(this); QtUiSettings uiSettings; loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); @@ -90,6 +95,7 @@ void QtUi::disconnectedFromCore() { void QtUi::registerNotificationBackend(AbstractNotificationBackend *backend) { if(!_notificationBackends.contains(backend)) { _notificationBackends.append(backend); + instance()->connect(backend, SIGNAL(activated()), SLOT(notificationActivated())); } } @@ -121,10 +127,11 @@ void QtUi::closeNotification(uint notificationId) { if((*i).notificationId == notificationId) { foreach(AbstractNotificationBackend *backend, _notificationBackends) backend->close(notificationId); - _notifications.erase(i); + i = _notifications.erase(i); break; + } else { + ++i; } - ++i; } } @@ -134,9 +141,10 @@ void QtUi::closeNotifications(BufferId bufferId) { if(!bufferId.isValid() || (*i).bufferId == bufferId) { foreach(AbstractNotificationBackend *backend, _notificationBackends) backend->close((*i).notificationId); - _notifications.erase(i); + i = _notifications.erase(i); + } else { + ++i; } - ++i; } } @@ -144,3 +152,8 @@ const QList &QtUi::activeNotification return _notifications; } +void QtUi::notificationActivated() { + // this might not work with some window managers + _mainWin->raise(); + _mainWin->activateWindow(); +}