From 98077b86d63ac63572a525d8a5c22a22b9c12aa8 Mon Sep 17 00:00:00 2001 From: Piyush Aggarwal Date: Sat, 12 Jun 2021 06:10:06 +0530 Subject: [PATCH] indicator: replace send file invocation with urlhandler --- indicator/deviceindicator.cpp | 20 ++++++++------------ 1 file changed, 8 insertions(+), 12 deletions(-) diff --git a/indicator/deviceindicator.cpp b/indicator/deviceindicator.cpp index 3b63cdf27..b4efefb68 100644 --- a/indicator/deviceindicator.cpp +++ b/indicator/deviceindicator.cpp @@ -55,18 +55,14 @@ DeviceIndicator::DeviceIndicator(DeviceDbusInterface* device) setWhenAvailable(device->hasPlugin(QStringLiteral("kdeconnect_findmyphone")), [findDevice](bool available) { findDevice->setVisible(available); }, this); // Send file - auto sendFile = addAction(QIcon::fromTheme(QStringLiteral("document-share")), i18n("Send file")); - connect(sendFile, &QAction::triggered, device, [device, this](){ - const QUrl url = QFileDialog::getOpenFileUrl(parentWidget(), i18n("Select file to send to '%1'", device->name()), QUrl::fromLocalFile(QDir::homePath())); - if (url.isEmpty()) - return; - - QDBusMessage msg = QDBusMessage::createMethodCall(QStringLiteral("org.kde.kdeconnect"), QStringLiteral("/modules/kdeconnect/devices/") + device->id() + QStringLiteral("/share"), QStringLiteral("org.kde.kdeconnect.device.share"), QStringLiteral("shareUrl")); - msg.setArguments(QVariantList() << url.toString()); - DBusHelper::sessionBus().call(msg); - }); - - setWhenAvailable(device->hasPlugin(QStringLiteral("kdeconnect_share")), [sendFile](bool available) { sendFile->setVisible(available); }, this); + const QString kdeconnectHandlerExecutable = QStandardPaths::findExecutable(QStringLiteral("kdeconnect-handler")); + if (!kdeconnectHandlerExecutable.isEmpty()) { + auto handlerApp = addAction(QIcon::fromTheme(QStringLiteral("document-share")), i18n("Send a file/URL")); + QObject::connect(handlerApp, &QAction::triggered, device, [device, kdeconnectHandlerExecutable] () { + QProcess::startDetached(kdeconnectHandlerExecutable, { QStringLiteral("--device"), device->id() }); + }); + handlerApp->setVisible(true); + } // SMS Messages const QString kdeconnectsmsExecutable = QStandardPaths::findExecutable(QStringLiteral("kdeconnect-sms"), { QCoreApplication::applicationDirPath() });