From 50b2bce82d6604702e327f594448c7fee0f85a4a Mon Sep 17 00:00:00 2001 From: =?utf8?q?M=C3=A9ven=20Car?= Date: Thu, 10 Jul 2025 11:45:44 +0200 Subject: [PATCH] movetonewfolder: allow to move folders * Set a widget parent for the job. * Better deduce the current working directory BUG: 506612 --- src/itemactions/movetonewfolderitemaction.cpp | 18 ++++++++++-------- src/itemactions/movetonewfolderitemaction.json | 3 ++- 2 files changed, 12 insertions(+), 9 deletions(-) diff --git a/src/itemactions/movetonewfolderitemaction.cpp b/src/itemactions/movetonewfolderitemaction.cpp index cfd6f25ee..993d088b9 100644 --- a/src/itemactions/movetonewfolderitemaction.cpp +++ b/src/itemactions/movetonewfolderitemaction.cpp @@ -10,6 +10,7 @@ #include #include #include +#include #include #include #include @@ -27,22 +28,23 @@ MoveToNewFolderItemAction::MoveToNewFolderItemAction(QObject *parent) QList MoveToNewFolderItemAction::actions(const KFileItemListProperties &fileItemInfos, QWidget *parentWidget) { const KFileItemList &selectedItems = fileItemInfos.items(); + + if (selectedItems.size() == 1 && selectedItems[0].isDir()) { + // skip single directory like the current working directory + return {}; + } QAction *createFolderFromSelected = new QAction(i18nc("@action:inmenu", "Move to New Folder…"), parentWidget); createFolderFromSelected->setIcon(QIcon::fromTheme(QStringLiteral("folder-new"))); - connect(createFolderFromSelected, &QAction::triggered, this, [=, this]() { - QString selectedFileDirPath = selectedItems.at(0).url().toString().remove(selectedItems.at(0).name()); - if (selectedFileDirPath.endsWith(QStringLiteral("/"))) { - selectedFileDirPath.removeLast(); - } - const QUrl newFolderDirUrl(selectedFileDirPath); - + connect(createFolderFromSelected, &QAction::triggered, this, [=]() { + const QUrl selectedFileDirPath = selectedItems.at(0).url().adjusted(QUrl::RemoveFilename | QUrl::StripTrailingSlash); auto newFileMenu = new KNewFileMenu(parentWidget); - newFileMenu->setWorkingDirectory(newFolderDirUrl); + newFileMenu->setWorkingDirectory(selectedFileDirPath); newFileMenu->createDirectory(); connect(newFileMenu, &KNewFileMenu::directoryCreated, this, [=](const QUrl &createdUrl) { KIO::CopyJob *job = KIO::move(selectedItems.urlList(), createdUrl); + KJobWidgets::setWindow(job, parentWidget); KIO::FileUndoManager::self()->recordCopyJob(job); newFileMenu->deleteLater(); }); diff --git a/src/itemactions/movetonewfolderitemaction.json b/src/itemactions/movetonewfolderitemaction.json index 185667c32..ce394007d 100644 --- a/src/itemactions/movetonewfolderitemaction.json +++ b/src/itemactions/movetonewfolderitemaction.json @@ -2,7 +2,8 @@ "KPlugin": { "Icon": "folder-new", "MimeTypes": [ - "application/octet-stream" + "application/octet-stream", + "inode/directory" ], "Name": "Move to New Folder", "Name[ar]": "انقل إلى مجلد جديد", -- 2.47.3