X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=66e07d0869b318b972371f77abdc2519c7c69ec6;hb=6f442c275cc5a2d5f1084ac2ceca5f1ffce1d024;hp=8ec12ef50be39ef42c50d29bf5faadca4b75dcaf;hpb=4775cbfc0dde54bad2a483a51409f392187a20f3;p=quassel.git diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 8ec12ef5..66e07d08 100644 --- a/src/qtui/qtui.cpp +++ b/src/qtui/qtui.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel Project * + * Copyright (C) 2005-09 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -20,30 +20,43 @@ #include "qtui.h" +#include "abstractnotificationbackend.h" #include "actioncollection.h" +#include "buffermodel.h" #include "chatlinemodel.h" +#include "contextmenuactionprovider.h" #include "mainwin.h" -#include "abstractnotificationbackend.h" #include "qtuimessageprocessor.h" +#include "qtuisettings.h" #include "qtuistyle.h" +#include "toolbaractionprovider.h" #include "types.h" -#include "uisettings.h" #include "util.h" QHash QtUi::_actionCollections; -MainWin *QtUi::_mainWin = 0; + +#ifdef Q_WS_X11 +# include +#endif + +QPointer QtUi::_instance = 0; +QPointer QtUi::_mainWin = 0; QList QtUi::_notificationBackends; QList QtUi::_notifications; QtUiStyle *QtUi::_style = 0; -QtUi::QtUi() : AbstractUi() { - if(_style != 0) { +QtUi::QtUi() : GraphicalUi() { + if(_instance != 0) { qWarning() << "QtUi has been instantiated again!"; return; } + _instance = this; + + setContextMenuActionProvider(new ContextMenuActionProvider(this)); + setToolBarActionProvider(new ToolBarActionProvider(this)); - UiSettings uiSettings; - loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); + QtUiSettings uiSettings; + Quassel::loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); _mainWin = new MainWin(); _style = new QtUiStyle; @@ -90,6 +103,7 @@ void QtUi::disconnectedFromCore() { void QtUi::registerNotificationBackend(AbstractNotificationBackend *backend) { if(!_notificationBackends.contains(backend)) { _notificationBackends.append(backend); + instance()->connect(backend, SIGNAL(activated(uint)), SLOT(notificationActivated(uint))); } } @@ -121,10 +135,9 @@ void QtUi::closeNotification(uint notificationId) { if((*i).notificationId == notificationId) { foreach(AbstractNotificationBackend *backend, _notificationBackends) backend->close(notificationId); - _notifications.erase(i); + i = _notifications.erase(i); break; - } - ++i; + } else ++i; } } @@ -134,9 +147,8 @@ void QtUi::closeNotifications(BufferId bufferId) { if(!bufferId.isValid() || (*i).bufferId == bufferId) { foreach(AbstractNotificationBackend *backend, _notificationBackends) backend->close((*i).notificationId); - _notifications.erase(i); - } - ++i; + i = _notifications.erase(i); + } else ++i; } } @@ -144,3 +156,21 @@ const QList &QtUi::activeNotification 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); + foreach(AbstractNotificationBackend *backend, _notificationBackends) + backend->close(notificationId); + _notifications.erase(i); + break; + } else ++i; + } + } + + mainWindow()->forceActivated(); +}