peerplays_migrated/programs/light_client/qml/TransferForm.qml

115 lines
4.4 KiB
QML
Raw Normal View History

2015-07-13 18:16:02 +00:00
import QtQuick 2.5
import QtQuick.Controls 1.4
import QtQuick.Dialogs 1.2
import QtQuick.Layouts 1.2
2015-07-14 19:06:00 +00:00
import Graphene.Client 0.1
import "."
2015-07-13 18:16:02 +00:00
2015-07-17 20:39:01 +00:00
/**
* This is the form for transferring some amount of asset from one account to another.
*/
2015-07-13 18:16:02 +00:00
Rectangle {
2015-07-17 20:39:01 +00:00
id: root
anchors.fill: parent
2015-07-14 19:06:00 +00:00
property GrapheneApplication app
signal finished
2015-07-17 20:39:01 +00:00
/// The Account object for the sender
property alias senderAccount: senderPicker.account
/// The Account object for the receiver
property alias receiverAccount: recipientPicker.account
/// The operation created in this form
property var operation
2015-07-17 20:39:01 +00:00
2015-07-13 18:16:02 +00:00
Component.onCompleted: console.log("Made a transfer form")
Component.onDestruction: console.log("Destroyed a transfer form")
2015-07-14 19:06:00 +00:00
ColumnLayout {
anchors.centerIn: parent
2015-07-14 19:06:00 +00:00
width: parent.width - Scaling.cm(2)
2015-07-15 21:55:12 +00:00
spacing: Scaling.mm(5)
2015-07-14 19:06:00 +00:00
AccountPicker {
id: senderPicker
2015-07-17 20:39:01 +00:00
// The senderPicker is really the heart of the form. Everything else in the form adjusts based on the account
// selected here. The assetField below updates to contain all assets this account has a nonzero balance in.
// The amountField updates based on the asset selected in the assetField to have the appropriate precision and
// to have a maximum value equal to the account's balance in that asset. The transfer button enables only when
// both accounts are set, and a nonzero amount is selected to be transferred.
app: root.app
2015-07-15 21:55:12 +00:00
Layout.fillWidth: true
Layout.minimumWidth: Scaling.cm(5)
2015-07-14 19:06:00 +00:00
Component.onCompleted: setFocus()
placeholderText: qsTr("Sender")
showBalance: balances? balances.reduce(function(foundIndex, balance, index) {
if (foundIndex >= 0) return foundIndex
2015-07-15 21:55:12 +00:00
return balance.type.symbol === assetField.currentText? index : -1
}, -1) : -1
onBalanceClicked: amountField.value = balance
2015-07-14 19:06:00 +00:00
}
AccountPicker {
id: recipientPicker
2015-07-17 20:39:01 +00:00
app: root.app
2015-07-15 21:55:12 +00:00
Layout.fillWidth: true
Layout.minimumWidth: Scaling.cm(5)
2015-07-14 19:06:00 +00:00
placeholderText: qsTr("Recipient")
layoutDirection: Qt.RightToLeft
}
2015-07-15 21:55:12 +00:00
TextField {
id: memoField
Layout.fillWidth: true
placeholderText: qsTr("Memo")
}
RowLayout {
2015-07-15 21:55:12 +00:00
Layout.fillWidth: true
2015-07-14 19:06:00 +00:00
SpinBox {
id: amountField
2015-07-14 19:06:00 +00:00
Layout.preferredWidth: Scaling.cm(4)
Layout.minimumWidth: Scaling.cm(1.5)
enabled: maxBalance
2015-07-14 19:06:00 +00:00
minimumValue: 0
maximumValue: maxBalance? maxBalance.amountReal() : 0
decimals: maxBalance? maxBalance.type.precision : 0
2015-07-17 20:06:07 +00:00
property Balance maxBalance: assetField.enabled && senderPicker.showBalance >= 0?
senderPicker.balances[senderPicker.showBalance] : null
2015-07-14 19:06:00 +00:00
}
ComboBox {
2015-07-15 21:55:12 +00:00
id: assetField
Layout.minimumWidth: Scaling.cm(1)
2015-07-17 20:06:07 +00:00
enabled: senderPicker.balances instanceof Array && senderPicker.balances.length > 0
model: enabled? senderPicker.balances.filter(function(balance) { return balance.amount > 0 })
.map(function(balance) { return balance.type.symbol })
: ["Asset Type"]
2015-07-14 19:06:00 +00:00
}
Text {
font.pixelSize: assetField.height / 2.5
text: {
var balance = amountField.maxBalance
if (!balance || !balance.type) return ""
var precisionAdjustment = Math.pow(10, balance.type.precision)
var op = app.operationBuilder.transfer(0, 0, amountField.value * precisionAdjustment,
balance.type.id, memoField.text, 0)
2015-07-22 21:38:44 +00:00
return qsTr("Fee:<br/>") + op.fee / precisionAdjustment + " CORE"
}
}
2015-07-14 19:06:00 +00:00
Item { Layout.fillWidth: true }
Button {
text: qsTr("Cancel")
onClicked: finished()
}
2015-07-14 19:06:00 +00:00
Button {
text: qsTr("Transfer")
2015-07-17 20:06:07 +00:00
enabled: senderPicker.account && recipientPicker.account && senderPicker.account !== recipientPicker.account && amountField.value
onClicked: console.log(amountField.value)
}
}
}
2015-07-13 18:16:02 +00:00
}