X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=1b513a76fc0a272506483c310301ebc411f46afd;hp=b3539217d1858f7fb68b4377e4246ca991144d45;hb=d0e9b9ff20a9b8e41b7983c6601aa4e04a50062f;hpb=374ea2a5188930b880ad67584a9b0055022feecf diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index b3539217..1b513a76 100644 --- a/src/qtui/qtui.cpp +++ b/src/qtui/qtui.cpp @@ -20,42 +20,130 @@ #include "qtui.h" +#include "abstractnotificationbackend.h" +#include "actioncollection.h" +#include "chatlinemodel.h" #include "mainwin.h" -#include "chatline-old.h" +#include "networkmodelactionprovider.h" +#include "qtuimessageprocessor.h" +#include "qtuisettings.h" +#include "qtuistyle.h" +#include "types.h" +#include "util.h" -QtUiStyle *QtUi::_style; +QHash QtUi::_actionCollections; +QPointer QtUi::_mainWin = 0; +QList QtUi::_notificationBackends; +QList QtUi::_notifications; +QtUiStyle *QtUi::_style = 0; -QtUi::QtUi() - : AbstractUi() -{ - mainWin = new MainWin(this); +QtUi::QtUi() : AbstractUi() { + if(_style != 0) { + qWarning() << "QtUi has been instantiated again!"; + return; + } + + _actionProvider = new NetworkModelActionProvider(this); + + QtUiSettings uiSettings; + loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); + + _mainWin = new MainWin(); _style = new QtUiStyle; - 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())); } QtUi::~QtUi() { + unregisterAllNotificationBackends(); delete _style; - delete mainWin; + delete _mainWin; } void QtUi::init() { - mainWin->init(); + _mainWin->init(); } -QtUiStyle *QtUi::style() { - return _style; +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; } -AbstractUiMsg *QtUi::layoutMsg(const Message &msg) { - return new ChatLineOld(msg); +MessageModel *QtUi::createMessageModel(QObject *parent) { + return new ChatLineModel(parent); +} + +AbstractMessageProcessor *QtUi::createMessageProcessor(QObject *parent) { + return new QtUiMessageProcessor(parent); } void QtUi::connectedToCore() { - mainWin->connectedToCore(); + _mainWin->connectedToCore(); } void QtUi::disconnectedFromCore() { - mainWin->disconnectedFromCore(); + _mainWin->disconnectedFromCore(); +} + +void QtUi::registerNotificationBackend(AbstractNotificationBackend *backend) { + if(!_notificationBackends.contains(backend)) { + _notificationBackends.append(backend); + } +} + +void QtUi::unregisterNotificationBackend(AbstractNotificationBackend *backend) { + _notificationBackends.removeAll(backend); +} + +void QtUi::unregisterAllNotificationBackends() { + _notificationBackends.clear(); } + +const QList &QtUi::notificationBackends() { + return _notificationBackends; +} + +uint QtUi::invokeNotification(BufferId bufId, const QString &sender, const QString &text) { + static int notificationId = 0; + //notificationId++; + AbstractNotificationBackend::Notification notification(++notificationId, bufId, sender, text); + _notifications.append(notification); + foreach(AbstractNotificationBackend *backend, _notificationBackends) + backend->notify(notification); + 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); + _notifications.erase(i); + break; + } + ++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); + _notifications.erase(i); + } + ++i; + } +} + +const QList &QtUi::activeNotifications() { + return _notifications; +} +