svn path=/trunk/playground/utils/dolphin/; revision=632656
#include "dolphinmainwindow.h"
#include "dolphinview.h"
#include "dolphinmainwindow.h"
#include "dolphinview.h"
#include <kdirmodel.h>
#include <kfileitem.h>
#include <kdirmodel.h>
#include <kfileitem.h>
DolphinIconsView::DolphinIconsView(DolphinView* parent) :
QListView(parent),
DolphinIconsView::DolphinIconsView(DolphinView* parent) :
QListView(parent),
{
setResizeMode(QListView::Adjust);
}
{
setResizeMode(QListView::Adjust);
}
const QModelIndex index = indexAt(event->pos());
if (index.isValid()) {
const QModelIndex index = indexAt(event->pos());
if (index.isValid()) {
- item = m_parentView->fileItem(index);
+ item = m_dolphinView->fileItem(index);
- m_parentView->openContextMenu(item, event->globalPos());
+ m_dolphinView->openContextMenu(item, event->globalPos());
}
void DolphinIconsView::mouseReleaseEvent(QMouseEvent* event)
{
QListView::mouseReleaseEvent(event);
}
void DolphinIconsView::mouseReleaseEvent(QMouseEvent* event)
{
QListView::mouseReleaseEvent(event);
- m_parentView->declareViewActive();
+ m_dolphinView->declareViewActive();
}
void DolphinIconsView::dragEnterEvent(QDragEnterEvent* event)
}
void DolphinIconsView::dragEnterEvent(QDragEnterEvent* event)
void DolphinIconsView::dropEvent(QDropEvent* event)
{
void DolphinIconsView::dropEvent(QDropEvent* event)
{
+ KFileItem* directory = 0;
+ bool dropIntoDirectory = false;
+ const QModelIndex index = indexAt(event->pos());
+ if (index.isValid()) {
+ KFileItem* item = m_dolphinView->fileItem(index);
+ assert(item != 0);
+ dropIntoDirectory = item->isDir();
+ if (dropIntoDirectory) {
+ directory = item;
+ }
+ }
+
const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData());
const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData());
+ if (urls.isEmpty() || (event->source() == this) && !dropIntoDirectory) {
+ QListView::dropEvent(event);
+ }
+ else {
event->acceptProposedAction();
event->acceptProposedAction();
-
- // TODO: handle dropping above a directory
-
- const KUrl& destination = m_parentView->url();
- m_parentView->mainWindow()->dropUrls(urls, destination);
+ const KUrl& destination = (directory == 0) ? m_dolphinView->url() :
+ directory->url();
+ m_dolphinView->mainWindow()->dropUrls(urls, destination);
virtual void dropEvent(QDropEvent* event);
private:
virtual void dropEvent(QDropEvent* event);
private:
- DolphinView* m_parentView;
+ DolphinView* m_dolphinView;