2023-02-17 11:09:15 -03:00
|
|
|
|
import QtQuick 2.13
|
2022-07-01 13:24:32 +02:00
|
|
|
|
import QtQuick.Controls 2.13
|
|
|
|
|
import QtQuick.Layouts 1.13
|
|
|
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
|
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
import StatusQ.Popups 0.1
|
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
|
import StatusQ.Core 0.1
|
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
|
|
|
|
|
|
import "../controls"
|
|
|
|
|
|
|
|
|
|
RowLayout {
|
2022-10-17 12:17:25 +02:00
|
|
|
|
id: root
|
2022-07-01 13:24:32 +02:00
|
|
|
|
|
2022-11-23 18:58:22 +01:00
|
|
|
|
property var store
|
2023-02-17 11:09:15 -03:00
|
|
|
|
property int minReceiveCryptoDecimals: 0
|
2022-10-17 12:17:25 +02:00
|
|
|
|
property bool isLoading: false
|
2022-11-23 18:58:22 +01:00
|
|
|
|
property bool isBridgeTx: false
|
2024-03-05 10:27:40 +01:00
|
|
|
|
property bool isCollectiblesTransfer: false
|
2022-12-09 10:10:05 +01:00
|
|
|
|
property var selectedAccount
|
2023-08-15 20:21:51 +02:00
|
|
|
|
property var toNetworksList
|
2022-10-17 12:17:25 +02:00
|
|
|
|
property var weiToEth: function(wei) {}
|
2023-02-17 09:56:31 -03:00
|
|
|
|
property var formatCurrencyAmount: function () {}
|
2022-11-23 18:58:22 +01:00
|
|
|
|
property var reCalculateSuggestedRoute: function() {}
|
2022-11-25 10:13:02 +01:00
|
|
|
|
property bool errorMode: false
|
2022-12-19 14:02:56 +01:00
|
|
|
|
property int errorType: Constants.NoError
|
2024-02-05 17:44:49 +01:00
|
|
|
|
property string selectedSymbol
|
2022-07-01 13:24:32 +02:00
|
|
|
|
spacing: 10
|
|
|
|
|
|
|
|
|
|
StatusRoundIcon {
|
|
|
|
|
Layout.alignment: Qt.AlignTop
|
|
|
|
|
radius: 8
|
2022-08-11 14:55:08 +03:00
|
|
|
|
asset.name: "flash"
|
2022-12-14 22:06:14 +01:00
|
|
|
|
asset.color: Theme.palette.directColor1
|
2022-07-01 13:24:32 +02:00
|
|
|
|
}
|
|
|
|
|
ColumnLayout {
|
|
|
|
|
Layout.alignment: Qt.AlignTop
|
2022-10-17 12:17:25 +02:00
|
|
|
|
Layout.preferredWidth: root.width
|
2023-01-27 18:46:42 +05:30
|
|
|
|
spacing: 4
|
2022-07-01 13:24:32 +02:00
|
|
|
|
StatusBaseText {
|
2024-02-12 17:44:35 +01:00
|
|
|
|
Layout.maximumWidth: parent.width
|
2022-07-01 13:24:32 +02:00
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
font.weight: Font.Medium
|
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
|
text: qsTr("Networks")
|
|
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
|
}
|
|
|
|
|
StatusBaseText {
|
2024-02-12 17:44:35 +01:00
|
|
|
|
Layout.maximumWidth: parent.width
|
2022-07-01 13:24:32 +02:00
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
color: Theme.palette.baseColor1
|
2022-11-23 18:58:22 +01:00
|
|
|
|
text: isBridgeTx ? qsTr("Choose the network to bridge token to") :
|
|
|
|
|
qsTr("The networks where the receipient will receive tokens. Amounts calculated automatically for the lowest cost.")
|
2022-07-01 13:24:32 +02:00
|
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
|
}
|
|
|
|
|
ScrollView {
|
|
|
|
|
Layout.fillWidth: true
|
2023-01-27 18:46:42 +05:30
|
|
|
|
Layout.preferredHeight: visible ? row.height + 10 : 0
|
|
|
|
|
Layout.topMargin: Style.current.smallPadding
|
2022-07-01 13:24:32 +02:00
|
|
|
|
contentWidth: row.width
|
|
|
|
|
contentHeight: row.height + 10
|
|
|
|
|
ScrollBar.vertical.policy: ScrollBar.AlwaysOff
|
|
|
|
|
ScrollBar.horizontal.policy: ScrollBar.AsNeeded
|
|
|
|
|
clip: true
|
2023-01-27 18:46:42 +05:30
|
|
|
|
visible: root.isBridgeTx ? true : !root.isLoading ? root.errorType === Constants.NoError : false
|
2022-12-14 22:06:14 +01:00
|
|
|
|
Column {
|
2022-07-01 13:24:32 +02:00
|
|
|
|
id: row
|
|
|
|
|
spacing: Style.current.padding
|
|
|
|
|
Repeater {
|
|
|
|
|
id: repeater
|
2022-07-21 14:15:02 +02:00
|
|
|
|
objectName: "networksList"
|
2023-08-15 20:21:51 +02:00
|
|
|
|
model: isBridgeTx ? store.fromNetworksModel : root.toNetworksList
|
2022-11-23 18:58:22 +01:00
|
|
|
|
delegate: isBridgeTx ? networkItem : routeItem
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
BalanceExceeded {
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
Layout.alignment: Qt.AlignHCenter
|
2023-01-27 18:46:42 +05:30
|
|
|
|
Layout.topMargin: Style.current.smallPadding
|
2022-12-19 14:02:56 +01:00
|
|
|
|
errorType: root.errorType
|
2023-01-27 18:46:42 +05:30
|
|
|
|
isLoading: root.isLoading && !root.isBridgeTx
|
2022-11-23 18:58:22 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ButtonGroup {
|
|
|
|
|
buttons: repeater.children
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Component {
|
|
|
|
|
id: routeItem
|
|
|
|
|
StatusListItem {
|
2023-08-15 20:21:51 +02:00
|
|
|
|
objectName: model.chainName
|
2022-11-23 18:58:22 +01:00
|
|
|
|
leftPadding: 5
|
|
|
|
|
rightPadding: 5
|
2022-12-14 22:06:14 +01:00
|
|
|
|
implicitWidth: 410
|
2023-08-15 20:21:51 +02:00
|
|
|
|
title: model.chainName
|
2022-11-25 10:13:02 +01:00
|
|
|
|
subTitle: {
|
2024-03-05 10:27:40 +01:00
|
|
|
|
if(root.isCollectiblesTransfer)
|
2023-08-31 12:27:15 +02:00
|
|
|
|
return ""
|
2023-08-15 20:21:51 +02:00
|
|
|
|
let amountOut = root.weiToEth(model.amountOut)
|
2024-02-05 17:44:49 +01:00
|
|
|
|
return root.formatCurrencyAmount(amountOut, root.selectedSymbol, {"minDecimals": root.minReceiveCryptoDecimals})
|
2022-11-25 10:13:02 +01:00
|
|
|
|
}
|
|
|
|
|
statusListItemSubTitle.color: root.errorMode ? Theme.palette.dangerColor1 : Theme.palette.primaryColor1
|
2022-11-23 18:58:22 +01:00
|
|
|
|
asset.width: 32
|
|
|
|
|
asset.height: 32
|
2023-08-15 20:21:51 +02:00
|
|
|
|
asset.name: Style.svg("tiny/" + model.iconUrl)
|
2022-11-23 18:58:22 +01:00
|
|
|
|
asset.isImage: true
|
|
|
|
|
color: "transparent"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Component {
|
|
|
|
|
id: networkItem
|
|
|
|
|
StatusRadioButton {
|
|
|
|
|
id: gasRectangle
|
|
|
|
|
width: contentItem.implicitWidth
|
|
|
|
|
contentItem: StatusListItem {
|
|
|
|
|
id: card
|
|
|
|
|
objectName: chainName
|
|
|
|
|
leftPadding: 5
|
|
|
|
|
rightPadding: 5
|
2023-01-27 18:46:42 +05:30
|
|
|
|
implicitWidth: 410
|
2022-11-23 18:58:22 +01:00
|
|
|
|
title: chainName
|
2024-02-05 17:44:49 +01:00
|
|
|
|
subTitle: root.formatCurrencyAmount(tokenBalance.amount, root.selectedSymbol)
|
2022-11-23 18:58:22 +01:00
|
|
|
|
statusListItemSubTitle.color: Theme.palette.primaryColor1
|
|
|
|
|
asset.width: 32
|
|
|
|
|
asset.height: 32
|
|
|
|
|
asset.name: Style.svg("tiny/" + iconUrl)
|
|
|
|
|
asset.isImage: true
|
2023-01-27 18:46:42 +05:30
|
|
|
|
border.color: gasRectangle.checked ? Theme.palette.primaryColor2 : "transparent"
|
2022-11-23 18:58:22 +01:00
|
|
|
|
color: {
|
|
|
|
|
if (sensor.containsMouse || highlighted || gasRectangle.checked) {
|
2023-01-27 18:46:42 +05:30
|
|
|
|
return Theme.palette.statusListItem.backgroundColor
|
2022-07-01 13:24:32 +02:00
|
|
|
|
}
|
2023-01-27 18:46:42 +05:30
|
|
|
|
return Theme.palette.baseColor2
|
2022-07-01 13:24:32 +02:00
|
|
|
|
}
|
2022-11-23 18:58:22 +01:00
|
|
|
|
onClicked: gasRectangle.toggle()
|
|
|
|
|
}
|
|
|
|
|
onCheckedChanged: {
|
2023-08-31 12:27:15 +02:00
|
|
|
|
store.setRouteDisabledChains(chainId, !gasRectangle.checked)
|
2022-11-23 18:58:22 +01:00
|
|
|
|
if(checked)
|
|
|
|
|
root.reCalculateSuggestedRoute()
|
|
|
|
|
}
|
|
|
|
|
checked: index === 0
|
|
|
|
|
indicator: Item {
|
|
|
|
|
width: card.width
|
|
|
|
|
height: card.height
|
|
|
|
|
}
|
|
|
|
|
Component.onCompleted: {
|
2023-08-31 12:27:15 +02:00
|
|
|
|
store.setRouteDisabledChains(chainId, !gasRectangle.checked)
|
2022-11-23 18:58:22 +01:00
|
|
|
|
if(index === (repeater.count -1))
|
|
|
|
|
root.reCalculateSuggestedRoute()
|
2022-07-01 13:24:32 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|