go-ethereum/ethereal/assets/qml/wallet.qml

551 lines
11 KiB
QML
Raw Normal View History

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
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"
MenuBar {
Menu {
title: "File"
MenuItem {
text: "Import App"
shortcut: "Ctrl+o"
onTriggered: openAppDialog.open()
}
2014-04-27 22:25:01 +00:00
MenuItem {
text: "Muted"
shortcut: "Ctrl+e"
onTriggered: ui.muted("")
}
}
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-21 11:37:40 +00:00
property var blockModel: ListModel {
id: blockModel
}
function setView(view) {
networkView.visible = false
historyView.visible = false
newTxView.visible = false
2014-05-21 12:00:54 +00:00
infoView.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
resizing: false
2014-02-23 00:56:04 +00:00
Rectangle {
id: menu
Layout.minimumWidth: 80
Layout.maximumWidth: 80
2014-02-23 00:56:04 +00:00
anchors.bottom: parent.bottom
anchors.top: parent.top
//color: "#D9DDE7"
color: "#252525"
2014-02-23 00:56:04 +00:00
2014-04-11 20:44:13 +00:00
ColumnLayout {
y: 50
anchors.left: parent.left
anchors.right: parent.right
height: 200
Image {
source: ui.assetPath("tx.png")
anchors.horizontalCenter: parent.horizontalCenter
MouseArea {
anchors.fill: parent
onClicked: {
setView(historyView)
}
2014-02-23 00:56:04 +00:00
}
}
Image {
source: ui.assetPath("new.png")
anchors.horizontalCenter: parent.horizontalCenter
MouseArea {
anchors.fill: parent
onClicked: {
setView(newTxView)
}
}
}
Image {
source: ui.assetPath("net.png")
anchors.horizontalCenter: parent.horizontalCenter
MouseArea {
anchors.fill: parent
onClicked: {
setView(networkView)
}
2014-02-23 00:56:04 +00:00
}
}
2014-05-21 12:00:54 +00:00
Image {
source: ui.assetPath("net.png")
anchors.horizontalCenter: parent.horizontalCenter
MouseArea {
anchors.fill: parent
onClicked: {
setView(infoView)
}
}
}
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 {
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
property var txModel: ListModel {
id: txModel
2014-02-23 00:56:04 +00:00
}
2014-02-21 11:37:40 +00:00
Rectangle {
id: historyView
anchors.fill: parent
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-04-11 21:05:02 +00:00
TableViewColumn{ role: "contract" ; title: "Contract" ; width: 100 }
model: txModel
}
}
2014-02-23 00:56:04 +00:00
Rectangle {
id: newTxView
property var title: "New transaction"
visible: false
anchors.fill: parent
color: "#00000000"
TabView{
anchors.fill: parent
anchors.rightMargin: 5
anchors.leftMargin: 5
anchors.topMargin: 5
anchors.bottomMargin: 5
id: newTransactionTab
Component.onCompleted:{
2014-04-11 20:44:13 +00:00
var component = Qt.createComponent("newTransaction/_simple_send.qml")
var newTransaction = component.createObject("newTransaction")
2014-04-11 19:18:38 +00:00
2014-04-11 20:44:13 +00:00
component = Qt.createComponent("newTransaction/_new_contract.qml")
var newContract = component.createObject("newContract")
2014-04-11 19:18:38 +00:00
2014-04-11 20:44:13 +00:00
addTab("Simple send", newTransaction)
2014-04-14 17:46:59 +00:00
addTab("Contracts", newContract)
2014-04-01 08:40:34 +00:00
}
2014-02-23 00:56:04 +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
property var logModel: ListModel {
id: logModel
}
2014-02-23 00:56:04 +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
model: logModel
2014-02-23 00:56:04 +00:00
}
}
2014-02-22 00:52:47 +00:00
2014-05-21 12:00:54 +00:00
Rectangle {
id: infoView
property var title: "Information"
visible: false
color: "#00000000"
anchors.fill: parent
Label {
id: addressLabel
text: "Address"
anchors {
margins: 5
top: parent.top
left: parent.left
}
}
TextField {
anchors {
margins: 5
left: addressLabel.right
top: parent.top
}
text: pub.getKey().address
width: 500
}
}
/*
2014-04-11 19:18:38 +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)
}
}
onAddPlugin: {
var pluginWin = pluginWindow.createObject(mainView)
console.log(pluginWin)
pluginWin.pluginTitle.text = "Test"
}
*/
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())
//ui.openHtml(Qt.resolvedUrl(ui.assetPath("test.html")))
ui.openHtml(openAppDialog.fileUrl.toString())
2014-02-21 16:29:59 +00:00
}
}
2014-02-21 11:37:40 +00:00
statusBar: StatusBar {
2014-02-21 16:29:59 +00:00
RowLayout {
anchors.fill: parent
Button {
property var enabled: true
2014-02-22 00:52:47 +00:00
id: connectButton
onClicked: {
if(this.enabled) {
ui.connect(this)
}
}
2014-02-22 00:52:47 +00:00
text: "Connect"
}
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
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
}
}
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"
onAccepted: {
ui.connectToPeer(addrField.text)
addPeerWin.visible = false
}
}
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
}
}
Component.onCompleted: {
addrField.focus = true
}
}
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
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-04-11 16:50:31 +00:00
Window {
id: debugWindow
visible: false
title: "Debugger"
minimumWidth: 600
minimumHeight: 600
width: 800
height: 600
2014-04-12 04:12:10 +00:00
Item {
id: keyHandler
focus: true
Keys.onPressed: {
if (event.key == Qt.Key_Space) {
ui.next()
}
}
}
2014-04-11 16:50:31 +00:00
SplitView {
2014-04-12 04:12:10 +00:00
2014-04-11 16:50:31 +00:00
anchors.fill: parent
property var asmModel: ListModel {
id: asmModel
}
TableView {
id: asmTableView
width: 200
TableViewColumn{ role: "value" ; title: "" ; width: 100 }
model: asmModel
}
Rectangle {
anchors.left: asmTableView.right
anchors.right: parent.right
SplitView {
orientation: Qt.Vertical
anchors.fill: parent
2014-04-14 21:14:07 +00:00
TableView {
property var memModel: ListModel {
id: memModel
}
height: parent.height/2
width: parent.width
TableViewColumn{ id:mnumColmn ; role: "num" ; title: "#" ; width: 50}
TableViewColumn{ role: "value" ; title: "Memory" ; width: 750}
model: memModel
}
SplitView {
orientation: Qt.Horizontal
TableView {
property var debuggerLog: ListModel {
id: debuggerLog
}
TableViewColumn{ role: "value"; title: "Debug messages" }
model: debuggerLog
}
TableView {
property var stackModel: ListModel {
id: stackModel
}
height: parent.height/2
width: parent.width
TableViewColumn{ role: "value" ; title: "Stack" ; width: parent.width }
model: stackModel
}
}
2014-04-11 16:50:31 +00:00
}
}
}
}
function setAsm(asm) {
asmModel.append({asm: asm})
}
2014-04-12 04:12:10 +00:00
function setInstruction(num) {
asmTableView.selection.clear()
asmTableView.selection.select(num-1)
}
2014-04-11 16:50:31 +00:00
function clearAsm() {
asmModel.clear()
}
function setMem(mem) {
memModel.append({num: mem.num, value: mem.value})
}
function clearMem(){
memModel.clear()
}
function setStack(stack) {
stackModel.append({value: stack})
}
2014-04-14 21:08:15 +00:00
function addDebugMessage(message){
console.log("WOOP:")
debuggerLog.append({value: message})
}
2014-04-11 16:50:31 +00:00
function clearStack() {
stackModel.clear()
}
2014-02-25 09:55:44 +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-21 12:23:35 +00:00
2014-02-23 00:56:04 +00:00
function addTx(tx) {
2014-04-12 04:13:11 +00:00
var isContract
if (tx.contract == true){
isContract = "Yes"
}else{
isContract = "No"
}
2014-04-12 04:13:11 +00:00
txModel.insert(0, {hash: tx.hash, address: tx.address, value: tx.value, contract: isContract})
2014-02-23 00:56:04 +00:00
}
2014-02-22 00:52:47 +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) {
if(str.len != 0) {
logModel.append({description: str})
2014-04-11 19:18:38 +00:00
}
2014-02-21 16:29:59 +00:00
}
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
}