You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

110 lines
1.8 KiB

import QtQuick 2.0
import QtQuick.Controls 1.3
import "js/InputValidator.js" as InputValidator
Item
{
id: editRoot
10 years ago
property string value
10 years ago
property string defaultValue
10 years ago
property bool readOnly: !boolCombo.enabled
property string subType
10 years ago
height: 20
width: 150
10 years ago
10 years ago
onReadOnlyChanged: {
boolCombo.enabled = !readOnly;
}
function isArray()
{
InputValidator.init()
return InputValidator.isArray(subType)
}
10 years ago
function init()
{
if (!isArray())
{
boolArray.visible = false
boolCombo.visible = true
value = format(value)
var setValue = "1"
if (value === "")
setValue = parseInt(defaultValue);
else
setValue = parseInt(value);
boolCombo.checked = setValue === "1" ? true: false
boolCombo.enabled = !readOnly;
}
else
{
boolArray.visible = true
boolCombo.visible = false
if (value === "")
boolArray.text = "[]"
else
boolArray.text = value
var formattedparam = []
var param = JSON.parse(boolArray.text)
for (var k in JSON.parse(boolArray.text))
formattedparam.push(parseInt(format(param[k])))
boolArray.text = JSON.stringify(formattedparam)
}
}
10 years ago
function finalize()
{
if (isArray())
value = boolArray.text
}
function format(value)
10 years ago
{
value = value === true ? "1" : value
value = value === false ? "0" : value;
value = value === "true" ? "1" : value
value = value === "false" ? "0" : value;
return value
10 years ago
}
Rectangle {
color: "transparent"
anchors.fill: parent
CheckBox
{
10 years ago
property bool inited;
Component.onCompleted:
{
10 years ago
init();
inited = true;
}
id: boolCombo
anchors.fill: parent
onCheckedChanged:
{
10 years ago
if (inited)
value = checked ? "1" : "0"
}
text: qsTr("True")
}
TextField
{
id: boolArray
onTextChanged:
{
value = text
}
}
}
}