Browse Source

TransactionDialog redesign

cl-refactor
yann300 10 years ago
parent
commit
baf7128719
  1. 18
      mix/qml/Block.qml
  2. 25
      mix/qml/QAddressView.qml
  3. 53
      mix/qml/StructView.qml
  4. 604
      mix/qml/TransactionDialog.qml

18
mix/qml/Block.qml

@ -243,7 +243,6 @@ ColumnLayout
} }
} }
Rectangle Rectangle
{ {
Layout.preferredWidth: toWidth Layout.preferredWidth: toWidth
@ -266,8 +265,6 @@ ColumnLayout
} }
} }
function userFrienldyToken(value) function userFrienldyToken(value)
{ {
if (value && value.indexOf("<") === 0) if (value && value.indexOf("<") === 0)
@ -293,7 +290,7 @@ ColumnLayout
color: labelColor color: labelColor
font.bold: true font.bold: true
font.pointSize: dbgStyle.absoluteSize(1) font.pointSize: dbgStyle.absoluteSize(1)
width: parent.width -30 width: parent.width - 30
text: { text: {
if (index >= 0 && transactions.get(index).returned) if (index >= 0 && transactions.get(index).returned)
return transactions.get(index).returned return transactions.get(index).returned
@ -402,18 +399,5 @@ ColumnLayout
} }
} }
} }
Rectangle
{
id: right
Layout.preferredWidth: blockWidth
height: 10
anchors.top: parent.bottom
anchors.topMargin: 5
color: "#DEDCDC"
radius: 15
anchors.left: parent.left
anchors.leftMargin: statusWidth
}
} }

25
mix/qml/QAddressView.qml

@ -2,14 +2,14 @@ import QtQuick 2.0
import QtQuick.Controls 1.3 import QtQuick.Controls 1.3
import QtQuick.Controls.Styles 1.3 import QtQuick.Controls.Styles 1.3
Item Row
{ {
property alias value: textinput.text property alias value: textinput.text
property alias accountRef: ctrModel property alias accountRef: ctrModel
property string subType property string subType
property bool readOnly property bool readOnly
property alias currentIndex: trCombobox.currentIndex property alias currentIndex: trCombobox.currentIndex
property alias currentText: textinput.text property alias displayInput: textInputRect.visible
property variant accounts property variant accounts
signal indexChanged() signal indexChanged()
id: editRoot id: editRoot
@ -22,7 +22,7 @@ Item
} }
function currentValue() { function currentValue() {
return currentText; return value;
} }
function currentType() function currentType()
@ -38,7 +38,6 @@ Item
function load() function load()
{ {
accountRef.clear(); accountRef.clear();
accountRef.append({"itemid": " - "});
if (subType === "contract" || subType === "address") if (subType === "contract" || subType === "address")
{ {
var trCr = 0; var trCr = 0;
@ -52,7 +51,7 @@ Item
if (i > transactionIndex) if (i > transactionIndex)
break; break;
var tr = blockChainPanel.model.blocks[k].transactions[i] var tr = blockChainPanel.model.blocks[k].transactions[i]
if (tr.functionId === tr.contractId /*&& (dec[1] === tr.contractId || item.subType === "address")*/) if (tr.functionId === tr.contractId)
{ {
accountRef.append({ "itemid": tr.contractId + " - " + trCr, "value": "<" + tr.contractId + " - " + trCr + ">", "type": "contract" }); accountRef.append({ "itemid": tr.contractId + " - " + trCr, "value": "<" + tr.contractId + " - " + trCr + ">", "type": "contract" });
trCr++; trCr++;
@ -87,6 +86,7 @@ Item
} }
trCombobox.currentIndex = 0; trCombobox.currentIndex = 0;
} }
trCombobox.update()
} }
function select(address) function select(address)
@ -102,10 +102,11 @@ Item
} }
Rectangle { Rectangle {
anchors.fill: parent //anchors.fill: parent
radius: 4 radius: 4
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
height: 20 height: 20
id: textInputRect
TextInput { TextInput {
id: textinput id: textinput
text: value text: value
@ -141,12 +142,12 @@ Item
property bool selected: false property bool selected: false
id: trCombobox id: trCombobox
model: ctrModel model: ctrModel
width: 350
textRole: "itemid" textRole: "itemid"
height: 20
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
anchors.left: textinput.parent.right
anchors.leftMargin: 3 function update()
onCurrentIndexChanged: { {
trCombobox.selected = false; trCombobox.selected = false;
if (currentText === "") if (currentText === "")
return; return;
@ -164,5 +165,9 @@ Item
} }
indexChanged(); indexChanged();
} }
onCurrentIndexChanged: {
update()
}
} }
} }

