forked from mirror/go-ethereum
commit
d4af5a5763
@ -1,196 +0,0 @@ |
|||||||
import QtQuick 2.0 |
|
||||||
import QtQuick.Controls 1.0; |
|
||||||
import QtQuick.Layouts 1.0; |
|
||||||
import QtQuick.Dialogs 1.0; |
|
||||||
import QtQuick.Window 2.1; |
|
||||||
import QtQuick.Controls.Styles 1.1 |
|
||||||
import Ethereum 1.0 |
|
||||||
|
|
||||||
Component { |
|
||||||
id: newContract |
|
||||||
Column { |
|
||||||
id: mainContractColumn |
|
||||||
function contractFormReady(){ |
|
||||||
if(codeView.text.length > 0 && txValue.text.length > 0 && txGas.text.length > 0 && txGasPrice.length > 0) { |
|
||||||
txButton.state = "READY" |
|
||||||
}else{ |
|
||||||
txButton.state = "NOTREADY" |
|
||||||
} |
|
||||||
} |
|
||||||
states: [ |
|
||||||
State{ |
|
||||||
name: "ERROR" |
|
||||||
PropertyChanges { target: txResult; visible:true} |
|
||||||
PropertyChanges { target: codeView; visible:true} |
|
||||||
}, |
|
||||||
State { |
|
||||||
name: "DONE" |
|
||||||
PropertyChanges { target: txValue; visible:false} |
|
||||||
PropertyChanges { target: txGas; visible:false} |
|
||||||
PropertyChanges { target: txGasPrice; visible:false} |
|
||||||
PropertyChanges { target: codeView; visible:false} |
|
||||||
PropertyChanges { target: txButton; visible:false} |
|
||||||
PropertyChanges { target: txDataLabel; visible:false} |
|
||||||
|
|
||||||
PropertyChanges { target: txResult; visible:true} |
|
||||||
PropertyChanges { target: txOutput; visible:true} |
|
||||||
PropertyChanges { target: newTxButton; visible:true} |
|
||||||
}, |
|
||||||
State { |
|
||||||
name: "SETUP" |
|
||||||
PropertyChanges { target: txValue; visible:true; text: ""} |
|
||||||
PropertyChanges { target: txGas; visible:true; text: ""} |
|
||||||
PropertyChanges { target: txGasPrice; visible:true; text: ""} |
|
||||||
PropertyChanges { target: codeView; visible:true; text: ""} |
|
||||||
PropertyChanges { target: txButton; visible:true} |
|
||||||
PropertyChanges { target: txDataLabel; visible:true} |
|
||||||
|
|
||||||
PropertyChanges { target: txResult; visible:false} |
|
||||||
PropertyChanges { target: txOutput; visible:false} |
|
||||||
PropertyChanges { target: newTxButton; visible:false} |
|
||||||
} |
|
||||||
] |
|
||||||
width: 400 |
|
||||||
spacing: 5 |
|
||||||
anchors.left: parent.left |
|
||||||
anchors.top: parent.top |
|
||||||
anchors.leftMargin: 5 |
|
||||||
anchors.topMargin: 5 |
|
||||||
|
|
||||||
TextField { |
|
||||||
id: txValue |
|
||||||
width: 200 |
|
||||||
placeholderText: "Amount" |
|
||||||
validator: RegExpValidator { regExp: /\d*/ } |
|
||||||
onTextChanged: { |
|
||||||
contractFormReady() |
|
||||||
} |
|
||||||
} |
|
||||||
TextField { |
|
||||||
id: txGas |
|
||||||
width: 200 |
|
||||||
validator: RegExpValidator { regExp: /\d*/ } |
|
||||||
placeholderText: "Gas" |
|
||||||
onTextChanged: { |
|
||||||
contractFormReady() |
|
||||||
} |
|
||||||
} |
|
||||||
TextField { |
|
||||||
id: txGasPrice |
|
||||||
width: 200 |
|
||||||
placeholderText: "Gas price" |
|
||||||
validator: RegExpValidator { regExp: /\d*/ } |
|
||||||
onTextChanged: { |
|
||||||
contractFormReady() |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
Row { |
|
||||||
id: rowContract |
|
||||||
ExclusiveGroup { id: contractTypeGroup } |
|
||||||
RadioButton { |
|
||||||
id: createContractRadio |
|
||||||
text: "Create contract" |
|
||||||
checked: true |
|
||||||
exclusiveGroup: contractTypeGroup |
|
||||||
onClicked: { |
|
||||||
txFuelRecipient.visible = false |
|
||||||
txDataLabel.text = "Contract code" |
|
||||||
} |
|
||||||
} |
|
||||||
RadioButton { |
|
||||||
id: runContractRadio |
|
||||||
text: "Run contract" |
|
||||||
exclusiveGroup: contractTypeGroup |
|
||||||
onClicked: { |
|
||||||
txFuelRecipient.visible = true |
|
||||||
txDataLabel.text = "Contract arguments" |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
|
|
||||||
Label { |
|
||||||
id: txDataLabel |
|
||||||
text: "Contract code" |
|
||||||
} |
|
||||||
|
|
||||||
TextArea { |
|
||||||
id: codeView |
|
||||||
height: 300 |
|
||||||
anchors.topMargin: 5 |
|
||||||
Layout.fillWidth: true |
|
||||||
width: parent.width /2 |
|
||||||
onTextChanged: { |
|
||||||
contractFormReady() |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
TextField { |
|
||||||
id: txFuelRecipient |
|
||||||
placeholderText: "Contract address" |
|
||||||
validator: RegExpValidator { regExp: /[a-f0-9]{40}/ } |
|
||||||
visible: false |
|
||||||
width: 530 |
|
||||||
} |
|
||||||
|
|
||||||
Button { |
|
||||||
id: txButton |
|
||||||
/* enabled: false */ |
|
||||||
states: [ |
|
||||||
State { |
|
||||||
name: "READY" |
|
||||||
PropertyChanges { target: txButton; /*enabled: true*/} |
|
||||||
}, |
|
||||||
State { |
|
||||||
name: "NOTREADY" |
|
||||||
PropertyChanges { target: txButton; /*enabled:false*/} |
|
||||||
} |
|
||||||
] |
|
||||||
text: "Send" |
|
||||||
onClicked: { |
|
||||||
//this.enabled = false |
|
||||||
var res = eth.create(txFuelRecipient.text, txValue.text, txGas.text, txGasPrice.text, codeView.text) |
|
||||||
if(res[1]) { |
|
||||||
txResult.text = "Your contract <b>could not</b> be send over the network:\n<b>" |
|
||||||
txResult.text += res[1].error() |
|
||||||
txResult.text += "</b>" |
|
||||||
mainContractColumn.state = "ERROR" |
|
||||||
} else { |
|
||||||
txResult.text = "Your transaction has been submitted:\n" |
|
||||||
txOutput.text = res[0].address |
|
||||||
mainContractColumn.state = "DONE" |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
||||||
Text { |
|
||||||
id: txResult |
|
||||||
visible: false |
|
||||||
} |
|
||||||
TextField { |
|
||||||
id: txOutput |
|
||||||
visible: false |
|
||||||
width: 530 |
|
||||||
} |
|
||||||
Button { |
|
||||||
id: newTxButton |
|
||||||
visible: false |
|
||||||
text: "Create an other contract" |
|
||||||
onClicked: { |
|
||||||
this.visible = false |
|
||||||
txResult.text = "" |
|
||||||
txOutput.text = "" |
|
||||||
mainContractColumn.state = "SETUP" |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
Button { |
|
||||||
id: debugButton |
|
||||||
text: "Debug" |
|
||||||
onClicked: { |
|
||||||
var res = ui.debugTx("", txValue.text, txGas.text, txGasPrice.text, codeView.text) |
|
||||||
debugWindow.visible = true |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
@ -1,112 +0,0 @@ |
|||||||
import QtQuick 2.0 |
|
||||||
import QtQuick.Controls 1.0; |
|
||||||
import QtQuick.Layouts 1.0; |
|
||||||
import QtQuick.Dialogs 1.0; |
|
||||||
import QtQuick.Window 2.1; |
|
||||||
import QtQuick.Controls.Styles 1.1 |
|
||||||
import Ethereum 1.0 |
|
||||||
|
|
||||||
Component { |
|
||||||
id: newTransaction |
|
||||||
Column { |
|
||||||
id: simpleSendColumn |
|
||||||
states: [ |
|
||||||
State{ |
|
||||||
name: "ERROR" |
|
||||||
}, |
|
||||||
State { |
|
||||||
name: "DONE" |
|
||||||
PropertyChanges { target: txSimpleValue; visible:false} |
|
||||||
PropertyChanges { target: txSimpleRecipient; visible:false} |
|
||||||
PropertyChanges { target:newSimpleTxButton; visible:false} |
|
||||||
|
|
||||||
PropertyChanges { target: txSimpleResult; visible:true} |
|
||||||
PropertyChanges { target: txSimpleOutput; visible:true} |
|
||||||
PropertyChanges { target:newSimpleTxButton; visible:true} |
|
||||||
}, |
|
||||||
State { |
|
||||||
name: "SETUP" |
|
||||||
PropertyChanges { target: txSimpleValue; visible:true; text: ""} |
|
||||||
PropertyChanges { target: txSimpleRecipient; visible:true; text: ""} |
|
||||||
PropertyChanges { target: txSimpleButton; visible:true} |
|
||||||
PropertyChanges { target:newSimpleTxButton; visible:false} |
|
||||||
} |
|
||||||
] |
|
||||||
spacing: 5 |
|
||||||
anchors.leftMargin: 5 |
|
||||||
anchors.topMargin: 5 |
|
||||||
anchors.top: parent.top |
|
||||||
anchors.left: parent.left |
|
||||||
|
|
||||||
function checkFormState(){ |
|
||||||
if(txSimpleRecipient.text.length == 40 && txSimpleValue.text.length > 0) { |
|
||||||
txSimpleButton.state = "READY" |
|
||||||
}else{ |
|
||||||
txSimpleButton.state = "NOTREADY" |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
TextField { |
|
||||||
id: txSimpleRecipient |
|
||||||
placeholderText: "Recipient address" |
|
||||||
Layout.fillWidth: true |
|
||||||
validator: RegExpValidator { regExp: /[a-f0-9]{40}/ } |
|
||||||
width: 530 |
|
||||||
onTextChanged: { checkFormState() } |
|
||||||
} |
|
||||||
TextField { |
|
||||||
id: txSimpleValue |
|
||||||
width: 200 |
|
||||||
placeholderText: "Amount" |
|
||||||
anchors.rightMargin: 5 |
|
||||||
validator: RegExpValidator { regExp: /\d*/ } |
|
||||||
onTextChanged: { checkFormState() } |
|
||||||
} |
|
||||||
Button { |
|
||||||
id: txSimpleButton |
|
||||||
/*enabled: false*/ |
|
||||||
states: [ |
|
||||||
State { |
|
||||||
name: "READY" |
|
||||||
PropertyChanges { target: txSimpleButton; /*enabled: true*/} |
|
||||||
}, |
|
||||||
State { |
|
||||||
name: "NOTREADY" |
|
||||||
PropertyChanges { target: txSimpleButton; /*enabled: false*/} |
|
||||||
} |
|
||||||
] |
|
||||||
text: "Send" |
|
||||||
onClicked: { |
|
||||||
//this.enabled = false |
|
||||||
var res = eth.transact(txSimpleRecipient.text, txSimpleValue.text,"","","") |
|
||||||
if(res[1]) { |
|
||||||
txSimpleResult.text = "There has been an error broadcasting your transaction:" + res[1].error() |
|
||||||
} else { |
|
||||||
txSimpleResult.text = "Your transaction has been broadcasted over the network.\nYour transaction id is:" |
|
||||||
txSimpleOutput.text = res[0].hash |
|
||||||
this.visible = false |
|
||||||
simpleSendColumn.state = "DONE" |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
||||||
Text { |
|
||||||
id: txSimpleResult |
|
||||||
visible: false |
|
||||||
|
|
||||||
} |
|
||||||
TextField { |
|
||||||
id: txSimpleOutput |
|
||||||
visible: false |
|
||||||
width: 530 |
|
||||||
} |
|
||||||
Button { |
|
||||||
id: newSimpleTxButton |
|
||||||
visible: false |
|
||||||
text: "Create an other transaction" |
|
||||||
onClicked: { |
|
||||||
this.visible = false |
|
||||||
simpleSendColumn.state = "SETUP" |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in new issue