X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=2efdf72ea229d67874f3200ea9887cf5aeb51ac8;hp=231bbf4bb6c94691fec1b10485297bc923911666;hb=af569a42f6635f6abfcedeb45b730ee64d53e0b8;hpb=b324a124e384bd8c9f54d97c5b5d6a5cc50fd91b diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 231bbf4b..2efdf72e 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 * @@ -21,38 +21,40 @@ #include "qtui.h" #include "abstractnotificationbackend.h" -#include "actioncollection.h" #include "chatlinemodel.h" +#include "contextmenuactionprovider.h" #include "mainwin.h" -#include "networkmodelactionprovider.h" #include "qtuimessageprocessor.h" #include "qtuisettings.h" #include "qtuistyle.h" +#include "toolbaractionprovider.h" #include "types.h" #include "util.h" -QHash QtUi::_actionCollections; QPointer QtUi::_instance = 0; QPointer QtUi::_mainWin = 0; QList QtUi::_notificationBackends; QList QtUi::_notifications; QtUiStyle *QtUi::_style = 0; -QtUi::QtUi() : AbstractUi() { +QtUi::QtUi() : GraphicalUi() { if(_instance != 0) { qWarning() << "QtUi has been instantiated again!"; return; } _instance = this; - _actionProvider = new NetworkModelActionProvider(this); + setContextMenuActionProvider(new ContextMenuActionProvider(this)); + setToolBarActionProvider(new ToolBarActionProvider(this)); QtUiSettings uiSettings; - loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); + Quassel::loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); _mainWin = new MainWin(); _style = new QtUiStyle; + setMainWidget(_mainWin); + connect(_mainWin, SIGNAL(connectToCore(const QVariantMap &)), this, SIGNAL(connectToCore(const QVariantMap &))); connect(_mainWin, SIGNAL(disconnectFromCore()), this, SIGNAL(disconnectFromCore())); } @@ -67,15 +69,6 @@ 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); } @@ -127,10 +120,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; } } @@ -140,9 +134,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; } }