┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/dolphiniconsview.cpp32
-rw-r--r--src/dolphiniconsview.h2
-rw-r--r--src/dolphinview.cpp1
3 files changed, 29 insertions, 6 deletions
diff --git a/src/dolphiniconsview.cpp b/src/dolphiniconsview.cpp
index eb3dde47f..11fbf69a0 100644
--- a/src/dolphiniconsview.cpp
+++ b/src/dolphiniconsview.cpp
@@ -19,14 +19,17 @@
***************************************************************************/
#include "dolphiniconsview.h"
+#include "dolphinmainwindow.h"
#include "dolphinview.h"
#include <kdirmodel.h>
#include <kfileitem.h>
+#include <QAbstractProxyModel>
+
DolphinIconsView::DolphinIconsView(DolphinView* parent) :
QListView(parent),
- m_parentView( parent )
+ m_parentView(parent)
{
setResizeMode(QListView::Adjust);
}
@@ -58,11 +61,8 @@ void DolphinIconsView::contextMenuEvent(QContextMenuEvent* event)
const QModelIndex index = indexAt(event->pos());
if (index.isValid()) {
- // TODO: assuming that model() returns an instance of the class
- // KDirModel is dangerous, especially in combination with a proxy model.
- // As the current test implementation of proxy model does not work, this
- // will be cleaned up later.
- KDirModel* dirModel = static_cast<KDirModel*>(model());
+ const QAbstractProxyModel* proxyModel = static_cast<const QAbstractProxyModel*>(model());
+ const KDirModel* dirModel = static_cast<const KDirModel*>(proxyModel->sourceModel());
item = dirModel->itemForIndex(index);
}
@@ -75,4 +75,24 @@ void DolphinIconsView::mouseReleaseEvent(QMouseEvent* event)
m_parentView->declareViewActive();
}
+void DolphinIconsView::dragEnterEvent(QDragEnterEvent* event)
+{
+ if (event->mimeData()->hasUrls()) {
+ event->acceptProposedAction();
+ }
+}
+
+void DolphinIconsView::dropEvent(QDropEvent* event)
+{
+ const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData());
+ if (!urls.isEmpty()) {
+ event->acceptProposedAction();
+
+ // TODO: handle dropping above a directory
+
+ const KUrl& destination = m_parentView->url();
+ m_parentView->mainWindow()->dropUrls(urls, destination);
+ }
+}
+
#include "dolphiniconsview.moc"
diff --git a/src/dolphiniconsview.h b/src/dolphiniconsview.h
index 53554740e..e8ead3eb6 100644
--- a/src/dolphiniconsview.h
+++ b/src/dolphiniconsview.h
@@ -45,6 +45,8 @@ protected:
virtual QStyleOptionViewItem viewOptions() const;
virtual void contextMenuEvent(QContextMenuEvent* event);
virtual void mouseReleaseEvent(QMouseEvent* event);
+ virtual void dragEnterEvent(QDragEnterEvent* event);
+ virtual void dropEvent(QDropEvent* event);
private:
DolphinView* m_parentView;
diff --git a/src/dolphinview.cpp b/src/dolphinview.cpp
index 4d6a9ed68..b88abed0f 100644
--- a/src/dolphinview.cpp
+++ b/src/dolphinview.cpp
@@ -105,6 +105,7 @@ DolphinView::DolphinView(DolphinMainWindow *mainWindow,
m_dirModel = new KDirModel();
m_dirModel->setDirLister(m_dirLister);
+ m_dirModel->setDropsAllowed(KDirModel::DropOnDirectory);
m_proxyModel = new DolphinSortFilterProxyModel(this);
m_proxyModel->setSourceModel(m_dirModel);