-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathOptionSelectors.qml
111 lines (98 loc) · 3.94 KB
/
OptionSelectors.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
103
104
105
106
107
108
109
110
111
/*
* Copyright 2013 Canonical Ltd.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation; version 3.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
import QtQuick 2.0
import Ubuntu.Components 1.3
Template {
objectName: "optionSelectorsTemplate"
TemplateSection {
title: i18n.tr("Option Selector")
className: "OptionSelector"
Column {
anchors.left: parent.left
anchors.right: parent.right
spacing: units.gu(3)
property var model: [
i18n.tr("Value 1"),
i18n.tr("This is the second value"),
i18n.tr("Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat."),
i18n.tr("Once upon a time there was a story nobody told."),
]
OptionSelector {
objectName: "optionselector_collapsed"
text: i18n.tr("Collapsed")
model: parent.model
}
OptionSelector {
objectName: "optionselector_expanded"
text: i18n.tr("Expanded")
expanded: true
model: parent.model
}
OptionSelector {
objectName: "optionselector_multipleselection"
text: i18n.tr("Multiple Selection")
expanded: false
multiSelection: true
model: parent.model
}
OptionSelector {
objectName: "optionselector_custommodel"
text: i18n.tr("Custom Model")
model: customModel
expanded: true
colourImage: true
delegate: selectorDelegate
}
Component {
id: selectorDelegate
OptionSelectorDelegate { text: name; subText: description; iconSource: image }
}
ListModel {
id: customModel
ListElement { name: "Name 1"; description: "Description 1"; image: "images.png" }
ListElement { name: "Name 2"; description: "Description 2"; image: "images.png" }
ListElement { name: "Name 3"; description: "Description 3"; image: "images.png" }
ListElement { name: "Name 4"; description: "Description 4"; image: "images.png" }
}
OptionSelector {
text: i18n.tr("Custom container height")
model: [i18n.tr("Value 1"),
i18n.tr("Value 2"),
i18n.tr("Value 3"),
i18n.tr("Value 4"),
i18n.tr("Value 5"),
i18n.tr("Value 6"),
i18n.tr("Value 7"),
i18n.tr("Value 8")]
containerHeight: itemHeight * 4
}
OptionSelector {
text: i18n.tr("No initial selection, scrollable.")
expanded: true
selectedIndex: -1
model: [i18n.tr("Value 1"),
i18n.tr("Value 2"),
i18n.tr("Value 3"),
i18n.tr("Value 4"),
i18n.tr("Value 5"),
i18n.tr("Value 6"),
i18n.tr("Value 7"),
i18n.tr("Value 8")]
containerHeight: itemHeight * 4
}
}
}
}