Port to new KNotifications action API
This commit is contained in:
parent
4b1b1b9b14
commit
0343c9401d
4 changed files with 62 additions and 15 deletions
|
@ -54,18 +54,34 @@ public:
|
||||||
notification->setTitle(QStringLiteral("KDE Connect"));
|
notification->setTitle(QStringLiteral("KDE Connect"));
|
||||||
notification->setText(
|
notification->setText(
|
||||||
i18n("Pairing request from %1\nKey: %2...", device->name().toHtmlEscaped(), QString::fromUtf8(device->verificationKey().left(8))));
|
i18n("Pairing request from %1\nKey: %2...", device->name().toHtmlEscaped(), QString::fromUtf8(device->verificationKey().left(8))));
|
||||||
notification->setDefaultAction(i18n("Open"));
|
|
||||||
notification->setActions(QStringList{i18n("Accept"), i18n("Reject"), i18n("View key")});
|
|
||||||
connect(notification, &KNotification::action1Activated, device, &Device::acceptPairing);
|
|
||||||
connect(notification, &KNotification::action2Activated, device, &Device::cancelPairing);
|
|
||||||
QString deviceId = device->id();
|
QString deviceId = device->id();
|
||||||
auto openSettings = [deviceId, notification] {
|
auto openSettings = [deviceId, notification] {
|
||||||
OpenConfig oc;
|
OpenConfig oc;
|
||||||
oc.setXdgActivationToken(notification->xdgActivationToken());
|
oc.setXdgActivationToken(notification->xdgActivationToken());
|
||||||
oc.openConfiguration(deviceId);
|
oc.openConfiguration(deviceId);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#if QT_VERSION_MAJOR == 6
|
||||||
|
KNotificationAction *openSettingsAction = notification->addDefaultAction(i18n("Open"));
|
||||||
|
connect(openSettingsAction, &KNotificationAction::activated, openSettings);
|
||||||
|
|
||||||
|
KNotificationAction *acceptAction = notification->addAction(i18n("Accept"));
|
||||||
|
connect(acceptAction, &KNotificationAction::activated, device, &Device::acceptPairing);
|
||||||
|
|
||||||
|
KNotificationAction *rejectAction = notification->addAction(i18n("Reject"));
|
||||||
|
connect(rejectAction, &KNotificationAction::activated, device, &Device::cancelPairing);
|
||||||
|
|
||||||
|
KNotificationAction *viewKeyAction = notification->addAction(i18n("View key"));
|
||||||
|
connect(viewKeyAction, &KNotificationAction::activated, openSettings);
|
||||||
|
#else
|
||||||
|
notification->setDefaultAction(i18n("Open"));
|
||||||
|
notification->setActions(QStringList() << i18n("Accept") << i18n("Reject") << i18n("View key"));
|
||||||
|
connect(notification, &KNotification::action1Activated, device, &Device::acceptPairing);
|
||||||
|
connect(notification, &KNotification::action2Activated, device, &Device::cancelPairing);
|
||||||
connect(notification, &KNotification::action3Activated, openSettings);
|
connect(notification, &KNotification::action3Activated, openSettings);
|
||||||
connect(notification, &KNotification::activated, openSettings);
|
connect(notification, &KNotification::activated, openSettings);
|
||||||
|
#endif
|
||||||
|
|
||||||
notification->sendEvent();
|
notification->sendEvent();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -45,10 +45,12 @@ Notification::Notification(const NetworkPacket &np, const Device *device, QObjec
|
||||||
parseNetworkPacket(np);
|
parseNetworkPacket(np);
|
||||||
createKNotification(np);
|
createKNotification(np);
|
||||||
|
|
||||||
|
#if QT_VERSION_MAJOR == 5
|
||||||
connect(m_notification, &KNotification::activated, this, [this](unsigned int actionIndex) {
|
connect(m_notification, &KNotification::activated, this, [this](unsigned int actionIndex) {
|
||||||
// Notification action indices start at 1
|
// Notification action indices start at 1
|
||||||
Q_EMIT actionTriggered(m_internalId, m_actions[actionIndex - 1]);
|
Q_EMIT actionTriggered(m_internalId, m_actions[actionIndex - 1]);
|
||||||
});
|
});
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void Notification::dismiss()
|
void Notification::dismiss()
|
||||||
|
@ -118,7 +120,17 @@ void Notification::createKNotification(const NetworkPacket &np)
|
||||||
m_notification->setReplyAction(std::move(replyAction));
|
m_notification->setReplyAction(std::move(replyAction));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if QT_VERSION_MAJOR == 6
|
||||||
|
for (const QString &actionId : std::as_const(m_actions)) {
|
||||||
|
KNotificationAction *action = m_notification->addAction(actionId);
|
||||||
|
|
||||||
|
connect(action, &KNotificationAction::activated, this, [this, actionId] {
|
||||||
|
Q_EMIT actionTriggered(m_internalId, actionId);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
#else
|
||||||
m_notification->setActions(m_actions);
|
m_notification->setActions(m_actions);
|
||||||
|
#endif
|
||||||
|
|
||||||
m_hasIcon = m_hasIcon && !m_payloadHash.isEmpty();
|
m_hasIcon = m_hasIcon && !m_payloadHash.isEmpty();
|
||||||
|
|
||||||
|
|
|
@ -158,15 +158,8 @@ void SharePlugin::receivePacket(const NetworkPacket &np)
|
||||||
notif->setComponentName(QStringLiteral("kdeconnect"));
|
notif->setComponentName(QStringLiteral("kdeconnect"));
|
||||||
notif->setText(text);
|
notif->setText(text);
|
||||||
notif->setTitle(i18nc("@info Some piece of text was received from a connected device", "Shared text from %1 copied to clipboard", device()->name()));
|
notif->setTitle(i18nc("@info Some piece of text was received from a connected device", "Shared text from %1 copied to clipboard", device()->name()));
|
||||||
QStringList actions;
|
|
||||||
actions << i18nc("@action:button Edit text with default text editor", "Open in Text Editor");
|
|
||||||
if (url.isValid() && (url.scheme() == QStringLiteral("http") || url.scheme() == QStringLiteral("https"))) {
|
|
||||||
qDebug() << url;
|
|
||||||
actions << i18nc("@action:button Open URL with default app", "Open Link");
|
|
||||||
}
|
|
||||||
notif->setActions(actions);
|
|
||||||
|
|
||||||
connect(notif, &KNotification::action1Activated, this, [this, text]() {
|
auto openTextEditor = [this, text] {
|
||||||
KService::Ptr service = KApplicationTrader::preferredService(QStringLiteral("text/plain"));
|
KService::Ptr service = KApplicationTrader::preferredService(QStringLiteral("text/plain"));
|
||||||
const QString defaultApp = service ? service->desktopEntryName() : QString();
|
const QString defaultApp = service ? service->desktopEntryName() : QString();
|
||||||
|
|
||||||
|
@ -188,12 +181,33 @@ void SharePlugin::receivePacket(const NetworkPacket &np)
|
||||||
QDesktopServices::openUrl(QUrl::fromLocalFile(fileName));
|
QDesktopServices::openUrl(QUrl::fromLocalFile(fileName));
|
||||||
Q_EMIT shareReceived(fileName);
|
Q_EMIT shareReceived(fileName);
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
connect(notif, &KNotification::action2Activated, this, [this, url]() {
|
auto openUrl = [this, url] {
|
||||||
QDesktopServices::openUrl(url);
|
QDesktopServices::openUrl(url);
|
||||||
Q_EMIT shareReceived(url.toString());
|
Q_EMIT shareReceived(url.toString());
|
||||||
});
|
};
|
||||||
|
|
||||||
|
#if QT_VERSION_MAJOR == 6
|
||||||
|
KNotificationAction *textEditorAction = notif->addAction(i18nc("@action:button Edit text with default text editor", "Open in Text Editor"));
|
||||||
|
connect(textEditorAction, &KNotificationAction::activated, this, openTextEditor);
|
||||||
|
|
||||||
|
if (url.isValid() && (url.scheme() == QStringLiteral("http") || url.scheme() == QStringLiteral("https"))) {
|
||||||
|
KNotificationAction *openLinkAction = notif->addAction(i18nc("@action:button Open URL with default app", "Open Link"));
|
||||||
|
connect(openLinkAction, &KNotificationAction::activated, this, openUrl);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
QStringList actions;
|
||||||
|
actions << i18nc("@action:button Edit text with default text editor", "Open in Text Editor");
|
||||||
|
if (url.isValid() && (url.scheme() == QStringLiteral("http") || url.scheme() == QStringLiteral("https"))) {
|
||||||
|
actions << i18nc("@action:button Open URL with default app", "Open Link");
|
||||||
|
}
|
||||||
|
notif->setActions(actions);
|
||||||
|
|
||||||
|
connect(notif, &KNotification::action1Activated, this, openTextEditor);
|
||||||
|
|
||||||
|
connect(notif, &KNotification::action2Activated, this, openUrl);
|
||||||
|
#endif
|
||||||
|
|
||||||
notif->sendEvent();
|
notif->sendEvent();
|
||||||
|
|
||||||
|
|
|
@ -61,8 +61,13 @@ void TelephonyPlugin::createNotification(const NetworkPacket &np)
|
||||||
m_currentCallNotification->setText(content);
|
m_currentCallNotification->setText(content);
|
||||||
|
|
||||||
if (event == QLatin1String("ringing")) {
|
if (event == QLatin1String("ringing")) {
|
||||||
|
#if QT_VERSION_MAJOR == 6
|
||||||
|
KNotificationAction *muteAction = m_currentCallNotification->addAction(i18n("Mute Call"));
|
||||||
|
connect(muteAction, &KNotificationAction::activated, this, &TelephonyPlugin::sendMutePacket);
|
||||||
|
#else
|
||||||
m_currentCallNotification->setActions(QStringList(i18n("Mute Call")));
|
m_currentCallNotification->setActions(QStringList(i18n("Mute Call")));
|
||||||
connect(m_currentCallNotification, &KNotification::action1Activated, this, &TelephonyPlugin::sendMutePacket);
|
connect(m_currentCallNotification, &KNotification::action1Activated, this, &TelephonyPlugin::sendMutePacket);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
m_currentCallNotification->sendEvent();
|
m_currentCallNotification->sendEvent();
|
||||||
|
|
Loading…
Reference in a new issue