X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=d19692cad79dcc93c44679718f1e9215a6a51814;hp=14597604a86df829faad242f1b683a09b54c5b48;hb=1f32c327ade7db3a1760b49508fb34aa10e98044;hpb=2ab3040da0e42f4afdd282e34f0d8b089020a73d diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index 14597604..d19692ca 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,45 +20,68 @@ #include "qtui.h" +#include "abstractnotificationbackend.h" #include "actioncollection.h" +#include "buffermodel.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; -QSet QtUi::_notificationBackends; +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() { - 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(); + _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(); +} + +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) { @@ -70,28 +93,93 @@ AbstractMessageProcessor *QtUi::createMessageProcessor(QObject *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.insert(backend); + _notificationBackends.append(backend); + instance()->connect(backend, SIGNAL(activated(uint)), SLOT(notificationActivated(uint))); } } void QtUi::unregisterNotificationBackend(AbstractNotificationBackend *backend) { - _notificationBackends.remove(backend); + _notificationBackends.removeAll(backend); } void QtUi::unregisterAllNotificationBackends() { _notificationBackends.clear(); } -void QtUi::notify(BufferId id, const QString &sender, const QString &text) { +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(id, sender, text); + 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); + i = _notifications.erase(i); + break; + } else ++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); + i = _notifications.erase(i); + } else ++i; + } +} + +const QList &QtUi::activeNotifications() { + return _notifications; +} + +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); + _notifications.erase(i); + break; + } else ++i; + } + } + +#ifdef Q_WS_X11 + // Bypass focus stealing prevention + QX11Info::setAppUserTime(QX11Info::appTime()); +#endif + + if(_mainWin->windowState() & Qt::WindowMinimized) { + // restore + _mainWin->setWindowState((_mainWin->windowState() & ~Qt::WindowMinimized) | Qt::WindowActive); + _mainWin->show(); + } + _mainWin->raise(); + _mainWin->activateWindow(); }