2023-05-10 13:05:45 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
|
2023-09-26 15:45:44 +02:00
|
|
|
import Models 1.0
|
|
|
|
import utils 1.0
|
2023-11-28 20:16:18 +01:00
|
|
|
import StatusQ 0.1
|
|
|
|
import StatusQ.Core.Utils 0.1 as SQUtils
|
2023-09-26 15:45:44 +02:00
|
|
|
import shared.stores 1.0
|
2023-11-28 20:16:18 +01:00
|
|
|
import SortFilterProxyModel 0.2
|
|
|
|
|
|
|
|
import AppLayouts.Wallet.stores 1.0
|
2023-09-26 15:45:44 +02:00
|
|
|
|
|
|
|
QtObject {
|
|
|
|
id: root
|
|
|
|
|
2024-05-28 19:39:41 +02:00
|
|
|
readonly property CurrenciesStore currencyStore: CurrenciesStore {}
|
2023-09-26 15:45:44 +02:00
|
|
|
readonly property var senderAccounts: WalletSendAccountsModel {
|
|
|
|
Component.onCompleted: selectedSenderAccount = senderAccounts.get(0)
|
|
|
|
}
|
|
|
|
property var accounts: senderAccounts
|
2023-11-28 20:16:18 +01:00
|
|
|
|
|
|
|
property WalletAssetsStore walletAssetStore
|
|
|
|
|
2023-09-26 15:45:44 +02:00
|
|
|
property QtObject tmpActivityController: QtObject {
|
|
|
|
property ListModel model: ListModel{}
|
|
|
|
}
|
|
|
|
|
2024-03-13 18:38:16 +01:00
|
|
|
property var flatNetworksModel: NetworksModel.flatNetworks
|
2023-09-26 15:45:44 +02:00
|
|
|
property var fromNetworksModel: NetworksModel.sendFromNetworks
|
|
|
|
property var toNetworksModel: NetworksModel.sendToNetworks
|
|
|
|
property var selectedSenderAccount: senderAccounts.get(0)
|
2024-03-27 22:49:46 +01:00
|
|
|
readonly property QtObject collectiblesModel: ManageCollectiblesModel {}
|
2023-09-26 15:45:44 +02:00
|
|
|
readonly property QtObject nestedCollectiblesModel: WalletNestedCollectiblesModel {}
|
|
|
|
|
|
|
|
readonly property QtObject walletSectionSendInst: QtObject {
|
|
|
|
signal transactionSent(var chainId, var txHash, var uuid, var error)
|
|
|
|
signal suggestedRoutesReady(var txRoutes)
|
|
|
|
}
|
|
|
|
readonly property QtObject mainModuleInst: QtObject {
|
|
|
|
signal resolvedENS(var resolvedPubKey, var resolvedAddress, var uuid)
|
|
|
|
}
|
|
|
|
|
2024-02-05 17:44:49 +01:00
|
|
|
property string selectedAssetKey
|
2023-09-26 15:45:44 +02:00
|
|
|
property bool showUnPreferredChains: false
|
|
|
|
property int sendType: Constants.SendType.Transfer
|
|
|
|
property string selectedRecipient
|
|
|
|
|
|
|
|
readonly property var savedAddressesModel: ListModel {
|
|
|
|
Component.onCompleted: {
|
|
|
|
for (let i = 0; i < 10; i++)
|
|
|
|
append({
|
|
|
|
name: "some saved addr name " + i,
|
|
|
|
ens: [],
|
|
|
|
address: "0x2B748A02e06B159C7C3E98F5064577B96E55A7b4",
|
2024-05-16 18:37:54 +02:00
|
|
|
chainShortNames: "eth:arb1"
|
2023-09-26 15:45:44 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function splitAndFormatAddressPrefix(textAddrss, updateInStore) {
|
|
|
|
return textAddrss
|
|
|
|
}
|
|
|
|
|
|
|
|
function resolveENS() {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
function getAsset(assetsList, symbol) {
|
2023-11-28 20:16:18 +01:00
|
|
|
const idx = SQUtils.ModelUtils.indexOf(assetsList, "symbol", symbol)
|
2023-09-26 15:45:44 +02:00
|
|
|
if (idx < 0) {
|
|
|
|
return {}
|
|
|
|
}
|
2023-11-28 20:16:18 +01:00
|
|
|
return SQUtils.ModelUtils.get(assetsList, idx)
|
2023-09-26 15:45:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function getCollectible(uid) {
|
2023-11-28 20:16:18 +01:00
|
|
|
const idx = SQUtils.ModelUtils.indexOf(collectiblesModel, "uid", uid)
|
2023-09-26 15:45:44 +02:00
|
|
|
if (idx < 0) {
|
|
|
|
return {}
|
|
|
|
}
|
2023-11-28 20:16:18 +01:00
|
|
|
return SQUtils.ModelUtils.get(collectiblesModel, idx)
|
2023-09-26 15:45:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function getSelectorCollectible(uid) {
|
2023-11-28 20:16:18 +01:00
|
|
|
const idx = SQUtils.ModelUtils.indexOf(nestedCollectiblesModel, "uid", uid)
|
2023-09-26 15:45:44 +02:00
|
|
|
if (idx < 0) {
|
|
|
|
return {}
|
|
|
|
}
|
2023-11-28 20:16:18 +01:00
|
|
|
return SQUtils.ModelUtils.get(nestedCollectiblesModel, idx)
|
2023-09-26 15:45:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function getHolding(holdingId, holdingType) {
|
2023-11-07 23:45:47 +01:00
|
|
|
if (holdingType === Constants.TokenType.ERC20) {
|
2024-01-30 14:15:58 +01:00
|
|
|
return getAsset(processedAssetsModel, holdingId)
|
2023-11-07 23:45:47 +01:00
|
|
|
} else if (holdingType === Constants.TokenType.ERC721) {
|
2023-09-26 15:45:44 +02:00
|
|
|
return getCollectible(holdingId)
|
|
|
|
} else {
|
|
|
|
return {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function getSelectorHolding(holdingId, holdingType) {
|
2023-11-07 23:45:47 +01:00
|
|
|
if (holdingType === Constants.TokenType.ERC20) {
|
2024-01-30 14:15:58 +01:00
|
|
|
return getAsset(processedAssetsModel, holdingId)
|
2023-11-07 23:45:47 +01:00
|
|
|
} else if (holdingType === Constants.TokenType.ERC721) {
|
2023-09-26 15:45:44 +02:00
|
|
|
return getSelectorCollectible(holdingId)
|
|
|
|
} else {
|
|
|
|
return {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function assetToSelectorAsset(asset) {
|
|
|
|
return asset
|
|
|
|
}
|
|
|
|
|
|
|
|
function collectibleToSelectorCollectible(collectible) {
|
|
|
|
return {
|
|
|
|
uid: collectible.uid,
|
|
|
|
chainId: collectible.chainId,
|
|
|
|
name: collectible.name,
|
|
|
|
iconUrl: collectible.imageUrl,
|
|
|
|
collectionUid: collectible.collectionUid,
|
|
|
|
collectionName: collectible.collectionName,
|
|
|
|
isCollection: false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function holdingToSelectorHolding(holding, holdingType) {
|
2023-11-28 20:16:18 +01:00
|
|
|
if (holdingType === Constants.TokenType.ERC20) {
|
2023-09-26 15:45:44 +02:00
|
|
|
return assetToSelectorAsset(holding)
|
2023-11-28 20:16:18 +01:00
|
|
|
} else if (holdingType === Constants.TokenType.ERC721) {
|
2023-09-26 15:45:44 +02:00
|
|
|
return collectibleToSelectorCollectible(holding)
|
|
|
|
} else {
|
|
|
|
return {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
readonly property string currentCurrency: "USD"
|
|
|
|
|
|
|
|
function getAllNetworksSupportedString() {
|
|
|
|
return "OPT"
|
|
|
|
}
|
|
|
|
|
|
|
|
function plainText(text) {
|
|
|
|
return text
|
|
|
|
}
|
|
|
|
|
|
|
|
function prepareTransactionsForAddress(address) {
|
|
|
|
console.log("prepareTransactionsForAddress:", address)
|
|
|
|
}
|
|
|
|
|
|
|
|
function getTransactions() {
|
|
|
|
return transactions
|
|
|
|
}
|
|
|
|
|
|
|
|
readonly property var transactions_: ListModel {
|
|
|
|
id: transactions
|
|
|
|
|
|
|
|
Component.onCompleted: {
|
|
|
|
for (let i = 0; i < 10; i++)
|
|
|
|
append({
|
|
|
|
to: "to",
|
|
|
|
loadingTransaction: false,
|
|
|
|
value: {
|
|
|
|
displayDecimals: true,
|
|
|
|
stripTrailingZeroes: true,
|
|
|
|
amount: 3.234
|
|
|
|
},
|
|
|
|
timestamp: new Date()
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-06-07 15:27:56 +03:00
|
|
|
function switchSenderAccountByAddress(address) {
|
|
|
|
for (let i = 0; i < senderAccounts.count; i++) {
|
|
|
|
if (senderAccounts.get(i).address === address) {
|
|
|
|
selectedSenderAccount = senderAccounts.get(i)
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
2023-09-26 15:45:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function getNetworkShortNames(chainIds) {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
function getShortChainIds(chainIds) {
|
|
|
|
let listOfChains = chainIds.split(":")
|
|
|
|
let listOfChainIds = []
|
|
|
|
for (let k =0;k<listOfChains.length;k++) {
|
2024-06-12 22:43:08 +02:00
|
|
|
listOfChainIds.push(SQUtils.ModelUtils.getByKey(flatNetworksModel, "shortName", listOfChains[k], "chainId"))
|
2023-09-26 15:45:44 +02:00
|
|
|
}
|
|
|
|
return listOfChainIds
|
|
|
|
}
|
|
|
|
|
|
|
|
function setSendType(sendType) {
|
|
|
|
root.sendType = sendType
|
|
|
|
}
|
|
|
|
|
|
|
|
function setSelectedRecipient(recipientAddress) {
|
|
|
|
root.selectedRecipient = recipientAddress
|
|
|
|
}
|
|
|
|
|
2024-02-05 17:44:49 +01:00
|
|
|
function setSelectedAssetKey(assetsKey) {
|
|
|
|
root.selectedAssetKey = assetsKey
|
2023-09-26 15:45:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function getWei2Eth(wei, decimals) {
|
|
|
|
return wei/(10**decimals)
|
|
|
|
}
|
|
|
|
|
|
|
|
function updateRoutePreferredChains(chainIds) {
|
|
|
|
root.toNetworksModel.updateRoutePreferredChains(chainIds)
|
|
|
|
}
|
|
|
|
|
|
|
|
function toggleShowUnPreferredChains() {
|
|
|
|
root.showUnPreferredChains = !root.showUnPreferredChains
|
|
|
|
}
|
|
|
|
|
2024-06-12 22:43:08 +02:00
|
|
|
function setRouteEnabledFromChains(chainId) {
|
|
|
|
}
|
|
|
|
|
2024-06-10 12:37:39 +02:00
|
|
|
function setSelectedTokenIsOwnerToken(isOwnerToken) {
|
|
|
|
}
|
|
|
|
|
|
|
|
function setSelectedTokenName(tokenName) {
|
|
|
|
}
|
|
|
|
|
2023-09-26 15:45:44 +02:00
|
|
|
property string amountToSend
|
|
|
|
property bool suggestedRoutesCalled: false
|
|
|
|
function suggestedRoutes(amount) {
|
|
|
|
root.amountToSend = amount
|
|
|
|
root.suggestedRoutesCalled = true
|
|
|
|
}
|
|
|
|
|
|
|
|
enum EstimatedTime {
|
|
|
|
Unknown = 0,
|
|
|
|
LessThanOneMin,
|
|
|
|
LessThanThreeMins,
|
|
|
|
LessThanFiveMins,
|
|
|
|
MoreThanFiveMins
|
|
|
|
}
|
|
|
|
|
|
|
|
function getLabelForEstimatedTxTime(estimatedFlag) {
|
|
|
|
switch(estimatedFlag) {
|
|
|
|
case TransactionStore.EstimatedTime.Unknown:
|
|
|
|
return qsTr("~ Unknown")
|
|
|
|
case TransactionStore.EstimatedTime.LessThanOneMin :
|
|
|
|
return qsTr("< 1 minute")
|
|
|
|
case TransactionStore.EstimatedTime.LessThanThreeMins :
|
|
|
|
return qsTr("< 3 minutes")
|
|
|
|
case TransactionStore.EstimatedTime.LessThanFiveMins:
|
|
|
|
return qsTr("< 5 minutes")
|
|
|
|
default:
|
|
|
|
return qsTr("> 5 minutes")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function resetStoredProperties() {
|
|
|
|
root.amountToSend = ""
|
|
|
|
root.sendType = Constants.SendType.Transfer
|
|
|
|
root.selectedRecipient = ""
|
2024-02-05 17:44:49 +01:00
|
|
|
root.selectedAssetKey = ""
|
2023-09-26 15:45:44 +02:00
|
|
|
root.showUnPreferredChains = false
|
|
|
|
root.fromNetworksModel.reset()
|
|
|
|
root.toNetworksModel.reset()
|
|
|
|
}
|
|
|
|
|
|
|
|
function getNetworkName(chainId) {
|
2024-06-12 22:43:08 +02:00
|
|
|
return SQUtils.ModelUtils.getByKey(flatNetworksModel, "chainId", chainId, "chainName")
|
2023-09-26 15:45:44 +02:00
|
|
|
}
|
2023-11-28 20:16:18 +01:00
|
|
|
|
2024-06-12 22:43:08 +02:00
|
|
|
function formatCurrencyAmountFromBigInt(balance, symbol, decimals, options = null) {
|
|
|
|
return currencyStore.formatCurrencyAmountFromBigInt(balance, symbol, decimals, options)
|
2024-01-30 14:15:58 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Property and methods below are used to apply advanced token management settings to the SendModal
|
|
|
|
property bool showCommunityAssetsInSend: true
|
|
|
|
property bool balanceThresholdEnabled: true
|
|
|
|
property real balanceThresholdAmount
|
|
|
|
|
|
|
|
// Property set from TokenLIstView and HoldingSelector to search token by name, symbol or contract address
|
|
|
|
property string assetSearchString
|
|
|
|
|
|
|
|
// Model prepared to provide filtered and sorted assets as per the advanced Settings in token management
|
|
|
|
property var processedAssetsModel: SortFilterProxyModel {
|
|
|
|
sourceModel: walletAssetStore.groupedAccountAssetsModel
|
|
|
|
proxyRoles: [
|
|
|
|
FastExpressionRole {
|
|
|
|
name: "isCommunityAsset"
|
|
|
|
expression: !!model.communityId
|
|
|
|
expectedRoles: ["communityId"]
|
|
|
|
},
|
|
|
|
FastExpressionRole {
|
|
|
|
name: "currentBalance"
|
2024-05-28 19:39:41 +02:00
|
|
|
expression: __getTotalBalance(model.balances, model.decimals)
|
2024-01-30 14:15:58 +01:00
|
|
|
expectedRoles: ["balances", "decimals", "symbol"]
|
|
|
|
},
|
|
|
|
FastExpressionRole {
|
|
|
|
name: "currentCurrencyBalance"
|
|
|
|
expression: {
|
|
|
|
if (!!model.marketDetails) {
|
|
|
|
return model.currentBalance * model.marketDetails.currencyPrice.amount
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
expectedRoles: ["marketDetails", "currentBalance"]
|
|
|
|
}
|
|
|
|
]
|
|
|
|
filters: [
|
|
|
|
FastExpressionFilter {
|
|
|
|
function search(symbol, name, addressPerChain, searchString) {
|
|
|
|
return (
|
|
|
|
symbol.startsWith(searchString.toUpperCase()) ||
|
|
|
|
name.toUpperCase().startsWith(searchString.toUpperCase()) || __searchAddressInList(addressPerChain, searchString)
|
|
|
|
)
|
|
|
|
}
|
2024-05-28 19:39:41 +02:00
|
|
|
expression: search(model.symbol, model.name, model.addressPerChain, root.assetSearchString)
|
2024-01-30 14:15:58 +01:00
|
|
|
expectedRoles: ["symbol", "name", "addressPerChain"]
|
|
|
|
},
|
|
|
|
ValueFilter {
|
|
|
|
roleName: "isCommunityAsset"
|
|
|
|
value: false
|
|
|
|
enabled: !showCommunityAssetsInSend
|
|
|
|
},
|
|
|
|
FastExpressionFilter {
|
|
|
|
expression: {
|
|
|
|
return model.currentCurrencyBalance > balanceThresholdAmount
|
|
|
|
}
|
2024-06-12 22:43:08 +02:00
|
|
|
expectedRoles: ["currentCurrencyBalance"]
|
2024-01-30 14:15:58 +01:00
|
|
|
enabled: balanceThresholdEnabled
|
|
|
|
}
|
|
|
|
]
|
|
|
|
sorters: RoleSorter {
|
|
|
|
roleName: "isCommunityAsset"
|
|
|
|
}
|
2023-11-28 20:16:18 +01:00
|
|
|
}
|
|
|
|
|
2024-01-30 14:15:58 +01:00
|
|
|
/* Internal function to search token address */
|
|
|
|
function __searchAddressInList(addressPerChain, searchString) {
|
|
|
|
let addressFound = false
|
|
|
|
let tokenAddresses = SQUtils.ModelUtils.modelToFlatArray(addressPerChain, "address")
|
|
|
|
for (let i =0; i< tokenAddresses.length; i++){
|
|
|
|
if(tokenAddresses[i].toUpperCase().startsWith(searchString.toUpperCase())) {
|
|
|
|
addressFound = true
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return addressFound
|
2023-11-28 20:16:18 +01:00
|
|
|
}
|
|
|
|
|
2024-01-30 14:15:58 +01:00
|
|
|
/* Internal function to calculate total balance */
|
2024-05-28 19:39:41 +02:00
|
|
|
function __getTotalBalance(balances, decimals) {
|
2024-01-30 14:15:58 +01:00
|
|
|
let totalBalance = 0
|
|
|
|
for(let i=0; i<balances.count; i++) {
|
|
|
|
let balancePerAddressPerChain = SQUtils.ModelUtils.get(balances, i)
|
|
|
|
totalBalance+=SQUtils.AmountsArithmetic.toNumber(balancePerAddressPerChain.balance, decimals)
|
|
|
|
}
|
|
|
|
return totalBalance
|
|
|
|
}
|
2023-09-26 15:45:44 +02:00
|
|
|
}
|