1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
|
/*
* SPDX-FileCopyrightText: 2006 Peter Penz <[email protected]>
*
* 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:
void addDirectoryItemContextMenu();
void addOpenParentFolderActions();
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,
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
|