2014-02-21 11:37:40 +00:00
|
|
|
import QtQuick 2.0
|
|
|
|
import QtQuick.Controls 1.0;
|
|
|
|
import QtQuick.Layouts 1.0;
|
2014-02-21 16:29:59 +00:00
|
|
|
import QtQuick.Dialogs 1.0;
|
2014-02-22 00:52:47 +00:00
|
|
|
import QtQuick.Window 2.1;
|
2014-02-23 00:56:04 +00:00
|
|
|
import QtQuick.Controls.Styles 1.1
|
2014-02-22 22:19:38 +00:00
|
|
|
import Ethereum 1.0
|
2014-02-21 11:37:40 +00:00
|
|
|
|
|
|
|
ApplicationWindow {
|
|
|
|
id: root
|
|
|
|
|
2014-02-23 00:56:04 +00:00
|
|
|
width: 900
|
2014-02-21 11:37:40 +00:00
|
|
|
height: 600
|
|
|
|
minimumHeight: 300
|
|
|
|
|
|
|
|
title: "Ethereal"
|
|
|
|
|
2014-02-22 22:19:38 +00:00
|
|
|
MenuBar {
|
|
|
|
Menu {
|
|
|
|
title: "File"
|
|
|
|
MenuItem {
|
|
|
|
text: "Import App"
|
|
|
|
shortcut: "Ctrl+o"
|
|
|
|
onTriggered: openAppDialog.open()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-04-10 18:53:12 +00:00
|
|
|
Menu {
|
|
|
|
title: "Test"
|
|
|
|
MenuItem {
|
|
|
|
text: "Test test"
|
|
|
|
shortcut: "Ctrl+t"
|
|
|
|
onTriggered: {
|
|
|
|
var win
|
|
|
|
function finishedLoading(){
|
|
|
|
console.log("Trigged")
|
|
|
|
win = wizard.createObject(root)
|
|
|
|
}
|
|
|
|
console.log("Loading wizard")
|
|
|
|
|
|
|
|
var wizard = Qt.createComponent("first_run.qml")
|
|
|
|
if(wizard.status== Component.Ready){
|
|
|
|
console.log("Component is ready")
|
|
|
|
finishedLoading()
|
|
|
|
}else if( wizard.status == Component.Error){
|
|
|
|
console.log("Error loading component:", wizard.errorString())
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
wizard.statusChanged.connect(finishedLoading)
|
|
|
|
console.log("Component is NOT ready")
|
|
|
|
win = wizard.createObject(root)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-02-22 22:19:38 +00:00
|
|
|
Menu {
|
|
|
|
title: "Network"
|
|
|
|
MenuItem {
|
|
|
|
text: "Add Peer"
|
|
|
|
shortcut: "Ctrl+p"
|
|
|
|
onTriggered: {
|
|
|
|
addPeerWin.visible = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
MenuItem {
|
|
|
|
text: "Start"
|
|
|
|
onTriggered: ui.connect()
|
|
|
|
}
|
|
|
|
}
|
2014-02-23 00:56:04 +00:00
|
|
|
|
|
|
|
Menu {
|
|
|
|
title: "Help"
|
|
|
|
MenuItem {
|
|
|
|
text: "About"
|
|
|
|
onTriggered: {
|
|
|
|
aboutWin.visible = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-02-22 22:19:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-02-21 11:37:40 +00:00
|
|
|
property var blockModel: ListModel {
|
|
|
|
id: blockModel
|
|
|
|
}
|
2014-02-28 11:16:46 +00:00
|
|
|
|
|
|
|
function setView(view) {
|
|
|
|
networkView.visible = false
|
|
|
|
historyView.visible = false
|
|
|
|
newTxView.visible = false
|
|
|
|
view.visible = true
|
|
|
|
//root.title = "Ethereal - " = view.title
|
|
|
|
}
|
2014-02-21 11:37:40 +00:00
|
|
|
|
2014-02-23 00:56:04 +00:00
|
|
|
SplitView {
|
|
|
|
anchors.fill: parent
|
2014-02-28 11:16:46 +00:00
|
|
|
resizing: false
|
2014-02-23 00:56:04 +00:00
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
id: menu
|
2014-02-28 11:16:46 +00:00
|
|
|
Layout.minimumWidth: 80
|
|
|
|
Layout.maximumWidth: 80
|
2014-02-23 00:56:04 +00:00
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
anchors.top: parent.top
|
2014-02-28 11:16:46 +00:00
|
|
|
//color: "#D9DDE7"
|
|
|
|
color: "#252525"
|
2014-02-23 00:56:04 +00:00
|
|
|
|
2014-02-28 11:16:46 +00:00
|
|
|
ColumnLayout {
|
|
|
|
y: 50
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.right: parent.right
|
|
|
|
height: 200
|
|
|
|
Image {
|
2014-03-05 09:44:33 +00:00
|
|
|
source: ui.assetPath("tx.png")
|
2014-02-28 11:16:46 +00:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
|
|
|
onClicked: {
|
|
|
|
setView(historyView)
|
|
|
|
}
|
2014-02-23 00:56:04 +00:00
|
|
|
}
|
|
|
|
}
|
2014-02-28 11:16:46 +00:00
|
|
|
Image {
|
2014-03-05 09:44:33 +00:00
|
|
|
source: ui.assetPath("new.png")
|
2014-02-28 11:16:46 +00:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
|
|
|
onClicked: {
|
|
|
|
setView(newTxView)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Image {
|
2014-03-05 09:44:33 +00:00
|
|
|
source: ui.assetPath("net.png")
|
2014-02-28 11:16:46 +00:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
|
|
|
onClicked: {
|
|
|
|
setView(networkView)
|
|
|
|
}
|
2014-02-23 00:56:04 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2014-02-21 16:29:59 +00:00
|
|
|
|
2014-02-23 00:56:04 +00:00
|
|
|
Rectangle {
|
2014-03-02 23:54:41 +00:00
|
|
|
id: mainView
|
|
|
|
color: "#00000000"
|
2014-02-23 00:56:04 +00:00
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.left: menu.right
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
anchors.top: parent.top
|
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
property var txModel: ListModel {
|
|
|
|
id: txModel
|
2014-02-23 00:56:04 +00:00
|
|
|
}
|
2014-02-21 11:37:40 +00:00
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
Rectangle {
|
|
|
|
id: historyView
|
|
|
|
anchors.fill: parent
|
2014-02-28 11:16:46 +00:00
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
property var title: "Transactions"
|
|
|
|
TableView {
|
|
|
|
id: txTableView
|
|
|
|
anchors.fill: parent
|
|
|
|
TableViewColumn{ role: "value" ; title: "Value" ; width: 100 }
|
|
|
|
TableViewColumn{ role: "address" ; title: "Address" ; width: 430 }
|
2014-02-28 11:16:46 +00:00
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
model: txModel
|
2014-02-28 11:16:46 +00:00
|
|
|
}
|
2014-03-02 23:54:41 +00:00
|
|
|
}
|
2014-02-23 00:56:04 +00:00
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
Rectangle {
|
|
|
|
id: newTxView
|
|
|
|
property var title: "New transaction"
|
|
|
|
visible: false
|
|
|
|
anchors.fill: parent
|
|
|
|
color: "#00000000"
|
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
width: 400
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.leftMargin: 5
|
2014-02-28 11:16:46 +00:00
|
|
|
anchors.topMargin: 5
|
2014-03-02 23:54:41 +00:00
|
|
|
TextField {
|
2014-03-27 18:41:42 +00:00
|
|
|
id: txRecipient
|
|
|
|
placeholderText: "Recipient address (or empty for contract)"
|
|
|
|
Layout.fillWidth: true
|
|
|
|
}
|
|
|
|
|
|
|
|
TextField {
|
|
|
|
id: txValue
|
2014-03-02 23:54:41 +00:00
|
|
|
width: 200
|
|
|
|
placeholderText: "Amount"
|
|
|
|
}
|
|
|
|
TextField {
|
2014-03-27 18:41:42 +00:00
|
|
|
id: txGas
|
|
|
|
width: 200
|
|
|
|
placeholderText: "Gas"
|
|
|
|
anchors.left: txValue
|
|
|
|
anchors.leftMargin: 5
|
|
|
|
}
|
|
|
|
TextField {
|
|
|
|
id: txGasPrice
|
|
|
|
width: 200
|
|
|
|
placeholderText: "Gas price"
|
|
|
|
anchors.left: txGas
|
|
|
|
anchors.leftMargin: 5
|
2014-03-02 23:54:41 +00:00
|
|
|
}
|
2014-02-23 00:56:04 +00:00
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
Label {
|
|
|
|
text: "Transaction data"
|
|
|
|
}
|
2014-03-27 18:41:42 +00:00
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
TextArea {
|
|
|
|
id: codeView
|
|
|
|
anchors.topMargin: 5
|
|
|
|
Layout.fillWidth: true
|
|
|
|
width: parent.width /2
|
|
|
|
}
|
|
|
|
|
|
|
|
Button {
|
2014-03-27 18:41:42 +00:00
|
|
|
id: txButton
|
2014-03-02 23:54:41 +00:00
|
|
|
text: "Send"
|
|
|
|
onClicked: {
|
2014-03-30 22:22:50 +00:00
|
|
|
//this.enabled = false
|
2014-04-01 08:40:34 +00:00
|
|
|
var res = eth.createTx(txRecipient.text, txValue.text, txGas.text, txGasPrice.text, codeView.text)
|
|
|
|
if(res[1]) {
|
|
|
|
txOutput.text = "Output:\n" + res[1].error()
|
|
|
|
} else {
|
|
|
|
txOutput.text = "Output:\n" + res[0]
|
|
|
|
}
|
|
|
|
txOutput.visible = true
|
2014-03-02 23:54:41 +00:00
|
|
|
}
|
2014-02-28 11:16:46 +00:00
|
|
|
}
|
2014-04-01 08:40:34 +00:00
|
|
|
TextArea {
|
|
|
|
id: txOutput
|
|
|
|
visible: false
|
|
|
|
Layout.fillWidth: true
|
|
|
|
height: 40
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
}
|
2014-02-23 00:56:04 +00:00
|
|
|
}
|
|
|
|
}
|
2014-02-28 11:16:46 +00:00
|
|
|
|
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
Rectangle {
|
|
|
|
id: networkView
|
|
|
|
property var title: "Network"
|
|
|
|
visible: false
|
|
|
|
anchors.fill: parent
|
|
|
|
|
|
|
|
TableView {
|
|
|
|
id: blockTable
|
|
|
|
width: parent.width
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.bottom: logView.top
|
|
|
|
TableViewColumn{ role: "number" ; title: "#" ; width: 100 }
|
|
|
|
TableViewColumn{ role: "hash" ; title: "Hash" ; width: 560 }
|
|
|
|
|
|
|
|
model: blockModel
|
|
|
|
|
|
|
|
/*
|
|
|
|
onDoubleClicked: {
|
|
|
|
popup.visible = true
|
|
|
|
popup.block = eth.getBlock(blockModel.get(row).hash)
|
|
|
|
popup.hashLabel.text = popup.block.hash
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
}
|
2014-02-23 00:56:04 +00:00
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
property var logModel: ListModel {
|
|
|
|
id: logModel
|
|
|
|
}
|
2014-02-23 00:56:04 +00:00
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
TableView {
|
|
|
|
id: logView
|
|
|
|
width: parent.width
|
|
|
|
height: 150
|
|
|
|
anchors.bottom: parent.bottom
|
|
|
|
TableViewColumn{ role: "description" ; title: "log" }
|
2014-02-22 00:52:47 +00:00
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
model: logModel
|
2014-02-23 00:56:04 +00:00
|
|
|
}
|
|
|
|
}
|
2014-02-22 00:52:47 +00:00
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
/*
|
|
|
|
signal addPlugin(string name)
|
|
|
|
Component {
|
|
|
|
id: pluginWindow
|
|
|
|
Rectangle {
|
|
|
|
anchors.fill: parent
|
|
|
|
Label {
|
|
|
|
id: pluginTitle
|
|
|
|
anchors.centerIn: parent
|
|
|
|
text: "Hello world"
|
|
|
|
}
|
|
|
|
Component.onCompleted: setView(this)
|
|
|
|
}
|
2014-02-23 00:56:04 +00:00
|
|
|
}
|
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
onAddPlugin: {
|
|
|
|
var pluginWin = pluginWindow.createObject(mainView)
|
|
|
|
console.log(pluginWin)
|
|
|
|
pluginWin.pluginTitle.text = "Test"
|
2014-02-23 00:56:04 +00:00
|
|
|
}
|
2014-03-02 23:54:41 +00:00
|
|
|
*/
|
2014-02-23 00:56:04 +00:00
|
|
|
}
|
2014-02-22 00:52:47 +00:00
|
|
|
}
|
|
|
|
|
2014-02-21 16:29:59 +00:00
|
|
|
FileDialog {
|
|
|
|
id: openAppDialog
|
|
|
|
title: "Open QML Application"
|
|
|
|
onAccepted: {
|
|
|
|
ui.open(openAppDialog.fileUrl.toString())
|
|
|
|
}
|
|
|
|
}
|
2014-02-21 11:37:40 +00:00
|
|
|
|
|
|
|
statusBar: StatusBar {
|
2014-02-21 16:29:59 +00:00
|
|
|
RowLayout {
|
|
|
|
anchors.fill: parent
|
|
|
|
Button {
|
2014-02-28 11:16:46 +00:00
|
|
|
property var enabled: true
|
2014-02-22 00:52:47 +00:00
|
|
|
id: connectButton
|
2014-02-28 11:16:46 +00:00
|
|
|
onClicked: {
|
|
|
|
if(this.enabled) {
|
|
|
|
ui.connect(this)
|
|
|
|
}
|
|
|
|
}
|
2014-02-22 00:52:47 +00:00
|
|
|
text: "Connect"
|
|
|
|
}
|
2014-03-02 23:54:41 +00:00
|
|
|
|
2014-02-22 00:52:47 +00:00
|
|
|
Button {
|
2014-02-25 10:24:04 +00:00
|
|
|
id: importAppButton
|
2014-02-22 00:52:47 +00:00
|
|
|
anchors.left: connectButton.right
|
|
|
|
anchors.leftMargin: 5
|
2014-02-21 16:29:59 +00:00
|
|
|
onClicked: openAppDialog.open()
|
|
|
|
text: "Import App"
|
|
|
|
}
|
|
|
|
|
2014-02-25 09:55:44 +00:00
|
|
|
Label {
|
2014-02-25 10:24:04 +00:00
|
|
|
anchors.left: importAppButton.right
|
|
|
|
anchors.leftMargin: 5
|
2014-02-25 09:55:44 +00:00
|
|
|
id: walletValueLabel
|
|
|
|
}
|
|
|
|
|
2014-02-21 16:29:59 +00:00
|
|
|
Label {
|
|
|
|
anchors.right: peerImage.left
|
|
|
|
anchors.rightMargin: 5
|
|
|
|
id: peerLabel
|
|
|
|
font.pixelSize: 8
|
|
|
|
text: "0 / 0"
|
2014-02-21 11:37:40 +00:00
|
|
|
}
|
2014-02-21 16:29:59 +00:00
|
|
|
Image {
|
|
|
|
id: peerImage
|
|
|
|
anchors.right: parent.right
|
|
|
|
width: 10; height: 10
|
2014-03-05 09:44:33 +00:00
|
|
|
source: ui.assetPath("network.png")
|
2014-02-21 16:29:59 +00:00
|
|
|
}
|
|
|
|
}
|
2014-02-21 11:37:40 +00:00
|
|
|
}
|
|
|
|
|
2014-02-22 00:52:47 +00:00
|
|
|
Window {
|
|
|
|
id: popup
|
|
|
|
visible: false
|
|
|
|
property var block
|
|
|
|
Label {
|
|
|
|
id: hashLabel
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-02-22 22:19:38 +00:00
|
|
|
Window {
|
|
|
|
id: addPeerWin
|
|
|
|
visible: false
|
|
|
|
minimumWidth: 230
|
|
|
|
maximumWidth: 230
|
|
|
|
maximumHeight: 50
|
|
|
|
minimumHeight: 50
|
|
|
|
|
|
|
|
TextField {
|
|
|
|
id: addrField
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: 10
|
|
|
|
placeholderText: "address:port"
|
2014-03-02 23:54:41 +00:00
|
|
|
onAccepted: {
|
|
|
|
ui.connectToPeer(addrField.text)
|
|
|
|
addPeerWin.visible = false
|
|
|
|
}
|
2014-02-22 22:19:38 +00:00
|
|
|
}
|
|
|
|
Button {
|
|
|
|
anchors.left: addrField.right
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
anchors.leftMargin: 5
|
|
|
|
text: "Add"
|
|
|
|
onClicked: {
|
|
|
|
ui.connectToPeer(addrField.text)
|
2014-02-25 09:55:44 +00:00
|
|
|
addPeerWin.visible = false
|
2014-02-22 22:19:38 +00:00
|
|
|
}
|
|
|
|
}
|
2014-03-02 23:54:41 +00:00
|
|
|
Component.onCompleted: {
|
|
|
|
addrField.focus = true
|
|
|
|
}
|
2014-02-22 22:19:38 +00:00
|
|
|
}
|
|
|
|
|
2014-02-23 00:56:04 +00:00
|
|
|
Window {
|
|
|
|
id: aboutWin
|
|
|
|
visible: false
|
|
|
|
title: "About"
|
2014-02-28 12:08:41 +00:00
|
|
|
minimumWidth: 350
|
|
|
|
maximumWidth: 350
|
2014-02-23 00:56:04 +00:00
|
|
|
maximumHeight: 200
|
|
|
|
minimumHeight: 200
|
|
|
|
|
2014-02-28 12:08:41 +00:00
|
|
|
Image {
|
|
|
|
id: aboutIcon
|
|
|
|
height: 150
|
|
|
|
width: 150
|
|
|
|
fillMode: Image.PreserveAspectFit
|
|
|
|
smooth: true
|
2014-03-05 09:44:33 +00:00
|
|
|
source: ui.assetPath("facet.png")
|
2014-02-28 12:08:41 +00:00
|
|
|
x: 10
|
|
|
|
y: 10
|
|
|
|
}
|
|
|
|
|
2014-02-23 00:56:04 +00:00
|
|
|
Text {
|
2014-02-28 12:08:41 +00:00
|
|
|
anchors.left: aboutIcon.right
|
|
|
|
anchors.leftMargin: 10
|
|
|
|
font.pointSize: 12
|
2014-04-01 08:40:34 +00:00
|
|
|
text: "<h2>Ethereal</h2><br><h3>Development</h3>Jeffrey Wilcke<br>Maran Hidskes<br><h3>Binary Distribution</h3>Jarrad Hope<br>"
|
2014-02-23 00:56:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2014-03-02 23:54:41 +00:00
|
|
|
function loadPlugin(name) {
|
|
|
|
console.log("Loading plugin" + name)
|
|
|
|
mainView.addPlugin(name)
|
|
|
|
}
|
|
|
|
|
2014-02-25 09:55:44 +00:00
|
|
|
function setWalletValue(value) {
|
|
|
|
walletValueLabel.text = value
|
|
|
|
}
|
|
|
|
|
2014-02-23 00:56:04 +00:00
|
|
|
function addTx(tx) {
|
|
|
|
txModel.insert(0, {hash: tx.hash, address: tx.address, value: tx.value})
|
|
|
|
}
|
2014-02-22 22:19:38 +00:00
|
|
|
|
2014-02-21 11:37:40 +00:00
|
|
|
function addBlock(block) {
|
2014-02-21 16:29:59 +00:00
|
|
|
blockModel.insert(0, {number: block.number, hash: block.hash})
|
2014-02-21 11:37:40 +00:00
|
|
|
}
|
2014-02-21 12:23:35 +00:00
|
|
|
|
2014-02-22 00:52:47 +00:00
|
|
|
function addLog(str) {
|
2014-02-24 12:51:16 +00:00
|
|
|
if(str.len != 0) {
|
|
|
|
logModel.append({description: str})
|
|
|
|
}
|
2014-02-22 00:52:47 +00:00
|
|
|
}
|
|
|
|
|
2014-02-21 12:23:35 +00:00
|
|
|
function setPeers(text) {
|
2014-02-21 16:29:59 +00:00
|
|
|
peerLabel.text = text
|
|
|
|
}
|
2014-02-21 11:37:40 +00:00
|
|
|
}
|