In Dolphin on wayland currently, if you right clicks a file and create a
zip file from it, Dolphin makes a new window.
What we want to happen is Dolphin to focus the window we have with the
file selected.
This patches Dolphin's dbusinterface.cpp to call
KWindowSystem::setCurrentXdgActivationToken()
with the startupID
#include "dolphin_generalsettings.h"
#include <KPropertiesDialog>
#include "dolphin_generalsettings.h"
#include <KPropertiesDialog>
+#include <KWindowSystem>
#include <QApplication>
#include <QDBusConnection>
#include <QApplication>
#include <QDBusConnection>
void DBusInterface::ShowFolders(const QStringList& uriList, const QString& startUpId)
{
void DBusInterface::ShowFolders(const QStringList& uriList, const QString& startUpId)
{
const QList<QUrl> urls = Dolphin::validateUris(uriList);
if (urls.isEmpty()) {
return;
}
const QList<QUrl> urls = Dolphin::validateUris(uriList);
if (urls.isEmpty()) {
return;
}
+ KWindowSystem::setCurrentXdgActivationToken(startUpId);
const auto serviceName = isDaemon() ? QString() : QStringLiteral("org.kde.dolphin-%1").arg(QCoreApplication::applicationPid());
if(!Dolphin::attachToExistingInstance(urls, false, GeneralSettings::splitView(), serviceName)) {
Dolphin::openNewWindow(urls);
const auto serviceName = isDaemon() ? QString() : QStringLiteral("org.kde.dolphin-%1").arg(QCoreApplication::applicationPid());
if(!Dolphin::attachToExistingInstance(urls, false, GeneralSettings::splitView(), serviceName)) {
Dolphin::openNewWindow(urls);
void DBusInterface::ShowItems(const QStringList& uriList, const QString& startUpId)
{
void DBusInterface::ShowItems(const QStringList& uriList, const QString& startUpId)
{
const QList<QUrl> urls = Dolphin::validateUris(uriList);
if (urls.isEmpty()) {
return;
}
const QList<QUrl> urls = Dolphin::validateUris(uriList);
if (urls.isEmpty()) {
return;
}
+ KWindowSystem::setCurrentXdgActivationToken(startUpId);
const auto serviceName = isDaemon() ? QString() : QStringLiteral("org.kde.dolphin-%1").arg(QCoreApplication::applicationPid());
if(!Dolphin::attachToExistingInstance(urls, true, GeneralSettings::splitView(), serviceName)) {
Dolphin::openNewWindow(urls, nullptr, Dolphin::OpenNewWindowFlag::Select);
const auto serviceName = isDaemon() ? QString() : QStringLiteral("org.kde.dolphin-%1").arg(QCoreApplication::applicationPid());
if(!Dolphin::attachToExistingInstance(urls, true, GeneralSettings::splitView(), serviceName)) {
Dolphin::openNewWindow(urls, nullptr, Dolphin::OpenNewWindowFlag::Select);
void DBusInterface::ShowItemProperties(const QStringList& uriList, const QString& startUpId)
{
void DBusInterface::ShowItemProperties(const QStringList& uriList, const QString& startUpId)
{
const QList<QUrl> urls = Dolphin::validateUris(uriList);
if (!urls.isEmpty()) {
const QList<QUrl> urls = Dolphin::validateUris(uriList);
if (!urls.isEmpty()) {
+ KWindowSystem::setCurrentXdgActivationToken(startUpId);
KPropertiesDialog::showDialog(urls);
}
}
KPropertiesDialog::showDialog(urls);
}
}
- // TODO: once Wayland clients can raise or activate themselves remove check from conditional
- if (KWindowSystem::isPlatformWayland() || inputUrls.isEmpty() || !GeneralSettings::openExternallyCalledFolderInNewTab()) {
+ if (inputUrls.isEmpty() || !GeneralSettings::openExternallyCalledFolderInNewTab()) {