X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/e46003aca365ca66ce7c7cccd47fb52d1da2fb91..d1099ee5bf4ed626a9ae9e5d30ec5ff3c468fa01:/src/draganddrophelper.cpp diff --git a/src/draganddrophelper.cpp b/src/draganddrophelper.cpp index d9188675a..637117a2b 100644 --- a/src/draganddrophelper.cpp +++ b/src/draganddrophelper.cpp @@ -1,5 +1,6 @@ /*************************************************************************** * Copyright (C) 2007 by Peter Penz * + * 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 * @@ -18,27 +19,61 @@ ***************************************************************************/ #include "draganddrophelper.h" +#include "dolphiniconsview.h" +#include "dolphincontroller.h" #include +#include #include +#include +#include +#include #include #include -#include +#include #include -#include -#include -#include -void DragAndDropHelper::startDrag(QAbstractItemView* itemView, Qt::DropActions supportedActions) +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"); +} + +void DragAndDropHelper::startDrag(QAbstractItemView* itemView, + Qt::DropActions supportedActions, + DolphinController* controller) +{ + // Do not start a new drag until the previous one has been finished. + // This is a (possibly temporary) fix for bug #187884. + static bool isDragging = false; + if (isDragging) { + return; + } + isDragging = true; + QModelIndexList indexes = itemView->selectionModel()->selectedIndexes(); - if (indexes.count() > 0) { + if (!indexes.isEmpty()) { QMimeData *data = itemView->model()->mimeData(indexes); if (data == 0) { return; } + if (controller != 0) { + controller->emitHideToolTip(); + } + QDrag* drag = new QDrag(itemView); QPixmap pixmap; if (indexes.count() == 1) { @@ -49,37 +84,56 @@ void DragAndDropHelper::startDrag(QAbstractItemView* itemView, Qt::DropActions s const KFileItem item = dirModel->itemForIndex(index); pixmap = item.pixmap(KIconLoader::SizeMedium, KIconLoader::SizeMedium); } else { - pixmap = KIcon("item-drag-multiple").pixmap(KIconLoader::SizeMedium, KIconLoader::SizeMedium); + pixmap = KIcon("document-multiple").pixmap(KIconLoader::SizeMedium, KIconLoader::SizeMedium); } drag->setPixmap(pixmap); drag->setMimeData(data); - drag->exec(supportedActions); + + m_dragSource = itemView; + drag->exec(supportedActions, Qt::IgnoreAction); + m_dragSource = 0; + } + isDragging = false; +} + +bool DragAndDropHelper::isDragSource(QAbstractItemView* itemView) +{ + return (m_dragSource != 0) && (m_dragSource == itemView); +} + +void DragAndDropHelper::dropUrls(const KFileItem& destItem, + const KUrl& destPath, + QDropEvent* event, + QWidget* widget) +{ + 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", "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); + } } } -void DragAndDropHelper::drawHoverIndication(QWidget* widget, - const QRect& bounds, - const QBrush& brush) +DragAndDropHelper::DragAndDropHelper() + : m_dragSource(0) { - QPainter painter(widget); - painter.save(); - QBrush blendedBrush(brush); - QColor color = blendedBrush.color(); - color.setAlpha(64); - blendedBrush.setColor(color); - - const int radius = 10; - QPainterPath path(QPointF(bounds.left(), bounds.top() + radius)); - path.quadTo(bounds.left(), bounds.top(), bounds.left() + radius, bounds.top()); - path.lineTo(bounds.right() - radius, bounds.top()); - path.quadTo(bounds.right(), bounds.top(), bounds.right(), bounds.top() + radius); - path.lineTo(bounds.right(), bounds.bottom() - radius); - path.quadTo(bounds.right(), bounds.bottom(), bounds.right() - radius, bounds.bottom()); - path.lineTo(bounds.left() + radius, bounds.bottom()); - path.quadTo(bounds.left(), bounds.bottom(), bounds.left(), bounds.bottom() - radius); - path.closeSubpath(); - - painter.setRenderHint(QPainter::Antialiasing); - painter.fillPath(path, blendedBrush); - painter.restore(); } + +#include "draganddrophelper.moc"