X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/c0fd7f2a19d82e91df1ec795aee7b335b442f0e8..b1c9b5126d:/src/draganddrophelper.cpp
diff --git a/src/draganddrophelper.cpp b/src/draganddrophelper.cpp
index bdbcfae19..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,27 +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());
-
- if ((urls.count() == 1) && (source == destination)) {
- emit errorMessage(i18nc("@info:status", "A folder cannot dropped on to itself"));
- } else if (sourceDir == destination) {
- const QString msg = i18ncp("@info:status",
- "The dropped item %2 is already inside the folder %3",
- "The dropped items are already inside the folder %3",
- urls.count(), source.fileName(), 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 {
@@ -121,6 +123,7 @@ void DragAndDropHelper::dropUrls(const KFileItem& destItem,
}
DragAndDropHelper::DragAndDropHelper()
+ : m_dragSource(0)
{
}