import QtQuick 2.5 import QtQuick.Controls 2.1 import QtQuick.Controls.Material 2.1 import QtQuick.Layouts 1.1 import Nymea 1.0 import "../components" import "../customviews" DeviceListPageBase { id: root header: GuhHeader { text: qsTr("Weather") onBackPressed: pageStack.pop() } ListView { anchors.fill: parent model: root.devicesProxy delegate: ItemDelegate { id: itemDelegate width: parent.width property bool inline: width > 500 property var device: devicesProxy.get(index); property var deviceClass: engine.deviceManager.deviceClasses.getDeviceClass(device.deviceClassId); bottomPadding: index === ListView.view.count - 1 ? topPadding : 0 contentItem: Pane { id: contentItem Material.elevation: 2 leftPadding: 0 rightPadding: 0 topPadding: 0 bottomPadding: 0 contentItem: ItemDelegate { leftPadding: 0 rightPadding: 0 topPadding: 0 bottomPadding: 0 contentItem: ColumnLayout { Rectangle { Layout.fillWidth: true Layout.preferredHeight: app.mediumFont + app.margins color: Qt.rgba(app.foregroundColor.r, app.foregroundColor.g, app.foregroundColor.b, .05) RowLayout { anchors { verticalCenter: parent.verticalCenter; left: parent.left; right: parent.right; margins: app.margins } Label { Layout.fillWidth: true text: model.name elide: Text.ElideRight } ColorIcon { Layout.preferredHeight: app.iconSize * .5 Layout.preferredWidth: height name: "../images/dialog-warning-symbolic.svg" visible: itemDelegate.deviceClass.interfaces.indexOf("connectable") >= 0 && itemDelegate.device.states.getState(itemDelegate.deviceClass.stateTypes.findByName("connected").id).value === false color: "red" } } } WeatherView { Layout.fillWidth: true device: itemDelegate.device deviceClass: itemDelegate.deviceClass } } onClicked: { var device = devicesProxy.get(index); var deviceClass = engine.deviceManager.deviceClasses.getDeviceClass(device.deviceClassId) pageStack.push(Qt.resolvedUrl("../devicepages/WeatherDevicePage.qml"), {device: devicesProxy.get(index)}) } } } } } }