X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/70999c96a27777c2b1d0774b410680abd47eb131..bd839796f1e165016f8a4dfd01b222b31fb7773f:/src/dolphincontextmenu.h diff --git a/src/dolphincontextmenu.h b/src/dolphincontextmenu.h index 69554b01f..f60be558e 100644 --- a/src/dolphincontextmenu.h +++ b/src/dolphincontextmenu.h @@ -1,42 +1,27 @@ -/*************************************************************************** - * Copyright (C) 2006 by Peter Penz * - * peter.penz@gmx.at * - * * - * 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 +#include +#include -class KMenu; -class KFileItem; -class QPoint; -class QWidget; -class DolphinView; +class QAction; +class DolphinMainWindow; +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 @@ -45,75 +30,107 @@ 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 QMenu { + 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. + * @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(DolphinView* parent, - KFileItem* fileInfo, - const QPoint& pos); + DolphinContextMenu(DolphinMainWindow *parent, + const KFileItem &fileInfo, + const KFileItemList &selectedItems, + const QUrl &baseUrl, + KFileItemActions *fileItemActions); - virtual ~DolphinContextMenu(); + ~DolphinContextMenu() override; - /** Opens the context menu modal. */ - void open(); +protected: + bool eventFilter(QObject *object, QEvent *event) override; private: - void openViewportContextMenu(); - void openItemContextMenu(); + /** + * 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 addAllActions(); + + void addTrashContextMenu(); + void addTrashItemContextMenu(); + void addItemContextMenu(); + void addViewportContextMenu(); + + void insertDefaultItemActions(const KFileItemListProperties &); + + bool placeExists(const QUrl &url) const; + + QAction *createPasteAction(); + + KFileItemListProperties &selectedItemsProperties() const; /** - * 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. + * Returns the file item for m_baseUrl. */ - QList insertOpenWithItems(KMenu* popup, - QVector& openWithVector); + KFileItem baseFileItem(); /** - * 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. + * Adds "Open With" actions */ - QList insertActionItems(KMenu* popup, - QVector& actionsVector); + void addOpenWithActions(); /** - * Returns true, if 'menu' contains already - * an entry with the name 'entryName'. + * Add services, custom actions, plugins and version control items to the menu */ - bool containsEntry(const KMenu* menu, - const QString& entryName) const; + void addAdditionalActions(const KFileItemListProperties &props); - DolphinView* m_dolphinView; - KFileItem* m_fileInfo; - QPoint m_pos; +private: + 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 { + NoContext = 0, + ItemContext = 1, + TrashContext = 2, + TimelineContext = 4, + SearchContext = 8, + RecentlyUsedContext = 16, + }; + + DolphinMainWindow *m_mainWindow; + + KFileItem m_fileInfo; + + QUrl m_baseUrl; + KFileItem *m_baseFileItem; /// File item for m_baseUrl + + KFileItemList m_selectedItems; + mutable KFileItemListProperties *m_selectedItemsProperties; + + int m_context; + KFileCopyToMenu m_copyToMenu; + + DolphinRemoveAction *m_removeAction; // Action that represents either 'Move To Trash' or 'Delete' + KFileItemActions *m_fileItemActions; }; #endif