From: Manuel Nickschas Date: Thu, 7 May 2009 17:27:57 +0000 (+0200) Subject: Select highlighted channel on clicking the blinking tray icon in all cases X-Git-Tag: 0.4.2~13 X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=commitdiff_plain;h=bbce706bf853ede08f70392f6d40323980873800 Select highlighted channel on clicking the blinking tray icon in all cases This was partially broken for KDEified Quassel. --- diff --git a/src/qtui/knotificationbackend.cpp b/src/qtui/knotificationbackend.cpp index f9f0eb6e..addba943 100644 --- a/src/qtui/knotificationbackend.cpp +++ b/src/qtui/knotificationbackend.cpp @@ -33,7 +33,10 @@ #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))); } @@ -47,14 +50,27 @@ void KNotificationBackend::notify(const Notification &n) { 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() { @@ -67,19 +83,13 @@ void KNotificationBackend::notificationActivated() { } 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 + if(reason == QSystemTrayIcon::Trigger && _lastNotificationId > 0) { + notificationActivated(_lastNotificationId); // most recent one } } void KNotificationBackend::notificationActivated(uint notificationId) { - QHash::iterator i = _notificationIds.begin(); - while(i != _notificationIds.end()) { - if(i.value() == notificationId) - i = _notificationIds.erase(i); - else - ++i; - } + removeNotificationById(notificationId); QtUi::mainWindow()->systemTray()->setInhibitActivation(); emit activated(notificationId); @@ -90,9 +100,9 @@ void KNotificationBackend::notificationActivated(uint notificationId) { } 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 { diff --git a/src/qtui/knotificationbackend.h b/src/qtui/knotificationbackend.h index 5c93ed5f..d846417c 100644 --- a/src/qtui/knotificationbackend.h +++ b/src/qtui/knotificationbackend.h @@ -48,7 +48,10 @@ private slots: private: class ConfigWidget; + void removeNotificationById(uint id); + QHash _notificationIds; + uint _lastNotificationId; }; class KNotificationBackend::ConfigWidget : public SettingsPage {