X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/b5cc2a6924cfd8f59611d3cec2edbb00a08b4ff1..ec4c6d07add47d5295a6f18d681ac879017d0f77:/src/sidebartreeview.cpp diff --git a/src/sidebartreeview.cpp b/src/sidebartreeview.cpp index ccd908463..a40d26c13 100644 --- a/src/sidebartreeview.cpp +++ b/src/sidebartreeview.cpp @@ -1,6 +1,5 @@ /*************************************************************************** - * Copyright (C) 2006 by Peter Penz * - * peter.penz@gmx.at * + * Copyright (C) 2006 by Peter Penz * * * * 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 * @@ -23,20 +22,21 @@ #include #include -#include -#include -#include +#include +#include -SidebarTreeView::SidebarTreeView(DolphinMainWindow* mainWindow, - QWidget* parent) : - QTreeView(parent), - m_mainWindow(mainWindow) +SidebarTreeView::SidebarTreeView(QWidget* parent) : + QTreeView(parent) { setAcceptDrops(true); setUniformRowHeights(true); setSelectionMode(QAbstractItemView::SingleSelection); setEditTriggers(QAbstractItemView::NoEditTriggers); setSortingEnabled(true); + setFrameStyle(QFrame::NoFrame); + setDragDropMode(QAbstractItemView::DragDrop); + setDropIndicatorShown(false); + setAutoExpandDelay(300); viewport()->setAttribute(Qt::WA_Hover); @@ -57,6 +57,7 @@ bool SidebarTreeView::event(QEvent* event) hideColumn(KDirModel::Permissions); hideColumn(KDirModel::Owner); hideColumn(KDirModel::Group); + hideColumn(KDirModel::Type); header()->hide(); } @@ -68,17 +69,20 @@ void SidebarTreeView::dragEnterEvent(QDragEnterEvent* event) if (event->mimeData()->hasUrls()) { event->acceptProposedAction(); } + QTreeView::dragEnterEvent(event); } void SidebarTreeView::dropEvent(QDropEvent* event) { const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData()); - if (urls.isEmpty() || (event->source() == this)) { + if (urls.isEmpty()) { QTreeView::dropEvent(event); - } - else { + } else { event->acceptProposedAction(); - //m_controller->indicateDroppedUrls(urls, event->pos()); + const QModelIndex index = indexAt(event->pos()); + if (index.isValid()) { + emit urlsDropped(urls, index); + } } }