aboutsummaryrefslogtreecommitdiffstats
path: root/tests/manual/tableview/storagemodel/main.qml
blob: 0888497ea73c2b070c48c20581afe5f211d045a9 (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
// Copyright (C) 2019 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only

import QtQuick
import QtQuick.Window
import Qt.labs.qmlmodels
import StorageModel

Window {
    id: window
    width: 480
    height: 300
    visible: true
    color: "darkgray"
    title: "Storage Volumes"

    TableView {
        id: table
        anchors.fill: parent
        anchors.margins: 10
        clip: true
        model: StorageModel { }
        columnSpacing: 1
        rowSpacing: 1
        resizableColumns: true
        delegate: DelegateChooser {
            role: "type"
            DelegateChoice {
                roleValue: "Value"
                delegate: Rectangle {
                    color: "tomato"
                    implicitWidth: Math.max(100, label.implicitWidth + 8)
                    implicitHeight: label.implicitHeight + 4

                    Rectangle {
                        x: parent.width - width
                        width: value * parent.width / valueMax
                        height: parent.height
                        color: "white"
                    }

                    Text {
                        id: label
                        anchors.baseline: parent.bottom
                        anchors.baselineOffset: -4
                        anchors.left: parent.left
                        anchors.leftMargin: 4
                        text: valueDisplay + " of " + valueMaxDisplay + " " + heading
                    }
                }
            }
            DelegateChoice {
                roleValue: "Flag"
                // We could use a checkbox here but that would be another component (e.g. from Controls)
                delegate: Rectangle {
                    implicitWidth: checkBox.implicitWidth + 8
                    implicitHeight: checkBox.implicitHeight + 4
                    Text {
                        id: checkBox
                        anchors.baseline: parent.bottom
                        anchors.baselineOffset: -4
                        anchors.left: parent.left
                        anchors.leftMargin: 4
                        text: (checkState ? "☑ " : "☐ ") + heading
                    }
                }
            }
            DelegateChoice {
                // roleValue: "String" // default delegate
                delegate: Rectangle {
                    implicitWidth: stringLabel.implicitWidth + 8
                    implicitHeight: stringLabel.implicitHeight + 4
                    Text {
                        id: stringLabel
                        anchors.baseline: parent.bottom
                        anchors.baselineOffset: -4
                        anchors.left: parent.left
                        anchors.leftMargin: 4
                        text: display
                    }
                }
            }
        }
    }
}