mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-12 23:35:32 +00:00
6d7fda53f6
Fixes #10125
108 lines
2.9 KiB
QML
108 lines
2.9 KiB
QML
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
|
|
|
|
ColumnLayout {
|
|
id: root
|
|
|
|
property int mode: HoldingTypes.Mode.Add
|
|
property alias tokenName: item.name
|
|
property alias tokenShortName: item.shortName
|
|
property alias tokenImage: item.iconSource
|
|
property alias amountText: amountInput.text
|
|
property alias amount: amountInput.amount
|
|
property alias tokenCategoryText: tokenLabel.text
|
|
property alias addOrUpdateButtonEnabled: addOrUpdateButton.enabled
|
|
property alias allowDecimals: amountInput.allowDecimals
|
|
readonly property bool amountValid: amountInput.valid && amountInput.text.length > 0
|
|
|
|
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
|
|
}
|
|
|
|
spacing: d.defaultSpacing
|
|
|
|
StatusBaseText {
|
|
id: tokenLabel
|
|
Layout.topMargin: 2 * d.defaultSpacing
|
|
Layout.fillWidth: true
|
|
Layout.alignment: Qt.AlignVCenter
|
|
Layout.leftMargin: d.defaultSpacing
|
|
color: Theme.palette.baseColor1
|
|
font.pixelSize: 12
|
|
elide: Text.ElideRight
|
|
}
|
|
|
|
TokenItem {
|
|
id: item
|
|
Layout.fillWidth: true
|
|
enabled: false
|
|
}
|
|
|
|
AmountInput {
|
|
id: amountInput
|
|
|
|
locale: LocaleUtils.userInputLocale
|
|
|
|
Layout.fillWidth: true
|
|
Layout.bottomMargin: (validationError !== "") ? root.spacing : 0
|
|
customHeight: d.defaultHeight
|
|
allowDecimals: true
|
|
keepHeight: true
|
|
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()
|
|
}
|
|
}
|
|
|
|
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
|
|
visible: root.mode === HoldingTypes.Mode.UpdateOrRemove
|
|
type: StatusBaseButton.Type.Danger
|
|
|
|
onClicked: root.removeClicked()
|
|
}
|
|
}
|