import QtQuick 2.2 import QtQuick.Controls 1.1 import QtQuick.Controls.Styles 1.1 import QtQuick.Dialogs 1.1 import QtQuick.Layouts 1.1 import Qt.labs.settings 1.0 import org.ethereum.qml.QEther 1.0 import "js/Debugger.js" as Debugger import "js/ErrorLocationFormater.js" as ErrorLocationFormater import "js/TransactionHelper.js" as TransactionHelper import "js/QEtherHelper.js" as QEtherHelper import "." Rectangle { color: selectedBlockColor property variant tx property variant currentState property variant bc property var blockIndex property var txIndex property string selectedBlockColor: "#accbf2" property string selectedBlockForeground: "#445e7f" function clear() { from.text = "" to.text = "" value.text = "" inputParams.clear() returnParams.clear() accounts.clear() events.clear() } function addAccount(address, amount) { accounts.add(address, amount) } function updateWidthTx(_tx, _state, _blockIndex, _txIndex) { from.text = clientModel.resolveAddress(_tx.sender) to.text = _tx.label value.text = _tx.value.format() tx = _tx blockIndex = _blockIndex txIndex = _txIndex currentState = _state inputParams.init() if (_tx.isContractCreation) { returnParams.role = "creationAddr" returnParams._data = { creationAddr : { } } returnParams._data.creationAddr[qsTr("contract address")] = _tx.returned } else { returnParams.role = "returnParameters" returnParams._data = tx } returnParams.init() accounts.init() events.init() } Column { anchors.fill: parent spacing: 15 Rectangle { height: 15 width: parent.width - 30 color: "transparent" Row { id: rowHeader anchors.horizontalCenter: parent.horizontalCenter anchors.top: rowHeader.parent.top anchors.topMargin: 6 spacing: 5 Label { id: fromLabel text: qsTr("from") visible: false color: selectedBlockForeground } Label { id: from color: selectedBlockForeground elide: Text.ElideRight maximumLineCount: 1 clip: true width: 200 } Label { id: toLabel text: qsTr("to") visible: false color: selectedBlockForeground } Label { id: to color: selectedBlockForeground elide: Text.ElideRight maximumLineCount: 1 clip: true width: 100 } Label { id: value color: selectedBlockForeground font.italic: true clip: true } } Image { anchors.right: rowHeader.parent.right anchors.top: rowHeader.parent.top anchors.topMargin: 5 source: "qrc:/qml/img/edit_combox.png" height: 15 fillMode: Image.PreserveAspectFit visible: from.text !== "" MouseArea { anchors.fill: parent onClicked: { bc.blockChainRepeater.editTx(blockIndex, txIndex) } } } } Rectangle { height: 1 width: parent.width - 30 anchors.horizontalCenter: parent.horizontalCenter border.color: "#cccccc" border.width: 1 } KeyValuePanel { height: 150 width: parent.width - 30 anchors.horizontalCenter: parent.horizontalCenter id: inputParams title: qsTr("INPUT PARAMETERS") role: "parameters" _data: tx } KeyValuePanel { height: 150 width: parent.width - 30 anchors.horizontalCenter: parent.horizontalCenter id: returnParams title: qsTr("RETURN PARAMETERS") role: "returnParameters" _data: tx } KeyValuePanel { height: 150 width: parent.width - 30 anchors.horizontalCenter: parent.horizontalCenter id: accounts title: qsTr("ACCOUNTS") role: "accounts" _data: currentState } KeyValuePanel { height: 150 width: parent.width - 30 anchors.horizontalCenter: parent.horizontalCenter id: events title: qsTr("EVENTS") function computeData() { model.clear() var ret = [] for (var k in tx.logs) { var param = "" for (var p in tx.logs[k].param) { param += " " + tx.logs[k].param[p].value + " " } param = "(" + param + ")" model.append({ "key": tx.logs[k].name, "value": param }) } } } } }