* Set a widget parent for the job.
* Better deduce the current working directory
BUG: 506612
#include <KLocalizedString>
#include <KPluginFactory>
#include <KNewFileMenu>
#include <KLocalizedString>
#include <KPluginFactory>
#include <KNewFileMenu>
#include <KIO/CopyJob>
#include <KIO/JobUiDelegate>
#include <KIO/FileUndoManager>
#include <KIO/CopyJob>
#include <KIO/JobUiDelegate>
#include <KIO/FileUndoManager>
QList<QAction *> MoveToNewFolderItemAction::actions(const KFileItemListProperties &fileItemInfos, QWidget *parentWidget)
{
const KFileItemList &selectedItems = fileItemInfos.items();
QList<QAction *> 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")));
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);
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);
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();
});
KIO::FileUndoManager::self()->recordCopyJob(job);
newFileMenu->deleteLater();
});
"KPlugin": {
"Icon": "folder-new",
"MimeTypes": [
"KPlugin": {
"Icon": "folder-new",
"MimeTypes": [
- "application/octet-stream"
+ "application/octet-stream",
+ "inode/directory"
],
"Name": "Move to New Folder",
"Name[ar]": "انقل إلى مجلد جديد",
],
"Name": "Move to New Folder",
"Name[ar]": "انقل إلى مجلد جديد",