Arkadiy Paronyan
10 years ago
14 changed files with 655 additions and 220 deletions
@ -0,0 +1,134 @@ |
|||||
|
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 "." |
||||
|
|
||||
|
ColumnLayout { |
||||
|
id: root |
||||
|
property alias title: titleLabel.text |
||||
|
property variant _data |
||||
|
property string role |
||||
|
property alias model: modelKeyValue |
||||
|
|
||||
|
function add(key, value) |
||||
|
{ |
||||
|
modelKeyValue.append({ "key": key, "value": value }) |
||||
|
} |
||||
|
|
||||
|
function clear() |
||||
|
{ |
||||
|
modelKeyValue.clear() |
||||
|
} |
||||
|
|
||||
|
function init() |
||||
|
{ |
||||
|
modelKeyValue.clear() |
||||
|
if (typeof(computeData) !== "undefined" && computeData instanceof Function) |
||||
|
computeData() |
||||
|
else |
||||
|
{ |
||||
|
if (_data !== undefined && _data[role] !== undefined) |
||||
|
{ |
||||
|
var keys = Object.keys(_data[role]) |
||||
|
for (var k in keys) |
||||
|
{ |
||||
|
modelKeyValue.append({ "key": keys[k] === "" ? "undefined" : keys[k], "value": _data[role][keys[k]] }) |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
RowLayout |
||||
|
{ |
||||
|
Layout.preferredHeight: 20 |
||||
|
Layout.fillWidth: true |
||||
|
Label |
||||
|
{ |
||||
|
id: titleLabel |
||||
|
anchors.left: parent.left |
||||
|
anchors.verticalCenter: parent.verticalCenter |
||||
|
color: "white" |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
RowLayout |
||||
|
{ |
||||
|
Layout.fillWidth: true |
||||
|
Layout.preferredHeight: 100 |
||||
|
ListModel |
||||
|
{ |
||||
|
id: modelKeyValue |
||||
|
} |
||||
|
|
||||
|
Rectangle |
||||
|
{ |
||||
|
Layout.fillWidth: true |
||||
|
Layout.fillHeight: true |
||||
|
color: "white" |
||||
|
radius: 2 |
||||
|
ScrollView |
||||
|
{ |
||||
|
id: columnValues |
||||
|
horizontalScrollBarPolicy: Qt.ScrollBarAlwaysOff |
||||
|
anchors.fill: parent |
||||
|
clip: true |
||||
|
ColumnLayout |
||||
|
{ |
||||
|
anchors.margins: 10 |
||||
|
Repeater |
||||
|
{ |
||||
|
id: repeaterKeyValue |
||||
|
model: modelKeyValue |
||||
|
RowLayout |
||||
|
{ |
||||
|
Layout.fillWidth: true |
||||
|
Layout.preferredHeight: 30 |
||||
|
spacing: 0 |
||||
|
Rectangle |
||||
|
{ |
||||
|
Layout.preferredWidth: columnValues.width / 2 |
||||
|
Label |
||||
|
{ |
||||
|
anchors.left: parent.left |
||||
|
anchors.leftMargin: 10 |
||||
|
text: { |
||||
|
if (index >= 0 && repeaterKeyValue.model.get(index).key !== undefined) |
||||
|
return repeaterKeyValue.model.get(index).key |
||||
|
else |
||||
|
return "" |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
Rectangle |
||||
|
{ |
||||
|
Layout.preferredWidth: columnValues.width / 2 - 10 |
||||
|
Label |
||||
|
{ |
||||
|
anchors.right: parent.right |
||||
|
anchors.rightMargin: 10 |
||||
|
text: { |
||||
|
if (index >= 0 && repeaterKeyValue.model.get(index).value !== undefined) |
||||
|
return repeaterKeyValue.model.get(index).value |
||||
|
else |
||||
|
return "" |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
@ -0,0 +1,203 @@ |
|||||
|
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: "#4F4F4F" |
||||
|
radius: 4 |
||||
|
property variant tx |
||||
|
property variant currentState |
||||
|
property variant bc |
||||
|
property var blockIndex |
||||
|
property var txIndex |
||||
|
|
||||
|
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: from.text !== "" |
||||
|
color: "#EAB920" |
||||
|
} |
||||
|
Label { |
||||
|
id: from |
||||
|
color: "#EAB920" |
||||
|
elide: Text.ElideRight |
||||
|
maximumLineCount: 1 |
||||
|
clip: true |
||||
|
width: 200 |
||||
|
} |
||||
|
Label { |
||||
|
id: toLabel |
||||
|
text: qsTr("to") |
||||
|
visible: from.text !== "" |
||||
|
color: "#EAB920" |
||||
|
} |
||||
|
Label { |
||||
|
id: to |
||||
|
color: "#EAB920" |
||||
|
elide: Text.ElideRight |
||||
|
maximumLineCount: 1 |
||||
|
clip: true |
||||
|
width: 100 |
||||
|
} |
||||
|
Label { |
||||
|
id: value |
||||
|
color: "#EAB920" |
||||
|
font.italic: true |
||||
|
clip: true |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
Image { |
||||
|
anchors.right: rowHeader.parent.right |
||||
|
anchors.top: rowHeader.parent.top |
||||
|
anchors.topMargin: -3 |
||||
|
source: "qrc:/qml/img/edittransaction2.png" |
||||
|
height: 30 |
||||
|
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 }) |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
Loading…
Reference in new issue