Unity 8
CardAttributes.qml
1 /*
2  * Copyright 2014 Canonical Ltd.
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; version 3.
7  *
8  * This program is distributed in the hope that it will be useful,
9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11  * GNU General Public License for more details.
12  *
13  * You should have received a copy of the GNU General Public License
14  * along with this program. If not, see <http://www.gnu.org/licenses/>.
15  */
16 
17 import QtQuick 2.2
18 import QtQuick.Layouts 1.1
19 import Ubuntu.Components 1.1
20 
21 GridLayout {
22  id: grid
23  anchors {
24  left: parent.left;
25  right: parent.right;
26  }
27  columns: 2 + repeater.count % 2
28  rowSpacing: units.gu(.5)
29  property alias model: repeater.model
30  property color color: Theme.palette.normal.baseText
31  property real fontScale: 1.0
32 
33  Repeater {
34  id: repeater
35  delegate: Row {
36  spacing: units.gu(0.5)
37  readonly property int column: index % grid.columns;
38  Layout.alignment: {
39  if (column == 0) return Qt.AlignLeft;
40  if (column == grid.columns - 1 || index == repeater.count - 1) return Qt.AlignRight;
41  if (column == 1) return Qt.AlignHCenter;
42  }
43  Layout.column: index % grid.columns
44  Layout.row: index / grid.columns
45  Layout.columnSpan: index == repeater.count - 1 && grid.columns == 3 && column == 1 ? 2 : 1
46  Layout.maximumWidth: Math.max(icon.width, label.x + label.implicitWidth)
47  Layout.fillWidth: true
48  height: units.gu(2)
49  Icon {
50  id: icon
51  height: units.gu(2)
52  source: "icon" in modelData && modelData["icon"] || ""
53  color: grid.color
54  }
55  Label {
56  id: label
57  width: parent.width - x
58  anchors.verticalCenter: parent.verticalCenter
59  text: "value" in modelData && modelData["value"] || "";
60  elide: Text.ElideRight
61  maximumLineCount: 1
62  font.weight: "style" in modelData && modelData["style"] === "highlighted" ? Font.Bold : Font.Light
63  fontSize: "small"
64  font.pixelSize: Math.round(FontUtils.sizeToPixels(fontSize) * fontScale)
65  color: grid.color
66  }
67  }
68  }
69 }