X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fknotificationbackend.cpp;h=f9f0eb6eb5e54fdfeb7c44caec888b65106c102c;hp=cc8497844667ef76f33f8d9da8dcf3624f8ba0c9;hb=6f442c275cc5a2d5f1084ac2ceca5f1ffce1d024;hpb=308e090392713b0fa2e402156fbae2fa74cab96a diff --git a/src/qtui/knotificationbackend.cpp b/src/qtui/knotificationbackend.cpp index cc849784..f9f0eb6e 100644 --- a/src/qtui/knotificationbackend.cpp +++ b/src/qtui/knotificationbackend.cpp @@ -34,7 +34,8 @@ #include "systemtray.h" KNotificationBackend::KNotificationBackend(QObject *parent) : AbstractNotificationBackend(parent) { - + connect(QtUi::mainWindow()->systemTray(), SIGNAL(activated(QSystemTrayIcon::ActivationReason)), + SLOT(notificationActivated(QSystemTrayIcon::ActivationReason))); } void KNotificationBackend::notify(const Notification &n) { @@ -62,7 +63,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 && _notificationIds.count() > 0) { + notificationActivated(_notificationIds.values().at(0)); // we choose a random one for now + } +} + +void KNotificationBackend::notificationActivated(uint notificationId) { + QHash::iterator i = _notificationIds.begin(); + while(i != _notificationIds.end()) { + if(i.value() == notificationId) + i = _notificationIds.erase(i); + else + ++i; + } + + QtUi::mainWindow()->systemTray()->setInhibitActivation(); + emit activated(notificationId); + + if(!_notificationIds.count()) + QtUi::mainWindow()->systemTray()->setAlert(false); + } void KNotificationBackend::notificationClosed() {