┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
path: root/src/treeviewsidebarpage.cpp
diff options
context:
space:
mode:
authorPeter Penz <[email protected]>2008-01-18 20:13:14 +0000
committerPeter Penz <[email protected]>2008-01-18 20:13:14 +0000
commita91bb8b0dba763c3537fbf9216df10662c2fc69e (patch)
treed63f11a1bbb2d0653e403d85eb721bb7a32027aa /src/treeviewsidebarpage.cpp
parentac73af7bedeebe2afa451249e8a6500651a6ec00 (diff)
Backport:
* Always take the root of an URL as root for the treeview (using a matching Places-URL leads to serious usability issues - see bug #150941 for details). * Don't reset the horizontal scrollbar position when expanding/reloading the tree. BUG: 150941 svn path=/branches/KDE/4.0/kdebase/apps/; revision=763173
Diffstat (limited to 'src/treeviewsidebarpage.cpp')
-rw-r--r--src/treeviewsidebarpage.cpp31
1 files changed, 17 insertions, 14 deletions
diff --git a/src/treeviewsidebarpage.cpp b/src/treeviewsidebarpage.cpp
index 3196fe7bd..7fa56566a 100644
--- a/src/treeviewsidebarpage.cpp
+++ b/src/treeviewsidebarpage.cpp
@@ -34,10 +34,12 @@
#include <QTreeView>
#include <QBoxLayout>
#include <QModelIndex>
+#include <QScrollBar>
TreeViewSidebarPage::TreeViewSidebarPage(QWidget* parent) :
SidebarPage(parent),
m_setLeafVisible(false),
+ m_horizontalPos(0),
m_dirLister(0),
m_dolphinModel(0),
m_proxyModel(0),
@@ -216,20 +218,16 @@ void TreeViewSidebarPage::loadTree(const KUrl& url)
Q_ASSERT(m_dirLister != 0);
m_leafDir = url;
- // adjust the root of the tree to the base place
- KFilePlacesModel* placesModel = DolphinSettings::instance().placesModel();
- KUrl baseUrl = placesModel->url(placesModel->closestItem(url));
- if (!baseUrl.isValid()) {
- // it's possible that no closest item is available and hence an
- // empty URL is returned
- if (url.isLocalFile()) {
- // use the root directory as base for local URLs
- baseUrl = KUrl("file:///");
- } else {
- // clear the path for non-local URLs and use it as base
- baseUrl = url;
- baseUrl.setPath(QString());
- }
+ m_horizontalPos = m_treeView->horizontalScrollBar()->value();
+
+ KUrl baseUrl = url;
+ if (url.isLocalFile()) {
+ // use the root directory as base for local URLs
+ baseUrl = KUrl("file:///");
+ } else {
+ // clear the path for non-local URLs and use it as base
+ baseUrl = url;
+ baseUrl.setPath(QString());
}
if (m_dirLister->url() != baseUrl) {
@@ -244,6 +242,9 @@ void TreeViewSidebarPage::selectLeafDirectory()
{
const QModelIndex dirIndex = m_dolphinModel->indexForUrl(m_leafDir);
const QModelIndex proxyIndex = m_proxyModel->mapFromSource(dirIndex);
+ if (!proxyIndex.isValid()) {
+ return;
+ }
if (m_setLeafVisible) {
m_treeView->scrollTo(proxyIndex);
@@ -252,6 +253,8 @@ void TreeViewSidebarPage::selectLeafDirectory()
QItemSelectionModel* selModel = m_treeView->selectionModel();
selModel->setCurrentIndex(proxyIndex, QItemSelectionModel::Select);
+
+ m_treeView->horizontalScrollBar()->setValue(m_horizontalPos);
}
#include "treeviewsidebarpage.moc"