2023-10-24 13:21:20 +02:00
|
|
|
|
import QtQuick 2.15
|
2024-01-04 13:05:54 +01:00
|
|
|
|
import QtQuick.Controls 2.15
|
2023-10-24 13:21:20 +02:00
|
|
|
|
import QtQuick.Layouts 1.15
|
|
|
|
|
|
2024-01-04 13:05:54 +01:00
|
|
|
|
import StatusQ.Core 0.1
|
2023-10-24 13:21:20 +02:00
|
|
|
|
import StatusQ.Controls 0.1
|
2024-01-04 13:05:54 +01:00
|
|
|
|
import StatusQ.Components 0.1
|
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
|
import StatusQ.Popups.Dialog 0.1
|
2023-10-24 13:21:20 +02:00
|
|
|
|
|
|
|
|
|
import shared.controls 1.0
|
2024-01-04 13:05:54 +01:00
|
|
|
|
import shared.stores 1.0 as SharedStores
|
2023-11-17 15:08:43 +01:00
|
|
|
|
import utils 1.0
|
2023-10-24 13:21:20 +02:00
|
|
|
|
|
2023-10-25 12:40:10 +02:00
|
|
|
|
import AppLayouts.Profile.panels 1.0
|
2023-11-17 15:08:43 +01:00
|
|
|
|
import AppLayouts.Wallet.panels 1.0
|
2023-10-25 12:40:10 +02:00
|
|
|
|
|
2023-10-24 13:21:20 +02:00
|
|
|
|
ColumnLayout {
|
|
|
|
|
id: root
|
|
|
|
|
|
2023-10-25 12:40:10 +02:00
|
|
|
|
required property var sourcesOfTokensModel // Expected roles: key, name, updatedAt, source, version, tokensCount, image
|
|
|
|
|
required property var tokensListModel // Expected roles: name, symbol, image, chainName, explorerUrl
|
|
|
|
|
|
2023-11-17 15:08:43 +01:00
|
|
|
|
required property var baseWalletAssetsModel
|
|
|
|
|
required property var baseWalletCollectiblesModel
|
|
|
|
|
|
2023-12-06 11:54:36 +01:00
|
|
|
|
property alias currentIndex: tabBar.currentIndex
|
|
|
|
|
|
2023-11-17 15:08:43 +01:00
|
|
|
|
readonly property bool dirty: {
|
|
|
|
|
if (!loader.item)
|
|
|
|
|
return false
|
|
|
|
|
if (tabBar.currentIndex > d.collectiblesTabIndex)
|
|
|
|
|
return false
|
2024-01-04 13:05:54 +01:00
|
|
|
|
// FIXME take advanced settings into account here too (#13178)
|
2023-11-22 20:58:02 +01:00
|
|
|
|
if (tabBar.currentIndex === d.collectiblesTabIndex && baseWalletCollectiblesModel.isFetching)
|
2023-11-17 15:08:43 +01:00
|
|
|
|
return false
|
|
|
|
|
return loader.item && loader.item.dirty
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function saveChanges() {
|
|
|
|
|
if (tabBar.currentIndex > d.collectiblesTabIndex)
|
|
|
|
|
return
|
2024-01-04 13:05:54 +01:00
|
|
|
|
// FIXME save advanced settings (#13178)
|
2023-11-17 15:08:43 +01:00
|
|
|
|
loader.item.saveSettings()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function resetChanges() {
|
|
|
|
|
if (tabBar.currentIndex > d.collectiblesTabIndex)
|
|
|
|
|
return
|
|
|
|
|
loader.item.revert()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QtObject {
|
|
|
|
|
id: d
|
|
|
|
|
|
|
|
|
|
readonly property int assetsTabIndex: 0
|
|
|
|
|
readonly property int collectiblesTabIndex: 1
|
2024-01-04 13:05:54 +01:00
|
|
|
|
readonly property int advancedTabIndex: 2
|
2023-11-17 15:08:43 +01:00
|
|
|
|
|
|
|
|
|
function checkLoadMoreCollectibles() {
|
|
|
|
|
if (tabBar.currentIndex !== collectiblesTabIndex)
|
|
|
|
|
return
|
|
|
|
|
// If there is no more items to load or we're already fetching, return
|
2023-11-22 20:58:02 +01:00
|
|
|
|
if (!root.baseWalletCollectiblesModel.hasMore || root.baseWalletCollectiblesModel.isFetching)
|
2023-11-17 15:08:43 +01:00
|
|
|
|
return
|
2023-11-22 20:58:02 +01:00
|
|
|
|
root.baseWalletCollectiblesModel.loadMore()
|
2023-11-17 15:08:43 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Connections {
|
2023-11-22 20:58:02 +01:00
|
|
|
|
target: root.baseWalletCollectiblesModel
|
2023-11-17 15:08:43 +01:00
|
|
|
|
function onHasMoreChanged() {
|
|
|
|
|
d.checkLoadMoreCollectibles()
|
|
|
|
|
}
|
|
|
|
|
function onIsFetchingChanged() {
|
|
|
|
|
d.checkLoadMoreCollectibles()
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-10-24 13:21:20 +02:00
|
|
|
|
StatusTabBar {
|
|
|
|
|
id: tabBar
|
|
|
|
|
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
Layout.topMargin: 5
|
|
|
|
|
|
|
|
|
|
StatusTabButton {
|
2023-11-17 15:08:43 +01:00
|
|
|
|
leftPadding: 0
|
2023-10-24 13:21:20 +02:00
|
|
|
|
width: implicitWidth
|
|
|
|
|
text: qsTr("Assets")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StatusTabButton {
|
|
|
|
|
width: implicitWidth
|
2023-11-17 15:08:43 +01:00
|
|
|
|
text: qsTr("Collectibles")
|
2023-10-24 13:21:20 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StatusTabButton {
|
|
|
|
|
width: implicitWidth
|
2024-01-04 13:05:54 +01:00
|
|
|
|
text: qsTr("Advanced")
|
2023-10-24 13:21:20 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-11-17 15:08:43 +01:00
|
|
|
|
// NB: we want to discard any pending unsaved changes when switching tabs or navigating away
|
|
|
|
|
Loader {
|
|
|
|
|
id: loader
|
2023-10-24 13:21:20 +02:00
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
Layout.fillHeight: true
|
2023-11-17 15:08:43 +01:00
|
|
|
|
active: visible
|
|
|
|
|
|
|
|
|
|
sourceComponent: {
|
|
|
|
|
switch (tabBar.currentIndex) {
|
|
|
|
|
case d.assetsTabIndex:
|
|
|
|
|
return tokensPanel
|
|
|
|
|
case d.collectiblesTabIndex:
|
|
|
|
|
return collectiblesPanel
|
2024-01-04 13:05:54 +01:00
|
|
|
|
case d.advancedTabIndex:
|
|
|
|
|
return advancedTab
|
2023-11-17 15:08:43 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-10-24 13:21:20 +02:00
|
|
|
|
|
2023-11-17 15:08:43 +01:00
|
|
|
|
Component {
|
|
|
|
|
id: tokensPanel
|
|
|
|
|
ManageAssetsPanel {
|
|
|
|
|
baseModel: root.baseWalletAssetsModel
|
2023-10-24 13:21:20 +02:00
|
|
|
|
}
|
2023-11-17 15:08:43 +01:00
|
|
|
|
}
|
2023-10-24 13:21:20 +02:00
|
|
|
|
|
2023-11-17 15:08:43 +01:00
|
|
|
|
Component {
|
|
|
|
|
id: collectiblesPanel
|
|
|
|
|
ManageCollectiblesPanel {
|
|
|
|
|
baseModel: root.baseWalletCollectiblesModel
|
|
|
|
|
Component.onCompleted: d.checkLoadMoreCollectibles()
|
2023-10-24 13:21:20 +02:00
|
|
|
|
}
|
2023-11-17 15:08:43 +01:00
|
|
|
|
}
|
2023-10-24 13:21:20 +02:00
|
|
|
|
|
2023-11-17 15:08:43 +01:00
|
|
|
|
Component {
|
2024-01-04 13:05:54 +01:00
|
|
|
|
id: advancedTab
|
|
|
|
|
ColumnLayout {
|
|
|
|
|
spacing: 0
|
|
|
|
|
StatusBaseText {
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
Layout.topMargin: 18
|
|
|
|
|
Layout.bottomMargin: 18
|
|
|
|
|
text: qsTr("Token lists")
|
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
|
}
|
|
|
|
|
SupportedTokenListsPanel {
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
Layout.fillHeight: true
|
|
|
|
|
sourcesOfTokensModel: root.sourcesOfTokensModel
|
|
|
|
|
tokensListModel: root.tokensListModel
|
|
|
|
|
}
|
|
|
|
|
StatusBaseText {
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
Layout.topMargin: 40 + 18
|
|
|
|
|
Layout.bottomMargin: 26
|
|
|
|
|
text: qsTr("Asset settings")
|
|
|
|
|
color: Theme.palette.baseColor1
|
|
|
|
|
}
|
|
|
|
|
StatusDialogDivider {
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
}
|
|
|
|
|
StatusListItem {
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
title: qsTr("Show community assets when sending tokens")
|
|
|
|
|
|
|
|
|
|
components: [
|
|
|
|
|
StatusSwitch {
|
|
|
|
|
id: showCommunityAssetsSwitch
|
|
|
|
|
checked: true // FIXME integrate with backend (#13178)
|
|
|
|
|
onCheckedChanged: {
|
|
|
|
|
// FIXME integrate with backend (#13178)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
onClicked: {
|
|
|
|
|
showCommunityAssetsSwitch.checked = !showCommunityAssetsSwitch.checked
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
StatusDialogDivider {
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
}
|
|
|
|
|
StatusListItem {
|
|
|
|
|
Layout.fillWidth: true
|
|
|
|
|
title: qsTr("Don’t display assets with balance lower than")
|
|
|
|
|
|
|
|
|
|
components: [
|
|
|
|
|
CurrencyAmountInput {
|
|
|
|
|
enabled: displayThresholdSwitch.checked
|
|
|
|
|
currencySymbol: SharedStores.RootStore.currencyStore.currentCurrency
|
|
|
|
|
value: 0.10 // FIXME integrate with backend (#13178)
|
|
|
|
|
},
|
|
|
|
|
StatusSwitch {
|
|
|
|
|
id: displayThresholdSwitch
|
|
|
|
|
checked: false // FIXME integrate with backend (#13178)
|
|
|
|
|
onCheckedChanged: {
|
|
|
|
|
// FIXME integrate with backend (#13178)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
onClicked: {
|
|
|
|
|
displayThresholdSwitch.checked = !displayThresholdSwitch.checked
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-10-24 13:21:20 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|