┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
path: root/src/treeviewsidebarpage.cpp
diff options
context:
space:
mode:
authorPeter Penz <[email protected]>2008-01-17 18:12:11 +0000
committerPeter Penz <[email protected]>2008-01-17 18:12:11 +0000
commitac73af7bedeebe2afa451249e8a6500651a6ec00 (patch)
treecdd80b4773a949f66d3551a136f13046633a6f26 /src/treeviewsidebarpage.cpp
parent79797f1072dfc77a2311a1e159c85a3d80c3a7cb (diff)
Treeview fixes (backport):
* don't jump to the selected folder when expanding a sub tree within the treeview widget * don't reset the root of non-local URLs when there is no Places-URL available BUG: 155996 BUG: 156008 svn path=/branches/KDE/4.0/kdebase/apps/; revision=762706
Diffstat (limited to 'src/treeviewsidebarpage.cpp')
-rw-r--r--src/treeviewsidebarpage.cpp42
1 files changed, 27 insertions, 15 deletions
diff --git a/src/treeviewsidebarpage.cpp b/src/treeviewsidebarpage.cpp
index 82e2a0507..3196fe7bd 100644
--- a/src/treeviewsidebarpage.cpp
+++ b/src/treeviewsidebarpage.cpp
@@ -37,6 +37,7 @@
TreeViewSidebarPage::TreeViewSidebarPage(QWidget* parent) :
SidebarPage(parent),
+ m_setLeafVisible(false),
m_dirLister(0),
m_dolphinModel(0),
m_proxyModel(0),
@@ -67,6 +68,7 @@ void TreeViewSidebarPage::setUrl(const KUrl& url)
SidebarPage::setUrl(url);
if (m_dirLister != 0) {
+ m_setLeafVisible = true;
loadTree(url);
}
}
@@ -184,21 +186,13 @@ void TreeViewSidebarPage::expandToLeafDir()
QModelIndex dirIndex = m_dolphinModel->indexForUrl(parentUrl);
QModelIndex proxyIndex = m_proxyModel->mapFromSource(dirIndex);
m_treeView->setExpanded(proxyIndex, true);
-
- // assure that m_leafDir gets selected
- dirIndex = m_dolphinModel->indexForUrl(m_leafDir);
- proxyIndex = m_proxyModel->mapFromSource(dirIndex);
- m_treeView->scrollTo(proxyIndex);
-
- QItemSelectionModel* selModel = m_treeView->selectionModel();
- selModel->setCurrentIndex(proxyIndex, QItemSelectionModel::Select);
+ selectLeafDirectory();
}
void TreeViewSidebarPage::loadSubTree()
{
- QItemSelectionModel* selModel = m_treeView->selectionModel();
- selModel->clearSelection();
+ m_treeView->selectionModel()->clearSelection();
if (m_leafDir.isParentOf(m_dirLister->url())) {
// The leaf directory is not a child of the base URL, hence
@@ -208,10 +202,7 @@ void TreeViewSidebarPage::loadSubTree()
const QModelIndex index = m_dolphinModel->indexForUrl(m_leafDir);
if (index.isValid()) {
- // the item with the given URL is already part of the model
- const QModelIndex proxyIndex = m_proxyModel->mapFromSource(index);
- m_treeView->scrollTo(proxyIndex);
- selModel->setCurrentIndex(proxyIndex, QItemSelectionModel::Select);
+ selectLeafDirectory();
} else {
// Load all sub directories that need to get expanded for making
// the leaf directory visible. The slot triggerExpanding() will
@@ -231,7 +222,14 @@ void TreeViewSidebarPage::loadTree(const KUrl& url)
if (!baseUrl.isValid()) {
// it's possible that no closest item is available and hence an
// empty URL is returned
- 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) {
@@ -242,4 +240,18 @@ void TreeViewSidebarPage::loadTree(const KUrl& url)
}
}
+void TreeViewSidebarPage::selectLeafDirectory()
+{
+ const QModelIndex dirIndex = m_dolphinModel->indexForUrl(m_leafDir);
+ const QModelIndex proxyIndex = m_proxyModel->mapFromSource(dirIndex);
+
+ if (m_setLeafVisible) {
+ m_treeView->scrollTo(proxyIndex);
+ m_setLeafVisible = false;
+ }
+
+ QItemSelectionModel* selModel = m_treeView->selectionModel();
+ selModel->setCurrentIndex(proxyIndex, QItemSelectionModel::Select);
+}
+
#include "treeviewsidebarpage.moc"