/**
* @brief Shows a tree view of the directories starting from
- * the currently selected bookmark.
+ * the currently selected place.
*
* The tree view is always synchronized with the currently active view
* from the main window.
TreeViewSidebarPage(QWidget* parent = 0);
virtual ~TreeViewSidebarPage();
+ /** @see QWidget::sizeHint() */
+ virtual QSize sizeHint() const;
+
public slots:
/**
* Changes the current selection inside the tree to \a url.
void dropUrls(const KUrl::List& urls,
const QModelIndex& index);
+ /**
+ * Invokes expandToLeafDir() asynchronously (the expanding
+ * may not be done in the context of this slot).
+ */
+ void triggerExpanding(const QModelIndex& index);
+
+ /**
+ * Expands all directories to make m_leafDir visible and
+ * adjusts the selection.
+ */
+ void expandToLeafDir();
+
+ /**
+ * Loads the sub tree to make m_leafDir visible. Is invoked
+ * indirectly by loadTree() after the directory lister has
+ * finished loading the root items.
+ */
+ void loadSubTree();
+
+private:
+ /**
+ * Initializes the base URL of the tree and expands all
+ * directories until \a url.
+ * @param url URL of the leaf directory that should get expanded.
+ */
+ void loadTree(const KUrl& url);
+
private:
KDirLister* m_dirLister;
KDirModel* m_dirModel;
DolphinSortFilterProxyModel* m_proxyModel;
SidebarTreeView* m_treeView;
+ KUrl m_leafDir;
};
#endif // TREEVIEWSIDEBARPAGE_H