X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/792ebd6691026d817442fe4a32a822a0ef68e767..17033c5da6c60d37ded588ea0fa44f73bd85dc1d:/src/sidebartreeview.cpp diff --git a/src/sidebartreeview.cpp b/src/sidebartreeview.cpp index d31300539..a876ee6c3 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); @@ -41,22 +40,21 @@ SidebarTreeView::SidebarTreeView(QWidget* parent) : setFrameStyle(QFrame::NoFrame); 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); - QPalette palette = viewport()->palette(); - palette.setColor(viewport()->backgroundRole(), Qt::transparent); - viewport()->setPalette(palette); + // make the background transparent and apply the window-text color + // to the text color, so that enough contrast is given for all color + // schemes + QPalette p = palette(); + p.setColor(QPalette::Active, QPalette::Text, p.color(QPalette::Active, QPalette::WindowText)); + p.setColor(QPalette::Inactive, QPalette::Text, p.color(QPalette::Inactive, QPalette::WindowText)); + p.setColor(QPalette::Disabled, QPalette::Text, p.color(QPalette::Disabled, QPalette::WindowText)); + setPalette(p); + viewport()->setAutoFillBackground(false); KFileItemDelegate* delegate = new KFileItemDelegate(this); setItemDelegate(delegate); @@ -68,7 +66,8 @@ SidebarTreeView::~SidebarTreeView() bool SidebarTreeView::event(QEvent* event) { - if (event->type() == QEvent::Polish) { + switch (event->type()) { + case QEvent::Polish: // hide all columns except of the 'Name' column hideColumn(DolphinModel::Size); hideColumn(DolphinModel::ModifiedTime); @@ -79,83 +78,70 @@ bool SidebarTreeView::event(QEvent* event) hideColumn(DolphinModel::Rating); hideColumn(DolphinModel::Tags); header()->hide(); - } - else if (event->type() == QEvent::UpdateRequest) { - resizeColumnToContents(DolphinModel::Name); - -// 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)) + break; + + case QEvent::Show: + // TODO: The opening/closing animation of subtrees flickers in combination with the + // sidebar when using the Oxygen style. As workaround the animation is turned off: + setAnimated(false); + break; + + case QEvent::UpdateRequest: // a wheel movement will scroll 1 item if (model()->rowCount() > 0) { verticalScrollBar()->setSingleStep(sizeHintForRow(0) / 3); } -#endif + break; + + default: + break; } - return QTreeView::event(event); + return KTreeView::event(event); } void SidebarTreeView::startDrag(Qt::DropActions supportedActions) { - DragAndDropHelper::startDrag(this, supportedActions); + DragAndDropHelper::instance().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); -} -void SidebarTreeView::dropEvent(QDropEvent* event) -{ - const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData()); - if (urls.isEmpty()) { - QTreeView::dropEvent(event); - } else { + if (event->mimeData()->hasUrls()) { + // accept url drops, independently from the destination item event->acceptProposedAction(); - const QModelIndex index = indexAt(event->pos()); - if (index.isValid()) { - emit urlsDropped(urls, index); - } } - m_dragging = false; } -void SidebarTreeView::paintEvent(QPaintEvent* event) +void SidebarTreeView::dropEvent(QDropEvent* 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); + const QModelIndex index = indexAt(event->pos()); + if (index.isValid()) { + emit urlsDropped(index, event); } + KTreeView::dropEvent(event); } #include "sidebartreeview.moc"