X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/f2ddae86660715776127381e840cc250b8664296..040bdcea237e2576aad744bc4e7b5cadedcc98dc:/src/sidebartreeview.cpp diff --git a/src/sidebartreeview.cpp b/src/sidebartreeview.cpp index a2cc3adc3..3b1b13bb1 100644 --- a/src/sidebartreeview.cpp +++ b/src/sidebartreeview.cpp @@ -40,16 +40,21 @@ SidebarTreeView::SidebarTreeView(QWidget* parent) : setFrameStyle(QFrame::NoFrame); setDragDropMode(QAbstractItemView::DragDrop); setDropIndicatorShown(false); - setAutoExpandDelay(300); setVerticalScrollMode(QListView::ScrollPerPixel); setHorizontalScrollMode(QListView::ScrollPerPixel); 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); @@ -80,17 +85,17 @@ bool SidebarTreeView::event(QEvent* event) } } - 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) { - QTreeView::dragEnterEvent(event); + KTreeView::dragEnterEvent(event); if (event->mimeData()->hasUrls()) { event->acceptProposedAction(); } @@ -98,13 +103,13 @@ void SidebarTreeView::dragEnterEvent(QDragEnterEvent* event) void SidebarTreeView::dragLeaveEvent(QDragLeaveEvent* event) { - QTreeView::dragLeaveEvent(event); + 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()); @@ -120,16 +125,11 @@ void SidebarTreeView::dragMoveEvent(QDragMoveEvent* event) void SidebarTreeView::dropEvent(QDropEvent* event) { - const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData()); - if (urls.isEmpty()) { - QTreeView::dropEvent(event); - } else { - event->acceptProposedAction(); - const QModelIndex index = indexAt(event->pos()); - if (index.isValid()) { - emit urlsDropped(urls, index); - } + const QModelIndex index = indexAt(event->pos()); + if (index.isValid()) { + emit urlsDropped(index, event); } + KTreeView::dropEvent(event); } #include "sidebartreeview.moc"