diff options
| author | Méven Car <[email protected]> | 2023-08-23 18:56:41 +0200 |
|---|---|---|
| committer | Méven Car <[email protected]> | 2023-08-23 18:56:41 +0200 |
| commit | ae1980442d70aa04b1699fbba1c3503fdab58e6d (patch) | |
| tree | 88b89a59585d93b680b6af0c0825576d11ae7555 /src/dolphinviewcontainer.cpp | |
| parent | 21cd9da8fd128723d73745606724f6f77625aac0 (diff) | |
| parent | d27ee07de7558470ef7b497fbe3d3504ce7cad07 (diff) | |
Merge branch 'master' into kf6
Diffstat (limited to 'src/dolphinviewcontainer.cpp')
| -rw-r--r-- | src/dolphinviewcontainer.cpp | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/dolphinviewcontainer.cpp b/src/dolphinviewcontainer.cpp index 1199da6c5..c0ef1997a 100644 --- a/src/dolphinviewcontainer.cpp +++ b/src/dolphinviewcontainer.cpp @@ -23,6 +23,7 @@ #if HAVE_KACTIVITIES #include <KActivities/ResourceInstance> #endif +#include <KApplicationTrader> #include <KFileItemActions> #include <KFilePlacesModel> #include <KIO/JobUiDelegateFactory> @@ -130,6 +131,7 @@ DolphinViewContainer::DolphinViewContainer(const QUrl &url, QWidget *parent) connect(m_view, &DolphinView::writeStateChanged, this, &DolphinViewContainer::writeStateChanged); connect(m_view, &DolphinView::requestItemInfo, this, &DolphinViewContainer::showItemInfo); connect(m_view, &DolphinView::itemActivated, this, &DolphinViewContainer::slotItemActivated); + connect(m_view, &DolphinView::fileMiddleClickActivated, this, &DolphinViewContainer::slotfileMiddleClickActivated); connect(m_view, &DolphinView::itemsActivated, this, &DolphinViewContainer::slotItemsActivated); connect(m_view, &DolphinView::redirection, this, &DolphinViewContainer::redirect); connect(m_view, &DolphinView::directoryLoadingStarted, this, &DolphinViewContainer::slotDirectoryLoadingStarted); @@ -730,6 +732,26 @@ void DolphinViewContainer::slotItemActivated(const KFileItem &item) job->start(); } +void DolphinViewContainer::slotfileMiddleClickActivated(const KFileItem &item) +{ + KService::List services = KApplicationTrader::queryByMimeType(item.mimetype()); + + if (services.length() >= 2) { + auto service = services.at(1); + + KIO::ApplicationLauncherJob *job = new KIO::ApplicationLauncherJob(service, this); + job->setUrls({item.url()}); + +#if KIO_VERSION >= QT_VERSION_CHECK(5, 98, 0) + job->setUiDelegate(KIO::createDefaultJobUiDelegate(KJobUiDelegate::AutoHandlingEnabled, this)); +#else + job->setUiDelegate(new KIO::JobUiDelegate(KJobUiDelegate::AutoHandlingEnabled, this)); +#endif + connect(job, &KIO::OpenUrlJob::finished, this, &DolphinViewContainer::slotOpenUrlFinished); + job->start(); + } +} + void DolphinViewContainer::slotItemsActivated(const KFileItemList &items) { Q_ASSERT(items.count() >= 2); |
