X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/d8669c68e40a6571dfcbdf38e3281a4aeb8c2be6..5840fcede7178c80d137f589110d09ee20a99483:/src/dolphiniconsview.cpp diff --git a/src/dolphiniconsview.cpp b/src/dolphiniconsview.cpp index 98d1a05b1..6d5509275 100644 --- a/src/dolphiniconsview.cpp +++ b/src/dolphiniconsview.cpp @@ -19,14 +19,17 @@ ***************************************************************************/ #include "dolphiniconsview.h" +#include "dolphinmainwindow.h" #include "dolphinview.h" #include #include +#include + DolphinIconsView::DolphinIconsView(DolphinView* parent) : QListView(parent), - m_parentView( parent ) + m_parentView(parent) { setResizeMode(QListView::Adjust); } @@ -58,8 +61,7 @@ void DolphinIconsView::contextMenuEvent(QContextMenuEvent* event) const QModelIndex index = indexAt(event->pos()); if (index.isValid()) { - KDirModel* dirModel = static_cast(model()); - item = dirModel->itemForIndex(index); + item = m_parentView->fileItem(index); } m_parentView->openContextMenu(item, event->globalPos()); @@ -71,4 +73,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"