1/****************************************************************************
2**
3** Copyright (C) 2019 The Qt Company Ltd.
4** Contact: https://www.qt.io/licensing/
5**
6** This file is part of the QtGui module of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial License Usage
10** Licensees holding valid commercial Qt licenses may use this file in
11** accordance with the commercial license agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and The Qt Company. For licensing terms
14** and conditions see https://www.qt.io/terms-conditions. For further
15** information use the contact form at https://www.qt.io/contact-us.
16**
17** GNU Lesser General Public License Usage
18** Alternatively, this file may be used under the terms of the GNU Lesser
19** General Public License version 3 as published by the Free Software
20** Foundation and appearing in the file LICENSE.LGPL3 included in the
21** packaging of this file. Please review the following information to
22** ensure the GNU Lesser General Public License version 3 requirements
23** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
24**
25** GNU General Public License Usage
26** Alternatively, this file may be used under the terms of the GNU
27** General Public License version 2.0 or (at your option) the GNU General
28** Public license version 3 or any later version approved by the KDE Free
29** Qt Foundation. The licenses are as published by the Free Software
30** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
31** included in the packaging of this file. Please review the following
32** information to ensure the GNU General Public License requirements will
33** be met: https://www.gnu.org/licenses/gpl-2.0.html and
34** https://www.gnu.org/licenses/gpl-3.0.html.
35**
36** $QT_END_LICENSE$
37**
38****************************************************************************/
39
40#ifndef QACTION_P_H
41#define QACTION_P_H
42
43//
44// W A R N I N G
45// -------------
46//
47// This file is not part of the Qt API. It exists for the convenience
48// of other Qt classes. This header file may change from version to
49// version without notice, or even be removed.
50//
51// We mean it.
52//
53
54#include <QtGui/private/qtguiglobal_p.h>
55#include <QtGui/qaction.h>
56#include <QtGui/qfont.h>
57#if QT_CONFIG(shortcut)
58# include <QtGui/private/qshortcutmap_p.h>
59#endif
60#include "private/qobject_p.h"
61
62QT_REQUIRE_CONFIG(action);
63
64QT_BEGIN_NAMESPACE
65
66class QShortcutMap;
67
68class Q_GUI_EXPORT QActionPrivate : public QObjectPrivate
69{
70 Q_DECLARE_PUBLIC(QAction)
71public:
72 QActionPrivate();
73 ~QActionPrivate();
74
75 virtual void destroy();
76
77#if QT_CONFIG(shortcut)
78 virtual QShortcutMap::ContextMatcher contextMatcher() const;
79#endif
80
81 static QActionPrivate *get(QAction *q)
82 {
83 return q->d_func();
84 }
85
86 bool setEnabled(bool enable, bool byGroup);
87 void setVisible(bool b);
88
89 QPointer<QActionGroup> group;
90 QString text;
91 QString iconText;
92 QIcon icon;
93 QString tooltip;
94 QString statustip;
95 QString whatsthis;
96#if QT_CONFIG(shortcut)
97 QList<QKeySequence> shortcuts;
98#endif
99 QVariant userData;
100
101 QObjectList associatedObjects;
102 virtual QObject *menu() const;
103 virtual void setMenu(QObject *menu);
104
105#if QT_CONFIG(shortcut)
106 QList<int> shortcutIds;
107 Qt::ShortcutContext shortcutContext = Qt::WindowShortcut;
108 uint autorepeat : 1;
109#endif
110 QFont font;
111 uint enabled : 1, explicitEnabled : 1, explicitEnabledValue : 1;
112 uint visible : 1, forceInvisible : 1;
113 uint checkable : 1;
114 uint checked : 1;
115 uint separator : 1;
116 uint fontSet : 1;
117
118 int iconVisibleInMenu : 2; // Only has values -1, 0, and 1
119 int shortcutVisibleInContextMenu : 2; // Only has values -1, 0, and 1
120
121 QAction::MenuRole menuRole = QAction::TextHeuristicRole;
122 QAction::Priority priority = QAction::NormalPriority;
123
124#if QT_CONFIG(shortcut)
125 void redoGrab(QShortcutMap &map);
126 void redoGrabAlternate(QShortcutMap &map);
127 void setShortcutEnabled(bool enable, QShortcutMap &map);
128#endif // QT_NO_SHORTCUT
129
130 bool showStatusText(QObject *widget, const QString &str);
131 void sendDataChanged();
132};
133
134QT_END_NAMESPACE
135
136#endif // QACTION_P_H
137