import QtQuick 2.4 import QtQuick.Controls 2.1 import QtQuick.Layouts 1.2 import Nymea 1.0 ItemDelegate { id: root property var paramType: null property var value: null property int operatorType: ParamDescriptors.ValueOperatorEquals contentItem: ColumnLayout { Label { Layout.fillWidth: true text: paramType.displayName } RowLayout { Layout.fillWidth: true spacing: app.margins ComboBox { FontMetrics { id: fm } Layout.fillWidth: true Layout.minimumWidth: { var minWidth = 0; for (var i = 0; i < model.length; i++) { minWidth = Math.max(minWidth, fm.boundingRect(model[i]).width) } return minWidth + 60; } property bool isNumeric: { switch (paramType.type.toLowerCase()) { case "bool": case "string": case "qstring": case "color": return false; case "int": case "double": return true; } console.warn("ParamDescriptorDelegate: Unhandled data type:", paramType.type.toLowerCase()); return false; } model: isNumeric ? [qsTr("is"), qsTr("is not"), qsTr("is greater"), qsTr("is smaller"), qsTr("is greater or equal"), qsTr("is smaller or equal")] : [qsTr("is"), qsTr("is not")]; onCurrentTextChanged: { switch (currentText) { case qsTr("is"): root.operatorType = ParamDescriptor.ValueOperatorEquals; break; case qsTr("is not"): root.operatorType = ParamDescriptor.ValueOperatorNotEquals; break; case qsTr("is greater"): root.operatorType = ParamDescriptor.ValueOperatorGreater; break; case qsTr("is smaller"): root.operatorType = ParamDescriptor.ValueOperatorLess; break; case qsTr("is greater or equal"): root.operatorType = ParamDescriptor.ValueOperatorGreaterOrEqual; break; case qsTr("is smaller or equal"): root.operatorType = ParamDescriptor.ValueOperatorLessOrEqual; break; } print("set operator to", root.operatorType, currentText) } } Loader { id: placeHolder Layout.fillWidth: true sourceComponent: { print("Datatye is:", paramType.name, paramType.type, paramType.minValue, paramType.maxValue, paramType.allowedValues) switch (paramType.type.toLowerCase()) { case "bool": return boolComponent; case "int": case "double": if (paramType.minValue !== undefined && paramType.maxValue !== undefined) { return labelComponent; } return textFieldComponent; case "string": case "qstring": case "color": if (paramType.allowedValues.length > 0) { return comboBoxComponent } return textFieldComponent; } console.warn("ParamDescriptorDelegate: Type delegate not implemented", paramType.type) return null; } } Label { text: paramType.unitString } } Loader { Layout.fillWidth: true sourceComponent: { switch (paramType.type.toLowerCase()) { case "int": case "double": if (paramType.minValue !== undefined && paramType.maxValue !== undefined) { return sliderComponent } } } } } Component { id: labelComponent Label { text: { switch (root.paramType.type.toLowerCase()) { case "double": return Math.round(root.value * 10) / 10 } return root.value } } } Component { id: textFieldComponent TextField { text: "" onTextChanged: { root.value = text; } } } Component { id: sliderComponent RowLayout { spacing: app.margins Label { text: root.paramType.minValue } Slider { from: paramType.minValue to: paramType.maxValue stepSize: { switch (root.paramType.type.toLowerCase()) { case "double": return 0.1 } return 1 } Layout.fillWidth: true onMoved: { root.value = value; } } Label { text: root.paramType.maxValue } } } Component { id: boolComponent ComboBox { model: ListModel { ListElement { modelData: "true"; value: true } ListElement { modelData: "false"; value: false } } onCurrentIndexChanged: { root.value = model.get(currentIndex).value } } } Component { id: comboBoxComponent ComboBox { model: paramType.allowedValues onCurrentIndexChanged: { root.value = paramType.allowedValues[currentIndex] } } } }