X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/546384562ae872614cd0c8fa568bd65ae41885da..d6488887ecf69d7f192b94de8dce34fae0b7eb76:/src/dolphincontextmenu.h diff --git a/src/dolphincontextmenu.h b/src/dolphincontextmenu.h index 82bc9f24d..c90999252 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 * @@ -21,22 +20,23 @@ #ifndef DOLPHINCONTEXTMENU_H #define DOLPHINCONTEXTMENU_H -#include -#include - +#include +#include #include -#include -#include +#include + +#include + +#include class KMenu; class KFileItem; -class QPoint; -class QWidget; -class DolphinView; +class QAction; +class DolphinMainWindow; /** * @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 @@ -45,30 +45,37 @@ 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 QObject { + Q_OBJECT + public: /** - * @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. + * @parent Pointer to the main window 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. + * @baseUrl Base URL of the viewport where the context menu + * should be opened. */ - DolphinContextMenu(DolphinView* parent, - KFileItem* fileInfo); + DolphinContextMenu(DolphinMainWindow* parent, + const KFileItem& fileInfo, + const KUrl& baseUrl); virtual ~DolphinContextMenu(); - /** Opens the context menu modal. */ + /** Opens the context menu model. */ void open(); private: - void openViewportContextMenu(); + void openTrashContextMenu(); + void openTrashItemContextMenu(); void openItemContextMenu(); + void openViewportContextMenu(); + + void insertDefaultItemActions(KMenu* popup); /** * Inserts the 'Open With...' submenu to \a popup. @@ -83,16 +90,6 @@ private: QList insertOpenWithItems(KMenu* popup, QVector& openWithVector); - /** - * 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. - */ - QList insertActionItems(KMenu* popup, - QVector& actionsVector); - /** * Returns true, if 'menu' contains already * an entry with the name 'entryName'. @@ -100,10 +97,15 @@ private: bool containsEntry(const KMenu* menu, const QString& entryName) const; - DolphinView* m_dolphinView; - KFileItem* m_fileInfo; + /** + * Adds the "Show menubar" action to the menu if the + * menubar is hidden. + */ + void addShowMenubarAction(KMenu* menu); - struct Entry { +private: + struct Entry + { int type; QString name; QString filePath; // empty for separator @@ -111,6 +113,20 @@ private: QString icon; QString comment; }; + + enum ContextType + { + NoContext = 0, + ItemContext = 1, + TrashContext = 2 + }; + + DolphinMainWindow* m_mainWindow; + KFileItem m_fileInfo; + KUrl m_baseUrl; + KFileItemList m_selectedItems; + KUrl::List m_selectedUrls; + int m_context; }; #endif