blob: 3c437efe039353b9e223476a419e2dfdad78cdd6 (
plain)
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
|
// Copyright (C) 2024 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
#include "qhelpcontentitem.h"
#include <QtCore/qstring.h>
#include <QtCore/qurl.h>
QT_BEGIN_NAMESPACE
class QHelpContentItemPrivate
{
public:
QString title;
QUrl link;
QHelpContentItem *parent;
QList<QHelpContentItem *> childItems = {};
};
/*!
\class QHelpContentItem
\inmodule QtHelp
\brief The QHelpContentItem class provides an item for use with QHelpContentModel.
\since 4.4
*/
QHelpContentItem::QHelpContentItem(const QString &name, const QUrl &link, QHelpContentItem *parent)
: d(new QHelpContentItemPrivate{name, link, parent})
{
if (parent)
parent->d->childItems.append(this);
}
/*!
Destroys the help content item.
*/
QHelpContentItem::~QHelpContentItem()
{
qDeleteAll(d->childItems);
delete d;
}
/*!
Returns the child of the content item in the give \a row.
\sa parent()
*/
QHelpContentItem *QHelpContentItem::child(int row) const
{
return d->childItems.value(row);
}
/*!
Returns the number of child items.
*/
int QHelpContentItem::childCount() const
{
return d->childItems.size();
}
/*!
Returns the row of this item from its parents view.
*/
int QHelpContentItem::row() const
{
// TODO: Optimize by keeping the index internally.
return d->parent ? d->parent->d->childItems.indexOf(const_cast<QHelpContentItem*>(this)) : 0;
}
/*!
Returns the title of the content item.
*/
QString QHelpContentItem::title() const
{
return d->title;
}
/*!
Returns the URL of this content item.
*/
QUrl QHelpContentItem::url() const
{
return d->link;
}
/*!
Returns the parent content item.
*/
QHelpContentItem *QHelpContentItem::parent() const
{
return d->parent;
}
/*!
Returns the position of a given \a child.
*/
int QHelpContentItem::childPosition(QHelpContentItem *child) const
{
return d->childItems.indexOf(child);
}
QT_END_NAMESPACE
|