X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/494f522b91972e5431ee9e2b1eb391d8ebc15ed6..a4ef4bbfdebad708e4b3c772c1ce3e236a4da145:/src/dolphinpart.h diff --git a/src/dolphinpart.h b/src/dolphinpart.h index 3d9ec0306..c70bc5a8d 100644 --- a/src/dolphinpart.h +++ b/src/dolphinpart.h @@ -22,17 +22,24 @@ #include #include +#include + +#include + +class DolphinNewFileMenu; +class DolphinViewActionHandler; class QActionGroup; class KAction; class KFileItemList; class KFileItem; class DolphinPartBrowserExtension; class DolphinSortFilterProxyModel; +class DolphinRemoteEncoding; class DolphinModel; class KDirLister; class DolphinView; -class QLineEdit; class KAboutData; +class DolphinRemoveAction; class DolphinPart : public KParts::ReadOnlyPart { @@ -42,29 +49,76 @@ class DolphinPart : public KParts::ReadOnlyPart // Even though it's konqueror doing the undo... Q_PROPERTY( bool supportsUndo READ supportsUndo ) + Q_PROPERTY( QString currentViewMode READ currentViewMode WRITE setCurrentViewMode ) + + // Used by konqueror when typing something like /home/dfaure/*.diff in the location bar + Q_PROPERTY( QString nameFilter READ nameFilter WRITE setNameFilter ) + + // Used by konqueror to implement the --select command-line option + Q_PROPERTY( KUrl::List filesToSelect READ filesToSelect WRITE setFilesToSelect ) + public: - explicit DolphinPart(QWidget* parentWidget, QObject* parent, const QStringList& args); + explicit DolphinPart(QWidget* parentWidget, QObject* parent, const QVariantList& args); ~DolphinPart(); static KAboutData* createAboutData(); + /** + * Standard KParts::ReadOnlyPart openUrl method. + * Called by Konqueror to view a directory in DolphinPart. + */ virtual bool openUrl(const KUrl& url); /// see the supportsUndo property bool supportsUndo() const { return true; } + /** + * Used by konqueror for setting the view mode + * @param viewModeName internal name for the view mode, like "icons" + * Those names come from the Actions line in dolphinpart.desktop, + * and have to match the name of the KActions. + */ + void setCurrentViewMode(const QString& viewModeName); + + /** + * Used by konqueror for displaying the current view mode. + * @see setCurrentViewMode + */ + QString currentViewMode() const; + + /// Returns the view owned by this part; used by DolphinPartBrowserExtension DolphinView* view() { return m_view; } + /** + * Sets a name filter, like *.diff + */ + void setNameFilter(const QString& nameFilter); + + /** + * Returns the current name filter. Used by konqueror to show it in the URL. + */ + QString nameFilter() const { return m_nameFilter; } + protected: /** * We reimplement openUrl so no need to implement openFile. */ virtual bool openFile() { return true; } +Q_SIGNALS: + /** + * Emitted when the view mode changes. Used by konqueror. + */ + void viewModeChanged(); + + + /** + * Emitted whenever the current URL is about to be changed. + */ + void aboutToOpenURL(); + private Q_SLOTS: - void slotCompleted(const KUrl& url); - void slotCanceled(const KUrl& url); - void slotInfoMessage(const QString& msg); + void slotMessage(const QString& msg); void slotErrorMessage(const QString& msg); /** * Shows the information for the item \a item inside the statusbar. If the @@ -74,24 +128,36 @@ private Q_SLOTS: /** * Handles clicking on an item */ - void slotItemTriggered(const KFileItem& item); + void slotItemActivated(const KFileItem& item); /** - * Opens the context menu on the current mouse position. - * @item File item context. If item is 0, the context menu - * should be applied to \a url. - * @url URL which contains \a item. + * Handles activation of multiple items + */ + void slotItemsActivated(const KFileItemList& items); + /** + * Creates a new window showing the content of \a url. */ - void slotOpenContextMenu(const KFileItem& item, const KUrl& url); + void createNewWindow(const KUrl& url); /** - * Emitted when the user requested a change of view mode + * Opens the context menu on the current mouse position. + * @pos Position in screen coordinates. + * @item File item context. If item is null, the context menu + * should be applied to \a url. + * @url URL which contains \a item. + * @customActions Actions that should be added to the context menu, + * if the file item is null. */ - void slotViewModeActionTriggered(QAction*); + void slotOpenContextMenu(const QPoint& pos, + const KFileItem& item, + const KUrl& url, + const QList& customActions); /** - * Asks the host to open the URL \a url if the current view has - * a different URL. + * Informs the host that we are opening \a url (e.g. after a redirection + * coming from KDirLister). + * Testcase 1: fish://localhost + * Testcase 2: showing a directory that is being renamed by another window (#180156) */ - void slotUrlChanged(const KUrl& url); + void slotDirectoryRedirection(const KUrl& oldUrl, const KUrl& newUrl); /** * Updates the state of the 'Edit' menu actions and emits @@ -99,22 +165,12 @@ private Q_SLOTS: */ void slotSelectionChanged(const KFileItemList& selection); - /** - * Same as in DolphinMainWindow: updates the view menu actions - */ - void updateViewActions(); - /** * Updates the text of the paste action dependent from * the number of items which are in the clipboard. */ void updatePasteAction(); - /** - * Connected to the "move_to_trash" action; adds "shift means del" handling. - */ - void slotTrashActivated(Qt::MouseButtons, Qt::KeyboardModifiers); - /** * Connected to all "Go" menu actions provided by DolphinPart */ @@ -126,21 +182,53 @@ private Q_SLOTS: void slotEditMimeType(); /** - * Connected to the "properties" action + * Connected to the "select_items_matching" action. + * Opens a dialog which permits to select all items matching a pattern like "*.jpg". + */ + void slotSelectItemsMatchingPattern(); + + /** + * Connected to the "unselect_items_matching" action. + * Opens a dialog which permits to unselect all items matching a pattern like "*.jpg". + */ + void slotUnselectItemsMatchingPattern(); + + /** + * Open a terminal window, starting with the current directory. + */ + void slotOpenTerminal(); + + /** + * Open KFind with the current path. + */ + void slotFindFile(); + + /** + * Updates the 'Create New...' sub menu, just before it's shown. */ - void slotProperties(); + void updateNewMenu(); /** - * Opens the dialog for creating a directory. Is connected - * with the key shortcut for "new directory" (F10). + * Updates the number of items (= number of files + number of + * directories) in the statusbar. If files are selected, the number + * of selected files and the sum of the filesize is shown. */ - void createDir(); + void updateStatusBar(); - /** Updates the state of the 'Sort Ascending/Descending' action. */ - void slotSortOrderChanged(Qt::SortOrder); + /** + * Notify container of folder loading progress. + */ + void updateProgress(int percent); - /** Updates the state of the 'Additional Information' actions. */ - void slotAdditionalInfoChanged(); + void createDirectory(); + + /** + * Called by konqueror --select + */ + void setFilesToSelect(const KUrl::List& files); + KUrl::List filesToSelect() const { return KUrl::List(); } // silence moc + + virtual bool eventFilter(QObject*, QEvent*); private: void createActions(); @@ -148,12 +236,19 @@ private: const QString& text, const QString& url, QActionGroup* actionGroup); + void openSelectionDialog(const QString& title, const QString& text, + bool selectItems); + private: DolphinView* m_view; - KDirLister* m_dirLister; - DolphinModel* m_dolphinModel; - DolphinSortFilterProxyModel* m_proxyModel; + DolphinViewActionHandler* m_actionHandler; + DolphinRemoteEncoding* m_remoteEncoding; DolphinPartBrowserExtension* m_extension; + DolphinNewFileMenu* m_newFileMenu; + KAction* m_findFileAction; + KAction* m_openTerminalAction; + QString m_nameFilter; + DolphinRemoveAction* m_removeAction; Q_DISABLE_COPY(DolphinPart) }; @@ -164,13 +259,34 @@ public: DolphinPartBrowserExtension( DolphinPart* part ) : KParts::BrowserExtension( part ), m_part(part) {} + virtual void restoreState(QDataStream &stream); + virtual void saveState(QDataStream &stream); + public Q_SLOTS: void cut(); void copy(); void paste(); + void pasteTo(const KUrl&); + void reparseConfiguration(); private: DolphinPart* m_part; }; + +class DolphinPartFileInfoExtension : public KParts::FileInfoExtension +{ + Q_OBJECT + +public: + DolphinPartFileInfoExtension(DolphinPart* part); + + virtual QueryModes supportedQueryModes() const; + virtual bool hasSelection() const; + + virtual KFileItemList queryFor(QueryMode mode) const; +protected: + DolphinPart* part() const; +}; + #endif /* DOLPHINPART_H */