X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/7bbb858a041d4b31bf3e79d6d7af9d067ffbd018..817f3952e2bed820ea3b50dfdfe91ccb99dcb748:/src/sidebartreeview.cpp diff --git a/src/sidebartreeview.cpp b/src/sidebartreeview.cpp index 52f207a78..3018737ab 100644 --- a/src/sidebartreeview.cpp +++ b/src/sidebartreeview.cpp @@ -21,6 +21,7 @@ #include "dolphincontroller.h" #include "dolphinmodel.h" +#include "draganddrophelper.h" #include #include @@ -29,8 +30,7 @@ #include SidebarTreeView::SidebarTreeView(QWidget* parent) : - QTreeView(parent), - m_dragging(false) + KTreeView(parent) { setAcceptDrops(true); setUniformRowHeights(true); @@ -40,7 +40,7 @@ SidebarTreeView::SidebarTreeView(QWidget* parent) : setFrameStyle(QFrame::NoFrame); setDragDropMode(QAbstractItemView::DragDrop); setDropIndicatorShown(false); - setAutoExpandDelay(300); + setVerticalScrollMode(QListView::ScrollPerPixel); setHorizontalScrollMode(QListView::ScrollPerPixel); @@ -79,43 +79,49 @@ bool SidebarTreeView::event(QEvent* event) } } - return QTreeView::event(event); + return KTreeView::event(event); +} + +void SidebarTreeView::startDrag(Qt::DropActions supportedActions) +{ + DragAndDropHelper::startDrag(this, supportedActions); } void SidebarTreeView::dragEnterEvent(QDragEnterEvent* event) { + KTreeView::dragEnterEvent(event); if (event->mimeData()->hasUrls()) { event->acceptProposedAction(); } - QTreeView::dragEnterEvent(event); - m_dragging = true; } void SidebarTreeView::dragLeaveEvent(QDragLeaveEvent* event) { - QTreeView::dragLeaveEvent(event); - - // TODO: remove this code when the issue #160611 is solved in Qt 4.4 - m_dragging = false; + KTreeView::dragLeaveEvent(event); setDirtyRegion(m_dropRect); } void SidebarTreeView::dragMoveEvent(QDragMoveEvent* event) { - QTreeView::dragMoveEvent(event); + KTreeView::dragMoveEvent(event); // TODO: remove this code when the issue #160611 is solved in Qt 4.4 const QModelIndex index = indexAt(event->pos()); setDirtyRegion(m_dropRect); m_dropRect = visualRect(index); setDirtyRegion(m_dropRect); + + if (event->mimeData()->hasUrls()) { + // accept url drops, independently from the destination item + event->acceptProposedAction(); + } } void SidebarTreeView::dropEvent(QDropEvent* event) { const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData()); if (urls.isEmpty()) { - QTreeView::dropEvent(event); + KTreeView::dropEvent(event); } else { event->acceptProposedAction(); const QModelIndex index = indexAt(event->pos()); @@ -123,18 +129,6 @@ void SidebarTreeView::dropEvent(QDropEvent* event) emit urlsDropped(urls, index); } } - m_dragging = false; -} - -void SidebarTreeView::paintEvent(QPaintEvent* event) -{ - QTreeView::paintEvent(event); - - // TODO: remove this code when the issue #160611 is solved in Qt 4.4 - if (m_dragging) { - const QBrush& brush = palette().brush(QPalette::Normal, QPalette::Highlight); - DolphinController::drawHoverIndication(viewport(), m_dropRect, brush); - } } #include "sidebartreeview.moc"