X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fknotificationbackend.cpp;h=99d52f83d13562edd71a42569fe1d81288691d2a;hb=9ea27e456f4163c37118f6dc34188809fc37d6d9;hp=64bdfdc30aa867678ea7cbf836d3572b52bf7161;hpb=8118229704229c33e151b3c707c8beaa0c077a86;p=quassel.git diff --git a/src/qtui/knotificationbackend.cpp b/src/qtui/knotificationbackend.cpp index 64bdfdc3..99d52f83 100644 --- a/src/qtui/knotificationbackend.cpp +++ b/src/qtui/knotificationbackend.cpp @@ -37,11 +37,26 @@ KNotificationBackend::KNotificationBackend(QObject *parent) : AbstractNotificati } void KNotificationBackend::notify(const Notification &n) { - //QString title = Client::networkModel()->networkName(n.bufferId) + " - " + Client::networkModel()->bufferName(n.bufferId); + QString type; + switch(n.type) { + case Highlight: + type = "Highlight"; break; + case HighlightFocused: + type = "HighlightFocused"; break; + case PrivMsg: + type = "PrivMsg"; break; + case PrivMsgFocused: + type = "PrivMsgFocused"; break; + } + QString message = QString("<%1> %2").arg(n.sender, n.message); - KNotification *notification = KNotification::event("Highlight", message, DesktopIcon("dialog-information"), QtUi::mainWindow(), + KNotification *notification = KNotification::event(type, message, DesktopIcon("dialog-information"), QtUi::mainWindow(), KNotification::Persistent|KNotification::RaiseWidgetOnActivation|KNotification::CloseWhenWidgetActivated); - connect(notification, SIGNAL(activated()), SLOT(notificationActivated())); + connect(notification, SIGNAL(activated(uint)), SLOT(notificationActivated())); + connect(notification, SIGNAL(closed()), SLOT(notificationClosed())); + notification->setActions(QStringList("View")); + _notificationIds[notification] = n.notificationId; + QtUi::mainWindow()->systemTray()->setAlert(true); } @@ -51,7 +66,18 @@ void KNotificationBackend::close(uint notificationId) { } void KNotificationBackend::notificationActivated() { - emit activated(); + uint id = 0; + KNotification *n = qobject_cast(sender()); + if(n && _notificationIds.contains(n)) + id = _notificationIds.value(n); + + emit activated(id); +} + +void KNotificationBackend::notificationClosed() { + KNotification *n = qobject_cast(sender()); + if(n && _notificationIds.contains(n)) + _notificationIds.remove(n); } SettingsPage *KNotificationBackend::createConfigWidget() const {