Support activation tokens for notifications

This commit is contained in:
Nicolas Werner 2023-11-20 13:59:20 +01:00
parent 234e05eef3
commit b16b52b40b
No known key found for this signature in database
GPG key ID: C8D75E610773F2D9
4 changed files with 22 additions and 0 deletions

View file

@ -101,6 +101,7 @@ private:
// but Qt slot declarations can not be inside an ifdef!
private slots:
void actionInvoked(uint id, QString action);
void activationToken(uint id, QString action);
void notificationClosed(uint id, uint reason);
void notificationReplied(uint id, QString reply);

View file

@ -22,6 +22,7 @@
#include "Cache.h"
#include "EventAccessors.h"
#include "Logging.h"
#include "MxcImageProvider.h"
#include "UserSettingsPage.h"
#include "Utils.h"
@ -58,6 +59,12 @@ NotificationsManager::NotificationsManager(QObject *parent)
QStringLiteral("ActionInvoked"),
this,
SLOT(actionInvoked(uint,QString)));
QDBusConnection::sessionBus().connect(QStringLiteral("org.freedesktop.Notifications"),
QStringLiteral("/org/freedesktop/Notifications"),
QStringLiteral("org.freedesktop.Notifications"),
QStringLiteral("ActivationToken"),
this,
SLOT(activationToken(uint,QString)));
QDBusConnection::sessionBus().connect(QStringLiteral("org.freedesktop.Notifications"),
QStringLiteral("/org/freedesktop/Notifications"),
QStringLiteral("org.freedesktop.Notifications"),
@ -256,6 +263,14 @@ NotificationsManager::actionInvoked(uint id, QString action)
}
}
// receive a wayland activation token from the notification manager
void
NotificationsManager::activationToken(uint, QString action)
{
nhlog::net()->debug("Got activation token for notification");
qputenv("XDG_ACTIVATION_TOKEN", action.toUtf8());
}
void
NotificationsManager::notificationReplied(uint id, QString reply)
{

View file

@ -182,6 +182,8 @@ void NotificationsManager::attachToMacNotifCenter()
// unused
void NotificationsManager::actionInvoked(uint, QString) { }
void NotificationsManager::activationToken(uint, QString) { }
void NotificationsManager::notificationReplied(uint, QString) { }
void NotificationsManager::notificationClosed(uint, uint) { }

View file

@ -95,6 +95,10 @@ void
NotificationsManager::actionInvoked(uint, QString)
{}
void
NotificationsManager::activationToken(uint, QString)
{}
void
NotificationsManager::notificationReplied(uint, QString)
{}