go-ethereum/wallet.qml

158 lines
2.7 KiB
QML
Raw Normal View History

2014-02-21 13:37:40 +02:00
import QtQuick 2.0
import QtQuick.Controls 1.0;
import QtQuick.Layouts 1.0;
2014-02-21 18:29:59 +02:00
import QtQuick.Dialogs 1.0;
2014-02-22 02:52:47 +02:00
import QtQuick.Window 2.1;
2014-02-21 13:37:40 +02:00
import GoExtensions 1.0
ApplicationWindow {
id: root
width: 800
height: 600
minimumHeight: 300
title: "Ethereal"
2014-02-21 18:29:59 +02:00
2014-02-21 13:37:40 +02:00
toolBar: ToolBar {
id: mainToolbar
RowLayout {
width: parent.width
Button {
text: "Send"
2014-02-21 18:29:59 +02:00
onClicked: console.log("SEND")
2014-02-21 13:37:40 +02:00
}
TextField {
width: 200
placeholderText: "Amount"
}
TextField {
width: 300
placeholderText: "Receiver Address (or empty for contract)"
Layout.fillWidth: true
}
}
}
SplitView {
id: splitView
height: 200
anchors.top: parent.top
anchors.right: parent.right
anchors.left: parent.left
TextArea {
id: codeView
width: parent.width /2
}
TextArea {
readOnly: true
}
}
property var blockModel: ListModel {
id: blockModel
}
TableView {
2014-02-22 02:52:47 +02:00
id: blockTable
2014-02-21 13:37:40 +02:00
width: parent.width
anchors.top: splitView.bottom
2014-02-22 02:52:47 +02:00
anchors.bottom: logView.top
2014-02-21 13:37:40 +02:00
TableViewColumn{ role: "number" ; title: "#" ; width: 100 }
TableViewColumn{ role: "hash" ; title: "Hash" ; width: 560 }
model: blockModel
2014-02-21 18:29:59 +02:00
onDoubleClicked: {
2014-02-22 02:52:47 +02:00
popup.visible = true
popup.block = eth.getBlock(blockModel.get(row).hash)
popup.hashLabel.text = popup.block.hash
2014-02-21 18:29:59 +02:00
}
2014-02-21 13:37:40 +02:00
}
2014-02-22 02:52:47 +02:00
property var logModel: ListModel {
id: logModel
}
TableView {
id: logView
width: parent.width
height: 150
anchors.bottom: parent.bottom
TableViewColumn{ role: "description" ; title: "log" }
model: logModel
}
2014-02-21 18:29:59 +02:00
FileDialog {
id: openAppDialog
title: "Open QML Application"
onAccepted: {
ui.open(openAppDialog.fileUrl.toString())
}
}
2014-02-21 13:37:40 +02:00
statusBar: StatusBar {
2014-02-21 18:29:59 +02:00
RowLayout {
anchors.fill: parent
Button {
2014-02-22 02:52:47 +02:00
id: connectButton
onClicked: ui.connect()
text: "Connect"
}
Button {
anchors.left: connectButton.right
anchors.leftMargin: 5
2014-02-21 18:29:59 +02:00
onClicked: openAppDialog.open()
text: "Import App"
}
Label { text: "0.0.1" }
Label {
anchors.right: peerImage.left
anchors.rightMargin: 5
id: peerLabel
font.pixelSize: 8
text: "0 / 0"
2014-02-21 13:37:40 +02:00
}
2014-02-21 18:29:59 +02:00
Image {
id: peerImage
anchors.right: parent.right
width: 10; height: 10
source: "network.png"
}
}
2014-02-21 13:37:40 +02:00
}
2014-02-22 02:52:47 +02:00
Window {
id: popup
visible: false
property var block
Label {
id: hashLabel
anchors.horizontalCenter: parent.horizontalCenter
anchors.verticalCenter: parent.verticalCenter
}
}
2014-02-21 13:37:40 +02:00
function addBlock(block) {
2014-02-21 18:29:59 +02:00
blockModel.insert(0, {number: block.number, hash: block.hash})
2014-02-21 13:37:40 +02:00
}
2014-02-21 14:23:35 +02:00
2014-02-22 02:52:47 +02:00
function addLog(str) {
console.log(str)
logModel.insert(0, {description: str})
}
2014-02-21 14:23:35 +02:00
function setPeers(text) {
2014-02-21 18:29:59 +02:00
peerLabel.text = text
}
2014-02-21 13:37:40 +02:00
}