X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/6987f297e6e275a1f46aa0f33919e86684c9ed8b..4b70446c17dff6646c11966670bcbe145d07c685:/src/dolphincontextmenu.h diff --git a/src/dolphincontextmenu.h b/src/dolphincontextmenu.h index 0dd0d2ebb..180f91787 100644 --- a/src/dolphincontextmenu.h +++ b/src/dolphincontextmenu.h @@ -1,6 +1,5 @@ /*************************************************************************** - * Copyright (C) 2006 by Peter Penz * - * peter.penz@gmx.at * + * 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 * @@ -15,30 +14,33 @@ * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * ***************************************************************************/ #ifndef DOLPHINCONTEXTMENU_H #define DOLPHINCONTEXTMENU_H -#include -#include -#include -#include -#include -#include -#include -#include - -class KMenu; -class KFileItem; -class QPoint; -class QWidget; -class DolphinView; +#include +#include +#include +#include +#include + +#include + +#include + +#include + +class QAction; +class DolphinMainWindow; +class KFileItemActions; +class KFileItemListProperties; +class DolphinRemoveAction; /** * @brief Represents the context menu which appears when doing a right - * click on an item or the viewport of the file manager. + * click on an item or the viewport of the file manager. * * Beside static menu entries (e. g. 'Paste' or 'Properties') two * dynamic sub menus are shown when opening a context menu above @@ -47,75 +49,102 @@ class DolphinView; * open items of the given MIME type. * - 'Actions': Contains all actions which can be applied to the * given item. - * - * @author Peter Penz */ -class DolphinContextMenu +class DolphinContextMenu : public KMenu { + Q_OBJECT + public: + enum Command + { + None, + OpenParentFolderInNewWindow, + OpenParentFolderInNewTab + }; + /** - * @parent Pointer to the dolphin view the context menu - * belongs to. - * @fileInfo Pointer to the file item the context menu - * is applied. If 0 is passed, the context menu - * is above the viewport. - * @pos Position of the upper left edge of the context menu. + * @parent Pointer to the main window the context menu + * belongs to. + * @pos Position in screen coordinates. + * @fileInfo Pointer to the file item the context menu + * is applied. If 0 is passed, the context menu + * is above the viewport. + * @baseUrl Base URL of the viewport where the context menu + * should be opened. */ - DolphinContextMenu(DolphinView* parent, - KFileItem* fileInfo, - const QPoint& pos); + DolphinContextMenu(DolphinMainWindow* parent, + const QPoint& pos, + const KFileItem& fileInfo, + const KUrl& baseUrl); virtual ~DolphinContextMenu(); - /** Opens the context menu modal. */ - void open(); + void setCustomActions(const QList& actions); + + /** + * Opens the context menu model and returns the requested + * command, that should be triggered by the caller. If + * Command::None has been returned, either the context-menu + * had been closed without executing an action or an + * already available action from the main-window has been + * executed. + */ + Command open(); + +protected: + virtual void keyPressEvent(QKeyEvent *ev); + virtual void keyReleaseEvent(QKeyEvent *ev); private: - void openViewportContextMenu(); + void openTrashContextMenu(); + void openTrashItemContextMenu(); void openItemContextMenu(); + void openViewportContextMenu(); + + void insertDefaultItemActions(const KFileItemListProperties&); /** - * Inserts the 'Open With...' submenu to \a popup. - * @param popup Menu where the 'Open With...' sub menu should - * be added. - * @param openWithVector Output parameter which contains all 'Open with...' - * services. - * @return Identifier of the first 'Open With...' entry. - * All succeeding identifiers have an increased value of 1 - * to the predecessor. + * Adds the "Show menubar" action to the menu if the + * menubar is hidden. */ - int insertOpenWithItems(KMenu* popup, - Q3ValueVector& openWithVector); + void addShowMenuBarAction(); + + bool placeExists(const KUrl& url) const; + + QAction* createPasteAction(); + + KFileItemListProperties& selectedItemsProperties() const; /** - * Inserts the 'Actions...' submenu to \a popup. - * @param popup Menu where the 'Actions...' sub menu should - * be added. - * @param openWithVector Output parameter which contains all 'Actions...' - * services. + * Returns the file item for m_baseUrl. */ - void insertActionItems(KMenu* popup, - Q3ValueVector& actionsVector); + KFileItem baseFileItem(); /** - * Returns true, if 'menu' contains already - * an entry with the name 'entryName'. + * Adds actions that have been installed as service-menu. + * (see http://techbase.kde.org/index.php?title=Development/Tutorials/Creating_Konqueror_Service_Menus) */ - bool containsEntry(const KMenu* menu, - const QString& entryName) const; - - enum { - submenuID = 90, - bookmarkID = 91, - openWithIDStart = 100, - actionsIDStart = 1000, - }; + void addServiceActions(KFileItemActions& fileItemActions); - DolphinView* m_dolphinView; - KFileItem* m_fileInfo; - QPoint m_pos; + /** + * Adds actions that are provided by a KFileItemActionPlugin. + */ + void addFileItemPluginActions(); + + /** + * Adds actions that are provided by a KVersionControlPlugin. + */ + void addVersionControlPluginActions(); - struct Entry { + /** + * Adds custom actions e.g. like the "[x] Expandable Folders"-action + * provided in the details view. + */ + void addCustomActions(); + +private: + struct Entry + { int type; QString name; QString filePath; // empty for separator @@ -123,6 +152,32 @@ private: QString icon; QString comment; }; + + enum ContextType + { + NoContext = 0, + ItemContext = 1, + TrashContext = 2 + }; + + QPoint m_pos; + DolphinMainWindow* m_mainWindow; + + KFileItem m_fileInfo; + + KUrl m_baseUrl; + KFileItem* m_baseFileItem; /// File item for m_baseUrl + + KFileItemList m_selectedItems; + mutable KFileItemListProperties* m_selectedItemsProperties; + + int m_context; + KonqCopyToMenu m_copyToMenu; + QList m_customActions; + + Command m_command; + + DolphinRemoveAction* m_removeAction; // Action that represents either 'Move To Trash' or 'Delete' }; #endif