#include "systemtray.h"
SystrayNotificationBackend::SystrayNotificationBackend(QObject *parent)
- : AbstractNotificationBackend(parent), _activeId(0)
+ : AbstractNotificationBackend(parent)
{
NotificationSettings notificationSettings;
_showBubble = notificationSettings.value("Systray/ShowBubble", true).toBool();
if(notification.type != Highlight && notification.type != PrivMsg)
return;
- /* fancy stuff to be implemented later: show notifications in order
- _notifications.append(notification);
- if(_showBubble && _notifications.count() == 1) {
- showBubble();
- }
- */
- _notifications.clear();
_notifications.append(notification);
if(_showBubble)
showBubble();
}
void SystrayNotificationBackend::close(uint notificationId) {
- Q_UNUSED(notificationId);
- /* fancy stuff to be implemented later
- int idx = _notifications.indexOf(notificationId);
-
- if(_notifications.isEmpty()) {
- */
- _notifications.clear();
- _activeId = 0;
+ QList<Notification>::iterator i = _notifications.begin();
+ while(i != _notifications.end()) {
+ if(i->notificationId == notificationId)
+ i = _notifications.erase(i);
+ else
+ ++i;
+ }
+
closeBubble();
- QtUi::mainWindow()->systemTray()->setAlert(false);
+
+ if(!_notifications.count())
+ QtUi::mainWindow()->systemTray()->setAlert(false);
}
void SystrayNotificationBackend::showBubble() {
// for now, we just show the last message
if(_notifications.isEmpty())
return;
- Notification n = _notifications.takeLast();
- _activeId = n.notificationId;
+ Notification n = _notifications.last();
QString title = Client::networkModel()->networkName(n.bufferId) + " - " + Client::networkModel()->bufferName(n.bufferId);
QString message = QString("<%1> %2").arg(n.sender, n.message);
QtUi::mainWindow()->systemTray()->showMessage(title, message);
void SystrayNotificationBackend::notificationActivated() {
if(QtUi::mainWindow()->systemTray()->isAlerted()) {
QtUi::mainWindow()->systemTray()->setInhibitActivation();
- emit activated(_activeId);
+ uint id = _notifications.count()? _notifications.last().notificationId : 0;
+ emit activated(id);
}
}