X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/2b895e7e2bd096e55faa1032ebc6a355a72c2325..b889a446bfe851a7f49821d469c5f3041b6e5774:/src/dolphincontextmenu.h diff --git a/src/dolphincontextmenu.h b/src/dolphincontextmenu.h index 419d3f9bd..f60be558e 100644 --- a/src/dolphincontextmenu.h +++ b/src/dolphincontextmenu.h @@ -1,36 +1,21 @@ -/*************************************************************************** - * 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 * - * the Free Software Foundation; either version 2 of the License, or * - * (at your option) any later version. * - * * - * This program is distributed in the hope that it will be useful, * - * but WITHOUT ANY WARRANTY; without even the implied warranty of * - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * - * GNU General Public License for more details. * - * * - * 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., * - * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * - ***************************************************************************/ +/* + * SPDX-FileCopyrightText: 2006 Peter Penz + * + * SPDX-License-Identifier: GPL-2.0-or-later + */ #ifndef DOLPHINCONTEXTMENU_H #define DOLPHINCONTEXTMENU_H -#include -#include #include -#include - - +#include +#include +#include +#include class QAction; class DolphinMainWindow; -class KFileItemActions; class KFileItemListProperties; class DolphinRemoveAction; @@ -51,130 +36,101 @@ class DolphinContextMenu : public QMenu Q_OBJECT public: - enum Command - { - None, - OpenParentFolder, - OpenParentFolderInNewWindow, - OpenParentFolderInNewTab - }; - /** * @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. + * @selectedItems The selected items for which the context menu + * is opened. This list generally includes \a fileInfo. * @baseUrl Base URL of the viewport where the context menu * should be opened. */ - DolphinContextMenu(DolphinMainWindow* parent, - const QPoint& pos, - const KFileItem& fileInfo, - const QUrl& baseUrl); - - virtual ~DolphinContextMenu(); - - void setCustomActions(const QList& actions); + DolphinContextMenu(DolphinMainWindow *parent, + const KFileItem &fileInfo, + const KFileItemList &selectedItems, + const QUrl &baseUrl, + KFileItemActions *fileItemActions); - /** - * 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(); + ~DolphinContextMenu() override; protected: - virtual void keyPressEvent(QKeyEvent *ev) Q_DECL_OVERRIDE; - virtual void keyReleaseEvent(QKeyEvent *ev) Q_DECL_OVERRIDE; + bool eventFilter(QObject *object, QEvent *event) override; private: - void openTrashContextMenu(); - void openTrashItemContextMenu(); - void openItemContextMenu(); - void openViewportContextMenu(); - - void insertDefaultItemActions(const KFileItemListProperties&); - /** - * Adds the "Show menubar" action to the menu if the - * menubar is hidden. + * Adds all the actions and menus to this menu based on all given information. + * This method calls the other helper methods for adding actions + * based on the context given in the constructor. */ - void addShowMenuBarAction(); + void addAllActions(); - bool placeExists(const QUrl& url) const; + void addTrashContextMenu(); + void addTrashItemContextMenu(); + void addItemContextMenu(); + void addViewportContextMenu(); - QAction* createPasteAction(); + void insertDefaultItemActions(const KFileItemListProperties &); - KFileItemListProperties& selectedItemsProperties() const; + bool placeExists(const QUrl &url) const; - /** - * Returns the file item for m_baseUrl. - */ - KFileItem baseFileItem(); + QAction *createPasteAction(); - /** - * Adds actions that have been installed as service-menu. - * (see http://techbase.kde.org/index.php?title=Development/Tutorials/Creating_Konqueror_Service_Menus) - */ - void addServiceActions(KFileItemActions& fileItemActions); + KFileItemListProperties &selectedItemsProperties() const; /** - * Adds actions that are provided by a KFileItemActionPlugin. + * Returns the file item for m_baseUrl. */ - void addFileItemPluginActions(); + KFileItem baseFileItem(); /** - * Adds actions that are provided by a KVersionControlPlugin. + * Adds "Open With" actions */ - void addVersionControlPluginActions(); + void addOpenWithActions(); /** - * Adds custom actions e.g. like the "[x] Expandable Folders"-action - * provided in the details view. + * Add services, custom actions, plugins and version control items to the menu */ - void addCustomActions(); + void addAdditionalActions(const KFileItemListProperties &props); private: - struct Entry - { + void addDirectoryItemContextMenu(); + void addOpenParentFolderActions(); + + struct Entry { int type; QString name; - QString filePath; // empty for separator + QString filePath; // empty for separator QString templatePath; // same as filePath for template QString icon; QString comment; }; - enum ContextType - { + enum ContextType { NoContext = 0, ItemContext = 1, - TrashContext = 2 + TrashContext = 2, + TimelineContext = 4, + SearchContext = 8, + RecentlyUsedContext = 16, }; - QPoint m_pos; - DolphinMainWindow* m_mainWindow; + DolphinMainWindow *m_mainWindow; KFileItem m_fileInfo; QUrl m_baseUrl; - KFileItem* m_baseFileItem; /// File item for m_baseUrl + KFileItem *m_baseFileItem; /// File item for m_baseUrl KFileItemList m_selectedItems; - mutable KFileItemListProperties* m_selectedItemsProperties; + mutable KFileItemListProperties *m_selectedItemsProperties; int m_context; KFileCopyToMenu m_copyToMenu; - QList m_customActions; - - Command m_command; - DolphinRemoveAction* m_removeAction; // Action that represents either 'Move To Trash' or 'Delete' + DolphinRemoveAction *m_removeAction; // Action that represents either 'Move To Trash' or 'Delete' + KFileItemActions *m_fileItemActions; }; #endif