diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/dolphiniconsview.cpp | 32 | ||||
| -rw-r--r-- | src/dolphiniconsview.h | 2 | ||||
| -rw-r--r-- | src/dolphinview.cpp | 1 |
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); |
