aboutsummaryrefslogtreecommitdiffstats
path: root/tests/auto/quick/qquicktableview/data/iscolumnloaded.qml
blob: 84cbe981bda56fe35178dbbad22f6dd4102b9984 (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
// Copyright (C) 2021 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only

import QtQuick
import QtQuick.Window

Item {
    width: 640
    height: 450

    property alias tableView: tableView
    property int itemsInColumnAfterLoaded: 0
    property int itemsInRowAfterLoaded: 0

    TableView {
        id: tableView
        width: 600
        height: 400
        anchors.margins: 1
        clip: true
        delegate: tableViewDelegate
        columnSpacing: 1
        rowSpacing: 1
        columnWidthProvider: function(column) {
            if (isColumnLoaded(column)) {
                var count = 0;
                for (var row = topRow; row <= bottomRow; ++row) {
                    var item = itemAtCell(Qt.point(column, row))
                    if (item)
                        count++;
                }
                itemsInColumnAfterLoaded = count;
            }

            return -1
        }
        rowHeightProvider: function(row) {
            if (isRowLoaded(row)) {
                var count = 0;
                for (var column = leftColumn; column <= rightColumn; ++column) {
                    var item = itemAtCell(Qt.point(column, row))
                    if (item)
                        count++;
                }
                itemsInRowAfterLoaded = count;
            }

            return -1
        }
    }

    Component {
        id: tableViewDelegate
        Rectangle {
            objectName: "tableViewDelegate"
            implicitWidth: 20
            implicitHeight: 20
            color: "lightgray"
            border.width: 1
            Text {
                anchors.centerIn: parent
                text: modelData
            }
        }
    }

}