X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/3cd004e748b02a3f7c17ece6b1679990fc425300..b1c9b5126d:/src/draganddrophelper.cpp diff --git a/src/draganddrophelper.cpp b/src/draganddrophelper.cpp index d5a52f859..002394155 100644 --- a/src/draganddrophelper.cpp +++ b/src/draganddrophelper.cpp @@ -61,7 +61,7 @@ void DragAndDropHelper::startDrag(QAbstractItemView* itemView, if (data == 0) { return; } - + if (controller != 0) { controller->emitHideToolTip(); } @@ -80,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, @@ -91,34 +99,21 @@ void DragAndDropHelper::dropUrls(const KFileItem& destItem, { const bool dropToItem = !destItem.isNull() && (destItem.isDir() || destItem.isDesktopFile()); const KUrl destination = dropToItem ? destItem.url() : destPath; - + 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", "extractFilesTo"); + "org.kde.DndExtract", "extractSelectedFilesTo"); message.setArguments(QVariantList() << destination.path()); QDBusConnection::sessionBus().call(message); - } else { + } else { const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData()); - const KUrl source = urls.first(); - const KUrl sourceDir = KUrl(source.directory()); - const bool singleSelection = (urls.count() == 1); - - if (singleSelection && (source == destination)) { - emit errorMessage(i18nc("@info:status", "A folder cannot dropped on to itself")); - } else if (sourceDir == destination) { - QString msg; - if (singleSelection) { - msg = i18nc("@info:status", - "The dropped item %1 is already inside " - "the folder %2", source.fileName(), destination.fileName()); - } else { - msg = i18nc("@info:status", - "The dropped items are already inside the folder %1", - destination.fileName()); - } - emit errorMessage(msg); + 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 { @@ -128,6 +123,7 @@ void DragAndDropHelper::dropUrls(const KFileItem& destItem, } DragAndDropHelper::DragAndDropHelper() + : m_dragSource(0) { }