X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=1b513a76fc0a272506483c310301ebc411f46afd;hp=0b8d3e696c65b6989f7d88fd2542202179b2a85f;hb=d0e9b9ff20a9b8e41b7983c6601aa4e04a50062f;hpb=011d2825dd89d2f93a72a49748581b16cc9bdb50 diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 0b8d3e69..1b513a76 100644 --- a/src/qtui/qtui.cpp +++ b/src/qtui/qtui.cpp @@ -20,19 +20,20 @@ #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" #include "types.h" -#include "uisettings.h" #include "util.h" -ActionCollection *QtUi::_actionCollection = 0; -MainWin *QtUi::_mainWin = 0; -QSet QtUi::_notificationBackends; +QHash QtUi::_actionCollections; +QPointer QtUi::_mainWin = 0; +QList QtUi::_notificationBackends; QList QtUi::_notifications; QtUiStyle *QtUi::_style = 0; @@ -41,9 +42,10 @@ QtUi::QtUi() : AbstractUi() { qWarning() << "QtUi has been instantiated again!"; return; } - _actionCollection = new ActionCollection(this); - UiSettings uiSettings; + _actionProvider = new NetworkModelActionProvider(this); + + QtUiSettings uiSettings; loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); _mainWin = new MainWin(); @@ -63,6 +65,15 @@ void QtUi::init() { _mainWin->init(); } +ActionCollection *QtUi::actionCollection(const QString &category) { + if(_actionCollections.contains(category)) + return _actionCollections.value(category); + ActionCollection *coll = new ActionCollection(mainWindow()); + coll->addAssociatedWidget(mainWindow()); + _actionCollections.insert(category, coll); + return coll; +} + MessageModel *QtUi::createMessageModel(QObject *parent) { return new ChatLineModel(parent); } @@ -81,19 +92,19 @@ void QtUi::disconnectedFromCore() { void QtUi::registerNotificationBackend(AbstractNotificationBackend *backend) { if(!_notificationBackends.contains(backend)) { - _notificationBackends.insert(backend); + _notificationBackends.append(backend); } } void QtUi::unregisterNotificationBackend(AbstractNotificationBackend *backend) { - _notificationBackends.remove(backend); + _notificationBackends.removeAll(backend); } void QtUi::unregisterAllNotificationBackends() { _notificationBackends.clear(); } -const QSet &QtUi::notificationBackends() { +const QList &QtUi::notificationBackends() { return _notificationBackends; }