-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.qml
102 lines (97 loc) · 3.18 KB
/
main.qml
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
import QtQuick 2.14
import QtQuick.Controls 2.14
import QtQuick.Window 2.14
import Qt.labs.qmlmodels 1.0
Window {
id: root
width: 640
height: 480
visible: true
title: qsTr("Properties table")
property string name: "Bob"
property bool enabled: true
property int count: 42
TableView {
anchors.fill: parent
model: TableModel {
id: theModel
TableModelColumn {
display: "name"
decoration: function() { return "";}
}
TableModelColumn {
display: "value"
decoration: "type"
}
rows: _rows
property var _rows: [
{
name: "Name",
type: "string",
value: root.name,
onValueChanged: function(v) {console.log('"name" changed to ',v)},
},
{
name: "Enabled",
type: "bool",
value: root.enabled,
onValueChanged: function(v) {console.log('"enabled" changed to ',v)},
},
{
name: "Count",
type: "int",
value: root.count,
onValueChanged: function(v) {console.log('"count" changed to ',v)},
},
{
name: "Count2",
type: "int",
value: root.count,
onValueChanged: function(v) {console.log('"count2" changed to ',v)},
},
]
function dispatchValueChange(row, decoration, value) {
row = _rows[row]
if(row && row.onValueChanged)
row.onValueChanged(value)
}
}
delegate: DelegateChooser {
role: "decoration"
DelegateChoice {
roleValue: "string"
delegate: TextField {
text: model.display
selectByMouse: true
onEditingFinished: theModel.dispatchValueChange(model.row, model.decoration, text)
}
}
DelegateChoice {
roleValue: "int"
delegate: SpinBox {
value: model.display
onValueChanged: theModel.dispatchValueChange(model.row, model.decoration, value)
}
}
DelegateChoice {
roleValue: "bool"
delegate: CheckBox {
checked: model.display
onCheckedChanged: theModel.dispatchValueChange(model.row, model.decoration, checked)
}
}
DelegateChoice {
delegate: Rectangle {
color: "beige"
implicitWidth: textLabel.width + 10
implicitHeight: textLabel.height
Text {
id: textLabel
anchors.centerIn: parent
text: model.display
}
}
}
}
}
}