mirror of
https://github.com/Nheko-Reborn/nheko.git
synced 2024-11-29 06:08:48 +03:00
Keep DBUS from blocking
This commit is contained in:
parent
b51bf6748b
commit
70a4e1e265
1 changed files with 48 additions and 40 deletions
|
@ -2,9 +2,11 @@
|
|||
|
||||
#include <QDebug>
|
||||
#include <QImage>
|
||||
#include <QtDBus/QDBusConnection>
|
||||
#include <QtDBus/QDBusMessage>
|
||||
#include <QtDBus/QDBusMetaType>
|
||||
#include <QDBusConnection>
|
||||
#include <QDBusMessage>
|
||||
#include <QDBusMetaType>
|
||||
#include <QDBusPendingCallWatcher>
|
||||
#include <QDBusPendingReply>
|
||||
|
||||
NotificationsManager::NotificationsManager(QObject *parent)
|
||||
: QObject(parent)
|
||||
|
@ -36,6 +38,12 @@ NotificationsManager::NotificationsManager(QObject *parent)
|
|||
SLOT(notificationReplied(uint, QString)));
|
||||
}
|
||||
|
||||
/**
|
||||
* This function is based on code from
|
||||
* https://github.com/rohieb/StratumsphereTrayIcon
|
||||
* Copyright (C) 2012 Roland Hieber <rohieb@rohieb.name>
|
||||
* Licensed under the GNU General Public License, version 3
|
||||
*/
|
||||
void
|
||||
NotificationsManager::postNotification(const QString &roomid,
|
||||
const QString &eventid,
|
||||
|
@ -44,28 +52,16 @@ NotificationsManager::postNotification(const QString &roomid,
|
|||
const QString &text,
|
||||
const QImage &icon)
|
||||
{
|
||||
uint id = showNotification(roomname, sender + ": " + text, icon);
|
||||
notificationIds[id] = roomEventId{roomid, eventid};
|
||||
}
|
||||
/**
|
||||
* This function is based on code from
|
||||
* https://github.com/rohieb/StratumsphereTrayIcon
|
||||
* Copyright (C) 2012 Roland Hieber <rohieb@rohieb.name>
|
||||
* Licensed under the GNU General Public License, version 3
|
||||
*/
|
||||
uint
|
||||
NotificationsManager::showNotification(const QString summary,
|
||||
const QString text,
|
||||
const QImage image)
|
||||
{
|
||||
Q_UNUSED(icon)
|
||||
|
||||
QVariantMap hints;
|
||||
hints["image-data"] = image;
|
||||
hints["image-data"] = sender + ": " + text;
|
||||
hints["sound-name"] = "message-new-instant";
|
||||
QList<QVariant> argumentList;
|
||||
argumentList << "nheko"; // app_name
|
||||
argumentList << (uint)0; // replace_id
|
||||
argumentList << ""; // app_icon
|
||||
argumentList << summary; // summary
|
||||
argumentList << roomname; // summary
|
||||
argumentList << text; // body
|
||||
// The list of actions has always the action name and then a localized version of that
|
||||
// action. Currently we just use an empty string for that.
|
||||
|
@ -79,15 +75,27 @@ NotificationsManager::showNotification(const QString summary,
|
|||
static QDBusInterface notifyApp("org.freedesktop.Notifications",
|
||||
"/org/freedesktop/Notifications",
|
||||
"org.freedesktop.Notifications");
|
||||
QDBusMessage reply =
|
||||
auto call =
|
||||
notifyApp.callWithArgumentList(QDBus::AutoDetect, "Notify", argumentList);
|
||||
if (reply.type() == QDBusMessage::ErrorMessage) {
|
||||
qDebug() << "D-Bus Error:" << reply.errorMessage();
|
||||
QDBusPendingCallWatcher watcher{QDBusPendingReply{call}};
|
||||
connect(&watcher, &QDBusPendingCallWatcher::finished, this, [&watcher, this, &roomid, &eventid]() {
|
||||
if (watcher.reply().type() == QDBusMessage::ErrorMessage)
|
||||
qDebug() << "D-Bus Error:" << watcher.reply().errorMessage();
|
||||
else
|
||||
notificationIds[watcher.reply().arguments().first().toUInt()] = roomEventId{roomid, eventid};
|
||||
});
|
||||
}
|
||||
|
||||
uint
|
||||
NotificationsManager::showNotification(const QString summary,
|
||||
const QString text,
|
||||
const QImage image)
|
||||
{
|
||||
Q_UNUSED(summary)
|
||||
Q_UNUSED(text)
|
||||
Q_UNUSED(image)
|
||||
|
||||
return 0;
|
||||
} else {
|
||||
return reply.arguments().first().toUInt();
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
void
|
||||
|
|
Loading…
Reference in a new issue