X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=c1ed4aa0096910823efd5c7207abcd52107a5e5e;hp=30727676bf9ca71e21d3aeb689a19e9be35b3625;hb=9a717378a859383363ea519dd9de9c0138d0db73;hpb=5c78a50fa720e5f82fcaa03c0176feab71d74c8e diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 30727676..c1ed4aa0 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,31 +20,37 @@ #include "qtui.h" +#include "abstractnotificationbackend.h" #include "actioncollection.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" -ActionCollection *QtUi::_actionCollection = 0; -MainWin *QtUi::_mainWin = 0; -QSet QtUi::_notificationBackends; +QHash QtUi::_actionCollections; +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; } - _actionCollection = new ActionCollection(this); + _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; @@ -63,6 +69,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 +96,20 @@ void QtUi::disconnectedFromCore() { void QtUi::registerNotificationBackend(AbstractNotificationBackend *backend) { if(!_notificationBackends.contains(backend)) { - _notificationBackends.insert(backend); + _notificationBackends.append(backend); + instance()->connect(backend, SIGNAL(activated()), SLOT(notificationActivated())); } } 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; } @@ -113,22 +129,24 @@ 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; } } void QtUi::closeNotifications(BufferId bufferId) { QList::iterator i = _notifications.begin(); while(i != _notifications.end()) { - if((*i).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; } } @@ -136,3 +154,8 @@ const QList &QtUi::activeNotification return _notifications; } +void QtUi::notificationActivated() { + // this might not work with some window managers + _mainWin->raise(); + _mainWin->activateWindow(); +}