2022-07-01 11:24:32 +00:00
|
|
|
|
import QtQuick 2.13
|
|
|
|
|
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 10:17:25 +00:00
|
|
|
|
id: root
|
2022-07-01 11:24:32 +00:00
|
|
|
|
|
2022-10-17 10:17:25 +00:00
|
|
|
|
property var bestRoutes
|
2022-07-01 11:24:32 +00:00
|
|
|
|
property double amountToSend: 0
|
2022-10-17 10:17:25 +00:00
|
|
|
|
property bool isLoading: false
|
|
|
|
|
property var weiToEth: function(wei) {}
|
2022-07-01 11:24:32 +00:00
|
|
|
|
|
|
|
|
|
spacing: 10
|
|
|
|
|
|
|
|
|
|
StatusRoundIcon {
|
|
|
|
|
Layout.alignment: Qt.AlignTop
|
|
|
|
|
radius: 8
|
2022-08-11 11:55:08 +00:00
|
|
|
|
asset.name: "flash"
|
2022-07-01 11:24:32 +00:00
|
|
|
|
}
|
|
|
|
|
ColumnLayout {
|
|
|
|
|
Layout.alignment: Qt.AlignTop
|
2022-10-17 10:17:25 +00:00
|
|
|
|
Layout.preferredWidth: root.width
|
2022-07-01 11:24:32 +00:00
|
|
|
|
StatusBaseText {
|
|
|
|
|
Layout.maximumWidth: 410
|
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
font.weight: Font.Medium
|
|
|
|
|
color: Theme.palette.directColor1
|
|
|
|
|
text: qsTr("Networks")
|
|
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
|
}
|
|
|
|
|
StatusBaseText {
|
|
|
|
|
Layout.maximumWidth: 410
|
|
|
|
|
font.pixelSize: 15
|
|
|
|
|
color: Theme.palette.baseColor1
|
2022-10-17 10:17:25 +00:00
|
|
|
|
text: qsTr("The networks where the receipient will receive tokens. Amounts calculated automatically for the lowest cost.")
|
2022-07-01 11:24:32 +00:00
|
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
|
}
|
|
|
|
|
BalanceExceeded {
|
2022-07-27 21:10:00 +00:00
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
Layout.alignment: Qt.AlignHCenter
|
2022-07-01 11:24:32 +00:00
|
|
|
|
Layout.topMargin: Style.current.bigPadding
|
2022-10-17 10:17:25 +00:00
|
|
|
|
transferPossible: root.bestRoutes !== undefined ? root.bestRoutes.length > 0 : true
|
|
|
|
|
amountToSend: root.amountToSend
|
|
|
|
|
isLoading: root.isLoading
|
2022-07-01 11:24:32 +00:00
|
|
|
|
}
|
|
|
|
|
ScrollView {
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
Layout.preferredHeight: row.height + 10
|
|
|
|
|
Layout.topMargin: Style.current.bigPadding
|
|
|
|
|
contentWidth: row.width
|
|
|
|
|
contentHeight: row.height + 10
|
|
|
|
|
ScrollBar.vertical.policy: ScrollBar.AlwaysOff
|
|
|
|
|
ScrollBar.horizontal.policy: ScrollBar.AsNeeded
|
|
|
|
|
clip: true
|
2022-10-17 10:17:25 +00:00
|
|
|
|
visible: !root.isLoading ? root.bestRoutes !== undefined ? root.bestRoutes.length > 0 : true : false
|
2022-07-01 11:24:32 +00:00
|
|
|
|
Row {
|
|
|
|
|
id: row
|
|
|
|
|
spacing: Style.current.padding
|
|
|
|
|
Repeater {
|
|
|
|
|
id: repeater
|
2022-07-21 12:15:02 +00:00
|
|
|
|
objectName: "networksList"
|
2022-10-17 10:17:25 +00:00
|
|
|
|
model: root.bestRoutes
|
2022-07-01 11:24:32 +00:00
|
|
|
|
StatusListItem {
|
|
|
|
|
id: item
|
2022-10-17 10:17:25 +00:00
|
|
|
|
objectName: modelData.toNetwork.chainName
|
2022-07-01 11:24:32 +00:00
|
|
|
|
leftPadding: 5
|
|
|
|
|
rightPadding: 5
|
2022-10-17 10:17:25 +00:00
|
|
|
|
implicitWidth: 150
|
|
|
|
|
title: modelData.toNetwork.chainName
|
|
|
|
|
subTitle: root.weiToEth(modelData.amountIn)
|
|
|
|
|
statusListItemSubTitle.color: Theme.palette.primaryColor1
|
2022-08-11 11:55:08 +00:00
|
|
|
|
asset.width: 32
|
|
|
|
|
asset.height: 32
|
2022-10-17 10:17:25 +00:00
|
|
|
|
asset.name: Style.svg("tiny/" + modelData.toNetwork.iconUrl)
|
2022-08-11 11:55:08 +00:00
|
|
|
|
asset.isImage: true
|
2022-07-01 11:24:32 +00:00
|
|
|
|
color: "transparent"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|