X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtui.cpp;h=d19692cad79dcc93c44679718f1e9215a6a51814;hp=d8d808f99b67d1d776a748b1f031acd760097dee;hb=1f32c327ade7db3a1760b49508fb34aa10e98044;hpb=a540a0285feef171e16fd6225b0e045fc5fc52e4 diff --git a/src/qtui/qtui.cpp b/src/qtui/qtui.cpp index d8d808f9..d19692ca 100644 --- a/src/qtui/qtui.cpp +++ b/src/qtui/qtui.cpp @@ -22,16 +22,23 @@ #include "abstractnotificationbackend.h" #include "actioncollection.h" +#include "buffermodel.h" #include "chatlinemodel.h" #include "contextmenuactionprovider.h" #include "mainwin.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; @@ -46,6 +53,7 @@ QtUi::QtUi() : GraphicalUi() { _instance = this; setContextMenuActionProvider(new ContextMenuActionProvider(this)); + setToolBarActionProvider(new ToolBarActionProvider(this)); QtUiSettings uiSettings; Quassel::loadTranslation(uiSettings.value("Locale", QLocale::system()).value()); @@ -95,7 +103,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))); } } @@ -129,9 +137,7 @@ void QtUi::closeNotification(uint notificationId) { backend->close(notificationId); i = _notifications.erase(i); break; - } else { - ++i; - } + } else ++i; } } @@ -142,9 +148,7 @@ void QtUi::closeNotifications(BufferId bufferId) { foreach(AbstractNotificationBackend *backend, _notificationBackends) backend->close((*i).notificationId); i = _notifications.erase(i); - } else { - ++i; - } + } else ++i; } } @@ -152,8 +156,30 @@ const QList &QtUi::activeNotification return _notifications; } -void QtUi::notificationActivated() { - // this might not work with some window managers +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(); }