X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/b5cc2a6924cfd8f59611d3cec2edbb00a08b4ff1..13b2fc55704fbc734cd4f9cbae56cfc2ef3ec0ce:/src/treeviewsidebarpage.h diff --git a/src/treeviewsidebarpage.h b/src/treeviewsidebarpage.h index 981090855..ba820ff20 100644 --- a/src/treeviewsidebarpage.h +++ b/src/treeviewsidebarpage.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2006 by Peter Penz + * Copyright (C) 2006 by Peter Penz * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * @@ -24,8 +24,7 @@ #include class KDirLister; -class KDirModel; -class KUrl; +class DolphinModel; class DolphinSortFilterProxyModel; class SidebarTreeView; @@ -33,7 +32,7 @@ class QModelIndex; /** * @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. @@ -43,49 +42,117 @@ class TreeViewSidebarPage : public SidebarPage Q_OBJECT public: - TreeViewSidebarPage(DolphinMainWindow* mainWindow, QWidget* parent = 0); + TreeViewSidebarPage(QWidget* parent = 0); virtual ~TreeViewSidebarPage(); -protected: - /** @see SidebarPage::activeViewChanged() */ - virtual void activeViewChanged(); + /** @see QWidget::sizeHint() */ + virtual QSize sizeHint() const; - /** @see QWidget::showEvent() */ - virtual void showEvent(QShowEvent* event); + void setShowHiddenFiles(bool show); + bool showHiddenFiles() const; + +signals: + /** + * Is emitted if the an URL change is requested. + */ + void changeUrl(const KUrl& url, Qt::MouseButtons buttons); -private slots: /** - * Updates the current selection inside the tree to - * \a url. + * This signal is emitted when the sidebar requests a change in the + * current selection. The file-management view recieving this signal is + * not required to select all listed files, limiting the selection to + * e.g. the current folder. The new selection will be reported via the + * setSelection slot. */ - void updateSelection(const KUrl& url); + void changeSelection(const KFileItemList& selection); /** - * Expands the tree in a way that the item with the URL m_selectedUrl - * gets visible. Is called by TreeViewSidebarPage::updateSelection() - * if the dir lister has been completed. + * This signal is emitted whenever a drop action on this widget needs the + * MainWindow's attention. */ - void expandSelectionParent(); + void urlsDropped(const KUrl::List& urls, const KUrl& destination); +public slots: + /** + * Changes the current selection inside the tree to \a url. + */ + virtual void setUrl(const KUrl& url); + +protected: + /** @see QWidget::showEvent() */ + virtual void showEvent(QShowEvent* event); + + /** @see QWidget::contextMenuEvent() */ + virtual void contextMenuEvent(QContextMenuEvent* event); + +private slots: /** * Updates the active view to the URL * which is given by the item with the index \a index. */ void updateActiveView(const QModelIndex& index); + /** + * Is emitted if the URLs \a urls have been dropped + * to the index \a index. */ + 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(); + + /** + * Invokes loadSubTree() asynchronously (the loading + * may not be done in the context of this slot). + */ + void triggerLoadSubTree(); + + /** + * 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(); + + /** + * Assures that the leaf folder gets visible. + */ + void scrollToLeaf(); + + void updateMouseButtons(); + private: /** - * Connects to signals from the currently active Dolphin view to get - * informed about highlighting changes. + * 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); + + /** + * Selects the current leaf directory m_leafDir and assures + * that the directory is visible if the leaf has been set by + * TreeViewSidebarPage::setUrl(). */ - void connectToActiveView(); + void selectLeafDirectory(); private: + bool m_setLeafVisible; + Qt::MouseButtons m_mouseButtons; KDirLister* m_dirLister; - KDirModel* m_dirModel; + DolphinModel* m_dolphinModel; DolphinSortFilterProxyModel* m_proxyModel; SidebarTreeView* m_treeView; - KUrl m_selectedUrl; + KUrl m_leafDir; }; -#endif // BOOKMARKSSIDEBARPAGE_H +#endif // TREEVIEWSIDEBARPAGE_H