X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/7bbb858a041d4b31bf3e79d6d7af9d067ffbd018..8991d904710c4ec151dc266ab5bbbd6124bb6d2c:/src/sidebartreeview.cpp diff --git a/src/sidebartreeview.cpp b/src/sidebartreeview.cpp index 52f207a78..9ab10a0b2 100644 --- a/src/sidebartreeview.cpp +++ b/src/sidebartreeview.cpp @@ -21,6 +21,7 @@ #include "dolphincontroller.h" #include "dolphinmodel.h" +#include "draganddrophelper.h" #include #include @@ -41,8 +42,15 @@ SidebarTreeView::SidebarTreeView(QWidget* parent) : setDragDropMode(QAbstractItemView::DragDrop); 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); @@ -73,15 +81,29 @@ 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); } +void SidebarTreeView::startDrag(Qt::DropActions supportedActions) +{ + DragAndDropHelper::startDrag(this, supportedActions); +} + void SidebarTreeView::dragEnterEvent(QDragEnterEvent* event) { if (event->mimeData()->hasUrls()) { @@ -133,7 +155,7 @@ void SidebarTreeView::paintEvent(QPaintEvent* 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); + DragAndDropHelper::drawHoverIndication(viewport(), m_dropRect, brush); } }