X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/d7d4fb9d26773c2d729b49d71af10e1378381ff3..d6488887ecf69d7f192b94de8dce34fae0b7eb76:/src/dolphincontextmenu.h diff --git a/src/dolphincontextmenu.h b/src/dolphincontextmenu.h index 49c21faa8..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,23 +20,23 @@ #ifndef DOLPHINCONTEXTMENU_H #define DOLPHINCONTEXTMENU_H -#include -#include -#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 @@ -46,32 +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. - * @pos Position of the upper left edge of the context menu. + * @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, - const QPoint& pos); + 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. @@ -84,17 +88,7 @@ private: * to the predecessor. */ QList insertOpenWithItems(KMenu* popup, - Q3ValueVector& 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, - Q3ValueVector& actionsVector); + QVector& openWithVector); /** * Returns true, if 'menu' contains already @@ -103,18 +97,15 @@ private: bool containsEntry(const KMenu* menu, const QString& entryName) const; - enum { - submenuID = 90, - bookmarkID = 91, - openWithIDStart = 100, - actionsIDStart = 1000, - }; - - DolphinView* m_dolphinView; - KFileItem* m_fileInfo; - QPoint m_pos; + /** + * 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 @@ -122,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