mirror of
https://invent.kde.org/system/dolphin
synced 2024-10-28 03:21:56 +00:00
137 lines
3.6 KiB
C++
137 lines
3.6 KiB
C++
/*
|
|
* SPDX-FileCopyrightText: 2006 Peter Penz <peter.penz19@gmail.com>
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
|
*/
|
|
|
|
#ifndef DOLPHINCONTEXTMENU_H
|
|
#define DOLPHINCONTEXTMENU_H
|
|
|
|
#include <KFileCopyToMenu>
|
|
#include <KFileItem>
|
|
#include <KFileItemActions>
|
|
|
|
#include <QMenu>
|
|
#include <QUrl>
|
|
|
|
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.
|
|
*
|
|
* Beside static menu entries (e. g. 'Paste' or 'Properties') two
|
|
* dynamic sub menus are shown when opening a context menu above
|
|
* an item:
|
|
* - 'Open With': Contains all applications which are registered to
|
|
* open items of the given MIME type.
|
|
* - 'Actions': Contains all actions which can be applied to the
|
|
* given item.
|
|
*/
|
|
class DolphinContextMenu : public QMenu
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
/**
|
|
* @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(DolphinMainWindow* parent,
|
|
const KFileItem& fileInfo,
|
|
const KFileItemList &selectedItems,
|
|
const QUrl& baseUrl,
|
|
KFileItemActions *fileItemActions);
|
|
|
|
~DolphinContextMenu() override;
|
|
|
|
protected:
|
|
bool eventFilter(QObject* object, QEvent* event) override;
|
|
|
|
private:
|
|
/**
|
|
* 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;
|
|
|
|
/**
|
|
* Returns the file item for m_baseUrl.
|
|
*/
|
|
KFileItem baseFileItem();
|
|
|
|
/**
|
|
* Adds "Open With" actions
|
|
*/
|
|
void addOpenWithActions();
|
|
|
|
/**
|
|
* Add services, custom actions, plugins and version control items to the menu
|
|
*/
|
|
void addAdditionalActions(const KFileItemListProperties &props);
|
|
|
|
private:
|
|
struct Entry
|
|
{
|
|
int type;
|
|
QString name;
|
|
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,
|
|
};
|
|
|
|
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'
|
|
void addDirectoryItemContextMenu();
|
|
KFileItemActions *m_fileItemActions;
|
|
|
|
};
|
|
|
|
#endif
|