2023-09-15 10:51:06 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Controls 2.15
|
|
|
|
import QtQuick.Layouts 1.15
|
2023-04-06 16:26:56 -03:00
|
|
|
|
|
|
|
import StatusQ.Core 0.1
|
2023-09-15 10:51:06 +02:00
|
|
|
import shared.popups.send.views 1.0
|
2023-04-06 16:26:56 -03:00
|
|
|
|
2023-09-15 10:51:06 +02:00
|
|
|
import Storybook 1.0
|
2024-02-05 17:44:49 +01:00
|
|
|
import Models 1.0
|
2023-04-06 16:26:56 -03:00
|
|
|
|
|
|
|
SplitView {
|
|
|
|
id: root
|
|
|
|
|
2024-02-05 17:44:49 +01:00
|
|
|
readonly property var tokensBySymbolModel: TokensBySymbolModel {}
|
|
|
|
|
2023-04-06 16:26:56 -03:00
|
|
|
readonly property double maxCryptoBalance: parseFloat(maxCryptoBalanceText.text)
|
|
|
|
readonly property int decimals: parseInt(decimalsText.text)
|
|
|
|
|
|
|
|
Logs { id: logs }
|
2024-04-16 11:09:02 +02:00
|
|
|
|
|
|
|
Component.onCompleted: amountToSendInput.input.forceActiveFocus()
|
|
|
|
|
2023-04-06 16:26:56 -03:00
|
|
|
SplitView {
|
|
|
|
orientation: Qt.Vertical
|
|
|
|
SplitView.fillWidth: true
|
|
|
|
|
|
|
|
Item {
|
|
|
|
SplitView.fillWidth: true
|
|
|
|
SplitView.fillHeight: true
|
|
|
|
|
|
|
|
AmountToSend {
|
|
|
|
id: amountToSendInput
|
|
|
|
isBridgeTx: false
|
|
|
|
interactive: true
|
2024-02-05 17:44:49 +01:00
|
|
|
selectedHolding: tokensBySymbolModel.data[0]
|
2023-09-15 10:51:06 +02:00
|
|
|
|
|
|
|
inputIsFiat: fiatInput.checked
|
|
|
|
|
2024-02-05 17:44:49 +01:00
|
|
|
maxInputBalance: inputIsFiat ? root.maxCryptoBalance*amountToSendInput.selectedHolding.marketDetails.currencyPrice.amount
|
2023-09-15 10:51:06 +02:00
|
|
|
: root.maxCryptoBalance
|
2023-04-06 16:26:56 -03:00
|
|
|
currentCurrency: "Fiat"
|
2024-04-16 11:09:02 +02:00
|
|
|
formatCurrencyAmount: function(amount, symbol, options, locale) {
|
2023-04-06 16:26:56 -03:00
|
|
|
const currencyAmount = {
|
2024-04-16 11:09:02 +02:00
|
|
|
amount: amount,
|
|
|
|
symbol: symbol,
|
|
|
|
displayDecimals: root.decimals,
|
|
|
|
stripTrailingZeroes: true
|
2023-04-06 16:26:56 -03:00
|
|
|
}
|
2024-04-16 11:09:02 +02:00
|
|
|
return LocaleUtils.currencyAmountToLocaleString(currencyAmount, options, locale)
|
2023-04-06 16:26:56 -03:00
|
|
|
}
|
|
|
|
onReCalculateSuggestedRoute: function() {
|
|
|
|
logs.logEvent("onReCalculateSuggestedRoute")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
LogsAndControlsPanel {
|
|
|
|
id: logsAndControlsPanel
|
|
|
|
|
|
|
|
SplitView.minimumHeight: 100
|
|
|
|
|
|
|
|
logsView.logText: logs.logText
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Pane {
|
|
|
|
SplitView.minimumWidth: 300
|
|
|
|
SplitView.preferredWidth: 300
|
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
Label {
|
|
|
|
Layout.topMargin: 10
|
|
|
|
Layout.fillWidth: true
|
|
|
|
text: "Max Crypto Balance"
|
|
|
|
}
|
|
|
|
|
|
|
|
TextField {
|
|
|
|
id: maxCryptoBalanceText
|
|
|
|
background: Rectangle { border.color: 'lightgrey' }
|
|
|
|
Layout.preferredWidth: 200
|
|
|
|
text: "1000000"
|
|
|
|
}
|
|
|
|
|
|
|
|
Label {
|
|
|
|
Layout.topMargin: 10
|
|
|
|
Layout.fillWidth: true
|
|
|
|
text: "Decimals"
|
|
|
|
}
|
|
|
|
|
|
|
|
TextField {
|
|
|
|
id: decimalsText
|
|
|
|
background: Rectangle { border.color: 'lightgrey' }
|
|
|
|
Layout.preferredWidth: 200
|
|
|
|
text: "6"
|
|
|
|
}
|
2023-09-15 10:51:06 +02:00
|
|
|
|
|
|
|
CheckBox {
|
|
|
|
id: fiatInput
|
|
|
|
|
|
|
|
text: "Fiat input value"
|
|
|
|
}
|
2023-04-06 16:26:56 -03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-07-31 14:21:14 +02:00
|
|
|
|
2023-09-15 10:51:06 +02:00
|
|
|
// category: Components
|