/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Copyright 2013 - 2020, nymea GmbH * Contact: contact@nymea.io * * This file is part of nymea. * This project including source code and documentation is protected by * copyright law, and remains the property of nymea GmbH. All rights, including * reproduction, publication, editing and translation, are reserved. The use of * this project is subject to the terms of a license agreement to be concluded * with nymea GmbH in accordance with the terms of use of nymea GmbH, available * under https://nymea.io/license * * GNU General Public License Usage * Alternatively, this project may be redistributed and/or modified under the * terms of the GNU General Public License as published by the Free Software * Foundation, GNU version 3. This project 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 General * Public License for more details. * * You should have received a copy of the GNU General Public License along with * this project. If not, see . * * For any further details and any questions please contact us under * contact@nymea.io or see our FAQ/Licensing Information on * https://nymea.io/license/faq * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ import QtQuick 2.5 import QtQuick.Controls 2.2 import QtQuick.Controls.Material 2.2 import QtQuick.Layouts 1.1 import Nymea 1.0 import "../../components" ComboBox { id: root property var value property var possibleValues property var possibleValuesDisplayNames signal changed(var value) function update() { print("possible:", root.possibleValues, root.possibleValuesDisplayNames) listModel.clear(); for (var i = 0; i < root.possibleValues.length; i++) { var value = root.possibleValues[i] var label = root.possibleValuesDisplayNames.length > i ? root.possibleValuesDisplayNames[i] : root.possibleValues[i] listModel.append({value: value, label: label}) } currentIndex = possibleValues.indexOf(root.value) } model: ListModel { id: listModel } onActivated: changed(model.get(index).value) textRole: "label" Component.onCompleted: { print("completed. values", possibleValues, "value", root.value) update(); } onPossibleValuesChanged: { print("Possible values changed:", possibleValues) update(); } }