2023-01-18 20:54:14 +01:00
|
|
|
import QtQuick 2.14
|
|
|
|
import QtQuick.Layouts 1.14
|
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
|
|
|
|
import shared.controls 1.0
|
|
|
|
|
2023-04-19 14:39:50 +02:00
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
|
2023-01-18 20:54:14 +01:00
|
|
|
ColumnLayout {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
property int mode: HoldingTypes.Mode.Add
|
|
|
|
property alias tokenName: item.name
|
|
|
|
property alias tokenShortName: item.shortName
|
2023-04-19 14:39:50 +02:00
|
|
|
property alias tokenAmount: item.amount
|
2023-01-18 20:54:14 +01:00
|
|
|
property alias tokenImage: item.iconSource
|
|
|
|
property alias amountText: amountInput.text
|
|
|
|
property alias amount: amountInput.amount
|
|
|
|
property alias tokenCategoryText: tokenLabel.text
|
2023-04-19 14:39:50 +02:00
|
|
|
property alias networkLabelText: d.networkLabelText
|
2023-01-18 20:54:14 +01:00
|
|
|
property alias addOrUpdateButtonEnabled: addOrUpdateButton.enabled
|
|
|
|
property alias allowDecimals: amountInput.allowDecimals
|
2023-04-19 14:39:50 +02:00
|
|
|
readonly property bool amountValid: amountInput.valid && !!amountInput.text
|
|
|
|
|
|
|
|
property var networksModel
|
2023-01-18 20:54:14 +01:00
|
|
|
|
|
|
|
signal addClicked
|
|
|
|
signal updateClicked
|
|
|
|
signal removeClicked
|
|
|
|
|
|
|
|
function setAmount(amount) {
|
|
|
|
amountInput.setAmount(amount)
|
|
|
|
}
|
|
|
|
|
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
|
|
|
|
// values from design
|
|
|
|
readonly property int defaultHeight: 44
|
|
|
|
readonly property int defaultSpacing: 8
|
2023-04-19 14:39:50 +02:00
|
|
|
|
|
|
|
property string networkLabelText: qsTr("Network for airdrop")
|
2023-01-18 20:54:14 +01:00
|
|
|
}
|
|
|
|
|
2023-04-19 14:39:50 +02:00
|
|
|
component CustomText: StatusBaseText {
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
font.pixelSize: 12
|
|
|
|
elide: Text.ElideRight
|
2023-01-18 20:54:14 +01:00
|
|
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.alignment: Qt.AlignVCenter
|
|
|
|
Layout.leftMargin: d.defaultSpacing
|
2023-04-19 14:39:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
spacing: d.defaultSpacing
|
|
|
|
|
|
|
|
CustomText {
|
|
|
|
id: tokenLabel
|
|
|
|
|
|
|
|
Layout.topMargin: 2 * d.defaultSpacing
|
2023-01-18 20:54:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
TokenItem {
|
|
|
|
id: item
|
2023-04-19 14:39:50 +02:00
|
|
|
|
2023-01-18 20:54:14 +01:00
|
|
|
Layout.fillWidth: true
|
|
|
|
enabled: false
|
|
|
|
}
|
|
|
|
|
2023-04-19 14:39:50 +02:00
|
|
|
Loader {
|
2023-04-27 23:38:09 +02:00
|
|
|
id: networksComboBoxLoader
|
|
|
|
|
2023-04-19 14:39:50 +02:00
|
|
|
active: !!root.networksModel
|
|
|
|
visible: active
|
|
|
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.topMargin: 14
|
|
|
|
Layout.bottomMargin: d.defaultSpacing
|
|
|
|
|
|
|
|
sourceComponent: ColumnLayout {
|
2023-04-27 23:38:09 +02:00
|
|
|
spacing: 10
|
|
|
|
|
|
|
|
property alias currentAmount: inlineNetworksComboBox.currentAmount
|
|
|
|
property alias currentInfiniteAmount: inlineNetworksComboBox.currentInfiniteAmount
|
2023-04-19 14:39:50 +02:00
|
|
|
|
|
|
|
CustomText {
|
|
|
|
id: networkLabel
|
|
|
|
|
|
|
|
text: d.networkLabelText
|
|
|
|
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
font.pixelSize: 12
|
|
|
|
elide: Text.ElideRight
|
|
|
|
}
|
|
|
|
|
|
|
|
InlineNetworksComboBox {
|
2023-04-27 23:38:09 +02:00
|
|
|
id: inlineNetworksComboBox
|
|
|
|
|
2023-04-19 14:39:50 +02:00
|
|
|
Layout.fillWidth: true
|
|
|
|
|
|
|
|
model: root.networksModel
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-01-18 20:54:14 +01:00
|
|
|
AmountInput {
|
|
|
|
id: amountInput
|
|
|
|
|
2023-04-04 13:13:33 -03:00
|
|
|
locale: LocaleUtils.userInputLocale
|
|
|
|
|
2023-01-18 20:54:14 +01:00
|
|
|
Layout.fillWidth: true
|
2023-04-27 23:38:09 +02:00
|
|
|
Layout.bottomMargin: (validationError !== "") ? root.spacing * 2 : 0
|
2023-01-18 20:54:14 +01:00
|
|
|
customHeight: d.defaultHeight
|
|
|
|
allowDecimals: true
|
|
|
|
keepHeight: true
|
2023-04-27 23:38:09 +02:00
|
|
|
|
|
|
|
validateMaximumAmount:
|
|
|
|
!!networksComboBoxLoader.item &&
|
|
|
|
!networksComboBoxLoader.item.currentInfiniteAmount
|
|
|
|
|
|
|
|
maximumAmount: !!networksComboBoxLoader.item
|
|
|
|
? networksComboBoxLoader.item.currentAmount : 0
|
|
|
|
|
2023-03-23 11:54:16 +02:00
|
|
|
onKeyPressed: {
|
|
|
|
if(!addOrUpdateButton.enabled) return
|
|
|
|
|
|
|
|
if(event.key === Qt.Key_Enter || event.key === Qt.Key_Return)
|
|
|
|
addOrUpdateButton.clicked()
|
|
|
|
}
|
|
|
|
onVisibleChanged: {
|
|
|
|
if(visible)
|
|
|
|
forceActiveFocus()
|
|
|
|
}
|
|
|
|
Component.onCompleted: {
|
|
|
|
if(visible)
|
|
|
|
forceActiveFocus()
|
|
|
|
}
|
2023-01-18 20:54:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
StatusButton {
|
|
|
|
id: addOrUpdateButton
|
|
|
|
|
|
|
|
text: (root.mode === HoldingTypes.Mode.Add) ? qsTr("Add") : qsTr("Update")
|
|
|
|
Layout.preferredHeight: d.defaultHeight
|
|
|
|
Layout.topMargin: d.defaultSpacing
|
|
|
|
Layout.fillWidth: true
|
|
|
|
onClicked: root.mode === HoldingTypes.Mode.Add
|
|
|
|
? root.addClicked() : root.updateClicked()
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusFlatButton {
|
|
|
|
text: qsTr("Remove")
|
|
|
|
Layout.preferredHeight: d.defaultHeight
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.topMargin: d.defaultSpacing
|
2023-01-24 22:49:07 +01:00
|
|
|
visible: root.mode === HoldingTypes.Mode.UpdateOrRemove
|
2023-01-18 20:54:14 +01:00
|
|
|
type: StatusBaseButton.Type.Danger
|
|
|
|
|
|
|
|
onClicked: root.removeClicked()
|
|
|
|
}
|
|
|
|
}
|