You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
210 lines
3.8 KiB
210 lines
3.8 KiB
import QtQuick 2.0
|
|
import QtQuick.Layouts 1.0
|
|
import QtQuick.Controls 1.1
|
|
import QtQuick.Controls.Styles 1.3
|
|
|
|
Rectangle {
|
|
anchors.fill: parent
|
|
color: "white"
|
|
property var worker
|
|
property variant sel
|
|
signal selected(string step)
|
|
id: root
|
|
|
|
function refreshCurrent()
|
|
{
|
|
menu.itemAt(sel).select()
|
|
}
|
|
|
|
function init()
|
|
{
|
|
menu.itemAt(0).select()
|
|
}
|
|
|
|
function itemClicked(step)
|
|
{
|
|
selected(step)
|
|
}
|
|
|
|
border.color: "#cccccc"
|
|
border.width: 1
|
|
|
|
ColumnLayout
|
|
{
|
|
anchors.fill: parent
|
|
anchors.margins: 1
|
|
Repeater
|
|
{
|
|
id: menu
|
|
model: [
|
|
{
|
|
step: 1,
|
|
type:"deploy",
|
|
label: qsTr("Deploy contracts")
|
|
},
|
|
{
|
|
step: 2,
|
|
type:"package",
|
|
label: qsTr("Package files")
|
|
},
|
|
{
|
|
step: 3,
|
|
type:"register",
|
|
label: qsTr("Register Dapp")
|
|
}
|
|
]
|
|
|
|
Rectangle
|
|
{
|
|
Layout.preferredHeight: 50
|
|
Layout.fillWidth: true
|
|
color: "white"
|
|
id: itemContainer
|
|
|
|
function select()
|
|
{
|
|
if (sel !== undefined)
|
|
{
|
|
menu.itemAt(sel).unselect()
|
|
}
|
|
labelContainer.state = "selected"
|
|
sel = index
|
|
itemClicked(menu.model[index].type)
|
|
}
|
|
|
|
function unselect()
|
|
{
|
|
labelContainer.state = ""
|
|
}
|
|
|
|
Rectangle {
|
|
width: 40
|
|
height: 40
|
|
color: "transparent"
|
|
border.color: "#cccccc"
|
|
border.width: 2
|
|
radius: width*0.5
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: 10
|
|
id: labelContainer
|
|
Label
|
|
{
|
|
color: "#cccccc"
|
|
id: label
|
|
anchors.centerIn: parent
|
|
text: menu.model[index].step
|
|
}
|
|
states: [
|
|
State {
|
|
name: "selected"
|
|
PropertyChanges { target: label; color: "white" }
|
|
PropertyChanges { target: labelContainer.border; color: "white" }
|
|
PropertyChanges { target: detail; color: "white" }
|
|
PropertyChanges { target: itemContainer; color: "#3395FE" }
|
|
}
|
|
]
|
|
}
|
|
|
|
Rectangle
|
|
{
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
anchors.left: label.parent.right
|
|
width: parent.width - 40
|
|
height: 40
|
|
color: "transparent"
|
|
Label
|
|
{
|
|
id: detail
|
|
color: "black"
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: 10
|
|
text: menu.model[index].label
|
|
}
|
|
}
|
|
|
|
MouseArea
|
|
{
|
|
anchors.fill: parent
|
|
onClicked:
|
|
{
|
|
itemContainer.select()
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
Connections {
|
|
target: projectModel
|
|
onDeploymentStarted: log.text = log.text + qsTr("Running deployment...") + "\n"
|
|
onDeploymentError: log.text = log.text + error + "\n"
|
|
onDeploymentComplete: log.text = log.text + qsTr("Deployment complete") + "\n"
|
|
onDeploymentStepChanged: log.text = log.text + message + "\n"
|
|
}
|
|
|
|
Rectangle
|
|
{
|
|
Layout.fillWidth: true
|
|
Layout.preferredHeight: 1
|
|
color: "#cccccc"
|
|
}
|
|
|
|
RowLayout
|
|
{
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
Layout.preferredHeight: 20
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: 2
|
|
Button
|
|
{
|
|
Layout.preferredHeight: 22
|
|
Layout.preferredWidth: 22
|
|
action: clearAction
|
|
iconSource: "qrc:/qml/img/cleariconactive.png"
|
|
}
|
|
|
|
Action {
|
|
id: clearAction
|
|
enabled: log.text !== ""
|
|
tooltip: qsTr("Clear")
|
|
onTriggered: {
|
|
log.text = ""
|
|
}
|
|
}
|
|
|
|
Button
|
|
{
|
|
Layout.preferredHeight: 22
|
|
text: qsTr("Clear Deployment")
|
|
action: clearDeployAction
|
|
}
|
|
|
|
Action {
|
|
id: clearDeployAction
|
|
onTriggered: {
|
|
worker.forceStopPooling()
|
|
fileIo.deleteDir(projectModel.deploymentDir)
|
|
projectModel.cleanDeploymentStatus()
|
|
root.refreshCurrent()
|
|
log.text = ""
|
|
}
|
|
}
|
|
}
|
|
|
|
ScrollView
|
|
{
|
|
Layout.fillHeight: true
|
|
Layout.fillWidth: true
|
|
Text
|
|
{
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: 2
|
|
font.pointSize: 9
|
|
font.italic: true
|
|
id: log
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|