X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/e7bd514a39f0b07ddfec85f5f7b391e16af7d279..b1c9b5126d:/src/draganddrophelper.cpp diff --git a/src/draganddrophelper.cpp b/src/draganddrophelper.cpp index 6e3fff2fc..002394155 100644 --- a/src/draganddrophelper.cpp +++ b/src/draganddrophelper.cpp @@ -1,6 +1,7 @@ /*************************************************************************** * Copyright (C) 2007 by Peter Penz * - * Copyright (C) 2007 by David Faure * * * + * Copyright (C) 2007 by David Faure * + * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * @@ -24,13 +25,28 @@ #include #include #include +#include +#include #include #include #include +#include #include -bool DragAndDropHelper::isMimeDataSupported(const QMimeData* mimeData) +class DragAndDropHelperSingleton +{ +public: + DragAndDropHelper instance; +}; +K_GLOBAL_STATIC(DragAndDropHelperSingleton, s_dragAndDropHelper) + +DragAndDropHelper& DragAndDropHelper::instance() +{ + return s_dragAndDropHelper->instance; +} + +bool DragAndDropHelper::isMimeDataSupported(const QMimeData* mimeData) const { return mimeData->hasUrls() || mimeData->hasFormat("application/x-kde-dndextract"); } @@ -45,7 +61,7 @@ void DragAndDropHelper::startDrag(QAbstractItemView* itemView, if (data == 0) { return; } - + if (controller != 0) { controller->emitHideToolTip(); } @@ -64,10 +80,18 @@ void DragAndDropHelper::startDrag(QAbstractItemView* itemView, } drag->setPixmap(pixmap); drag->setMimeData(data); + + m_dragSource = itemView; drag->exec(supportedActions, Qt::IgnoreAction); + m_dragSource = 0; } } +bool DragAndDropHelper::isDragSource(QAbstractItemView* itemView) +{ + return (m_dragSource != 0) && (m_dragSource == itemView); +} + void DragAndDropHelper::dropUrls(const KFileItem& destItem, const KUrl& destPath, QDropEvent* event, @@ -75,14 +99,32 @@ void DragAndDropHelper::dropUrls(const KFileItem& destItem, { const bool dropToItem = !destItem.isNull() && (destItem.isDir() || destItem.isDesktopFile()); const KUrl destination = dropToItem ? destItem.url() : destPath; - - const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData()); - const KUrl sourceDir = KUrl(urls.first().directory()); - if (sourceDir != destination) { - if (dropToItem) { + + const QMimeData* mimeData = event->mimeData(); + if (mimeData->hasFormat("application/x-kde-dndextract")) { + QString remoteDBusClient = mimeData->data("application/x-kde-dndextract"); + QDBusMessage message = QDBusMessage::createMethodCall(remoteDBusClient, "/DndExtract", + "org.kde.DndExtract", "extractSelectedFilesTo"); + message.setArguments(QVariantList() << destination.path()); + QDBusConnection::sessionBus().call(message); + } else { + const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData()); + const int urlsCount = urls.count(); + if (urlsCount == 0) { + // TODO: handle dropping of other data + } else if ((urlsCount == 1) && (urls.first() == destination)) { + emit errorMessage(i18nc("@info:status", "A folder cannot be dropped into itself")); + } else if (dropToItem) { KonqOperations::doDrop(destItem, destination, event, widget); } else { KonqOperations::doDrop(KFileItem(), destination, event, widget); } } } + +DragAndDropHelper::DragAndDropHelper() + : m_dragSource(0) +{ +} + +#include "draganddrophelper.moc"