|
@ -2,15 +2,18 @@ import QtQuick 2.2 |
|
|
import QtQuick.Controls 1.1 |
|
|
import QtQuick.Controls 1.1 |
|
|
import QtQuick.Layouts 1.1 |
|
|
import QtQuick.Layouts 1.1 |
|
|
import QtQuick.Window 2.0 |
|
|
import QtQuick.Window 2.0 |
|
|
|
|
|
import QtQuick.Controls.Styles 1.3 |
|
|
import org.ethereum.qml.QEther 1.0 |
|
|
import org.ethereum.qml.QEther 1.0 |
|
|
import "js/TransactionHelper.js" as TransactionHelper |
|
|
import "js/TransactionHelper.js" as TransactionHelper |
|
|
|
|
|
import "." |
|
|
|
|
|
|
|
|
Window { |
|
|
Window { |
|
|
id: modalTransactionDialog |
|
|
id: modalTransactionDialog |
|
|
modality: Qt.WindowModal |
|
|
modality: Qt.WindowModal |
|
|
width: 640 |
|
|
width: 640 |
|
|
height:640 |
|
|
height: 700 |
|
|
visible: false |
|
|
visible: false |
|
|
|
|
|
color: StateDialogStyle.generic.backgroundColor |
|
|
|
|
|
|
|
|
property int transactionIndex |
|
|
property int transactionIndex |
|
|
property alias transactionParams: paramsModel; |
|
|
property alias transactionParams: paramsModel; |
|
@ -155,11 +158,17 @@ Window { |
|
|
return item; |
|
|
return item; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
SourceSansProRegular |
|
|
|
|
|
{ |
|
|
|
|
|
id: regularFont |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
ColumnLayout { |
|
|
ColumnLayout { |
|
|
id: dialogContent |
|
|
id: dialogContent |
|
|
width: parent.width |
|
|
width: parent.width |
|
|
anchors.left: parent.left |
|
|
anchors.left: parent.left |
|
|
anchors.right: parent.right |
|
|
anchors.right: parent.right |
|
|
|
|
|
anchors.top: parent.top |
|
|
anchors.margins: 10 |
|
|
anchors.margins: 10 |
|
|
spacing: 30 |
|
|
spacing: 30 |
|
|
RowLayout |
|
|
RowLayout |
|
@ -170,10 +179,12 @@ Window { |
|
|
Label { |
|
|
Label { |
|
|
Layout.preferredWidth: 75 |
|
|
Layout.preferredWidth: 75 |
|
|
text: qsTr("Function") |
|
|
text: qsTr("Function") |
|
|
|
|
|
font.family: regularFont.name |
|
|
|
|
|
color: "#808080" |
|
|
} |
|
|
} |
|
|
ComboBox { |
|
|
ComboBox { |
|
|
id: functionComboBox |
|
|
id: functionComboBox |
|
|
Layout.fillWidth: true |
|
|
Layout.preferredWidth: 350 |
|
|
currentIndex: -1 |
|
|
currentIndex: -1 |
|
|
textRole: "text" |
|
|
textRole: "text" |
|
|
editable: false |
|
|
editable: false |
|
@ -183,6 +194,10 @@ Window { |
|
|
onCurrentIndexChanged: { |
|
|
onCurrentIndexChanged: { |
|
|
loadParameters(); |
|
|
loadParameters(); |
|
|
} |
|
|
} |
|
|
|
|
|
style: ComboBoxStyle |
|
|
|
|
|
{ |
|
|
|
|
|
font: regularFont.name |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -191,70 +206,190 @@ Window { |
|
|
{ |
|
|
{ |
|
|
id: rowValue |
|
|
id: rowValue |
|
|
Layout.fillWidth: true |
|
|
Layout.fillWidth: true |
|
|
|
|
|
height: 150 |
|
|
Label { |
|
|
Label { |
|
|
Layout.preferredWidth: 75 |
|
|
Layout.preferredWidth: 75 |
|
|
text: qsTr("Value") |
|
|
text: qsTr("Value") |
|
|
|
|
|
font.family: regularFont.name |
|
|
|
|
|
color: "#808080" |
|
|
} |
|
|
} |
|
|
Rectangle |
|
|
|
|
|
{ |
|
|
|
|
|
Layout.fillWidth: true |
|
|
|
|
|
Ether { |
|
|
Ether { |
|
|
id: valueField |
|
|
id: valueField |
|
|
edit: true |
|
|
edit: true |
|
|
displayFormattedValue: true |
|
|
displayFormattedValue: true |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
RowLayout |
|
|
RowLayout |
|
|
{ |
|
|
{ |
|
|
id: rowGas |
|
|
id: rowGas |
|
|
Layout.fillWidth: true |
|
|
Layout.fillWidth: true |
|
|
|
|
|
height: 150 |
|
|
Label { |
|
|
Label { |
|
|
Layout.preferredWidth: 75 |
|
|
Layout.preferredWidth: 75 |
|
|
text: qsTr("Gas") |
|
|
text: qsTr("Gas") |
|
|
|
|
|
font.family: regularFont.name |
|
|
|
|
|
color: "#808080" |
|
|
} |
|
|
} |
|
|
Rectangle |
|
|
|
|
|
{ |
|
|
|
|
|
Layout.fillWidth: true |
|
|
|
|
|
Ether { |
|
|
Ether { |
|
|
id: gasField |
|
|
id: gasField |
|
|
edit: true |
|
|
edit: true |
|
|
displayFormattedValue: true |
|
|
displayFormattedValue: true |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
RowLayout |
|
|
RowLayout |
|
|
{ |
|
|
{ |
|
|
id: rowGasPrice |
|
|
id: rowGasPrice |
|
|
Layout.fillWidth: true |
|
|
Layout.fillWidth: true |
|
|
|
|
|
height: 150 |
|
|
Label { |
|
|
Label { |
|
|
Layout.preferredWidth: 75 |
|
|
Layout.preferredWidth: 75 |
|
|
text: qsTr("Gas Price") |
|
|
text: qsTr("Gas Price") |
|
|
|
|
|
font.family: regularFont.name |
|
|
|
|
|
color: "#808080" |
|
|
} |
|
|
} |
|
|
Rectangle |
|
|
|
|
|
{ |
|
|
|
|
|
Layout.fillWidth: true |
|
|
|
|
|
Ether { |
|
|
Ether { |
|
|
id: gasPriceField |
|
|
id: gasPriceField |
|
|
edit: true |
|
|
edit: true |
|
|
displayFormattedValue: true |
|
|
displayFormattedValue: true |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
//ColumnLayout |
|
|
|
|
|
//{ |
|
|
|
|
|
//Layout.fillHeight: true; |
|
|
|
|
|
//Layout.fillWidth: true; |
|
|
|
|
|
//visible: paramsModel.count > 0 |
|
|
|
|
|
|
|
|
|
|
|
Label { |
|
|
|
|
|
text: qsTr("Parameters") |
|
|
|
|
|
Layout.preferredWidth: 75 |
|
|
|
|
|
font.family: regularFont.name |
|
|
|
|
|
color: "#808080" |
|
|
|
|
|
visible: paramsModel.count > 0 |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
RowLayout |
|
|
Repeater |
|
|
|
|
|
{ |
|
|
|
|
|
model: paramsModel |
|
|
|
|
|
visible: paramsModel.count > 0 |
|
|
|
|
|
Rectangle |
|
|
{ |
|
|
{ |
|
|
|
|
|
color: "transparent" |
|
|
Layout.fillWidth: true |
|
|
Layout.fillWidth: true |
|
|
|
|
|
height: 150 |
|
|
Label { |
|
|
Label { |
|
|
text: qsTr("Parameters") |
|
|
id: typeLabel |
|
|
Layout.preferredWidth: 75 |
|
|
text: type |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Label { |
|
|
|
|
|
anchors.left: typeLabel.right |
|
|
|
|
|
id: nameLabel |
|
|
|
|
|
text: name |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Label { |
|
|
|
|
|
anchors.left: nameLabel.right |
|
|
|
|
|
id: equalLabel |
|
|
|
|
|
text: "=" |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Loader |
|
|
|
|
|
{ |
|
|
|
|
|
anchors.left: equalLabel.right |
|
|
|
|
|
id: typeLoader |
|
|
|
|
|
height: 50 |
|
|
|
|
|
width: 150 |
|
|
|
|
|
Connections { |
|
|
|
|
|
target: typeLoader.item |
|
|
|
|
|
onTextChanged: { |
|
|
|
|
|
console.log("text changed 0 " + value); |
|
|
|
|
|
value = typeLoader.item.text; |
|
|
|
|
|
console.log("text changed 1 " + value); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
sourceComponent: |
|
|
|
|
|
{ |
|
|
|
|
|
console.log(type); |
|
|
|
|
|
if (type.indexOf("int") !== -1) |
|
|
|
|
|
return intViewComp; |
|
|
|
|
|
else if (type.indexOf("bool") !== -1) |
|
|
|
|
|
return boolViewComp; |
|
|
|
|
|
else if (type.indexOf("string") !== -1) |
|
|
|
|
|
return stringViewComp; |
|
|
|
|
|
else if (type.indexOf("hash") !== -1) |
|
|
|
|
|
return hashViewComp; |
|
|
|
|
|
else |
|
|
|
|
|
return null; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Component |
|
|
|
|
|
{ |
|
|
|
|
|
id: intViewComp |
|
|
|
|
|
QIntTypeView |
|
|
|
|
|
{ |
|
|
|
|
|
height: 50 |
|
|
|
|
|
width: 150 |
|
|
|
|
|
id: intView |
|
|
|
|
|
text: value |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Component |
|
|
|
|
|
{ |
|
|
|
|
|
id: boolViewComp |
|
|
|
|
|
QBoolTypeView |
|
|
|
|
|
{ |
|
|
|
|
|
height: 50 |
|
|
|
|
|
width: 150 |
|
|
|
|
|
id: boolView |
|
|
|
|
|
defaultValue: "1" |
|
|
|
|
|
Component.onCompleted: |
|
|
|
|
|
{ |
|
|
|
|
|
/*loaderEditor.updateValue(styleData.row, styleData.role, |
|
|
|
|
|
(paramsModel.get(styleData.row).value === "" ? defaultValue : |
|
|
|
|
|
paramsModel.get(styleData.row).value)); |
|
|
|
|
|
text = (paramsModel.get(styleData.row).value === "" ? defaultValue : paramsModel.get(styleData.row).value);*/ |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Component |
|
|
|
|
|
{ |
|
|
|
|
|
id: stringViewComp |
|
|
|
|
|
QStringTypeView |
|
|
|
|
|
{ |
|
|
|
|
|
height: 50 |
|
|
|
|
|
width: 150 |
|
|
|
|
|
id: stringView |
|
|
|
|
|
text: value |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Component |
|
|
|
|
|
{ |
|
|
|
|
|
id: hashViewComp |
|
|
|
|
|
QHashTypeView |
|
|
|
|
|
{ |
|
|
|
|
|
height: 50 |
|
|
|
|
|
width: 150 |
|
|
|
|
|
id: hashView |
|
|
|
|
|
text: value |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
TableView { |
|
|
//} |
|
|
|
|
|
|
|
|
|
|
|
/*TableView { |
|
|
model: paramsModel |
|
|
model: paramsModel |
|
|
Layout.preferredWidth: 120 * 2 + 240 |
|
|
Layout.fillWidth: true |
|
|
Layout.minimumHeight: 150 |
|
|
Layout.minimumHeight: 150 |
|
|
Layout.preferredHeight: 400 |
|
|
Layout.preferredHeight: 400 |
|
|
Layout.maximumHeight: 600 |
|
|
Layout.maximumHeight: 600 |
|
@ -276,8 +411,7 @@ Window { |
|
|
|
|
|
|
|
|
rowDelegate: rowDelegate |
|
|
rowDelegate: rowDelegate |
|
|
itemDelegate: editableDelegate |
|
|
itemDelegate: editableDelegate |
|
|
} |
|
|
}*/ |
|
|
} |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
RowLayout |
|
|
RowLayout |
|
@ -332,6 +466,7 @@ Window { |
|
|
|
|
|
|
|
|
sourceComponent: |
|
|
sourceComponent: |
|
|
{ |
|
|
{ |
|
|
|
|
|
console.log("role " + styleData.role); |
|
|
if (styleData.role === "value") |
|
|
if (styleData.role === "value") |
|
|
{ |
|
|
{ |
|
|
if (paramsModel.get(styleData.row) === undefined) |
|
|
if (paramsModel.get(styleData.row) === undefined) |
|
@ -349,53 +484,7 @@ Window { |
|
|
return editor; |
|
|
return editor; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
Component |
|
|
|
|
|
{ |
|
|
|
|
|
id: intViewComp |
|
|
|
|
|
QIntTypeView |
|
|
|
|
|
{ |
|
|
|
|
|
id: intView |
|
|
|
|
|
text: styleData.value |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Component |
|
|
|
|
|
{ |
|
|
|
|
|
id: boolViewComp |
|
|
|
|
|
QBoolTypeView |
|
|
|
|
|
{ |
|
|
|
|
|
id: boolView |
|
|
|
|
|
defaultValue: "1" |
|
|
|
|
|
Component.onCompleted: |
|
|
|
|
|
{ |
|
|
|
|
|
loaderEditor.updateValue(styleData.row, styleData.role, |
|
|
|
|
|
(paramsModel.get(styleData.row).value === "" ? defaultValue : |
|
|
|
|
|
paramsModel.get(styleData.row).value)); |
|
|
|
|
|
text = (paramsModel.get(styleData.row).value === "" ? defaultValue : paramsModel.get(styleData.row).value); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Component |
|
|
|
|
|
{ |
|
|
|
|
|
id: stringViewComp |
|
|
|
|
|
QStringTypeView |
|
|
|
|
|
{ |
|
|
|
|
|
id: stringView |
|
|
|
|
|
text: styleData.value |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Component |
|
|
|
|
|
{ |
|
|
|
|
|
id: hashViewComp |
|
|
|
|
|
QHashTypeView |
|
|
|
|
|
{ |
|
|
|
|
|
id: hashView |
|
|
|
|
|
text: styleData.value |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Component { |
|
|
Component { |
|
|
id: editor |
|
|
id: editor |
|
@ -404,12 +493,7 @@ Window { |
|
|
readOnly: true |
|
|
readOnly: true |
|
|
color: styleData.textColor |
|
|
color: styleData.textColor |
|
|
text: styleData.value |
|
|
text: styleData.value |
|
|
MouseArea { |
|
|
font.family: regularFont.name |
|
|
id: mouseArea |
|
|
|
|
|
anchors.fill: parent |
|
|
|
|
|
hoverEnabled: true |
|
|
|
|
|
onClicked: textinput.forceActiveFocus() |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|