53
mix/qml/StructView.qml

@ -13,51 +13,38 @@ Column
property int transactionIndex property int transactionIndex
property string context property string context
Layout.fillWidth: true Layout.fillWidth: true
spacing: 0 spacing: 5
DebuggerPaneStyle {
id: dbgStyle
}
Repeater Repeater
{ {
id: repeater id: repeater
visible: model.length > 0 visible: model.length > 0
Layout.fillWidth: true //height: parent.height
RowLayout RowLayout
{ {
id: row id: row
height: 20 + (members[index].type.category === QSolidityType.Struct ? (20 * members[index].type.members.length) : 0) height: 20 + (members[index].type.category === QSolidityType.Struct ? (20 * members[index].type.members.length) : 0)
Layout.fillWidth: true Layout.fillWidth: true
DefaultLabel { Rectangle
height: 20 {
id: typeLabel Layout.preferredWidth: 150
text: modelData.type.name Row
anchors.verticalCenter: parent.verticalCenter {
font.family: dbgStyle.general.basicFont anchors.right: parent.right
color: dbgStyle.general.basicColor anchors.verticalCenter: parent.verticalCenter
font.pointSize: dbgStyle.general.basicFontSize Label {
} height: 20
id: nameLabel
DefaultLabel { text: modelData.name
height: 20 }
id: nameLabel
text: modelData.name
anchors.verticalCenter: parent.verticalCenter
font.family: dbgStyle.general.basicFont
color: dbgStyle.general.basicColor
font.pointSize: dbgStyle.general.basicFontSize
}
DefaultLabel { Label {
height: 20 height: 20
id: equalLabel id: typeLabel
text: "=" text: "(" + modelData.type.name + ")"
anchors.verticalCenter: parent.verticalCenter }
font.family: dbgStyle.general.basicFont }
color: dbgStyle.general.basicColor
font.pointSize: dbgStyle.general.basicFontSize
} }
Loader Loader

604
mix/qml/TransactionDialog.qml

@ -12,8 +12,8 @@ import "."
Dialog { Dialog {
id: modalTransactionDialog id: modalTransactionDialog
modality: Qt.ApplicationModal modality: Qt.ApplicationModal
width: 570 width: 630
height: 500 height: 550
visible: false visible: false
title: qsTr("Edit Transaction") title: qsTr("Edit Transaction")
property int transactionIndex property int transactionIndex
@ -22,7 +22,7 @@ Dialog {
property alias gasAuto: gasAutoCheck.checked; property alias gasAuto: gasAutoCheck.checked;
property alias gasPrice: gasPriceField.value; property alias gasPrice: gasPriceField.value;
property alias transactionValue: valueField.value; property alias transactionValue: valueField.value;
property string contractId: contractComboBox.currentValue(); property string contractId: contractCreationComboBox.currentValue();
property alias functionId: functionComboBox.currentText; property alias functionId: functionComboBox.currentText;
property var paramValues; property var paramValues;
property var paramsModel: []; property var paramsModel: [];
@ -36,11 +36,6 @@ Dialog {
} }
function open(index, blockIdx, item) { function open(index, blockIdx, item) {
rowFunction.visible = !useTransactionDefaultValue;
rowValue.visible = !useTransactionDefaultValue;
rowGas.visible = !useTransactionDefaultValue;
rowGasPrice.visible = !useTransactionDefaultValue;
transactionIndex = index transactionIndex = index
blockIndex = blockIdx blockIndex = blockIdx
typeLoader.transactionIndex = index typeLoader.transactionIndex = index
@ -52,48 +47,19 @@ Dialog {
valueField.value = item.value; valueField.value = item.value;
var contractId = item.contractId; var contractId = item.contractId;
var functionId = item.functionId; var functionId = item.functionId;
rowFunction.visible = true;
paramValues = item.parameters !== undefined ? item.parameters : {}; paramValues = item.parameters !== undefined ? item.parameters : {};
if (item.sender) if (item.sender)
senderComboBox.select(item.sender); senderComboBox.select(item.sender);
contractsModel.clear();
var contractIndex = -1;
var contracts = codeModel.contracts;
for (var c in contracts) {
contractsModel.append({ cid: c, text: contracts[c].contract.name });
if (contracts[c].contract.name === contractId)
contractIndex = contractsModel.count - 1;
}
if (contractIndex == -1 && contractsModel.count > 0)
contractIndex = 0; //@todo suggest unused contract
contractComboBox.currentIndex = contractIndex;
recipients.accounts = senderComboBox.model;
recipients.subType = "address";
recipients.load();
recipients.init();
recipients.select(contractId);
if (item.isContractCreation) trTypeCreate.checked = item.isContractCreation
loadFunctions(contractComboBox.currentValue()); trTypeSend.checked = !item.isFunctionCall
else trTypeExecute.checked = item.isFunctionCall && !item.isContractCreation
loadFunctions(contractFromToken(recipients.currentValue()))
selectFunction(functionId);
trType.checked = item.isContractCreation load(item.isContractCreation, item.isFunctionCall, functionId, contractId)
trType.init();
paramsModel = [];
if (item.isContractCreation)
loadCtorParameters();
else
loadParameters();
visible = true; visible = true;
valueField.focus = true;
} }
function loadCtorParameters(contractId) function loadCtorParameters(contractId)
@ -111,12 +77,12 @@ Dialog {
function loadFunctions(contractId) function loadFunctions(contractId)
{ {
functionsModel.clear(); functionsModel.clear();
functionsModel.append({ text: " - " });
var contract = codeModel.contracts[contractId]; var contract = codeModel.contracts[contractId];
if (contract) { if (contract) {
var functions = codeModel.contracts[contractId].contract.functions; var functions = codeModel.contracts[contractId].contract.functions;
for (var f = 0; f < functions.length; f++) { for (var f = 0; f < functions.length; f++) {
functionsModel.append({ text: functions[f].name }); if (functions[f].name !== contractId)
functionsModel.append({ text: functions[f].name });
} }
} }
} }
@ -156,9 +122,9 @@ Dialog {
function loadParameters() { function loadParameters() {
paramsModel = [] paramsModel = []
if (functionComboBox.currentIndex >= 0 && functionComboBox.currentIndex < functionsModel.count) { if (functionComboBox.currentIndex >= 0 && functionComboBox.currentIndex < functionsModel.count) {
var contract = codeModel.contracts[contractFromToken(recipients.currentValue())]; var contract = codeModel.contracts[contractFromToken(contractCreationComboBox.currentValue())];
if (contract) { if (contract) {
var func = contract.contract.functions[functionComboBox.currentIndex - 1]; var func = contract.contract.functions[functionComboBox.currentIndex + 1];
if (func) { if (func) {
var parameters = func.parameters; var parameters = func.parameters;
for (var p = 0; p < parameters.length; p++) for (var p = 0; p < parameters.length; p++)
@ -175,9 +141,7 @@ Dialog {
typeLoader.members = [] typeLoader.members = []
typeLoader.value = paramValues; typeLoader.value = paramValues;
typeLoader.members = paramsModel; typeLoader.members = paramsModel;
paramLabel.visible = paramsModel.length > 0; paramScroll.updateView()
paramScroll.visible = paramsModel.length > 0;
modalTransactionDialog.height = (paramsModel.length > 0 ? 500 : 300);
} }
function acceptAndClose() function acceptAndClose()
@ -213,16 +177,16 @@ Dialog {
item.functionId = transactionDialog.functionId; item.functionId = transactionDialog.functionId;
} }
item.isContractCreation = trType.checked; item.isContractCreation = trTypeCreate.checked;
if (item.isContractCreation) if (item.isContractCreation)
item.functionId = item.contractId; item.functionId = item.contractId;
item.isFunctionCall = item.functionId !== " - "; item.isFunctionCall = trTypeExecute.checked
if (!item.isContractCreation) if (!item.isContractCreation)
{ {
item.contractId = recipients.currentText; item.contractId = recipientsAccount.currentValue();
item.label = item.contractId + " " + item.functionId; item.label = contractFromToken(item.contractId) + "." + item.functionId + "()";
if (recipients.current().type === "address") if (recipientsAccount.current().type === "address")
{ {
item.functionId = ""; item.functionId = "";
item.isFunctionCall = false; item.isFunctionCall = false;
@ -230,8 +194,9 @@ Dialog {
} }
else else
{ {
item.isFunctionCall = true
item.functionId = item.contractId; item.functionId = item.contractId;
item.label = qsTr("Deploy") + " " + item.contractId; item.label = item.contractId + "." + item.contractId + "()";
} }
item.saveStatus = saveStatus item.saveStatus = saveStatus
item.sender = senderComboBox.model[senderComboBox.currentIndex].secret; item.sender = senderComboBox.model[senderComboBox.currentIndex].secret;
@ -246,269 +211,392 @@ Dialog {
return token; return token;
} }
function load(isContractCreation, isFunctionCall, functionId, contractId)
{
if (!isContractCreation)
{
contractCreationComboBox.visible = false
recipientsAccount.visible = true
recipientsAccount.accounts = senderComboBox.model;
amountLabel.text = qsTr("Amount")
if (!isFunctionCall)
recipientsAccount.subType = "address"
else
recipientsAccount.subType = "contract";
recipientsAccount.load();
recipientsAccount.init();
if (contractId)
recipientsAccount.select(contractId);
if (functionId)
selectFunction(functionId);
if (isFunctionCall)
{
labelRecipient.text = qsTr("Recipient Contract")
functionRect.show()
loadFunctions(contractFromToken(recipientsAccount.currentValue()))
loadParameters();
paramScroll.updateView()
}
else
{
paramsModel = []
paramScroll.updateView()
labelRecipient.text = qsTr("Recipient Account")
functionRect.hide()
}
}
else
{
//contract creation
contractsModel.clear();
var contractIndex = -1;
var contracts = codeModel.contracts;
for (var c in contracts) {
contractsModel.append({ cid: c, text: contracts[c].contract.name });
if (contracts[c].contract.name === contractId)
contractIndex = contractsModel.count - 1;
}
if (contractIndex == -1 && contractsModel.count > 0)
contractIndex = 0; //@todo suggest unused contract
contractCreationComboBox.currentIndex = contractIndex;
contractCreationComboBox.visible = true
labelRecipient.text = qsTr("Contract")
amountLabel.text = qsTr("Endownment")
functionRect.hide()
recipientsAccount.visible = false
loadCtorParameters(contractCreationComboBox.currentValue());
paramScroll.updateView()
}
}
contentItem: Rectangle { contentItem: Rectangle {
color: transactionDialogStyle.generic.backgroundColor color: transactionDialogStyle.generic.backgroundColor
anchors.fill: parent
ColumnLayout { ColumnLayout {
anchors.fill: parent width: modalTransactionDialog.width - 30
ColumnLayout { anchors.horizontalCenter: parent.horizontalCenter
anchors.fill: parent anchors.top: parent.top
anchors.margins: 10 anchors.topMargin: 20
ColumnLayout {
id: dialogContent
anchors.top: parent.top
spacing: 10
RowLayout
{
id: rowSender
Layout.fillWidth: true
height: 150
DefaultLabel {
Layout.preferredWidth: 75
text: qsTr("Sender")
}
ComboBox {
function select(secret) RowLayout
{ {
for (var i in model) Layout.fillWidth: true
if (model[i].secret === secret) Rectangle
{ {
currentIndex = i; Layout.preferredWidth: 150
break; Label {
} anchors.right: parent.right
} anchors.verticalCenter: parent.verticalCenter
text: qsTr("Sender Account")
id: senderComboBox
Layout.preferredWidth: 350
currentIndex: 0
textRole: "name"
editable: false
}
} }
}
RowLayout ComboBox {
function select(secret)
{ {
id: rowIsContract for (var i in model)
Layout.fillWidth: true if (model[i].secret === secret)
height: 150
CheckBox {
id: trType
onCheckedChanged:
{
init();
}
function init()
{ {
rowFunction.visible = !checked; currentIndex = i;
rowContract.visible = checked; break;
rowRecipient.visible = !checked;
paramLabel.visible = checked;
paramScroll.visible = checked;
functionComboBox.enabled = !checked;
if (checked)
loadCtorParameters(contractComboBox.currentValue());
} }
text: qsTr("is contract creation")
checked: true
}
} }
Layout.preferredWidth: 350
id: senderComboBox
currentIndex: 0
textRole: "name"
editable: false
}
}
RowLayout RowLayout
{
Layout.fillWidth: true
Rectangle
{
Layout.preferredWidth: 150
Layout.preferredHeight: 80
color: "transparent"
Label
{ {
id: rowRecipient anchors.verticalCenter: parent.verticalCenter
Layout.fillWidth: true anchors.top: parent.top
height: 150 anchors.right: parent.right
DefaultLabel { text: qsTr("Type of Transaction")
Layout.preferredWidth: 75 }
text: qsTr("Recipient") }
}
QAddressView Column
{ {
id: recipients Layout.preferredWidth: 150
onIndexChanged: Layout.preferredHeight: 90
ExclusiveGroup {
id: rbbuttonList
onCurrentChanged: {
if (current)
{ {
rowFunction.visible = current().type === "contract"; if (current.objectName === "trTypeSend")
paramLabel.visible = current().type === "contract"; {
paramScroll.visible = current().type === "contract"; recipientsAccount.visible = true
if (!rowIsContract.checked) contractCreationComboBox.visible = false
loadFunctions(contractFromToken(recipients.currentValue())) modalTransactionDialog.load(false, false)
}
else if (current.objectName === "trTypeCreate")
{
contractCreationComboBox.visible = true
recipientsAccount.visible = false
modalTransactionDialog.load(true, true)
}
else if (current.objectName === "trTypeExecute")
{
recipientsAccount.visible = true
contractCreationComboBox.visible = false
modalTransactionDialog.load(false, true)
}
} }
} }
} }
RowLayout RadioButton {
{ id: trTypeSend
id: rowContract objectName: "trTypeSend"
Layout.fillWidth: true exclusiveGroup: rbbuttonList
height: 150 height: 30
DefaultLabel { text: qsTr("Send ether to account")
Layout.preferredWidth: 75
text: qsTr("Contract")
}
ComboBox {
id: contractComboBox
function currentValue() {
return (currentIndex >=0 && currentIndex < contractsModel.count) ? contractsModel.get(currentIndex).cid : "";
}
Layout.preferredWidth: 350
currentIndex: -1
textRole: "text"
editable: false
model: ListModel {
id: contractsModel
}
onCurrentIndexChanged: {
loadCtorParameters(currentValue());
}
}
} }
RowLayout RadioButton {
{ id: trTypeCreate
id: rowFunction objectName: "trTypeCreate"
Layout.fillWidth: true exclusiveGroup: rbbuttonList
height: 150 height: 30
DefaultLabel { text: qsTr("Create Contract")
Layout.preferredWidth: 75
text: qsTr("Function")
}
ComboBox {
id: functionComboBox
Layout.preferredWidth: 350
currentIndex: -1
textRole: "text"
editable: false
model: ListModel {
id: functionsModel
}
onCurrentIndexChanged: {
loadParameters();
}
}
} }
CommonSeparator RadioButton {
{ id: trTypeExecute
Layout.fillWidth: true objectName: "trTypeExecute"
exclusiveGroup: rbbuttonList
height: 30
text: qsTr("Execute Contract")
}
}
}
RowLayout
{
Layout.fillWidth: true
Rectangle
{
Layout.preferredWidth: 150
Label {
id: labelRecipient
anchors.verticalCenter: parent.verticalCenter
anchors.right: parent.right
text: qsTr("Recipient Account")
} }
}
RowLayout QAddressView
{
id: recipientsAccount
displayInput: false
onIndexChanged:
{ {
id: rowValue if (rbbuttonList.current.objectName === "trTypeExecute")
Layout.fillWidth: true loadFunctions(contractFromToken(currentValue()))
height: 150 }
DefaultLabel { }
Layout.preferredWidth: 75
text: qsTr("Value") ComboBox {
} id: contractCreationComboBox
Ether { function currentValue() {
id: valueField return (currentIndex >=0 && currentIndex < contractsModel.count) ? contractsModel.get(currentIndex).cid : "";
edit: true }
displayFormattedValue: true Layout.preferredWidth: 350
} currentIndex: -1
textRole: "text"
editable: false
model: ListModel {
id: contractsModel
} }
onCurrentIndexChanged: {
loadCtorParameters(currentValue());
}
}
}
RowLayout
{
Layout.fillWidth: true
Rectangle
{
Layout.preferredWidth: 150
id: functionRect
CommonSeparator function hide()
{ {
Layout.fillWidth: true functionRect.visible = false
functionComboBox.visible = false
} }
RowLayout function show()
{ {
id: rowGas functionRect.visible = true
Layout.fillWidth: true functionComboBox.visible = true
height: 150 }
DefaultLabel {
Layout.preferredWidth: 75
text: qsTr("Gas")
}
DefaultTextField Label {
{ anchors.verticalCenter: parent.verticalCenter
property variant gasValue anchors.right: parent.right
onGasValueChanged: text = gasValue.value(); text: qsTr("Function")
onTextChanged: gasValue.setValue(text); }
implicitWidth: 200 }
enabled: !gasAutoCheck.checked
id: gasValueEdit;
}
CheckBox ComboBox {
{ id: functionComboBox
id: gasAutoCheck Layout.preferredWidth: 350
checked: true currentIndex: -1
text: qsTr("Auto"); textRole: "text"
} editable: false
model: ListModel {
id: functionsModel
} }
onCurrentIndexChanged: {
loadParameters();
}
}
}
CommonSeparator RowLayout
{
Layout.fillWidth: true
ScrollView
{
id: paramScroll
anchors.topMargin: 10
Layout.fillWidth: true
function updateView()
{ {
Layout.fillWidth: true paramScroll.height = paramsModel.length < 4 ? paramsModel.length * 20 : 145
paramScroll.parent.Layout.preferredHeight = paramsModel.length < 4 ? paramsModel.length * 20 : 145
paramScroll.visible = paramsModel.length !== 0
} }
RowLayout StructView
{ {
id: rowGasPrice id: typeLoader
Layout.fillWidth: true Layout.preferredWidth: 500
height: 150 members: paramsModel;
DefaultLabel { accounts: senderComboBox.model
Layout.preferredWidth: 75 context: "parameter"
text: qsTr("Gas Price")
}
Ether {
id: gasPriceField
edit: true
displayFormattedValue: true
}
} }
}
}
CommonSeparator RowLayout
{ {
Layout.fillWidth: true Layout.fillWidth: true
Rectangle
{
Layout.preferredWidth: 150
Label {
id: amountLabel
anchors.verticalCenter: parent.verticalCenter
anchors.right: parent.right
text: qsTr("Amount")
} }
}
Ether {
id: valueField
edit: true
displayFormattedValue: true
}
}
Rectangle
{
color: "#cccccc"
height: 1
Layout.fillWidth: true
}
Rectangle
{
width: parent.width
height: 20
color: "transparent"
Label {
text: qsTr("Transaction fees")
anchors.horizontalCenter: parent.horizontalCenter
}
}
DefaultLabel { RowLayout
id: paramLabel {
text: qsTr("Parameters:") Layout.fillWidth: true
Layout.preferredWidth: 75 Rectangle
{
Layout.preferredWidth: 150
Label {
anchors.verticalCenter: parent.verticalCenter
anchors.right: parent.right
text: qsTr("Gas")
} }
}
ScrollView Row
{
DefaultTextField
{ {
id: paramScroll property variant gasValue
anchors.top: paramLabel.bottom onGasValueChanged: text = gasValue.value();
anchors.topMargin: 10 onTextChanged: gasValue.setValue(text);
Layout.fillWidth: true implicitWidth: 200
Layout.fillHeight: true enabled: !gasAutoCheck.checked
StructView id: gasValueEdit;
{
id: typeLoader
Layout.preferredWidth: 150
members: paramsModel;
accounts: senderComboBox.model
context: "parameter"
}
} }
CommonSeparator CheckBox
{ {
Layout.fillWidth: true id: gasAutoCheck
visible: paramsModel.length > 0 checked: true
text: qsTr("Auto");
} }
} }
} }
RowLayout
{
Layout.fillWidth: true
Rectangle
{
Layout.preferredWidth: 150
Label {
anchors.verticalCenter: parent.verticalCenter
anchors.right: parent.right
text: qsTr("Gas Price")
}
}
Ether {
id: gasPriceField
edit: true
displayFormattedValue: true
}
}
RowLayout RowLayout
{ {
anchors.bottom: parent.bottom anchors.bottom: parent.bottom
anchors.right: parent.right; anchors.right: parent.right;
Button { Button {
text: qsTr("OK"); text: qsTr("OK");
onClicked: { onClicked: {
var invalid = InputValidator.validate(paramsModel, paramValues); var invalid = InputValidator.validate(paramsModel, paramValues);

Loading…
Cancel
Save