Kirigami2

toolbarlayout.h
1/*
2 * SPDX-FileCopyrightText: 2020 Arjen Hiemstra <ahiemstra@heimr.nl>
3 *
4 * SPDX-License-Identifier: LGPL-2.1-only OR LGPL-3.0-only OR LicenseRef-KDE-Accepted-LGPL
5 */
6
7#ifndef TOOLBARLAYOUT_H
8#define TOOLBARLAYOUT_H
9
10#include <QQuickItem>
11#include <memory>
12
13class ToolBarLayoutPrivate;
14
15/**
16 * Attached property for ToolBarLayout delegates.
17 */
19{
21 /**
22 * The action this delegate was created for.
23 */
24 Q_PROPERTY(QObject *action READ action CONSTANT FINAL)
25public:
27
28 QObject *action() const;
29 void setAction(QObject *action);
30
31private:
32 QObject *m_action = nullptr;
33};
34
35/**
36 * An item that creates delegates for actions and lays them out in a row.
37 *
38 * This effectively combines RowLayout and Repeater in a single item, with the
39 * addition of some extra performance enhancing tweaks. It will create instances
40 * of ::fullDelegate and ::itemDelegate for each action in ::actions . These are
41 * then positioned horizontally. Any action that ends up being placed outside
42 * the width of the item is hidden and will be part of ::hiddenActions.
43 *
44 * The items created as delegates are always created asynchronously, to avoid
45 * creation lag spikes. Each delegate has access to the action it was created
46 * for through the ToolBarLayoutAttached attached property.
47 */
49{
51 QML_ELEMENT
52 QML_ATTACHED(ToolBarLayoutAttached)
53 /**
54 * The actions this layout should create delegates for.
55 */
56 Q_PROPERTY(QQmlListProperty<QObject> actions READ actionsProperty NOTIFY actionsChanged FINAL)
57 /**
58 * A list of actions that do not fit in the current view and are thus hidden.
59 */
60 Q_PROPERTY(QList<QObject *> hiddenActions READ hiddenActions NOTIFY hiddenActionsChanged FINAL)
61 /**
62 * A component that is used to create full-size delegates from.
63 *
64 * Each delegate has three states, it can be full-size, icon-only or hidden.
65 * By default, the full-size delegate is used. When the action has the
66 * DisplayHint::IconOnly hint set, it will always use the iconDelegate. When
67 * it has the DisplayHint::KeepVisible hint set, it will use the full-size
68 * delegate when it fits. If not, it will use the iconDelegate, unless even
69 * that does not fit, in which case it will still be hidden.
70 */
71 Q_PROPERTY(QQmlComponent *fullDelegate READ fullDelegate WRITE setFullDelegate NOTIFY fullDelegateChanged FINAL)
72 /**
73 * A component that is used to create icon-only delegates from.
74 *
75 * \sa fullDelegate
76 */
77 Q_PROPERTY(QQmlComponent *iconDelegate READ iconDelegate WRITE setIconDelegate NOTIFY iconDelegateChanged FINAL)
78 /**
79 * A component that is used to create separator delegates from.
80 *
81 * \since 6.7
82 *
83 * \sa fullDelegate
84 */
85 Q_PROPERTY(QQmlComponent *separatorDelegate READ separatorDelegate WRITE setSeparatorDelegate NOTIFY separatorDelegateChanged FINAL)
86 /**
87 * A component that is used to create the "more button" item from.
88 *
89 * The more button is shown when there are actions that do not fit the
90 * current view. It is intended to have functionality to show these hidden
91 * actions, like popup a menu with them showing.
92 */
93 Q_PROPERTY(QQmlComponent *moreButton READ moreButton WRITE setMoreButton NOTIFY moreButtonChanged FINAL)
94 /**
95 * The amount of spacing between individual delegates.
96 */
97 Q_PROPERTY(qreal spacing READ spacing WRITE setSpacing NOTIFY spacingChanged FINAL)
98 /**
99 * How to align the delegates within this layout.
100 *
101 * When there is more space available than required by the visible delegates,
102 * we need to determine how to place the delegates. This property determines
103 * how to do that. Note that the moreButton, if visible, will always be
104 * placed at the end of the layout.
105 */
106 Q_PROPERTY(Qt::Alignment alignment READ alignment WRITE setAlignment NOTIFY alignmentChanged FINAL)
107 /**
108 * The combined width of visible delegates in this layout.
109 */
110 Q_PROPERTY(qreal visibleWidth READ visibleWidth NOTIFY visibleWidthChanged FINAL)
111 /**
112 * The minimum width this layout can have.
113 *
114 * This is equal to the width of the moreButton.
115 */
116 Q_PROPERTY(qreal minimumWidth READ minimumWidth NOTIFY minimumWidthChanged FINAL)
117 /**
118 * Which direction to layout in.
119 *
120 * This is primarily intended to support right-to-left layouts. When set to
121 * LeftToRight, delegates will be layout with the first item on the left and
122 * following items to the right of that. The more button will be placed at
123 * the rightmost position. Alignment flags work normally.
124 *
125 * When set to RightToLeft, delegates will be layout with the first item on
126 * the right and following items to the left of that. The more button will
127 * be placed at the leftmost position. Alignment flags are inverted, so
128 * AlignLeft will align items to the right, and vice-versa.
129 */
130 Q_PROPERTY(Qt::LayoutDirection layoutDirection READ layoutDirection WRITE setLayoutDirection NOTIFY layoutDirectionChanged FINAL)
131 /**
132 * How to handle items that do not match the toolbar's height.
133 *
134 * When toolbar items do not match the height of the toolbar, there are
135 * several ways we can deal with this. This property sets the preferred way.
136 *
137 * The default is HeightMode::ConstrainIfLarger .
138 *
139 * \sa HeightMode
140 */
141 Q_PROPERTY(HeightMode heightMode READ heightMode WRITE setHeightMode NOTIFY heightModeChanged FINAL)
142
143public:
145
146 /**
147 * An enum describing several modes that can be used to deal with items with
148 * a height that does not match the toolbar's height.
149 */
151 AlwaysCenter, ///< Always center items, allowing them to go outside the bounds of the layout if they are larger.
152 AlwaysFill, ///< Always match the height of the layout. Larger items will be reduced in height, smaller items will be increased.
153 ConstrainIfLarger, ///< If the item is larger than the toolbar, reduce its height. Otherwise center it in the toolbar.
154 };
155 Q_ENUM(HeightMode)
156
157 ToolBarLayout(QQuickItem *parent = nullptr);
158 ~ToolBarLayout() override;
159
160 ActionsProperty actionsProperty() const;
161 /**
162 * Add an action to the list of actions.
163 *
164 * \param action The action to add.
165 */
166 void addAction(QObject *action);
167 /**
168 * Remove an action from the list of actions.
169 *
170 * \param action The action to remove.
171 */
172 void removeAction(QObject *action);
173 /**
174 * Clear the list of actions.
175 */
176 void clearActions();
177 Q_SIGNAL void actionsChanged();
178
180 Q_SIGNAL void hiddenActionsChanged();
181
183 void setFullDelegate(QQmlComponent *newFullDelegate);
184 Q_SIGNAL void fullDelegateChanged();
185
187 void setIconDelegate(QQmlComponent *newIconDelegate);
188 Q_SIGNAL void iconDelegateChanged();
189
191 void setSeparatorDelegate(QQmlComponent *newSeparatorDelegate);
192 Q_SIGNAL void separatorDelegateChanged();
193
194 QQmlComponent *moreButton() const;
195 void setMoreButton(QQmlComponent *newMoreButton);
196 Q_SIGNAL void moreButtonChanged();
197
198 qreal spacing() const;
199 void setSpacing(qreal newSpacing);
200 Q_SIGNAL void spacingChanged();
201
202 Qt::Alignment alignment() const;
203 void setAlignment(Qt::Alignment newAlignment);
204 Q_SIGNAL void alignmentChanged();
205
206 qreal visibleWidth() const;
207 Q_SIGNAL void visibleWidthChanged();
208
209 qreal minimumWidth() const;
210 Q_SIGNAL void minimumWidthChanged();
211
213 void setLayoutDirection(Qt::LayoutDirection &newLayoutDirection);
214 Q_SIGNAL void layoutDirectionChanged();
215
216 HeightMode heightMode() const;
217 void setHeightMode(HeightMode newHeightMode);
218 Q_SIGNAL void heightModeChanged();
219
220 /**
221 * Queue a relayout of this layout.
222 *
223 * \note The layouting happens during the next scene graph polishing phase.
224 */
225 Q_SLOT void relayout();
226
227 static ToolBarLayoutAttached *qmlAttachedProperties(QObject *object)
228 {
229 return new ToolBarLayoutAttached(object);
230 }
231
232protected:
233 void componentComplete() override;
234 void geometryChange(const QRectF &newGeometry, const QRectF &oldGeometry) override;
235 void itemChange(QQuickItem::ItemChange change, const QQuickItem::ItemChangeData &data) override;
236 void updatePolish() override;
237
238private:
239 friend class ToolBarLayoutPrivate;
240 const std::unique_ptr<ToolBarLayoutPrivate> d;
241};
242
243QML_DECLARE_TYPEINFO(ToolBarLayout, QML_HAS_ATTACHED_PROPERTIES)
244
245#endif // TOOLBARLAYOUT_H
Attached property for ToolBarLayout delegates.
QObject * action
The action this delegate was created for.
An item that creates delegates for actions and lays them out in a row.
QQmlComponent * iconDelegate
A component that is used to create icon-only delegates from.
Q_SLOT void relayout()
Queue a relayout of this layout.
Qt::Alignment alignment
How to align the delegates within this layout.
QQmlComponent * moreButton
A component that is used to create the "more button" item from.
void removeAction(QObject *action)
Remove an action from the list of actions.
Qt::LayoutDirection layoutDirection
Which direction to layout in.
HeightMode heightMode
How to handle items that do not match the toolbar's height.
void clearActions()
Clear the list of actions.
qreal visibleWidth
The combined width of visible delegates in this layout.
qreal spacing
The amount of spacing between individual delegates.
qreal minimumWidth
The minimum width this layout can have.
QML_ELEMENTQQmlListProperty< QObject > actions
The actions this layout should create delegates for.
QQmlComponent * fullDelegate
A component that is used to create full-size delegates from.
void addAction(QObject *action)
Add an action to the list of actions.
QQmlComponent * separatorDelegate
A component that is used to create separator delegates from.
HeightMode
An enum describing several modes that can be used to deal with items with a height that does not matc...
@ AlwaysFill
Always match the height of the layout. Larger items will be reduced in height, smaller items will be ...
@ ConstrainIfLarger
If the item is larger than the toolbar, reduce its height. Otherwise center it in the toolbar.
@ AlwaysCenter
Always center items, allowing them to go outside the bounds of the layout if they are larger.
QList< QObject * > hiddenActions
A list of actions that do not fit in the current view and are thus hidden.
Q_ENUM(...)
Q_OBJECTQ_OBJECT
Q_PROPERTY(...)
Q_SIGNALQ_SIGNAL
Q_SLOTQ_SLOT
QObject * parent() const const
typedef Alignment
LayoutDirection
This file is part of the KDE documentation.
Documentation copyright © 1996-2025 The KDE developers.
Generated on Fri Jan 3 2025 11:48:03 by doxygen 1.12.0 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.