#include "treeviewsidebarpage.h"
-#include "kbookmarkmanager.h"
#include "dolphinmainwindow.h"
#include "dolphinsortfilterproxymodel.h"
#include "dolphinview.h"
+#include "dolphinsettings.h"
#include "sidebartreeview.h"
#include "treeviewcontextmenu.h"
+#include <kfileplacesmodel.h>
#include <kdirlister.h>
#include <kdirmodel.h>
#include <kfileitem.h>
#include <QItemSelectionModel>
#include <QTreeView>
#include <QVBoxLayout>
-#include "dolphinsettings.h"
TreeViewSidebarPage::TreeViewSidebarPage(QWidget* parent) :
SidebarPage(parent),
m_treeView->setModel(m_proxyModel);
m_proxyModel->setSorting(DolphinView::SortByName);
- m_proxyModel->setSortOrder(Qt::Ascending);
+ m_proxyModel->setSortOrder(Qt::AscendingOrder);
connect(m_treeView, SIGNAL(clicked(const QModelIndex&)),
this, SLOT(updateActiveView(const QModelIndex&)));
void TreeViewSidebarPage::setUrl(const KUrl& url)
{
- if (!url.isValid() || (url == m_url)) {
+ if (!url.isValid() || (url == SidebarPage::url())) {
return;
}
- m_url = url;
-
- // adjust the root of the tree to the base bookmark
- KBookmarkManager* bookmarkManager = DolphinSettings::instance().bookmarkManager();
- const KUrl baseUrl = bookmarkManager->root().closestBookmark(url).url();
- if (m_dirLister->url() != baseUrl) {
- m_dirLister->stop();
- m_dirLister->openUrl(baseUrl);
- }
-
- // select the folder which contains the given URL
- QItemSelectionModel* selModel = m_treeView->selectionModel();
- selModel->clearSelection();
-
- const QModelIndex index = m_dirModel->indexForUrl(url);
- 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);
- }
- else {
- // The item with the given URL is not loaded by the model yet. Iterate
- // backward to the base URL and trigger the loading of the items for
- // each hierarchy level.
- connect(m_dirLister, SIGNAL(completed()),
- this, SLOT(expandSelectionParent()));
-
- KUrl parentUrl = url.upUrl();
- while (!parentUrl.isParentOf(baseUrl)) {
- m_dirLister->openUrl(parentUrl, true, false);
- parentUrl = parentUrl.upUrl();
- }
- }
-
+ SidebarPage::setUrl(url);
+ // TODO: it makes only sense to load the tree if the TreeViewSidebarPage
+ // is visible, but currently an assertion is triggered in KDirModel when hiding
+ // the tree view, changing to a complete different hierarchy and showing it again.
+ //if (isVisible()) {
+ loadTree(url);
+ //}
}
void TreeViewSidebarPage::showEvent(QShowEvent* event)
{
SidebarPage::showEvent(event);
+ loadTree(url());
}
void TreeViewSidebarPage::contextMenuEvent(QContextMenuEvent* event)
this, SLOT(expandSelectionParent()));
// expand the parent folder of the selected item
- KUrl parentUrl = m_url.upUrl();
+ KUrl parentUrl = url().upUrl();
if (!m_dirLister->url().isParentOf(parentUrl)) {
return;
}
m_treeView->setExpanded(proxyIndex, true);
// select the item and assure that the item is visible
- index = m_dirModel->indexForUrl(m_url);
+ index = m_dirModel->indexForUrl(url());
if (index.isValid()) {
proxyIndex = m_proxyModel->mapFromSource(index);
m_treeView->scrollTo(proxyIndex);
}
}
+void TreeViewSidebarPage::loadTree(const KUrl& url)
+{
+ // adjust the root of the tree to the base bookmark
+ 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
+ baseUrl = url;
+ }
+
+ if (m_dirLister->url() != baseUrl) {
+ m_dirLister->stop();
+ m_dirLister->openUrl(baseUrl);
+ }
+
+ // select the folder which contains the given URL
+ QItemSelectionModel* selModel = m_treeView->selectionModel();
+ selModel->clearSelection();
+
+ const QModelIndex index = m_dirModel->indexForUrl(url);
+ 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);
+ } else {
+ // The item with the given URL is not loaded by the model yet. Iterate
+ // backward to the base URL and trigger the loading of the items for
+ // each hierarchy level.
+ connect(m_dirLister, SIGNAL(completed()),
+ this, SLOT(expandSelectionParent()));
+
+ // Implementation note: It is important to remove the trailing slash from
+ // the parent URL, as the directories from the dir lister (KDirLister::directories())
+ // don't have a trailing slash and hence KUrl::List::contains() would fail...
+ KUrl parentUrl = url.upUrl();
+ parentUrl.adjustPath(KUrl::RemoveTrailingSlash);
+ while (!parentUrl.isParentOf(baseUrl)) {
+ if (m_dirLister->directories().contains(parentUrl)) {
+ m_dirLister->updateDirectory(parentUrl);
+ } else {
+ m_dirLister->openUrl(parentUrl, true, false);
+ }
+ parentUrl = parentUrl.upUrl();
+ parentUrl.adjustPath(KUrl::RemoveTrailingSlash);
+ }
+ }
+}
+
#include "treeviewsidebarpage.moc"