blob: a526d8669a9f8e29bbc5813b85f064923354ab5a (
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
|
// Copyright (C) 2017 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
import QtQuick 2.0
Item {
visible: true
width: 640
height: 480
property ListView listView
Loader {
id: loader
anchors.fill: parent
asynchronous: true
sourceComponent: comp
onStatusChanged: {
if (status == Loader.Ready) {
// Assign the listview to the root prop late, so
// that the c++ part doesn't start before everything is ready.
listView = item.listView
}
}
}
Component {
id: comp
Item {
property alias listView: listView
ListView {
id: listView
model: ListModel {
id: listModel
ListElement { title: "one" }
ListElement { title: "two" }
}
anchors.fill: parent
orientation: ListView.Horizontal
delegate: Item {
id: delegateRoot
objectName: "delegate"
width: 200
height: 200
Component.onCompleted: {
if (index === listModel.count - 1) {
// Add a new item while the outer Loader is still incubating async. If the new model item
// incubates using e.g QQmlIncubator::AsynchronousIfNested, it will also be loaded async, which
// is not currently supported (the item will not be added to the listview, or end up the wrong
// position, depending on its index and the current state of the refill/layout logic in
// QQuickListView).
// We add the new item here at the last delegates Component.onCompleted to hit the point in time
// when the listview is not expecting any more async items. In that case, the item will only be
// added to the list of visible items if incubated synchronously, which gives us something we
// can test for in the auto-test.
listModel.insert(0, {title: "zero"});
}
}
Rectangle {
anchors.fill: parent
border.width: 1
Text {
anchors.centerIn: parent
text: index
}
}
}
}
}
}
}
|