2023-11-24 13:16:13 +01:00
|
|
|
|
import QtQuick 2.13
|
2022-08-08 23:12:12 +02:00
|
|
|
|
import QtQuick.Controls 2.14
|
|
|
|
|
|
|
|
|
|
import utils 1.0
|
|
|
|
|
import shared.controls 1.0
|
|
|
|
|
|
2023-10-30 23:18:58 +01:00
|
|
|
|
import StatusQ 0.1
|
2022-08-08 23:12:12 +02:00
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
|
import StatusQ.Core 0.1
|
2023-11-24 13:16:13 +01:00
|
|
|
|
import StatusQ.Core.Utils 0.1 as SQUtils
|
2022-08-08 23:12:12 +02:00
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
|
2023-11-24 13:16:13 +01:00
|
|
|
|
import SortFilterProxyModel 0.2
|
|
|
|
|
|
2022-08-08 23:12:12 +02:00
|
|
|
|
Control {
|
|
|
|
|
id: root
|
|
|
|
|
|
|
|
|
|
property alias primaryText: tokenName.text
|
|
|
|
|
property alias secondaryText: cryptoBalance.text
|
|
|
|
|
property alias tertiaryText: fiatBalance.text
|
|
|
|
|
property var balances
|
2023-11-24 13:16:13 +01:00
|
|
|
|
property int decimals
|
|
|
|
|
property var allNetworksModel
|
2023-03-15 10:17:25 +01:00
|
|
|
|
property bool isLoading: false
|
|
|
|
|
property string errorTooltipText
|
2022-08-11 14:55:08 +03:00
|
|
|
|
property StatusAssetSettings asset: StatusAssetSettings {
|
2022-08-08 23:12:12 +02:00
|
|
|
|
width: 40
|
|
|
|
|
height: 40
|
|
|
|
|
}
|
2022-12-29 13:44:51 -03:00
|
|
|
|
property var formatBalance: function(balance){}
|
2022-08-08 23:12:12 +02:00
|
|
|
|
|
|
|
|
|
topPadding: Style.current.padding
|
|
|
|
|
|
|
|
|
|
contentItem: Column {
|
|
|
|
|
spacing: 4
|
|
|
|
|
Row {
|
|
|
|
|
spacing: 8
|
|
|
|
|
StatusSmartIdenticon {
|
|
|
|
|
id: identiconLoader
|
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
2022-08-11 14:55:08 +03:00
|
|
|
|
asset: root.asset
|
2023-03-15 10:17:25 +01:00
|
|
|
|
loading: root.isLoading
|
2022-08-08 23:12:12 +02:00
|
|
|
|
}
|
2023-03-15 10:17:25 +01:00
|
|
|
|
StatusTextWithLoadingState {
|
2022-08-08 23:12:12 +02:00
|
|
|
|
id: tokenName
|
|
|
|
|
width: Math.min(root.width - identiconLoader.width - cryptoBalance.width - fiatBalance.width - 24, implicitWidth)
|
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
|
font.pixelSize: 22
|
|
|
|
|
lineHeight: 30
|
|
|
|
|
lineHeightMode: Text.FixedHeight
|
|
|
|
|
elide: Text.ElideRight
|
2023-03-15 10:17:25 +01:00
|
|
|
|
customColor: Theme.palette.directColor1
|
|
|
|
|
loading: root.isLoading
|
2022-08-08 23:12:12 +02:00
|
|
|
|
}
|
2023-03-15 10:17:25 +01:00
|
|
|
|
StatusTextWithLoadingState {
|
2022-08-08 23:12:12 +02:00
|
|
|
|
id: cryptoBalance
|
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
|
font.pixelSize: 22
|
|
|
|
|
lineHeight: 30
|
|
|
|
|
lineHeightMode: Text.FixedHeight
|
2023-03-15 10:17:25 +01:00
|
|
|
|
customColor: Theme.palette.baseColor1
|
|
|
|
|
loading: root.isLoading
|
2022-08-08 23:12:12 +02:00
|
|
|
|
}
|
|
|
|
|
StatusBaseText {
|
|
|
|
|
id: dotSeparator
|
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
|
anchors.verticalCenterOffset: -15
|
|
|
|
|
font.pixelSize: 50
|
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
|
text: "."
|
|
|
|
|
}
|
2023-03-15 10:17:25 +01:00
|
|
|
|
StatusTextWithLoadingState {
|
2022-08-08 23:12:12 +02:00
|
|
|
|
id: fiatBalance
|
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
|
font.pixelSize: 22
|
|
|
|
|
lineHeight: 30
|
|
|
|
|
lineHeightMode: Text.FixedHeight
|
2023-03-15 10:17:25 +01:00
|
|
|
|
customColor: Theme.palette.baseColor1
|
|
|
|
|
loading: root.isLoading
|
2022-08-08 23:12:12 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2023-11-24 13:16:13 +01:00
|
|
|
|
|
2022-08-08 23:12:12 +02:00
|
|
|
|
Row {
|
|
|
|
|
spacing: Style.current.smallPadding
|
|
|
|
|
anchors.left: parent.left
|
|
|
|
|
anchors.leftMargin: identiconLoader.width
|
|
|
|
|
Repeater {
|
|
|
|
|
id: chainRepeater
|
2023-11-24 13:16:13 +01:00
|
|
|
|
model: root.allNetworksModel
|
2022-08-08 23:12:12 +02:00
|
|
|
|
delegate: InformationTag {
|
2023-11-24 13:16:13 +01:00
|
|
|
|
readonly property double aggregatedbalance: balancesAggregator.value/(10 ** root.decimals)
|
|
|
|
|
SortFilterProxyModel {
|
|
|
|
|
id: filteredBalances
|
|
|
|
|
sourceModel: root.balances
|
|
|
|
|
filters: ValueFilter {
|
|
|
|
|
roleName: "chainId"
|
|
|
|
|
value: model.chainId
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
SumAggregator {
|
|
|
|
|
id: balancesAggregator
|
|
|
|
|
model: filteredBalances
|
|
|
|
|
roleName: "balance"
|
|
|
|
|
}
|
|
|
|
|
tagPrimaryLabel.text: root.formatBalance(aggregatedbalance)
|
2023-10-30 23:18:58 +01:00
|
|
|
|
tagPrimaryLabel.color: model.chainColor
|
|
|
|
|
image.source: Style.svg("tiny/%1".arg(model.iconUrl))
|
2023-03-15 10:17:25 +01:00
|
|
|
|
loading: root.isLoading
|
2023-11-24 13:16:13 +01:00
|
|
|
|
visible: balancesAggregator.value > 0
|
2023-03-15 10:17:25 +01:00
|
|
|
|
rightComponent: StatusFlatRoundButton {
|
|
|
|
|
width: 14
|
|
|
|
|
height: visible ? 14 : 0
|
|
|
|
|
icon.width: 14
|
|
|
|
|
icon.height: 14
|
|
|
|
|
icon.name: "tiny/warning"
|
|
|
|
|
icon.color: Theme.palette.dangerColor1
|
|
|
|
|
tooltip.text: root.errorTooltipText
|
|
|
|
|
visible: !!root.errorTooltipText
|
|
|
|
|
}
|
2022-08-08 23:12:12 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|