2023-12-06 11:54:36 +01:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Layouts 1.15
|
2021-10-05 22:50:22 +02:00
|
|
|
|
2024-07-18 16:10:24 -04:00
|
|
|
import StatusQ.Components 0.1
|
2022-05-23 14:45:29 +03:00
|
|
|
import StatusQ.Controls 0.1
|
2024-06-14 19:50:52 +02:00
|
|
|
import StatusQ.Core 0.1
|
2023-12-06 11:54:36 +01:00
|
|
|
import StatusQ.Core.Theme 0.1
|
2024-06-14 19:50:52 +02:00
|
|
|
import StatusQ.Core.Utils 0.1
|
2022-05-23 14:45:29 +03:00
|
|
|
|
2021-10-05 22:50:22 +02:00
|
|
|
import utils 1.0
|
2023-08-23 13:46:04 +02:00
|
|
|
import shared.controls 1.0
|
2022-03-25 09:46:47 +01:00
|
|
|
import shared.views 1.0
|
2024-02-25 23:32:59 -03:00
|
|
|
import shared.stores 1.0 as SharedStores
|
2023-09-11 07:20:36 -03:00
|
|
|
import shared.panels 1.0
|
2021-10-28 00:27:49 +03:00
|
|
|
|
2022-09-05 11:15:47 +02:00
|
|
|
import "./"
|
2021-10-05 22:50:22 +02:00
|
|
|
import "../stores"
|
|
|
|
import "../panels"
|
2022-07-28 22:56:44 +02:00
|
|
|
import "../views/collectibles"
|
2021-10-05 22:50:22 +02:00
|
|
|
|
2023-12-26 11:19:41 +01:00
|
|
|
RightTabBaseView {
|
2022-07-19 15:17:35 +02:00
|
|
|
id: root
|
2021-10-05 22:50:22 +02:00
|
|
|
|
|
|
|
property alias currentTabIndex: walletTabBar.currentIndex
|
|
|
|
|
2023-04-26 17:53:49 +02:00
|
|
|
signal launchShareAddressModal()
|
2024-05-13 19:23:01 +02:00
|
|
|
signal launchSwapModal(string tokensKey)
|
2023-04-26 17:53:49 +02:00
|
|
|
|
2023-05-31 09:47:52 +02:00
|
|
|
function resetView() {
|
2024-04-10 11:44:15 +02:00
|
|
|
resetStack()
|
2023-05-31 09:47:52 +02:00
|
|
|
root.currentTabIndex = 0
|
|
|
|
}
|
|
|
|
|
2022-09-13 19:17:54 +03:00
|
|
|
function resetStack() {
|
|
|
|
stack.currentIndex = 0;
|
2024-06-06 16:10:20 +03:00
|
|
|
RootStore.backButtonName = d.getBackButtonText(stack.currentIndex);
|
2022-09-13 19:17:54 +03:00
|
|
|
}
|
|
|
|
|
2024-02-20 10:04:39 +01:00
|
|
|
headerButton.onClicked: {
|
|
|
|
root.launchShareAddressModal()
|
|
|
|
}
|
|
|
|
header.visible: stack.currentIndex === 0
|
|
|
|
|
2023-12-26 11:19:41 +01:00
|
|
|
StackLayout {
|
|
|
|
id: stack
|
2024-01-10 10:27:11 +01:00
|
|
|
anchors.fill: parent
|
2023-07-13 10:48:26 +02:00
|
|
|
|
2023-04-26 19:31:34 +02:00
|
|
|
onCurrentIndexChanged: {
|
|
|
|
RootStore.backButtonName = d.getBackButtonText(currentIndex)
|
|
|
|
}
|
2021-10-05 22:50:22 +02:00
|
|
|
|
2023-12-26 11:19:41 +01:00
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
function getBackButtonText(index) {
|
|
|
|
switch(index) {
|
|
|
|
case 1:
|
|
|
|
return qsTr("Collectibles")
|
|
|
|
case 2:
|
|
|
|
return qsTr("Assets")
|
|
|
|
case 3:
|
|
|
|
return qsTr("Activity")
|
|
|
|
default:
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
}
|
2024-02-25 23:32:59 -03:00
|
|
|
|
|
|
|
readonly property var detailedCollectibleActivityController: RootStore.tmpActivityController0
|
2023-12-26 11:19:41 +01:00
|
|
|
}
|
|
|
|
|
2024-07-26 16:47:18 +02:00
|
|
|
Component {
|
|
|
|
id: confirmHideCommunityAssetsPopup
|
|
|
|
|
|
|
|
ConfirmHideCommunityAssetsPopup {
|
|
|
|
destroyOnClose: true
|
|
|
|
|
|
|
|
required property string communityId
|
|
|
|
|
|
|
|
onConfirmButtonClicked: {
|
|
|
|
RootStore.walletAssetsStore.assetsController.showHideGroup(communityId, false /*hide*/)
|
|
|
|
close();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-20 19:32:36 +02:00
|
|
|
// StackLayout.currentIndex === 0
|
2023-04-26 19:31:34 +02:00
|
|
|
ColumnLayout {
|
2023-04-26 17:53:49 +02:00
|
|
|
spacing: 0
|
2023-08-23 13:46:04 +02:00
|
|
|
|
|
|
|
ImportKeypairInfo {
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.topMargin: Style.current.bigPadding
|
|
|
|
Layout.preferredHeight: childrenRect.height
|
|
|
|
visible: root.store.walletSectionInst.hasPairedDevices && root.store.walletSectionInst.keypairOperabilityForObservedAccount === Constants.keypair.operability.nonOperable
|
|
|
|
|
|
|
|
onRunImport: {
|
|
|
|
root.store.walletSectionInst.runKeypairImportPopup()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-12-06 11:54:36 +01:00
|
|
|
RowLayout {
|
2023-04-26 19:31:34 +02:00
|
|
|
Layout.fillWidth: true
|
2023-12-06 11:54:36 +01:00
|
|
|
StatusTabBar {
|
|
|
|
id: walletTabBar
|
|
|
|
objectName: "rightSideWalletTabBar"
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.topMargin: Style.current.padding
|
|
|
|
|
|
|
|
StatusTabButton {
|
2024-03-22 14:55:07 +07:00
|
|
|
objectName: "assetsTabButton"
|
2023-12-06 11:54:36 +01:00
|
|
|
leftPadding: 0
|
|
|
|
width: implicitWidth
|
|
|
|
text: qsTr("Assets")
|
|
|
|
}
|
|
|
|
StatusTabButton {
|
2024-03-22 14:55:07 +07:00
|
|
|
objectName: "collectiblesTabButton"
|
2023-12-06 11:54:36 +01:00
|
|
|
width: implicitWidth
|
|
|
|
text: qsTr("Collectibles")
|
|
|
|
}
|
|
|
|
StatusTabButton {
|
2024-03-22 14:55:07 +07:00
|
|
|
objectName: "activityTabButton"
|
2023-12-06 11:54:36 +01:00
|
|
|
rightPadding: 0
|
|
|
|
width: implicitWidth
|
|
|
|
text: qsTr("Activity")
|
2024-07-18 16:10:24 -04:00
|
|
|
|
|
|
|
StatusBetaTag {
|
|
|
|
// TODO remove me when Activity is no longer experimental
|
|
|
|
// Keep Activity as the last tab for now as the Experimental tag don't flow
|
|
|
|
anchors.top: parent.top
|
|
|
|
anchors.topMargin: 6
|
|
|
|
anchors.left: parent.right
|
|
|
|
anchors.leftMargin: 5
|
|
|
|
}
|
2023-12-06 11:54:36 +01:00
|
|
|
}
|
|
|
|
onCurrentIndexChanged: {
|
|
|
|
RootStore.setCurrentViewedHoldingType(walletTabBar.currentIndex === 1 ? Constants.TokenType.ERC721 : Constants.TokenType.ERC20)
|
|
|
|
}
|
2022-07-28 22:56:44 +02:00
|
|
|
}
|
2023-12-06 11:54:36 +01:00
|
|
|
StatusFlatButton {
|
|
|
|
id: filterButton
|
2024-03-22 14:55:07 +07:00
|
|
|
objectName: "filterButton"
|
2023-12-06 11:54:36 +01:00
|
|
|
icon.name: "filter"
|
|
|
|
checkable: true
|
|
|
|
icon.color: checked ? Theme.palette.primaryColor1 : Theme.palette.baseColor1
|
|
|
|
Behavior on icon.color { ColorAnimation { duration: 200; easing.type: Easing.InOutQuad } }
|
|
|
|
highlighted: checked
|
2023-09-12 16:26:38 +02:00
|
|
|
}
|
2023-04-26 19:31:34 +02:00
|
|
|
}
|
2024-01-25 11:18:58 +00:00
|
|
|
Loader {
|
2023-11-22 20:58:02 +01:00
|
|
|
id: mainViewLoader
|
2023-04-26 19:31:34 +02:00
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.fillHeight: true
|
2024-01-25 11:18:58 +00:00
|
|
|
sourceComponent: {
|
|
|
|
switch (walletTabBar.currentIndex) {
|
|
|
|
case 0: return assetsView
|
|
|
|
case 1: return collectiblesView
|
|
|
|
case 2: return historyView
|
2022-07-28 22:56:44 +02:00
|
|
|
}
|
2023-04-26 19:31:34 +02:00
|
|
|
}
|
2024-01-25 11:18:58 +00:00
|
|
|
|
|
|
|
Component {
|
|
|
|
id: assetsView
|
2024-06-14 19:50:52 +02:00
|
|
|
|
2024-06-14 20:20:07 +02:00
|
|
|
AssetsView {
|
2024-06-14 19:50:52 +02:00
|
|
|
AssetsViewAdaptor {
|
|
|
|
id: assetsViewAdaptor
|
|
|
|
|
|
|
|
accounts: RootStore.addressFilters
|
2024-07-15 18:56:50 +03:00
|
|
|
chains: RootStore.networkFiltersArray
|
2024-06-14 19:50:52 +02:00
|
|
|
|
|
|
|
marketValueThreshold:
|
|
|
|
RootStore.tokensStore.displayAssetsBelowBalance
|
|
|
|
? RootStore.tokensStore.getDisplayAssetsBelowBalanceThresholdDisplayAmount()
|
|
|
|
: 0
|
|
|
|
|
|
|
|
Connections {
|
|
|
|
target: RootStore.tokensStore
|
|
|
|
|
|
|
|
function displayAssetsBelowBalanceThresholdChanged() {
|
|
|
|
assetsViewAdaptor.marketValueThresholdChanged()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
tokensModel: RootStore.walletAssetsStore.groupedAccountAssetsModel
|
|
|
|
|
|
|
|
formatBalance: (balance, symbol) => {
|
|
|
|
return LocaleUtils.currencyAmountToLocaleString(
|
|
|
|
RootStore.currencyStore.getCurrencyAmount(balance, symbol))
|
|
|
|
}
|
|
|
|
|
|
|
|
chainsError: (chains) => {
|
|
|
|
if (!root.networkConnectionStore)
|
|
|
|
return ""
|
|
|
|
return root.networkConnectionStore.getBlockchainNetworkDownText(chains)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
loading: RootStore.overview.balanceLoading
|
|
|
|
sorterVisible: filterButton.checked
|
|
|
|
customOrderAvailable: RootStore.walletAssetsStore.assetsController.hasSettings
|
|
|
|
model: assetsViewAdaptor.model
|
|
|
|
|
|
|
|
marketDataError: !!root.networkConnectionStore
|
|
|
|
? root.networkConnectionStore.getMarketNetworkDownText()
|
|
|
|
: ""
|
|
|
|
balanceError: {
|
|
|
|
if (!root.networkConnectionStore)
|
|
|
|
return ""
|
|
|
|
|
|
|
|
return (root.networkConnectionStore.noBlockchainConnectionAndNoCache
|
|
|
|
&& !root.networkConnectionStore.noMarketConnectionAndNoCache)
|
|
|
|
? root.networkConnectionStore.noBlockchainConnectionAndNoCacheText
|
|
|
|
: ""
|
|
|
|
}
|
|
|
|
|
|
|
|
formatFiat: balance => RootStore.currencyStore.formatCurrencyAmount(
|
|
|
|
balance, RootStore.currencyStore.currentCurrency)
|
|
|
|
|
|
|
|
sendEnabled: root.networkConnectionStore.sendBuyBridgeEnabled &&
|
|
|
|
!RootStore.overview.isWatchOnlyAccount && RootStore.overview.canSend
|
2024-08-02 11:24:40 +02:00
|
|
|
communitySendEnabled: RootStore.tokensStore.showCommunityAssetsInSend
|
2024-06-14 19:50:52 +02:00
|
|
|
swapEnabled: !RootStore.overview.isWatchOnlyAccount
|
2024-08-12 12:41:27 +02:00
|
|
|
swapVisible: root.swapEnabled
|
2024-06-14 19:50:52 +02:00
|
|
|
|
|
|
|
onSendRequested: {
|
|
|
|
const modal = root.sendModal
|
|
|
|
|
|
|
|
modal.preSelectedSendType = Constants.SendType.Transfer
|
2024-08-01 12:17:36 +02:00
|
|
|
modal.preSelectedHoldingID = key
|
2024-06-14 19:50:52 +02:00
|
|
|
modal.preSelectedHoldingType = Constants.TokenType.ERC20
|
|
|
|
modal.onlyAssets = true
|
|
|
|
modal.open()
|
|
|
|
}
|
|
|
|
|
|
|
|
onSwapRequested: root.launchSwapModal(key)
|
|
|
|
onReceiveRequested: root.launchShareAddressModal()
|
|
|
|
onCommunityClicked: Global.switchToCommunity(communityKey)
|
2024-07-26 16:47:18 +02:00
|
|
|
|
|
|
|
onHideRequested: (key) => {
|
|
|
|
const token = ModelUtils.getByKey(model, "key", key)
|
|
|
|
Global.openConfirmHideAssetPopup(token.symbol, token.name, token.icon, !!token.communityId)
|
|
|
|
}
|
|
|
|
onHideCommunityAssetsRequested:
|
|
|
|
(communityKey) => {
|
|
|
|
const community = ModelUtils.getByKey(model, "communityId", communityKey)
|
|
|
|
confirmHideCommunityAssetsPopup.createObject(root, {
|
|
|
|
name: community.communityName,
|
|
|
|
icon: community.communityIcon,
|
|
|
|
communityId: communityKey }
|
|
|
|
).open()
|
|
|
|
}
|
2024-06-14 19:50:52 +02:00
|
|
|
onManageTokensRequested: Global.changeAppSectionBySectionType(
|
|
|
|
Constants.appSection.profile,
|
|
|
|
Constants.settingsSubsection.wallet,
|
|
|
|
Constants.walletSettingsSubsection.manageAssets)
|
2024-07-26 16:47:18 +02:00
|
|
|
onAssetClicked: (key) => {
|
2024-06-14 19:50:52 +02:00
|
|
|
const token = ModelUtils.getByKey(model, "key", key)
|
|
|
|
|
|
|
|
SharedStores.RootStore.getHistoricalDataForToken(
|
|
|
|
token.symbol, RootStore.currencyStore.currentCurrency)
|
|
|
|
|
2024-01-25 11:18:58 +00:00
|
|
|
assetDetailView.token = token
|
2024-08-02 11:24:40 +02:00
|
|
|
RootStore.setCurrentViewedHolding(
|
|
|
|
token.symbol, token.key, Constants.TokenType.ERC20, token.communityId ?? "")
|
2024-01-25 11:18:58 +00:00
|
|
|
stack.currentIndex = 2
|
|
|
|
}
|
2023-11-22 20:58:02 +01:00
|
|
|
}
|
|
|
|
}
|
2024-06-14 19:50:52 +02:00
|
|
|
|
2024-01-25 11:18:58 +00:00
|
|
|
Component {
|
|
|
|
id: collectiblesView
|
|
|
|
CollectiblesView {
|
2024-07-17 17:55:52 +03:00
|
|
|
ownedAccountsModel: RootStore.nonWatchAccounts
|
2024-01-31 19:09:44 +01:00
|
|
|
controller: RootStore.collectiblesStore.collectiblesController
|
2024-01-25 11:18:58 +00:00
|
|
|
networkFilters: RootStore.networkFilters
|
|
|
|
addressFilters: RootStore.addressFilters
|
|
|
|
sendEnabled: root.networkConnectionStore.sendBuyBridgeEnabled && !RootStore.overview.isWatchOnlyAccount && RootStore.overview.canSend
|
|
|
|
filterVisible: filterButton.checked
|
|
|
|
onCollectibleClicked: {
|
|
|
|
RootStore.collectiblesStore.getDetailedCollectible(chainId, contractAddress, tokenId)
|
2024-08-02 11:24:40 +02:00
|
|
|
RootStore.setCurrentViewedHolding(uid, uid, tokenType, communityId)
|
2024-02-25 23:32:59 -03:00
|
|
|
d.detailedCollectibleActivityController.resetFilter()
|
2024-04-10 11:44:15 +02:00
|
|
|
d.detailedCollectibleActivityController.setFilterAddressesJson(JSON.stringify(RootStore.addressFilters.split(":")))
|
2024-02-25 23:32:59 -03:00
|
|
|
d.detailedCollectibleActivityController.setFilterChainsJson(JSON.stringify([chainId]), false)
|
|
|
|
d.detailedCollectibleActivityController.setFilterCollectibles(JSON.stringify([uid]))
|
|
|
|
d.detailedCollectibleActivityController.updateFilter()
|
|
|
|
|
2024-01-25 11:18:58 +00:00
|
|
|
stack.currentIndex = 1
|
|
|
|
}
|
2024-07-19 14:20:26 +03:00
|
|
|
onSendRequested: (symbol, tokenType, fromAddress) => {
|
2024-07-17 17:55:52 +03:00
|
|
|
const collectible = ModelUtils.getByKey(controller.sourceModel, "symbol", symbol)
|
2024-07-19 14:20:26 +03:00
|
|
|
if (!!collectible && collectible.communityPrivilegesLevel === Constants.TokenPrivilegesLevel.Owner) {
|
2024-07-17 17:55:52 +03:00
|
|
|
Global.openTransferOwnershipPopup(collectible.communityId,
|
|
|
|
collectible.communityName,
|
|
|
|
collectible.communityImage,
|
|
|
|
{
|
2024-07-19 14:20:26 +03:00
|
|
|
key: collectible.tokenId,
|
|
|
|
privilegesLevel: collectible.communityPrivilegesLevel,
|
|
|
|
chainId: collectible.chainId,
|
|
|
|
name: collectible.name,
|
|
|
|
artworkSource: collectible.communityImage,
|
|
|
|
accountAddress: fromAddress,
|
|
|
|
tokenAddress: collectible.contractAddress
|
2024-07-17 17:55:52 +03:00
|
|
|
},
|
|
|
|
root.sendModal)
|
|
|
|
return
|
|
|
|
}
|
2024-07-19 14:20:26 +03:00
|
|
|
|
|
|
|
root.sendModal.preSelectedAccountAddress = fromAddress
|
2024-07-17 17:55:52 +03:00
|
|
|
root.sendModal.preSelectedHoldingID = symbol
|
|
|
|
root.sendModal.preSelectedHoldingType = tokenType
|
|
|
|
root.sendModal.preSelectedSendType = tokenType === Constants.TokenType.ERC721 ?
|
|
|
|
Constants.SendType.ERC721Transfer:
|
|
|
|
Constants.SendType.ERC1155Transfer
|
|
|
|
root.sendModal.onlyAssets = false
|
|
|
|
root.sendModal.open()
|
|
|
|
}
|
2024-01-25 11:18:58 +00:00
|
|
|
onReceiveRequested: (symbol) => root.launchShareAddressModal()
|
|
|
|
onSwitchToCommunityRequested: (communityId) => Global.switchToCommunity(communityId)
|
|
|
|
onManageTokensRequested: Global.changeAppSectionBySectionType(Constants.appSection.profile, Constants.settingsSubsection.wallet,
|
2024-01-31 19:09:44 +01:00
|
|
|
Constants.walletSettingsSubsection.manageCollectibles)
|
2024-02-07 19:58:56 -03:00
|
|
|
isFetching: RootStore.collectiblesStore.areCollectiblesFetching
|
|
|
|
isUpdating: RootStore.collectiblesStore.areCollectiblesUpdating
|
|
|
|
isError: RootStore.collectiblesStore.areCollectiblesError
|
2024-01-25 11:18:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
Component {
|
2023-09-21 08:58:44 +02:00
|
|
|
id: historyView
|
2024-01-25 11:18:58 +00:00
|
|
|
HistoryView {
|
|
|
|
overview: RootStore.overview
|
2024-02-22 15:41:19 +01:00
|
|
|
communitiesStore: root.communitiesStore
|
2024-01-25 11:18:58 +00:00
|
|
|
showAllAccounts: RootStore.showAllAccounts
|
|
|
|
sendModal: root.sendModal
|
|
|
|
filterVisible: filterButton.checked
|
2024-02-29 11:53:08 -03:00
|
|
|
onLaunchTransactionDetail: function (txID) {
|
|
|
|
RootStore.activityController.fetchTxDetails(txID)
|
2024-01-25 11:18:58 +00:00
|
|
|
stack.currentIndex = 3
|
|
|
|
}
|
2022-07-28 22:56:44 +02:00
|
|
|
}
|
|
|
|
}
|
2022-07-19 15:17:35 +02:00
|
|
|
}
|
2023-04-26 19:31:34 +02:00
|
|
|
}
|
|
|
|
CollectibleDetailView {
|
2024-02-29 11:53:08 -03:00
|
|
|
id: collectibleDetailView
|
|
|
|
|
|
|
|
visible : (stack.currentIndex === 1)
|
|
|
|
|
2023-07-17 20:56:40 -03:00
|
|
|
collectible: RootStore.collectiblesStore.detailedCollectible
|
|
|
|
isCollectibleLoading: RootStore.collectiblesStore.isDetailedCollectibleLoading
|
2024-02-25 23:32:59 -03:00
|
|
|
activityModel: d.detailedCollectibleActivityController.model
|
2024-03-27 22:49:46 +01:00
|
|
|
addressFilters: RootStore.addressFilters
|
2024-02-25 23:32:59 -03:00
|
|
|
rootStore: SharedStores.RootStore
|
|
|
|
walletRootStore: RootStore
|
|
|
|
communitiesStore: root.communitiesStore
|
2023-09-11 07:20:36 -03:00
|
|
|
|
|
|
|
onVisibleChanged: {
|
2024-02-25 23:32:59 -03:00
|
|
|
if (!visible) {
|
2023-11-07 23:45:47 +01:00
|
|
|
RootStore.resetCurrentViewedHolding(Constants.TokenType.ERC721)
|
2024-02-25 23:32:59 -03:00
|
|
|
}
|
2023-09-11 07:20:36 -03:00
|
|
|
}
|
2024-02-29 11:53:08 -03:00
|
|
|
|
|
|
|
onLaunchTransactionDetail: function (txID) {
|
|
|
|
d.detailedCollectibleActivityController.fetchTxDetails(txID)
|
|
|
|
stack.currentIndex = 3
|
|
|
|
|
|
|
|
// Take user to the activity view when they press the "Back" button
|
|
|
|
walletTabBar.currentIndex = 2
|
|
|
|
}
|
2023-04-26 19:31:34 +02:00
|
|
|
}
|
|
|
|
AssetsDetailView {
|
|
|
|
id: assetDetailView
|
2022-10-28 20:17:16 +03:00
|
|
|
|
2023-04-26 19:31:34 +02:00
|
|
|
visible: (stack.currentIndex === 2)
|
2022-10-28 20:17:16 +03:00
|
|
|
|
2024-03-13 18:38:16 +01:00
|
|
|
allNetworksModel: RootStore.filteredFlatModel
|
2023-04-26 17:53:49 +02:00
|
|
|
address: RootStore.overview.mixedcaseAddress
|
2023-11-24 13:16:13 +01:00
|
|
|
currencyStore: RootStore.currencyStore
|
|
|
|
networkFilters: RootStore.networkFilters
|
2023-05-22 17:05:04 +03:00
|
|
|
|
2023-04-26 19:31:34 +02:00
|
|
|
networkConnectionStore: root.networkConnectionStore
|
2023-09-11 07:20:36 -03:00
|
|
|
|
|
|
|
onVisibleChanged: {
|
|
|
|
if (!visible)
|
2023-11-07 23:45:47 +01:00
|
|
|
RootStore.resetCurrentViewedHolding(Constants.TokenType.ERC20)
|
2023-09-11 07:20:36 -03:00
|
|
|
}
|
2021-10-05 22:50:22 +02:00
|
|
|
}
|
2023-04-25 18:54:50 +02:00
|
|
|
|
2024-03-20 19:32:36 +02:00
|
|
|
Loader {
|
|
|
|
active: stack.currentIndex === 3
|
|
|
|
|
|
|
|
sourceComponent: TransactionDetailView {
|
|
|
|
controller: RootStore.activityDetailsController
|
|
|
|
onVisibleChanged: {
|
|
|
|
if (visible) {
|
|
|
|
if (!!transaction) {
|
|
|
|
RootStore.addressWasShown(transaction.sender)
|
|
|
|
if (transaction.sender !== transaction.recipient) {
|
|
|
|
RootStore.addressWasShown(transaction.recipient)
|
|
|
|
}
|
2023-12-20 11:46:33 +01:00
|
|
|
}
|
2024-03-20 19:32:36 +02:00
|
|
|
} else {
|
|
|
|
controller.resetActivityEntry()
|
2023-12-20 11:46:33 +01:00
|
|
|
}
|
|
|
|
}
|
2024-03-20 19:32:36 +02:00
|
|
|
showAllAccounts: RootStore.showAllAccounts
|
|
|
|
communitiesStore: root.communitiesStore
|
|
|
|
sendModal: root.sendModal
|
|
|
|
contactsStore: root.contactsStore
|
|
|
|
networkConnectionStore: root.networkConnectionStore
|
|
|
|
visible: (stack.currentIndex === 3)
|
2023-06-12 10:14:19 +02:00
|
|
|
}
|
2022-03-23 12:08:49 +01:00
|
|
|
}
|
2021-10-05 22:50:22 +02:00
|
|
|
}
|
|
|
|
}
|