X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=7be5bd4d335b831257d2476845dce1ee082ae2dd;hp=27cf97151698fbefc8546354ffece1bce5139412;hb=6245a8d29e893eaff25a12b0be2f47b64f0f7bcd;hpb=3af9d3aeccfac1218ad3342434e5fda0c4ad1266 diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 27cf9715..7be5bd4d 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,37 +21,43 @@ #include "qtui.h" #include "abstractnotificationbackend.h" -#include "actioncollection.h" +#include "buffermodel.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; +#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() { +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()); + setUiStyle(new QtUiStyle(this)); _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())); @@ -59,7 +65,6 @@ QtUi::QtUi() : AbstractUi() { QtUi::~QtUi() { unregisterAllNotificationBackends(); - delete _style; delete _mainWin; } @@ -67,15 +72,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); } @@ -95,7 +91,7 @@ void QtUi::disconnectedFromCore() { void QtUi::registerNotificationBackend(AbstractNotificationBackend *backend) { if(!_notificationBackends.contains(backend)) { _notificationBackends.append(backend); - instance()->connect(backend, SIGNAL(activated()), SLOT(notificationActivated())); + instance()->connect(backend, SIGNAL(activated(uint)), SLOT(notificationActivated(uint))); } } @@ -111,10 +107,10 @@ const QList &QtUi::notificationBackends() { return _notificationBackends; } -uint QtUi::invokeNotification(BufferId bufId, const QString &sender, const QString &text) { +uint QtUi::invokeNotification(BufferId bufId, AbstractNotificationBackend::NotificationType type, const QString &sender, const QString &text) { static int notificationId = 0; //notificationId++; - AbstractNotificationBackend::Notification notification(++notificationId, bufId, sender, text); + AbstractNotificationBackend::Notification notification(++notificationId, bufId, type, sender, text); _notifications.append(notification); foreach(AbstractNotificationBackend *backend, _notificationBackends) backend->notify(notification); @@ -129,9 +125,7 @@ void QtUi::closeNotification(uint notificationId) { backend->close(notificationId); i = _notifications.erase(i); break; - } else { - ++i; - } + } else ++i; } } @@ -142,9 +136,7 @@ void QtUi::closeNotifications(BufferId bufferId) { foreach(AbstractNotificationBackend *backend, _notificationBackends) backend->close((*i).notificationId); i = _notifications.erase(i); - } else { - ++i; - } + } else ++i; } } @@ -152,8 +144,21 @@ const QList &QtUi::activeNotification return _notifications; } -void QtUi::notificationActivated() { - // this might not work with some window managers - _mainWin->raise(); - _mainWin->activateWindow(); +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(); }