X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/58d37b233177765b4908e2ab32413afe9fbd4da6..13b2fc55704fbc734cd4f9cbae56cfc2ef3ec0ce:/src/sidebartreeview.cpp diff --git a/src/sidebartreeview.cpp b/src/sidebartreeview.cpp index 9ab10a0b2..a2cc3adc3 100644 --- a/src/sidebartreeview.cpp +++ b/src/sidebartreeview.cpp @@ -30,8 +30,7 @@ #include SidebarTreeView::SidebarTreeView(QWidget* parent) : - QTreeView(parent), - m_dragging(false) + KTreeView(parent) { setAcceptDrops(true); setUniformRowHeights(true); @@ -43,14 +42,8 @@ SidebarTreeView::SidebarTreeView(QWidget* parent) : setDropIndicatorShown(false); setAutoExpandDelay(300); -// TODO: Remove this check when 4.3.2 is released and KDE requires it... this -// check avoids a division by zero happening on versions before 4.3.1. -// Right now KDE in theory can be shipped with Qt 4.3.0 and above. -// ereslibre -#if (QT_VERSION >= QT_VERSION_CHECK(4, 3, 2) || defined(QT_KDE_QT_COPY)) setVerticalScrollMode(QListView::ScrollPerPixel); setHorizontalScrollMode(QListView::ScrollPerPixel); -#endif viewport()->setAttribute(Qt::WA_Hover); @@ -81,19 +74,10 @@ bool SidebarTreeView::event(QEvent* event) header()->hide(); } else if (event->type() == QEvent::UpdateRequest) { - // TODO: Remove this check when 4.3.2 is released and KDE requires it... this - // check avoids a division by zero happening on versions before 4.3.1. - // Right now KDE in theory can be shipped with Qt 4.3.0 and above. - // ereslibre -#if (QT_VERSION >= QT_VERSION_CHECK(4, 3, 2) || defined(QT_KDE_QT_COPY)) // a wheel movement will scroll 1 item if (model()->rowCount() > 0) { verticalScrollBar()->setSingleStep(sizeHintForRow(0) / 3); } -#endif - } - else if (event->type() == QEvent::MetaCall) { - resizeColumnToContents(DolphinModel::Name); } return QTreeView::event(event); @@ -106,19 +90,15 @@ void SidebarTreeView::startDrag(Qt::DropActions supportedActions) void SidebarTreeView::dragEnterEvent(QDragEnterEvent* event) { + QTreeView::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; setDirtyRegion(m_dropRect); } @@ -131,6 +111,11 @@ void SidebarTreeView::dragMoveEvent(QDragMoveEvent* event) 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) @@ -145,18 +130,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); - DragAndDropHelper::drawHoverIndication(viewport(), m_dropRect, brush); - } } #include "sidebartreeview.moc"