X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fknotificationbackend.cpp;h=4e1379636ad4acd84d60c47aa9761f2c844ed090;hp=99d52f83d13562edd71a42569fe1d81288691d2a;hb=ef316d0db50a39efe45d71fe2eb4ea880724526b;hpb=9ea27e456f4163c37118f6dc34188809fc37d6d9 diff --git a/src/qtui/knotificationbackend.cpp b/src/qtui/knotificationbackend.cpp index 99d52f83..4e137963 100644 --- a/src/qtui/knotificationbackend.cpp +++ b/src/qtui/knotificationbackend.cpp @@ -22,6 +22,7 @@ #include #include +#include #include "knotificationbackend.h" @@ -32,8 +33,12 @@ #include "qtui.h" #include "systemtray.h" -KNotificationBackend::KNotificationBackend(QObject *parent) : AbstractNotificationBackend(parent) { - +KNotificationBackend::KNotificationBackend(QObject *parent) +: AbstractNotificationBackend(parent), + _lastNotificationId(0) +{ + connect(QtUi::mainWindow()->systemTray(), SIGNAL(activated(QSystemTrayIcon::ActivationReason)), + SLOT(notificationActivated(QSystemTrayIcon::ActivationReason))); } void KNotificationBackend::notify(const Notification &n) { @@ -49,20 +54,35 @@ void KNotificationBackend::notify(const Notification &n) { type = "PrivMsgFocused"; break; } - QString message = QString("<%1> %2").arg(n.sender, n.message); + QString message = QString("<%1> %2").arg(n.sender, Qt::escape(n.message)); KNotification *notification = KNotification::event(type, message, DesktopIcon("dialog-information"), QtUi::mainWindow(), - KNotification::Persistent|KNotification::RaiseWidgetOnActivation|KNotification::CloseWhenWidgetActivated); + KNotification::RaiseWidgetOnActivation + |KNotification::CloseWhenWidgetActivated + |KNotification::CloseOnTimeout); connect(notification, SIGNAL(activated(uint)), SLOT(notificationActivated())); connect(notification, SIGNAL(closed()), SLOT(notificationClosed())); notification->setActions(QStringList("View")); - _notificationIds[notification] = n.notificationId; + _notificationIds[notification] = _lastNotificationId = n.notificationId; QtUi::mainWindow()->systemTray()->setAlert(true); } +void KNotificationBackend::removeNotificationById(uint notificationId) { + QHash::iterator i = _notificationIds.begin(); + while(i != _notificationIds.end()) { + if(i.value() == notificationId) + i = _notificationIds.erase(i); + else + ++i; + } + if(_lastNotificationId == notificationId) + _lastNotificationId = 0; +} + void KNotificationBackend::close(uint notificationId) { - Q_UNUSED(notificationId); - QtUi::mainWindow()->systemTray()->setAlert(false); + removeNotificationById(notificationId); + if(!_notificationIds.count()) + QtUi::mainWindow()->systemTray()->setAlert(false); } void KNotificationBackend::notificationActivated() { @@ -71,13 +91,30 @@ void KNotificationBackend::notificationActivated() { if(n && _notificationIds.contains(n)) id = _notificationIds.value(n); - emit activated(id); + notificationActivated(id); +} + +void KNotificationBackend::notificationActivated(QSystemTrayIcon::ActivationReason reason) { + if(reason == QSystemTrayIcon::Trigger && _lastNotificationId > 0) { + notificationActivated(_lastNotificationId); // most recent one + } +} + +void KNotificationBackend::notificationActivated(uint notificationId) { + removeNotificationById(notificationId); + + QtUi::mainWindow()->systemTray()->setInhibitActivation(); + emit activated(notificationId); + + if(!_notificationIds.count()) + QtUi::mainWindow()->systemTray()->setAlert(false); + } void KNotificationBackend::notificationClosed() { - KNotification *n = qobject_cast(sender()); - if(n && _notificationIds.contains(n)) - _notificationIds.remove(n); + //KNotification *n = qobject_cast(sender()); + //if(n && _notificationIds.contains(n)) + // _notificationIds.remove(n); } SettingsPage *KNotificationBackend::createConfigWidget() const {