2022-12-14 22:06:14 +01:00
|
|
|
import QtQuick 2.13
|
|
|
|
import QtQuick.Layouts 1.13
|
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
|
|
|
|
import utils 1.0
|
2023-01-08 19:23:51 -03:00
|
|
|
import shared.stores 1.0
|
2022-12-14 22:06:14 +01:00
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
id: root
|
|
|
|
|
2024-02-05 17:44:49 +01:00
|
|
|
property var selectedHolding
|
2022-12-14 22:06:14 +01:00
|
|
|
property bool isLoading: false
|
2023-02-17 09:56:31 -03:00
|
|
|
property double cryptoValueToReceive
|
2022-12-14 22:06:14 +01:00
|
|
|
property bool isBridgeTx: false
|
2023-01-08 19:23:51 -03:00
|
|
|
property bool inputIsFiat: false
|
|
|
|
property string currentCurrency
|
2023-02-17 11:09:15 -03:00
|
|
|
property int minCryptoDecimals: 0
|
|
|
|
property int minFiatDecimals: 0
|
2023-02-17 09:56:31 -03:00
|
|
|
property var formatCurrencyAmount: function() {}
|
2022-12-14 22:06:14 +01:00
|
|
|
|
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
readonly property string fiatValue: {
|
2024-02-05 17:44:49 +01:00
|
|
|
if(!root.selectedHolding || !root.selectedHolding.symbol || !root.selectedHolding.marketDetails ||
|
|
|
|
!root.selectedHolding.marketDetails.currencyPrice || !cryptoValueToReceive)
|
2023-01-08 19:23:51 -03:00
|
|
|
return LocaleUtils.numberToLocaleString(0, 2)
|
2024-02-05 17:44:49 +01:00
|
|
|
let fiatValue = cryptoValueToReceive * root.selectedHolding.marketDetails.currencyPrice.amount
|
2023-02-17 11:09:15 -03:00
|
|
|
return root.formatCurrencyAmount(fiatValue, root.currentCurrency, inputIsFiat ? {"minDecimals": root.minFiatDecimals, "stripTrailingZeroes": true} : {})
|
2023-01-08 19:23:51 -03:00
|
|
|
}
|
|
|
|
readonly property string cryptoValue: {
|
2024-02-05 17:44:49 +01:00
|
|
|
if(!root.selectedHolding || !root.selectedHolding.symbol || !cryptoValueToReceive)
|
2023-01-08 19:23:51 -03:00
|
|
|
return LocaleUtils.numberToLocaleString(0, 2)
|
2024-02-05 17:44:49 +01:00
|
|
|
return root.formatCurrencyAmount(cryptoValueToReceive, root.selectedHolding.symbol, !inputIsFiat ? {"minDecimals": root.minCryptoDecimals, "stripTrailingZeroes": true} : {})
|
2022-12-14 22:06:14 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusBaseText {
|
|
|
|
Layout.alignment: Qt.AlignRight | Qt.AlignTop
|
|
|
|
text: root.isBridgeTx ? qsTr("Amount Bridged") : qsTr("Recipient will get")
|
|
|
|
font.pixelSize: 13
|
|
|
|
lineHeight: 18
|
|
|
|
lineHeightMode: Text.FixedHeight
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
}
|
|
|
|
RowLayout {
|
|
|
|
Layout.alignment: Qt.AlignRight
|
|
|
|
Layout.preferredHeight: 42
|
|
|
|
StatusBaseText {
|
|
|
|
id: amountToReceiveText
|
|
|
|
Layout.alignment: Qt.AlignVCenter
|
2023-01-08 19:23:51 -03:00
|
|
|
text: isLoading ? "..." : inputIsFiat ? d.fiatValue : d.cryptoValue
|
2022-12-14 22:06:14 +01:00
|
|
|
font.pixelSize: Utils.getFontSizeBasedOnLetterCount(text)
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
RowLayout {
|
|
|
|
Layout.alignment: Qt.AlignRight | Qt.AlignBottom
|
|
|
|
StatusBaseText {
|
|
|
|
id: txtFiatBalance
|
|
|
|
Layout.alignment: Qt.AlignLeft | Qt.AlignTop
|
2023-01-08 19:23:51 -03:00
|
|
|
text: isLoading ? "..." : inputIsFiat ? d.cryptoValue : d.fiatValue
|
2022-12-14 22:06:14 +01:00
|
|
|
font.pixelSize: 13
|
|
|
|
color: Theme.palette.directColor5
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|