|
|
@ -3,6 +3,7 @@ import QtQuick.Controls 1.1 |
|
|
|
import QtQuick.Layouts 1.1 |
|
|
|
import QtQuick.Window 2.0 |
|
|
|
import org.ethereum.qml.QEther 1.0 |
|
|
|
import "js/TransactionHelper.js" as TransactionHelper |
|
|
|
|
|
|
|
Window { |
|
|
|
id: modalTransactionDialog |
|
|
@ -18,15 +19,25 @@ Window { |
|
|
|
property alias transactionValue: valueField.value; |
|
|
|
property alias functionId: functionComboBox.currentText; |
|
|
|
property var itemParams; |
|
|
|
property bool isConstructorTransaction; |
|
|
|
property bool useTransactionDefaultValue: false |
|
|
|
|
|
|
|
signal accepted; |
|
|
|
|
|
|
|
function open(index, item) { |
|
|
|
rowFunction.visible = !useTransactionDefaultValue; |
|
|
|
rowValue.visible = !useTransactionDefaultValue; |
|
|
|
rowGas.visible = !useTransactionDefaultValue; |
|
|
|
rowGasPrice.visible = !useTransactionDefaultValue; |
|
|
|
|
|
|
|
transactionIndex = index; |
|
|
|
gasField.value = item.gas; |
|
|
|
gasPriceField.value = item.gasPrice; |
|
|
|
valueField.value = item.value; |
|
|
|
var functionId = item.functionId; |
|
|
|
isConstructorTransaction = item.executeConstructor; |
|
|
|
rowFunction.visible = !item.executeConstructor; |
|
|
|
|
|
|
|
itemParams = item.parameters !== undefined ? item.parameters : {}; |
|
|
|
functionsModel.clear(); |
|
|
|
var functionIndex = -1; |
|
|
@ -41,7 +52,17 @@ Window { |
|
|
|
functionIndex = 0; //@todo suggest unused funtion |
|
|
|
|
|
|
|
functionComboBox.currentIndex = functionIndex; |
|
|
|
loadParameters(); |
|
|
|
paramsModel.clear(); |
|
|
|
if (!item.executeConstructor) |
|
|
|
loadParameters(); |
|
|
|
else |
|
|
|
{ |
|
|
|
var parameters = codeModel.code.contract.constructor.parameters; |
|
|
|
for (var p = 0; p < parameters.length; p++) { |
|
|
|
var pname = parameters[p].name; |
|
|
|
paramsModel.append({ name: pname, type: parameters[p].type, value: itemParams[pname] !== undefined ? itemParams[pname].value() : "" }); |
|
|
|
} |
|
|
|
} |
|
|
|
visible = true; |
|
|
|
valueField.focus = true; |
|
|
|
} |
|
|
@ -49,7 +70,6 @@ Window { |
|
|
|
function loadParameters() { |
|
|
|
if (!paramsModel) |
|
|
|
return; |
|
|
|
paramsModel.clear(); |
|
|
|
if (functionComboBox.currentIndex >= 0 && functionComboBox.currentIndex < functionsModel.count) { |
|
|
|
var func = codeModel.code.contract.functions[functionComboBox.currentIndex]; |
|
|
|
var parameters = func.parameters; |
|
|
@ -67,112 +87,159 @@ Window { |
|
|
|
|
|
|
|
function getItem() |
|
|
|
{ |
|
|
|
var item = { |
|
|
|
functionId: transactionDialog.functionId, |
|
|
|
gas: transactionDialog.gas, |
|
|
|
gasPrice: transactionDialog.gasPrice, |
|
|
|
value: transactionDialog.transactionValue, |
|
|
|
parameters: {} |
|
|
|
var item; |
|
|
|
if (!useTransactionDefaultValue) |
|
|
|
{ |
|
|
|
item = { |
|
|
|
functionId: transactionDialog.functionId, |
|
|
|
gas: transactionDialog.gas, |
|
|
|
gasPrice: transactionDialog.gasPrice, |
|
|
|
value: transactionDialog.transactionValue, |
|
|
|
parameters: {}, |
|
|
|
executeConstructor: isConstructorTransaction |
|
|
|
}; |
|
|
|
} |
|
|
|
else |
|
|
|
{ |
|
|
|
item = TransactionHelper.defaultTransaction(); |
|
|
|
item.functionId = transactionDialog.functionId; |
|
|
|
item.executeConstructor = isConstructorTransaction; |
|
|
|
} |
|
|
|
|
|
|
|
if (isConstructorTransaction) |
|
|
|
item.functionId = qsTr("Constructor"); |
|
|
|
|
|
|
|
for (var p = 0; p < transactionDialog.transactionParams.count; p++) { |
|
|
|
var parameter = transactionDialog.transactionParams.get(p); |
|
|
|
var intComponent = Qt.createComponent("qrc:/qml/BigIntValue.qml"); |
|
|
|
var param = intComponent.createObject(modalTransactionDialog); |
|
|
|
|
|
|
|
param.setValue(parameter.value); |
|
|
|
item.parameters[parameter.name] = param; |
|
|
|
} |
|
|
|
return item; |
|
|
|
} |
|
|
|
|
|
|
|
GridLayout { |
|
|
|
ColumnLayout { |
|
|
|
id: dialogContent |
|
|
|
columns: 2 |
|
|
|
anchors.fill: parent |
|
|
|
width: parent.width |
|
|
|
anchors.left: parent.left |
|
|
|
anchors.right: parent.right |
|
|
|
anchors.margins: 10 |
|
|
|
rowSpacing: 10 |
|
|
|
columnSpacing: 10 |
|
|
|
|
|
|
|
Label { |
|
|
|
text: qsTr("Function") |
|
|
|
} |
|
|
|
ComboBox { |
|
|
|
id: functionComboBox |
|
|
|
spacing: 30 |
|
|
|
RowLayout |
|
|
|
{ |
|
|
|
id: rowFunction |
|
|
|
Layout.fillWidth: true |
|
|
|
currentIndex: -1 |
|
|
|
textRole: "text" |
|
|
|
editable: false |
|
|
|
model: ListModel { |
|
|
|
id: functionsModel |
|
|
|
height: 150 |
|
|
|
Label { |
|
|
|
Layout.preferredWidth: 75 |
|
|
|
text: qsTr("Function") |
|
|
|
} |
|
|
|
onCurrentIndexChanged: { |
|
|
|
loadParameters(); |
|
|
|
ComboBox { |
|
|
|
id: functionComboBox |
|
|
|
Layout.fillWidth: true |
|
|
|
currentIndex: -1 |
|
|
|
textRole: "text" |
|
|
|
editable: false |
|
|
|
model: ListModel { |
|
|
|
id: functionsModel |
|
|
|
} |
|
|
|
onCurrentIndexChanged: { |
|
|
|
loadParameters(); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
Label { |
|
|
|
text: qsTr("Value") |
|
|
|
} |
|
|
|
Rectangle |
|
|
|
|
|
|
|
RowLayout |
|
|
|
{ |
|
|
|
id: rowValue |
|
|
|
Layout.fillWidth: true |
|
|
|
Ether { |
|
|
|
id: valueField |
|
|
|
edit: true |
|
|
|
displayFormattedValue: true |
|
|
|
Label { |
|
|
|
Layout.preferredWidth: 75 |
|
|
|
text: qsTr("Value") |
|
|
|
} |
|
|
|
Rectangle |
|
|
|
{ |
|
|
|
Layout.fillWidth: true |
|
|
|
Ether { |
|
|
|
id: valueField |
|
|
|
edit: true |
|
|
|
displayFormattedValue: true |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
Label { |
|
|
|
text: qsTr("Gas") |
|
|
|
} |
|
|
|
Rectangle |
|
|
|
|
|
|
|
RowLayout |
|
|
|
{ |
|
|
|
id: rowGas |
|
|
|
Layout.fillWidth: true |
|
|
|
Ether { |
|
|
|
id: gasField |
|
|
|
edit: true |
|
|
|
displayFormattedValue: true |
|
|
|
Label { |
|
|
|
Layout.preferredWidth: 75 |
|
|
|
text: qsTr("Gas") |
|
|
|
} |
|
|
|
Rectangle |
|
|
|
{ |
|
|
|
Layout.fillWidth: true |
|
|
|
Ether { |
|
|
|
id: gasField |
|
|
|
edit: true |
|
|
|
displayFormattedValue: true |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
Label { |
|
|
|
text: qsTr("Gas Price") |
|
|
|
} |
|
|
|
Rectangle |
|
|
|
RowLayout |
|
|
|
{ |
|
|
|
id: rowGasPrice |
|
|
|
Layout.fillWidth: true |
|
|
|
Ether { |
|
|
|
id: gasPriceField |
|
|
|
edit: true |
|
|
|
displayFormattedValue: true |
|
|
|
Label { |
|
|
|
Layout.preferredWidth: 75 |
|
|
|
text: qsTr("Gas Price") |
|
|
|
} |
|
|
|
Rectangle |
|
|
|
{ |
|
|
|
Layout.fillWidth: true |
|
|
|
Ether { |
|
|
|
id: gasPriceField |
|
|
|
edit: true |
|
|
|
displayFormattedValue: true |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
Label { |
|
|
|
text: qsTr("Parameters") |
|
|
|
} |
|
|
|
TableView { |
|
|
|
model: paramsModel |
|
|
|
RowLayout |
|
|
|
{ |
|
|
|
Layout.fillWidth: true |
|
|
|
|
|
|
|
TableViewColumn { |
|
|
|
role: "name" |
|
|
|
title: "Name" |
|
|
|
width: 120 |
|
|
|
} |
|
|
|
TableViewColumn { |
|
|
|
role: "type" |
|
|
|
title: "Type" |
|
|
|
width: 120 |
|
|
|
} |
|
|
|
TableViewColumn { |
|
|
|
role: "value" |
|
|
|
title: "Value" |
|
|
|
width: 120 |
|
|
|
Label { |
|
|
|
text: qsTr("Parameters") |
|
|
|
Layout.preferredWidth: 75 |
|
|
|
} |
|
|
|
TableView { |
|
|
|
model: paramsModel |
|
|
|
Layout.fillWidth: true |
|
|
|
|
|
|
|
itemDelegate: { |
|
|
|
return editableDelegate; |
|
|
|
TableViewColumn { |
|
|
|
role: "name" |
|
|
|
title: "Name" |
|
|
|
width: 120 |
|
|
|
} |
|
|
|
TableViewColumn { |
|
|
|
role: "type" |
|
|
|
title: "Type" |
|
|
|
width: 120 |
|
|
|
} |
|
|
|
TableViewColumn { |
|
|
|
role: "value" |
|
|
|
title: "Value" |
|
|
|
width: 120 |
|
|
|
} |
|
|
|
|
|
|
|
itemDelegate: { |
|
|
|
return editableDelegate; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|