parent
29665956f1
commit
f597ef4e6a
|
@ -93,8 +93,8 @@ proc suggestedRoutes*(self: Controller, account: string, amount: Uint256, token:
|
||||||
return suggestedRoutes.toJson()
|
return suggestedRoutes.toJson()
|
||||||
|
|
||||||
proc transfer*(self: Controller, from_addr: string, to_addr: string, tokenSymbol: string,
|
proc transfer*(self: Controller, from_addr: string, to_addr: string, tokenSymbol: string,
|
||||||
value: string, uuid: string, selectedRoutes: seq[TransactionPathDto], password: string) =
|
value: string, uuid: string, selectedRoutes: seq[TransactionPathDto], password: string, sendType: int) =
|
||||||
self.transactionService.transfer(from_addr, to_addr, tokenSymbol, value, uuid, selectedRoutes, password)
|
self.transactionService.transfer(from_addr, to_addr, tokenSymbol, value, uuid, selectedRoutes, password, sendType)
|
||||||
|
|
||||||
proc areTestNetworksEnabled*(self: Controller): bool =
|
proc areTestNetworksEnabled*(self: Controller): bool =
|
||||||
return self.walletAccountService.areTestNetworksEnabled()
|
return self.walletAccountService.areTestNetworksEnabled()
|
||||||
|
|
|
@ -30,7 +30,7 @@ method suggestedRoutesReady*(self: AccessInterface, suggestedRoutes: SuggestedRo
|
||||||
raise newException(ValueError, "No implementation available")
|
raise newException(ValueError, "No implementation available")
|
||||||
|
|
||||||
method authenticateAndTransfer*(self: AccessInterface, from_addr: string, to_addr: string,
|
method authenticateAndTransfer*(self: AccessInterface, from_addr: string, to_addr: string,
|
||||||
tokenSymbol: string, value: string, uuid: string) {.base.} =
|
tokenSymbol: string, value: string, uuid: string, sendType: int) {.base.} =
|
||||||
raise newException(ValueError, "No implementation available")
|
raise newException(ValueError, "No implementation available")
|
||||||
|
|
||||||
method onUserAuthenticated*(self: AccessInterface, password: string) {.base.} =
|
method onUserAuthenticated*(self: AccessInterface, password: string) {.base.} =
|
||||||
|
|
|
@ -30,6 +30,7 @@ type TmpSendTransactionDetails = object
|
||||||
value: string
|
value: string
|
||||||
paths: seq[TransactionPathDto]
|
paths: seq[TransactionPathDto]
|
||||||
uuid: string
|
uuid: string
|
||||||
|
sendType: int
|
||||||
|
|
||||||
type
|
type
|
||||||
Module* = ref object of io_interface.AccessInterface
|
Module* = ref object of io_interface.AccessInterface
|
||||||
|
@ -241,12 +242,13 @@ method viewDidLoad*(self: Module) =
|
||||||
method getTokenBalanceOnChain*(self: Module, address: string, chainId: int, symbol: string): CurrencyAmount =
|
method getTokenBalanceOnChain*(self: Module, address: string, chainId: int, symbol: string): CurrencyAmount =
|
||||||
return self.controller.getTokenBalanceOnChain(address, chainId, symbol)
|
return self.controller.getTokenBalanceOnChain(address, chainId, symbol)
|
||||||
|
|
||||||
method authenticateAndTransfer*(self: Module, from_addr: string, to_addr: string, tokenSymbol: string, value: string, uuid: string) =
|
method authenticateAndTransfer*(self: Module, from_addr: string, to_addr: string, tokenSymbol: string, value: string, uuid: string, sendType: int) =
|
||||||
self.tmpSendTransactionDetails.fromAddr = from_addr
|
self.tmpSendTransactionDetails.fromAddr = from_addr
|
||||||
self.tmpSendTransactionDetails.toAddr = to_addr
|
self.tmpSendTransactionDetails.toAddr = to_addr
|
||||||
self.tmpSendTransactionDetails.tokenSymbol = tokenSymbol
|
self.tmpSendTransactionDetails.tokenSymbol = tokenSymbol
|
||||||
self.tmpSendTransactionDetails.value = value
|
self.tmpSendTransactionDetails.value = value
|
||||||
self.tmpSendTransactionDetails.uuid = uuid
|
self.tmpSendTransactionDetails.uuid = uuid
|
||||||
|
self.tmpSendTransactionDetails.sendType = sendType
|
||||||
|
|
||||||
if singletonInstance.userProfile.getIsKeycardUser():
|
if singletonInstance.userProfile.getIsKeycardUser():
|
||||||
let keyUid = singletonInstance.userProfile.getKeyUid()
|
let keyUid = singletonInstance.userProfile.getKeyUid()
|
||||||
|
@ -282,7 +284,7 @@ method onUserAuthenticated*(self: Module, password: string) =
|
||||||
self.controller.transfer(
|
self.controller.transfer(
|
||||||
self.tmpSendTransactionDetails.fromAddr, self.tmpSendTransactionDetails.toAddr,
|
self.tmpSendTransactionDetails.fromAddr, self.tmpSendTransactionDetails.toAddr,
|
||||||
self.tmpSendTransactionDetails.tokenSymbol, self.tmpSendTransactionDetails.value, self.tmpSendTransactionDetails.uuid,
|
self.tmpSendTransactionDetails.tokenSymbol, self.tmpSendTransactionDetails.value, self.tmpSendTransactionDetails.uuid,
|
||||||
self.tmpSendTransactionDetails.paths, password
|
self.tmpSendTransactionDetails.paths, password, self.tmpSendTransactionDetails.sendType
|
||||||
)
|
)
|
||||||
|
|
||||||
method transactionWasSent*(self: Module, chainId: int, txHash, uuid, error: string) =
|
method transactionWasSent*(self: Module, chainId: int, txHash, uuid, error: string) =
|
||||||
|
|
|
@ -178,21 +178,21 @@ QtObject:
|
||||||
self.items[i].amountOut = path.getAmountOut()
|
self.items[i].amountOut = path.getAmountOut()
|
||||||
self.dataChanged(index, index, @[ModelRole.AmountOut.int])
|
self.dataChanged(index, index, @[ModelRole.AmountOut.int])
|
||||||
|
|
||||||
proc getDisabledNetworkChainIds*(self: NetworkModel): seq[int] =
|
proc getRouteDisabledNetworkChainIds*(self: NetworkModel): seq[int] =
|
||||||
var disbaledChains: seq[int] = @[]
|
var disbaledChains: seq[int] = @[]
|
||||||
for item in self.items:
|
for item in self.items:
|
||||||
if not item.getIsEnabled():
|
if not item.getIsEnabled():
|
||||||
disbaledChains.add(item.getChainId())
|
disbaledChains.add(item.getChainId())
|
||||||
return disbaledChains
|
return disbaledChains
|
||||||
|
|
||||||
proc getLockedChainIds*(self: NetworkModel): string =
|
proc getRouteLockedChainIds*(self: NetworkModel): string =
|
||||||
var jsonObject = newJObject()
|
var jsonObject = newJObject()
|
||||||
for item in self.items:
|
for item in self.items:
|
||||||
if item.getLocked():
|
if item.getLocked():
|
||||||
jsonObject[$item.getChainId()] = %* ("0x" & item.getLockedAmount())
|
jsonObject[$item.getChainId()] = %* ("0x" & item.getLockedAmount())
|
||||||
return $jsonObject
|
return $jsonObject
|
||||||
|
|
||||||
proc updatePreferredChains*(self: NetworkModel, chainIds: string) =
|
proc updateRoutePreferredChains*(self: NetworkModel, chainIds: string) =
|
||||||
try:
|
try:
|
||||||
for i in 0 ..< self.items.len:
|
for i in 0 ..< self.items.len:
|
||||||
let index = self.createIndex(i, 0, nil)
|
let index = self.createIndex(i, 0, nil)
|
||||||
|
@ -211,28 +211,28 @@ QtObject:
|
||||||
except:
|
except:
|
||||||
discard
|
discard
|
||||||
|
|
||||||
proc getPreferredNetworkChainIds*(self: NetworkModel): seq[int] =
|
proc getRoutePreferredNetworkChainIds*(self: NetworkModel): seq[int] =
|
||||||
var preferredChains: seq[int] = @[]
|
var preferredChains: seq[int] = @[]
|
||||||
for item in self.items:
|
for item in self.items:
|
||||||
if item.getIsPreferred():
|
if item.getIsPreferred():
|
||||||
preferredChains.add(item.getChainId())
|
preferredChains.add(item.getChainId())
|
||||||
return preferredChains
|
return preferredChains
|
||||||
|
|
||||||
proc disableUnpreferredChains*(self: NetworkModel) =
|
proc disableRouteUnpreferredChains*(self: NetworkModel) =
|
||||||
for i in 0 ..< self.items.len:
|
for i in 0 ..< self.items.len:
|
||||||
if not self.items[i].getIsPreferred():
|
if not self.items[i].getIsPreferred():
|
||||||
let index = self.createIndex(i, 0, nil)
|
let index = self.createIndex(i, 0, nil)
|
||||||
self.items[i].isEnabled = false
|
self.items[i].isEnabled = false
|
||||||
self.dataChanged(index, index, @[ModelRole.IsEnabled.int])
|
self.dataChanged(index, index, @[ModelRole.IsEnabled.int])
|
||||||
|
|
||||||
proc enableUnpreferredChains*(self: NetworkModel) =
|
proc enableRouteUnpreferredChains*(self: NetworkModel) =
|
||||||
for i in 0 ..< self.items.len:
|
for i in 0 ..< self.items.len:
|
||||||
if not self.items[i].getIsPreferred():
|
if not self.items[i].getIsPreferred():
|
||||||
let index = self.createIndex(i, 0, nil)
|
let index = self.createIndex(i, 0, nil)
|
||||||
self.items[i].isEnabled = true
|
self.items[i].isEnabled = true
|
||||||
self.dataChanged(index, index, @[ModelRole.IsEnabled.int])
|
self.dataChanged(index, index, @[ModelRole.IsEnabled.int])
|
||||||
|
|
||||||
proc setAllNetworksAsPreferredChains*(self: NetworkModel) {.slot.} =
|
proc setAllNetworksAsRoutePreferredChains*(self: NetworkModel) {.slot.} =
|
||||||
for i in 0 ..< self.items.len:
|
for i in 0 ..< self.items.len:
|
||||||
let index = self.createIndex(i, 0, nil)
|
let index = self.createIndex(i, 0, nil)
|
||||||
self.items[i].isPreferred = true
|
self.items[i].isPreferred = true
|
||||||
|
@ -256,20 +256,28 @@ QtObject:
|
||||||
return item.getChainName()
|
return item.getChainName()
|
||||||
return ""
|
return ""
|
||||||
|
|
||||||
proc toggleDisabledChains*(self: NetworkModel, chainId: int) {.slot.} =
|
proc toggleRouteDisabledChains*(self: NetworkModel, chainId: int) {.slot.} =
|
||||||
for i in 0 ..< self.items.len:
|
for i in 0 ..< self.items.len:
|
||||||
if(self.items[i].getChainId() == chainId):
|
if(self.items[i].getChainId() == chainId):
|
||||||
let index = self.createIndex(i, 0, nil)
|
let index = self.createIndex(i, 0, nil)
|
||||||
self.items[i].isEnabled = not self.items[i].getIsEnabled()
|
self.items[i].isEnabled = not self.items[i].getIsEnabled()
|
||||||
self.dataChanged(index, index, @[ModelRole.IsEnabled.int])
|
self.dataChanged(index, index, @[ModelRole.IsEnabled.int])
|
||||||
|
|
||||||
proc setDisabledChains*(self: NetworkModel, chainId: int, disabled: bool) {.slot.} =
|
proc setRouteDisabledChains*(self: NetworkModel, chainId: int, disabled: bool) {.slot.} =
|
||||||
for i in 0 ..< self.items.len:
|
for i in 0 ..< self.items.len:
|
||||||
if(self.items[i].getChainId() == chainId):
|
if(self.items[i].getChainId() == chainId):
|
||||||
let index = self.createIndex(i, 0, nil)
|
let index = self.createIndex(i, 0, nil)
|
||||||
self.items[i].isEnabled = not disabled
|
self.items[i].isEnabled = not disabled
|
||||||
self.dataChanged(index, index, @[ModelRole.IsEnabled.int])
|
self.dataChanged(index, index, @[ModelRole.IsEnabled.int])
|
||||||
|
|
||||||
|
proc setRouteEnabledFromChains*(self: NetworkModel, chainId: int) {.slot.} =
|
||||||
|
for i in 0 ..< self.items.len:
|
||||||
|
let index = self.createIndex(i, 0, nil)
|
||||||
|
self.items[i].isEnabled = false
|
||||||
|
if(self.items[i].getChainId() == chainId):
|
||||||
|
self.items[i].isEnabled = true
|
||||||
|
self.dataChanged(index, index, @[ModelRole.IsEnabled.int])
|
||||||
|
|
||||||
proc lockCard*(self: NetworkModel, chainId: int, amount: string, lock: bool) {.slot.} =
|
proc lockCard*(self: NetworkModel, chainId: int, amount: string, lock: bool) {.slot.} =
|
||||||
for i in 0 ..< self.items.len:
|
for i in 0 ..< self.items.len:
|
||||||
if(self.items[i].getChainId() == chainId):
|
if(self.items[i].getChainId() == chainId):
|
||||||
|
|
|
@ -146,9 +146,9 @@ QtObject:
|
||||||
proc updateNetworksDisabledChains(self: View) =
|
proc updateNetworksDisabledChains(self: View) =
|
||||||
# if the setting to show unpreferred chains is toggled, add all unpreferred chains to disabled chains list
|
# if the setting to show unpreferred chains is toggled, add all unpreferred chains to disabled chains list
|
||||||
if not self.showUnPreferredChains:
|
if not self.showUnPreferredChains:
|
||||||
self.toNetworksModel.disableUnpreferredChains()
|
self.toNetworksModel.disableRouteUnpreferredChains()
|
||||||
else:
|
else:
|
||||||
self.toNetworksModel.enableUnpreferredChains()
|
self.toNetworksModel.enableRouteUnpreferredChains()
|
||||||
|
|
||||||
proc updateNetworksTokenBalance(self: View) =
|
proc updateNetworksTokenBalance(self: View) =
|
||||||
for chainId in self.toNetworksModel.getAllNetworksChainIds():
|
for chainId in self.toNetworksModel.getAllNetworksChainIds():
|
||||||
|
@ -173,8 +173,8 @@ QtObject:
|
||||||
self.transactionSent(chainId, txHash, uuid, error)
|
self.transactionSent(chainId, txHash, uuid, error)
|
||||||
|
|
||||||
proc authenticateAndTransfer*(self: View, from_addr: string, to_addr: string, tokenSymbol: string,
|
proc authenticateAndTransfer*(self: View, from_addr: string, to_addr: string, tokenSymbol: string,
|
||||||
value: string, uuid: string) {.slot.} =
|
value: string, uuid: string, sendType: int) {.slot.} =
|
||||||
self.delegate.authenticateAndTransfer(from_addr, to_addr, tokenSymbol, value, uuid)
|
self.delegate.authenticateAndTransfer(from_addr, to_addr, tokenSymbol, value, uuid, sendType)
|
||||||
|
|
||||||
proc suggestedRoutesReady*(self: View, suggestedRoutes: QVariant) {.signal.}
|
proc suggestedRoutesReady*(self: View, suggestedRoutes: QVariant) {.signal.}
|
||||||
proc setTransactionRoute*(self: View, routes: TransactionRoutes) =
|
proc setTransactionRoute*(self: View, routes: TransactionRoutes) =
|
||||||
|
@ -190,8 +190,8 @@ QtObject:
|
||||||
discard
|
discard
|
||||||
|
|
||||||
return self.delegate.suggestedRoutes(self.selectedSenderAccount.address(),
|
return self.delegate.suggestedRoutes(self.selectedSenderAccount.address(),
|
||||||
parsedAmount, self.selectedAssetSymbol, self.fromNetworksModel.getDisabledNetworkChainIds(),
|
parsedAmount, self.selectedAssetSymbol, self.fromNetworksModel.getRouteDisabledNetworkChainIds(),
|
||||||
self.toNetworksModel.getDisabledNetworkChainIds(), self.toNetworksModel.getPreferredNetworkChainIds(), sendType, self.fromNetworksModel.getLockedChainIds())
|
self.toNetworksModel.getRouteDisabledNetworkChainIds(), self.toNetworksModel.getRoutePreferredNetworkChainIds(), sendType, self.fromNetworksModel.getRouteLockedChainIds())
|
||||||
|
|
||||||
proc switchSenderAccountByAddress*(self: View, address: string) =
|
proc switchSenderAccountByAddress*(self: View, address: string) =
|
||||||
let (account, index) = self.senderAccounts.getItemByAddress(address)
|
let (account, index) = self.senderAccounts.getItemByAddress(address)
|
||||||
|
@ -223,8 +223,8 @@ QtObject:
|
||||||
self.setSelectetReceiveAccount(account)
|
self.setSelectetReceiveAccount(account)
|
||||||
self.delegate.setSelectedReceiveAccountIndex(idx)
|
self.delegate.setSelectedReceiveAccountIndex(idx)
|
||||||
|
|
||||||
proc updatePreferredChains*(self: View, chainIds: string) {.slot.} =
|
proc updateRoutePreferredChains*(self: View, chainIds: string) {.slot.} =
|
||||||
self.toNetworksModel.updatePreferredChains(chainIds)
|
self.toNetworksModel.updateRoutePreferredChains(chainIds)
|
||||||
|
|
||||||
proc getSelectedSenderAccountAddress*(self: View): string =
|
proc getSelectedSenderAccountAddress*(self: View): string =
|
||||||
return self.selectedSenderAccount.address()
|
return self.selectedSenderAccount.address()
|
||||||
|
|
|
@ -23,6 +23,8 @@ type
|
||||||
amountOutMin*: Option[UInt256] # (optional) amountOutMin in case of a bridge hop transaction
|
amountOutMin*: Option[UInt256] # (optional) amountOutMin in case of a bridge hop transaction
|
||||||
bonderFee*: Option[string] # (optional) bonderFee in case of a bridge hop transaction
|
bonderFee*: Option[string] # (optional) bonderFee in case of a bridge hop transaction
|
||||||
|
|
||||||
|
tokenID*: Option[UInt256] # (optional) chainID in case of a ERC721 transaction
|
||||||
|
|
||||||
proc `%`*(x: TransactionDataDto): JsonNode =
|
proc `%`*(x: TransactionDataDto): JsonNode =
|
||||||
result = newJobject()
|
result = newJobject()
|
||||||
result["from"] = %x.source
|
result["from"] = %x.source
|
||||||
|
@ -55,18 +57,22 @@ proc `%`*(x: TransactionDataDto): JsonNode =
|
||||||
result["amountOutMin"] = %x.amountOutMin.unsafeGet
|
result["amountOutMin"] = %x.amountOutMin.unsafeGet
|
||||||
if x.bonderFee.isSome:
|
if x.bonderFee.isSome:
|
||||||
result["bonderFee"] = %x.bonderFee.unsafeGet
|
result["bonderFee"] = %x.bonderFee.unsafeGet
|
||||||
|
if x.tokenID.isSome:
|
||||||
|
result["tokenID"] = %x.tokenID.unsafeGet
|
||||||
|
|
||||||
type TransactionBridgeDto* = object
|
type TransactionBridgeDto* = object
|
||||||
bridgeName*: string
|
bridgeName*: string
|
||||||
chainID*: int
|
chainID*: int
|
||||||
simpleTx*: TransactionDataDto
|
transferTx*: TransactionDataDto
|
||||||
hopTx*: TransactionDataDto
|
hopTx*: TransactionDataDto
|
||||||
cbridgeTx*: TransactionDataDto
|
cbridgeTx*: TransactionDataDto
|
||||||
|
eRC721TransferTx*: TransactionDataDto
|
||||||
|
|
||||||
proc `%`*(x: TransactionBridgeDto): JsonNode =
|
proc `%`*(x: TransactionBridgeDto): JsonNode =
|
||||||
result = newJobject()
|
result = newJobject()
|
||||||
result["bridgeName"] = %x.bridgeName
|
result["bridgeName"] = %x.bridgeName
|
||||||
result["chainID"] = %x.chainID
|
result["chainID"] = %x.chainID
|
||||||
result["simpleTx"] = %x.simpleTx
|
result["transferTx"] = %x.transferTx
|
||||||
result["hopTx"] = %x.hopTx
|
result["hopTx"] = %x.hopTx
|
||||||
result["cbridgeTx"] = %x.cbridgeTx
|
result["cbridgeTx"] = %x.cbridgeTx
|
||||||
|
result["eRC721TransferTx"] = %x.eRC721TransferTx
|
||||||
|
|
|
@ -68,7 +68,7 @@ proc addFirstSimpleBridgeTxFlag(paths: seq[TransactionPathDto]) : seq[Transactio
|
||||||
if not firstSimplePath:
|
if not firstSimplePath:
|
||||||
firstSimplePath = true
|
firstSimplePath = true
|
||||||
path.isFirstSimpleTx = true
|
path.isFirstSimpleTx = true
|
||||||
if path.bridgeName != "Simple":
|
if path.bridgeName != "Transfer":
|
||||||
if not firstBridgePath:
|
if not firstBridgePath:
|
||||||
firstBridgePath = false
|
firstBridgePath = false
|
||||||
path.isFirstBridgeTx = true
|
path.isFirstBridgeTx = true
|
||||||
|
|
|
@ -9,6 +9,16 @@ import ../../common/conversion as service_conversion
|
||||||
|
|
||||||
import ./backend/transactions
|
import ./backend/transactions
|
||||||
|
|
||||||
|
type
|
||||||
|
SendType* {.pure.} = enum
|
||||||
|
Transfer
|
||||||
|
ENSRegister
|
||||||
|
ENSRelease
|
||||||
|
ENSSetPubKey
|
||||||
|
StickersBuy
|
||||||
|
Bridge
|
||||||
|
ERC721Transfer
|
||||||
|
|
||||||
type
|
type
|
||||||
PendingTransactionTypeDto* {.pure.} = enum
|
PendingTransactionTypeDto* {.pure.} = enum
|
||||||
RegisterENS = "RegisterENS",
|
RegisterENS = "RegisterENS",
|
||||||
|
|
|
@ -44,8 +44,9 @@ const SIGNAL_HISTORY_ERROR* = "historyError"
|
||||||
const SIGNAL_CRYPTO_SERVICES_READY* = "cryptoServicesReady"
|
const SIGNAL_CRYPTO_SERVICES_READY* = "cryptoServicesReady"
|
||||||
const SIGNAL_TRANSACTION_DECODED* = "transactionDecoded"
|
const SIGNAL_TRANSACTION_DECODED* = "transactionDecoded"
|
||||||
|
|
||||||
const SIMPLE_TX_BRIDGE_NAME = "Simple"
|
const SIMPLE_TX_BRIDGE_NAME = "Transfer"
|
||||||
const HOP_TX_BRIDGE_NAME = "Hop"
|
const HOP_TX_BRIDGE_NAME = "Hop"
|
||||||
|
const ERC721_TRANSFER_NAME = "ERC721Transfer"
|
||||||
|
|
||||||
type
|
type
|
||||||
EstimatedTime* {.pure.} = enum
|
EstimatedTime* {.pure.} = enum
|
||||||
|
@ -214,16 +215,17 @@ QtObject:
|
||||||
txData.data = data
|
txData.data = data
|
||||||
|
|
||||||
var path = TransactionBridgeDto(bridgeName: SIMPLE_TX_BRIDGE_NAME, chainID: route.fromNetwork.chainId)
|
var path = TransactionBridgeDto(bridgeName: SIMPLE_TX_BRIDGE_NAME, chainID: route.fromNetwork.chainId)
|
||||||
path.simpleTx = txData
|
path.transferTx = txData
|
||||||
return path
|
return path
|
||||||
|
|
||||||
proc createPath*(self: Service, route: TransactionPathDto, txData: TransactionDataDto, tokenSymbol: string, to_addr: string): TransactionBridgeDto =
|
proc createPath*(self: Service, route: TransactionPathDto, txData: TransactionDataDto, tokenSymbol: string, to_addr: string): TransactionBridgeDto =
|
||||||
var path = TransactionBridgeDto(bridgeName: route.bridgeName, chainID: route.fromNetwork.chainId)
|
var path = TransactionBridgeDto(bridgeName: route.bridgeName, chainID: route.fromNetwork.chainId)
|
||||||
var hopTx = TransactionDataDto()
|
var hopTx = TransactionDataDto()
|
||||||
var cbridgeTx = TransactionDataDto()
|
var cbridgeTx = TransactionDataDto()
|
||||||
|
var eRC721TransferTx = TransactionDataDto()
|
||||||
|
|
||||||
if(route.bridgeName == SIMPLE_TX_BRIDGE_NAME):
|
if(route.bridgeName == SIMPLE_TX_BRIDGE_NAME):
|
||||||
path.simpleTx = txData
|
path.transferTx = txData
|
||||||
elif(route.bridgeName == HOP_TX_BRIDGE_NAME):
|
elif(route.bridgeName == HOP_TX_BRIDGE_NAME):
|
||||||
hopTx = txData
|
hopTx = txData
|
||||||
hopTx.chainID = route.toNetwork.chainId.some
|
hopTx.chainID = route.toNetwork.chainId.some
|
||||||
|
@ -232,6 +234,12 @@ QtObject:
|
||||||
hopTx.amount = route.amountIn.some
|
hopTx.amount = route.amountIn.some
|
||||||
hopTx.bonderFee = route.bonderFees.some
|
hopTx.bonderFee = route.bonderFees.some
|
||||||
path.hopTx = hopTx
|
path.hopTx = hopTx
|
||||||
|
elif(route.bridgeName == ERC721_TRANSFER_NAME):
|
||||||
|
eRC721TransferTx = txData
|
||||||
|
eRC721TransferTx.chainID = route.toNetwork.chainId.some
|
||||||
|
eRC721TransferTx.recipient = parseAddress(to_addr).some
|
||||||
|
eRC721TransferTx.tokenID = stint.u256(tokenSymbol).some
|
||||||
|
path.eRC721TransferTx = eRC721TransferTx
|
||||||
else:
|
else:
|
||||||
cbridgeTx = txData
|
cbridgeTx = txData
|
||||||
cbridgeTx.chainID = route.toNetwork.chainId.some
|
cbridgeTx.chainID = route.toNetwork.chainId.some
|
||||||
|
@ -239,7 +247,6 @@ QtObject:
|
||||||
cbridgeTx.recipient = parseAddress(to_addr).some
|
cbridgeTx.recipient = parseAddress(to_addr).some
|
||||||
cbridgeTx.amount = route.amountIn.some
|
cbridgeTx.amount = route.amountIn.some
|
||||||
path.cbridgeTx = cbridgeTx
|
path.cbridgeTx = cbridgeTx
|
||||||
|
|
||||||
return path
|
return path
|
||||||
|
|
||||||
proc transferEth*(
|
proc transferEth*(
|
||||||
|
@ -303,19 +310,31 @@ QtObject:
|
||||||
uuid: string,
|
uuid: string,
|
||||||
routes: seq[TransactionPathDto],
|
routes: seq[TransactionPathDto],
|
||||||
password: string,
|
password: string,
|
||||||
|
sendType: int
|
||||||
) =
|
) =
|
||||||
try:
|
try:
|
||||||
|
let isERC721Transfer = sendType == ord(ERC721Transfer)
|
||||||
var paths: seq[TransactionBridgeDto] = @[]
|
var paths: seq[TransactionBridgeDto] = @[]
|
||||||
var chainID = 0
|
var chainID = 0
|
||||||
|
|
||||||
if(routes.len > 0):
|
if(routes.len > 0):
|
||||||
chainID = routes[0].fromNetwork.chainID
|
chainID = routes[0].fromNetwork.chainID
|
||||||
|
|
||||||
|
var amountToSend: Stuint[256]
|
||||||
|
var toAddress: Address
|
||||||
|
var tokenSym = tokenSymbol
|
||||||
|
if isERC721Transfer:
|
||||||
|
amountToSend = value.parse(Stuint[256])
|
||||||
|
let contract_tokenId = tokenSym.split(":")
|
||||||
|
if contract_tokenId.len == 2:
|
||||||
|
toAddress = parseAddress(contract_tokenId[0])
|
||||||
|
tokenSym = contract_tokenId[1]
|
||||||
|
else:
|
||||||
let network = self.networkService.getNetwork(chainID)
|
let network = self.networkService.getNetwork(chainID)
|
||||||
|
let token = self.tokenService.findTokenBySymbol(network.chainId, tokenSym)
|
||||||
|
amountToSend = conversion.eth2Wei(parseFloat(value), token.decimals)
|
||||||
|
toAddress = token.address
|
||||||
|
|
||||||
let token = self.tokenService.findTokenBySymbol(network.chainId, tokenSymbol)
|
|
||||||
let amountToSend = conversion.eth2Wei(parseFloat(value), token.decimals)
|
|
||||||
let toAddress = token.address
|
|
||||||
let transfer = Transfer(
|
let transfer = Transfer(
|
||||||
to: parseAddress(to_addr),
|
to: parseAddress(to_addr),
|
||||||
value: amountToSend,
|
value: amountToSend,
|
||||||
|
@ -336,14 +355,15 @@ QtObject:
|
||||||
$route.gasAmount, gasFees, route.gasFees.eip1559Enabled, $route.gasFees.maxPriorityFeePerGas, $route.gasFees.maxFeePerGasM)
|
$route.gasAmount, gasFees, route.gasFees.eip1559Enabled, $route.gasFees.maxPriorityFeePerGas, $route.gasFees.maxFeePerGasM)
|
||||||
txData.data = data
|
txData.data = data
|
||||||
|
|
||||||
paths.add(self.createPath(route, txData, tokenSymbol, to_addr))
|
paths.add(self.createPath(route, txData, tokenSym, to_addr))
|
||||||
|
|
||||||
let response = transactions.createMultiTransaction(
|
var response: RpcResponse[JsonNode]
|
||||||
|
response = transactions.createMultiTransaction(
|
||||||
MultiTransactionCommandDto(
|
MultiTransactionCommandDto(
|
||||||
fromAddress: from_addr,
|
fromAddress: from_addr,
|
||||||
toAddress: to_addr,
|
toAddress: to_addr,
|
||||||
fromAsset: tokenSymbol,
|
fromAsset: tokenSym,
|
||||||
toAsset: tokenSymbol,
|
toAsset: tokenSym,
|
||||||
fromAmount: "0x" & amountToSend.toHex,
|
fromAmount: "0x" & amountToSend.toHex,
|
||||||
multiTxType: transactions.MultiTransactionType.MultiTransactionSend,
|
multiTxType: transactions.MultiTransactionType.MultiTransactionSend,
|
||||||
),
|
),
|
||||||
|
@ -368,6 +388,7 @@ QtObject:
|
||||||
uuid: string,
|
uuid: string,
|
||||||
selectedRoutes: seq[TransactionPathDto],
|
selectedRoutes: seq[TransactionPathDto],
|
||||||
password: string,
|
password: string,
|
||||||
|
sendType: int
|
||||||
) =
|
) =
|
||||||
try:
|
try:
|
||||||
var chainID = 0
|
var chainID = 0
|
||||||
|
@ -383,7 +404,7 @@ QtObject:
|
||||||
if(isEthTx):
|
if(isEthTx):
|
||||||
self.transferEth(from_addr, to_addr, tokenSymbol, value, uuid, selectedRoutes, password)
|
self.transferEth(from_addr, to_addr, tokenSymbol, value, uuid, selectedRoutes, password)
|
||||||
else:
|
else:
|
||||||
self.transferToken(from_addr, to_addr, tokenSymbol, value, uuid, selectedRoutes, password)
|
self.transferToken(from_addr, to_addr, tokenSymbol, value, uuid, selectedRoutes, password, sendType)
|
||||||
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
self.events.emit(SIGNAL_TRANSACTION_SENT, TransactionSentArgs(chainId: 0, txHash: "", uuid: uuid, error: fmt"Error sending token transfer transaction: {e.msg}"))
|
self.events.emit(SIGNAL_TRANSACTION_SENT, TransactionSentArgs(chainId: 0, txHash: "", uuid: uuid, error: fmt"Error sending token transfer transaction: {e.msg}"))
|
||||||
|
|
|
@ -144,12 +144,24 @@ Item {
|
||||||
|
|
||||||
footer: WalletFooter {
|
footer: WalletFooter {
|
||||||
visible: !root.showAllAccounts
|
visible: !root.showAllAccounts
|
||||||
sendModal: root.sendModalPopup
|
|
||||||
width: parent.width
|
width: parent.width
|
||||||
height: root.showAllAccounts ? implicitHeight : 61
|
height: root.showAllAccounts ? implicitHeight : 61
|
||||||
walletStore: RootStore
|
walletStore: RootStore
|
||||||
networkConnectionStore: root.networkConnectionStore
|
networkConnectionStore: root.networkConnectionStore
|
||||||
onLaunchShareAddressModal: Global.openPopup(receiveModalComponent)
|
onLaunchShareAddressModal: Global.openPopup(receiveModalComponent)
|
||||||
|
onLaunchSendModal: {
|
||||||
|
root.sendModalPopup.sendType = Constants.SendType.Transfer
|
||||||
|
root.sendModalPopup.preSelectedHoldingID = walletStore.currentViewedHoldingID
|
||||||
|
root.sendModalPopup.preSelectedHoldingType = walletStore.currentViewedHoldingType
|
||||||
|
root.sendModalPopup.open()
|
||||||
|
}
|
||||||
|
onLaunchBridgeModal: {
|
||||||
|
root.sendModalPopup.isBridgeTx = true
|
||||||
|
root.sendModalPopup.sendType = Constants.SendType.Bridge
|
||||||
|
root.sendModalPopup.preSelectedHoldingID = walletStore.currentViewedHoldingID
|
||||||
|
root.sendModalPopup.preSelectedHoldingType = walletStore.currentViewedHoldingType
|
||||||
|
root.sendModalPopup.open()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -15,11 +15,12 @@ import "../popups"
|
||||||
Rectangle {
|
Rectangle {
|
||||||
id: root
|
id: root
|
||||||
|
|
||||||
property var sendModal
|
|
||||||
property var walletStore
|
property var walletStore
|
||||||
property var networkConnectionStore
|
property var networkConnectionStore
|
||||||
|
|
||||||
signal launchShareAddressModal()
|
signal launchShareAddressModal()
|
||||||
|
signal launchSendModal()
|
||||||
|
signal launchBridgeModal()
|
||||||
|
|
||||||
color: Theme.palette.statusAppLayout.rightPanelBackgroundColor
|
color: Theme.palette.statusAppLayout.rightPanelBackgroundColor
|
||||||
|
|
||||||
|
@ -39,11 +40,7 @@ Rectangle {
|
||||||
icon: "send"
|
icon: "send"
|
||||||
text: qsTr("Send")
|
text: qsTr("Send")
|
||||||
interactive: networkConnectionStore.sendBuyBridgeEnabled
|
interactive: networkConnectionStore.sendBuyBridgeEnabled
|
||||||
onClicked: function() {
|
onClicked: root.launchSendModal()
|
||||||
sendModal.preSelectedHoldingID = walletStore.currentViewedHoldingID
|
|
||||||
sendModal.preSelectedHoldingType = walletStore.currentViewedHoldingType
|
|
||||||
sendModal.open()
|
|
||||||
}
|
|
||||||
tooltipText: networkConnectionStore.sendBuyBridgeToolTipText
|
tooltipText: networkConnectionStore.sendBuyBridgeToolTipText
|
||||||
visible: !walletStore.overview.isWatchOnlyAccount
|
visible: !walletStore.overview.isWatchOnlyAccount
|
||||||
}
|
}
|
||||||
|
@ -61,12 +58,7 @@ Rectangle {
|
||||||
buttonType: DisabledTooltipButton.Flat
|
buttonType: DisabledTooltipButton.Flat
|
||||||
text: qsTr("Bridge")
|
text: qsTr("Bridge")
|
||||||
interactive: networkConnectionStore.sendBuyBridgeEnabled
|
interactive: networkConnectionStore.sendBuyBridgeEnabled
|
||||||
onClicked: function() {
|
onClicked: root.launchBridgeModal()
|
||||||
sendModal.isBridgeTx = true
|
|
||||||
sendModal.preSelectedHoldingID = walletStore.currentViewedHoldingID
|
|
||||||
sendModal.preSelectedHoldingType = walletStore.currentViewedHoldingType
|
|
||||||
sendModal.open()
|
|
||||||
}
|
|
||||||
tooltipText: networkConnectionStore.sendBuyBridgeToolTipText
|
tooltipText: networkConnectionStore.sendBuyBridgeToolTipText
|
||||||
visible: !walletStore.overview.isWatchOnlyAccount
|
visible: !walletStore.overview.isWatchOnlyAccount
|
||||||
}
|
}
|
||||||
|
|
|
@ -1348,12 +1348,13 @@ Item {
|
||||||
property bool isBridgeTx
|
property bool isBridgeTx
|
||||||
property string preSelectedHoldingID
|
property string preSelectedHoldingID
|
||||||
property var preSelectedHoldingType
|
property var preSelectedHoldingType
|
||||||
|
property int sendType: -1
|
||||||
sourceComponent: SendModal {
|
sourceComponent: SendModal {
|
||||||
onlyAssets: false
|
onlyAssets: false
|
||||||
onClosed: {
|
onClosed: {
|
||||||
sendModal.closed()
|
sendModal.closed()
|
||||||
sendModal.isBridgeTx = false
|
sendModal.isBridgeTx = false
|
||||||
|
sendModal.sendType = -1
|
||||||
sendModal.preSelectedHoldingID = ""
|
sendModal.preSelectedHoldingID = ""
|
||||||
sendModal.preSelectedHoldingType = Constants.HoldingType.Unknown
|
sendModal.preSelectedHoldingType = Constants.HoldingType.Unknown
|
||||||
}
|
}
|
||||||
|
@ -1365,6 +1366,9 @@ Item {
|
||||||
if(isBridgeTx) {
|
if(isBridgeTx) {
|
||||||
item.isBridgeTx = sendModal.isBridgeTx
|
item.isBridgeTx = sendModal.isBridgeTx
|
||||||
}
|
}
|
||||||
|
if(sendModal.sendType >= 0) {
|
||||||
|
item.sendType = sendModal.sendType
|
||||||
|
}
|
||||||
if(preSelectedHoldingType !== Constants.HoldingType.Unknown) {
|
if(preSelectedHoldingType !== Constants.HoldingType.Unknown) {
|
||||||
item.preSelectedHoldingID = sendModal.preSelectedHoldingID
|
item.preSelectedHoldingID = sendModal.preSelectedHoldingID
|
||||||
item.preSelectedHoldingType = sendModal.preSelectedHoldingType
|
item.preSelectedHoldingType = sendModal.preSelectedHoldingType
|
||||||
|
|
|
@ -117,7 +117,7 @@ Item {
|
||||||
property double tokenFees: modelData.tokenFees
|
property double tokenFees: modelData.tokenFees
|
||||||
property double tokenFeesFiat: root.getFiatValue(tokenFees, root.selectedTokenSymbol, root.currentCurrency)
|
property double tokenFeesFiat: root.getFiatValue(tokenFees, root.selectedTokenSymbol, root.currentCurrency)
|
||||||
subTitle: root.formatCurrencyAmount(tokenFees, root.selectedTokenSymbol)
|
subTitle: root.formatCurrencyAmount(tokenFees, root.selectedTokenSymbol)
|
||||||
visible: modelData.bridgeName !== "Simple"
|
visible: modelData.bridgeName !== "Transfer"
|
||||||
statusListItemSubTitle.width: 100
|
statusListItemSubTitle.width: 100
|
||||||
statusListItemSubTitle.elide: Text.ElideMiddle
|
statusListItemSubTitle.elide: Text.ElideMiddle
|
||||||
components: [
|
components: [
|
||||||
|
|
|
@ -24,8 +24,6 @@ import "../views"
|
||||||
StatusDialog {
|
StatusDialog {
|
||||||
id: popup
|
id: popup
|
||||||
|
|
||||||
property bool isBridgeTx: false
|
|
||||||
|
|
||||||
property string preSelectedRecipient
|
property string preSelectedRecipient
|
||||||
property string preDefinedAmountToSend
|
property string preDefinedAmountToSend
|
||||||
property var preSelectedHolding
|
property var preSelectedHolding
|
||||||
|
@ -44,7 +42,8 @@ StatusDialog {
|
||||||
property var bestRoutes
|
property var bestRoutes
|
||||||
property alias addressText: recipientLoader.addressText
|
property alias addressText: recipientLoader.addressText
|
||||||
property bool isLoading: false
|
property bool isLoading: false
|
||||||
property int sendType: isBridgeTx ? Constants.SendType.Bridge : Constants.SendType.Transfer
|
property int sendType: Constants.SendType.Transfer
|
||||||
|
|
||||||
property MessageDialog sendingError: MessageDialog {
|
property MessageDialog sendingError: MessageDialog {
|
||||||
id: sendingError
|
id: sendingError
|
||||||
title: qsTr("Error sending the transaction")
|
title: qsTr("Error sending the transaction")
|
||||||
|
@ -60,20 +59,21 @@ StatusDialog {
|
||||||
recipientAddress,
|
recipientAddress,
|
||||||
d.selectedSymbol,
|
d.selectedSymbol,
|
||||||
amountToSendInput.cryptoValueToSend,
|
amountToSendInput.cryptoValueToSend,
|
||||||
d.uuid)
|
d.uuid,
|
||||||
|
sendType)
|
||||||
}
|
}
|
||||||
|
|
||||||
property var recalculateRoutesAndFees: Backpressure.debounce(popup, 600, function() {
|
property var recalculateRoutesAndFees: Backpressure.debounce(popup, 600, function() {
|
||||||
if(!!popup.selectedAccount && d.isSelectedHoldingValidAsset && recipientLoader.ready && amountToSendInput.inputNumberValid) {
|
if(!!popup.selectedAccount && !!d.selectedHolding && recipientLoader.ready && amountToSendInput.inputNumberValid) {
|
||||||
popup.isLoading = true
|
popup.isLoading = true
|
||||||
let amount = Math.round(amountToSendInput.cryptoValueToSend * Math.pow(10, d.selectedHolding.decimals))
|
let amount = d.isERC721Transfer ? 1: Math.round(amountToSendInput.cryptoValueToSend * Math.pow(10, d.selectedHolding.decimals))
|
||||||
popup.store.suggestedRoutes(amount.toString(16), popup.sendType)
|
popup.store.suggestedRoutes(amount.toString(16), popup.sendType)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
QtObject {
|
QtObject {
|
||||||
id: d
|
id: d
|
||||||
readonly property int errorType: !amountToSendInput.input.valid ? Constants.SendAmountExceedsBalance :
|
readonly property int errorType: !amountToSendInput.input.valid && !isERC721Transfer ? Constants.SendAmountExceedsBalance :
|
||||||
(popup.bestRoutes && popup.bestRoutes.count === 0 &&
|
(popup.bestRoutes && popup.bestRoutes.count === 0 &&
|
||||||
!!amountToSendInput.input.text && recipientLoader.ready && !popup.isLoading) ?
|
!!amountToSendInput.input.text && recipientLoader.ready && !popup.isLoading) ?
|
||||||
Constants.NoRoute : Constants.NoError
|
Constants.NoRoute : Constants.NoError
|
||||||
|
@ -88,7 +88,8 @@ StatusDialog {
|
||||||
property string totalTimeEstimate
|
property string totalTimeEstimate
|
||||||
property double totalFeesInFiat
|
property double totalFeesInFiat
|
||||||
property double totalAmountToReceive
|
property double totalAmountToReceive
|
||||||
|
readonly property bool isBridgeTx: popup.sendType === Constants.SendType.Bridge
|
||||||
|
readonly property bool isERC721Transfer: popup.sendType === Constants.SendType.ERC721Transfer
|
||||||
property var selectedHolding: null
|
property var selectedHolding: null
|
||||||
property var selectedHoldingType: Constants.HoldingType.Unknown
|
property var selectedHoldingType: Constants.HoldingType.Unknown
|
||||||
readonly property bool isSelectedHoldingValidAsset: !!selectedHolding && selectedHoldingType === Constants.HoldingType.Asset
|
readonly property bool isSelectedHoldingValidAsset: !!selectedHolding && selectedHoldingType === Constants.HoldingType.Asset
|
||||||
|
@ -102,8 +103,8 @@ StatusDialog {
|
||||||
}
|
}
|
||||||
|
|
||||||
function setSelectedHolding(holding, holdingType) {
|
function setSelectedHolding(holding, holdingType) {
|
||||||
d.selectedHolding = holding
|
|
||||||
d.selectedHoldingType = holdingType
|
d.selectedHoldingType = holdingType
|
||||||
|
d.selectedHolding = holding
|
||||||
let selectorHolding = store.holdingToSelectorHolding(holding, holdingType)
|
let selectorHolding = store.holdingToSelectorHolding(holding, holdingType)
|
||||||
holdingSelector.setSelectedItem(selectorHolding, holdingType)
|
holdingSelector.setSelectedItem(selectorHolding, holdingType)
|
||||||
}
|
}
|
||||||
|
@ -114,11 +115,25 @@ StatusDialog {
|
||||||
}
|
}
|
||||||
|
|
||||||
function setHoveredHolding(holding, holdingType) {
|
function setHoveredHolding(holding, holdingType) {
|
||||||
d.hoveredHolding = holding
|
|
||||||
d.hoveredHoldingType = holdingType
|
d.hoveredHoldingType = holdingType
|
||||||
|
d.hoveredHolding = holding
|
||||||
let selectorHolding = store.holdingToSelectorHolding(holding, holdingType)
|
let selectorHolding = store.holdingToSelectorHolding(holding, holdingType)
|
||||||
holdingSelector.setHoveredItem(selectorHolding, holdingType)
|
holdingSelector.setHoveredItem(selectorHolding, holdingType)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onSelectedHoldingChanged: {
|
||||||
|
if (d.selectedHoldingType === Constants.HoldingType.Asset) {
|
||||||
|
popup.sendType = Constants.SendType.Transfer
|
||||||
|
store.setSelectedAssetSymbol(selectedHolding.symbol)
|
||||||
|
} else if (d.selectedHoldingType === Constants.HoldingType.Collectible) {
|
||||||
|
popup.sendType = Constants.SendType.ERC721Transfer
|
||||||
|
amountToSendInput.input.text = 1
|
||||||
|
store.setSelectedAssetSymbol(selectedHolding.contractAddress+":"+selectedHolding.tokenId)
|
||||||
|
store.setRouteEnabledFromChains(selectedHolding.chainId)
|
||||||
|
store.updateRoutePreferredChains(selectedHolding.chainId)
|
||||||
|
}
|
||||||
|
recalculateRoutesAndFees()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
width: 556
|
width: 556
|
||||||
|
@ -152,12 +167,14 @@ StatusDialog {
|
||||||
recipientLoader.selectedRecipient = {address: popup.preSelectedRecipient}
|
recipientLoader.selectedRecipient = {address: popup.preSelectedRecipient}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(popup.isBridgeTx) {
|
if(d.isBridgeTx) {
|
||||||
recipientLoader.selectedRecipientType = TabAddressSelectorView.Type.Address
|
recipientLoader.selectedRecipientType = TabAddressSelectorView.Type.Address
|
||||||
recipientLoader.selectedRecipient = {address: popup.selectedAccount.address}
|
recipientLoader.selectedRecipient = {address: popup.selectedAccount.address}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onClosed: popup.store.resetStoredProperties()
|
||||||
|
|
||||||
header: AccountsModalHeader {
|
header: AccountsModalHeader {
|
||||||
anchors.top: parent.top
|
anchors.top: parent.top
|
||||||
anchors.topMargin: -height - 18
|
anchors.topMargin: -height - 18
|
||||||
|
@ -215,7 +232,7 @@ StatusDialog {
|
||||||
id: modalHeader
|
id: modalHeader
|
||||||
Layout.alignment: Qt.AlignVCenter | Qt.AlignLeft
|
Layout.alignment: Qt.AlignVCenter | Qt.AlignLeft
|
||||||
verticalAlignment: Text.AlignVCenter
|
verticalAlignment: Text.AlignVCenter
|
||||||
text: popup.isBridgeTx ? qsTr("Bridge") : qsTr("Send")
|
text: d.isBridgeTx ? qsTr("Bridge") : qsTr("Send")
|
||||||
font.pixelSize: 28
|
font.pixelSize: 28
|
||||||
lineHeight: 38
|
lineHeight: 38
|
||||||
lineHeightMode: Text.FixedHeight
|
lineHeightMode: Text.FixedHeight
|
||||||
|
@ -230,7 +247,8 @@ StatusDialog {
|
||||||
assetsModel: popup.selectedAccount && popup.selectedAccount.assets ? popup.selectedAccount.assets : null
|
assetsModel: popup.selectedAccount && popup.selectedAccount.assets ? popup.selectedAccount.assets : null
|
||||||
collectiblesModel: popup.selectedAccount ? popup.nestedCollectiblesModel : null
|
collectiblesModel: popup.selectedAccount ? popup.nestedCollectiblesModel : null
|
||||||
currentCurrencySymbol: RootStore.currencyStore.currentCurrencySymbol
|
currentCurrencySymbol: RootStore.currencyStore.currentCurrencySymbol
|
||||||
visible: !!d.selectedHolding || !!d.hoveredHolding
|
visible: (!!d.selectedHolding && d.selectedHoldingType !== Constants.HoldingType.Unknown) ||
|
||||||
|
(!!d.hoveredHolding && d.hoveredHoldingType !== Constants.HoldingType.Unknown)
|
||||||
getNetworkIcon: function(chainId){
|
getNetworkIcon: function(chainId){
|
||||||
return RootStore.getNetworkIcon(chainId)
|
return RootStore.getNetworkIcon(chainId)
|
||||||
}
|
}
|
||||||
|
@ -242,9 +260,9 @@ StatusDialog {
|
||||||
StatusListItemTag {
|
StatusListItemTag {
|
||||||
Layout.alignment: Qt.AlignVCenter | Qt.AlignRight
|
Layout.alignment: Qt.AlignVCenter | Qt.AlignRight
|
||||||
Layout.preferredHeight: 22
|
Layout.preferredHeight: 22
|
||||||
visible: d.isSelectedHoldingValidAsset || d.isHoveredHoldingValidAsset
|
visible: d.isSelectedHoldingValidAsset || d.isHoveredHoldingValidAsset && !d.isERC721Transfer
|
||||||
title: {
|
title: {
|
||||||
if(d.isHoveredHoldingValidAsset) {
|
if(d.isHoveredHoldingValidAsset && !!d.hoveredHolding.symbol) {
|
||||||
const balance = popup.currencyStore.formatCurrencyAmount((amountToSendInput.inputIsFiat ? d.hoveredHolding.totalCurrencyBalance.amount : d.hoveredHolding.totalBalance.amount) , d.hoveredHolding.symbol)
|
const balance = popup.currencyStore.formatCurrencyAmount((amountToSendInput.inputIsFiat ? d.hoveredHolding.totalCurrencyBalance.amount : d.hoveredHolding.totalBalance.amount) , d.hoveredHolding.symbol)
|
||||||
return qsTr("Max: %1").arg(balance)
|
return qsTr("Max: %1").arg(balance)
|
||||||
}
|
}
|
||||||
|
@ -288,11 +306,11 @@ StatusDialog {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
RowLayout {
|
RowLayout {
|
||||||
visible: d.isSelectedHoldingValidAsset
|
visible: d.isSelectedHoldingValidAsset && !d.isERC721Transfer
|
||||||
AmountToSend {
|
AmountToSend {
|
||||||
id: amountToSendInput
|
id: amountToSendInput
|
||||||
Layout.fillWidth:true
|
Layout.fillWidth:true
|
||||||
isBridgeTx: popup.isBridgeTx
|
isBridgeTx: d.isBridgeTx
|
||||||
interactive: popup.interactive
|
interactive: popup.interactive
|
||||||
selectedSymbol: d.selectedSymbol
|
selectedSymbol: d.selectedSymbol
|
||||||
maxInputBalance: d.maxInputBalance
|
maxInputBalance: d.maxInputBalance
|
||||||
|
@ -314,10 +332,11 @@ StatusDialog {
|
||||||
id: amountToReceive
|
id: amountToReceive
|
||||||
Layout.alignment: Qt.AlignRight
|
Layout.alignment: Qt.AlignRight
|
||||||
Layout.fillWidth:true
|
Layout.fillWidth:true
|
||||||
visible: !!popup.bestRoutes && popup.bestRoutes !== undefined && popup.bestRoutes.count > 0 && amountToSendInput.inputNumberValid
|
visible: !!popup.bestRoutes && popup.bestRoutes !== undefined &&
|
||||||
|
popup.bestRoutes.count > 0 && amountToSendInput.inputNumberValid
|
||||||
isLoading: popup.isLoading
|
isLoading: popup.isLoading
|
||||||
selectedSymbol: d.selectedSymbol
|
selectedSymbol: d.selectedSymbol
|
||||||
isBridgeTx: popup.isBridgeTx
|
isBridgeTx: d.isBridgeTx
|
||||||
cryptoValueToReceive: d.totalAmountToReceive
|
cryptoValueToReceive: d.totalAmountToReceive
|
||||||
inputIsFiat: amountToSendInput.inputIsFiat
|
inputIsFiat: amountToSendInput.inputIsFiat
|
||||||
minCryptoDecimals: amountToSendInput.minReceiveCryptoDecimals
|
minCryptoDecimals: amountToSendInput.minReceiveCryptoDecimals
|
||||||
|
@ -366,7 +385,7 @@ StatusDialog {
|
||||||
anchors.right: parent.right
|
anchors.right: parent.right
|
||||||
anchors.leftMargin: Style.current.bigPadding
|
anchors.leftMargin: Style.current.bigPadding
|
||||||
anchors.rightMargin: Style.current.bigPadding
|
anchors.rightMargin: Style.current.bigPadding
|
||||||
visible: !isBridgeTx && !!d.selectedHolding
|
visible: !d.isBridgeTx && !!d.selectedHolding
|
||||||
StatusBaseText {
|
StatusBaseText {
|
||||||
id: label
|
id: label
|
||||||
elide: Text.ElideRight
|
elide: Text.ElideRight
|
||||||
|
@ -378,7 +397,8 @@ StatusDialog {
|
||||||
id: recipientLoader
|
id: recipientLoader
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
store: popup.store
|
store: popup.store
|
||||||
isBridgeTx: popup.isBridgeTx
|
isERC721Transfer: d.isERC721Transfer
|
||||||
|
isBridgeTx: d.isBridgeTx
|
||||||
interactive: popup.interactive
|
interactive: popup.interactive
|
||||||
selectedAsset: d.selectedHolding
|
selectedAsset: d.selectedHolding
|
||||||
onIsLoading: popup.isLoading = true
|
onIsLoading: popup.isLoading = true
|
||||||
|
@ -398,7 +418,7 @@ StatusDialog {
|
||||||
recipientLoader.selectedRecipientType = type
|
recipientLoader.selectedRecipientType = type
|
||||||
recipientLoader.selectedRecipient = recipient
|
recipientLoader.selectedRecipient = recipient
|
||||||
}
|
}
|
||||||
visible: !recipientLoader.ready && !isBridgeTx && !!d.selectedHolding
|
visible: !recipientLoader.ready && !d.isBridgeTx && !!d.selectedHolding
|
||||||
}
|
}
|
||||||
|
|
||||||
NetworkSelector {
|
NetworkSelector {
|
||||||
|
@ -419,7 +439,8 @@ StatusDialog {
|
||||||
visible: recipientLoader.ready && !!d.selectedHolding && amountToSendInput.inputNumberValid
|
visible: recipientLoader.ready && !!d.selectedHolding && amountToSendInput.inputNumberValid
|
||||||
errorType: d.errorType
|
errorType: d.errorType
|
||||||
isLoading: popup.isLoading
|
isLoading: popup.isLoading
|
||||||
isBridgeTx: popup.isBridgeTx
|
isBridgeTx: d.isBridgeTx
|
||||||
|
isERC721Transfer: d.isERC721Transfer
|
||||||
}
|
}
|
||||||
|
|
||||||
FeesView {
|
FeesView {
|
||||||
|
@ -442,7 +463,7 @@ StatusDialog {
|
||||||
}
|
}
|
||||||
|
|
||||||
footer: SendModalFooter {
|
footer: SendModalFooter {
|
||||||
nextButtonText: popup.isBridgeTx ? qsTr("Bridge") : qsTr("Send")
|
nextButtonText: d.isBridgeTx ? qsTr("Bridge") : qsTr("Send")
|
||||||
maxFiatFees: popup.isLoading ? "..." : popup.currencyStore.formatCurrencyAmount(d.totalFeesInFiat, popup.currencyStore.currentCurrency)
|
maxFiatFees: popup.isLoading ? "..." : popup.currencyStore.formatCurrencyAmount(d.totalFeesInFiat, popup.currencyStore.currentCurrency)
|
||||||
totalTimeEstimate: popup.isLoading? "..." : d.totalTimeEstimate
|
totalTimeEstimate: popup.isLoading? "..." : d.totalTimeEstimate
|
||||||
pending: d.isPendingTx || popup.isLoading
|
pending: d.isPendingTx || popup.isLoading
|
||||||
|
|
|
@ -45,8 +45,8 @@ QtObject {
|
||||||
globalUtils.copyToClipboard(text)
|
globalUtils.copyToClipboard(text)
|
||||||
}
|
}
|
||||||
|
|
||||||
function authenticateAndTransfer(from, to, tokenSymbol, amount, uuid) {
|
function authenticateAndTransfer(from, to, tokenSymbol, amount, uuid, sendType) {
|
||||||
walletSectionSendInst.authenticateAndTransfer(from, to, tokenSymbol, amount, uuid)
|
walletSectionSendInst.authenticateAndTransfer(from, to, tokenSymbol, amount, uuid, sendType)
|
||||||
}
|
}
|
||||||
|
|
||||||
function suggestedRoutes(amount, sendType) {
|
function suggestedRoutes(amount, sendType) {
|
||||||
|
@ -180,15 +180,19 @@ QtObject {
|
||||||
}
|
}
|
||||||
|
|
||||||
function toggleFromDisabledChains(chainId) {
|
function toggleFromDisabledChains(chainId) {
|
||||||
fromNetworksModel.toggleDisabledChains(chainId)
|
fromNetworksModel.toggleRouteDisabledChains(chainId)
|
||||||
}
|
}
|
||||||
|
|
||||||
function toggleToDisabledChains(chainId) {
|
function toggleToDisabledChains(chainId) {
|
||||||
toNetworksModel.toggleDisabledChains(chainId)
|
toNetworksModel.toggleRouteDisabledChains(chainId)
|
||||||
}
|
}
|
||||||
|
|
||||||
function setDisabledChains(chainId, disabled) {
|
function setRouteDisabledChains(chainId, disabled) {
|
||||||
toNetworksModel.setDisabledChains(chainId, disabled)
|
toNetworksModel.setRouteDisabledChains(chainId, disabled)
|
||||||
|
}
|
||||||
|
|
||||||
|
function setRouteEnabledFromChains(chainId) {
|
||||||
|
fromNetworksModel.setRouteEnabledFromChains(chainId)
|
||||||
}
|
}
|
||||||
|
|
||||||
function setSelectedAssetSymbol(symbol) {
|
function setSelectedAssetSymbol(symbol) {
|
||||||
|
@ -199,16 +203,16 @@ QtObject {
|
||||||
return fromNetworksModel.getNetworkName(chainId)
|
return fromNetworksModel.getNetworkName(chainId)
|
||||||
}
|
}
|
||||||
|
|
||||||
function updatePreferredChains(chainIds) {
|
function updateRoutePreferredChains(chainIds) {
|
||||||
walletSectionSendInst.updatePreferredChains(chainIds)
|
walletSectionSendInst.updateRoutePreferredChains(chainIds)
|
||||||
}
|
}
|
||||||
|
|
||||||
function toggleShowUnPreferredChains() {
|
function toggleShowUnPreferredChains() {
|
||||||
walletSectionSendInst.toggleShowUnPreferredChains()
|
walletSectionSendInst.toggleShowUnPreferredChains()
|
||||||
}
|
}
|
||||||
|
|
||||||
function setAllNetworksAsPreferredChains() {
|
function setAllNetworksAsRoutePreferredChains() {
|
||||||
toNetworksModel.setAllNetworksAsPreferredChains()
|
toNetworksModel.setAllNetworksAsRoutePreferredChains()
|
||||||
}
|
}
|
||||||
|
|
||||||
function lockCard(chainId, amount, lock) {
|
function lockCard(chainId, amount, lock) {
|
||||||
|
@ -220,7 +224,7 @@ QtObject {
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: move to nim
|
// TODO: move to nim
|
||||||
function splitAndFormatAddressPrefix(text, isBridgeTx) {
|
function splitAndFormatAddressPrefix(text, updateInStore) {
|
||||||
let address = ""
|
let address = ""
|
||||||
let tempPreferredChains = []
|
let tempPreferredChains = []
|
||||||
let chainFound = false
|
let chainFound = false
|
||||||
|
@ -236,18 +240,17 @@ QtObject {
|
||||||
let chainColor = fromNetworksModel.getNetworkColor(word)
|
let chainColor = fromNetworksModel.getNetworkColor(word)
|
||||||
if(!!chainColor) {
|
if(!!chainColor) {
|
||||||
chainFound = true
|
chainFound = true
|
||||||
if(!isBridgeTx)
|
|
||||||
tempPreferredChains.push(fromNetworksModel.getNetworkChainId(word))
|
tempPreferredChains.push(fromNetworksModel.getNetworkChainId(word))
|
||||||
editedText += `<span style='color: %1'>%2</span>`.arg(chainColor).arg(word)+':'
|
editedText += `<span style='color: %1'>%2</span>`.arg(chainColor).arg(word)+':'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!isBridgeTx) {
|
if(updateInStore) {
|
||||||
if(!chainFound)
|
if(!chainFound)
|
||||||
updatePreferredChains(networksModule.getMainnetChainId())
|
updateRoutePreferredChains(networksModule.getMainnetChainId())
|
||||||
else
|
else
|
||||||
updatePreferredChains(tempPreferredChains.join(":"))
|
updateRoutePreferredChains(tempPreferredChains.join(":"))
|
||||||
}
|
}
|
||||||
|
|
||||||
editedText +="</a></p>"
|
editedText +="</a></p>"
|
||||||
|
|
|
@ -30,6 +30,7 @@ Item {
|
||||||
property bool errorMode: advancedNetworkRoutingPage.errorMode
|
property bool errorMode: advancedNetworkRoutingPage.errorMode
|
||||||
property bool interactive: true
|
property bool interactive: true
|
||||||
property bool isBridgeTx: false
|
property bool isBridgeTx: false
|
||||||
|
property bool isERC721Transfer: false
|
||||||
property var toNetworksList
|
property var toNetworksList
|
||||||
property int errorType: Constants.NoError
|
property int errorType: Constants.NoError
|
||||||
|
|
||||||
|
@ -45,6 +46,7 @@ Item {
|
||||||
id: tabBar
|
id: tabBar
|
||||||
anchors.top: parent.top
|
anchors.top: parent.top
|
||||||
anchors.horizontalCenter: parent.horizontalCenter
|
anchors.horizontalCenter: parent.horizontalCenter
|
||||||
|
visible: !root.isERC721Transfer
|
||||||
StatusSwitchTabButton {
|
StatusSwitchTabButton {
|
||||||
text: qsTr("Simple")
|
text: qsTr("Simple")
|
||||||
}
|
}
|
||||||
|
@ -58,12 +60,12 @@ Item {
|
||||||
|
|
||||||
StackLayout {
|
StackLayout {
|
||||||
id: stackLayout
|
id: stackLayout
|
||||||
anchors.top: tabBar.bottom
|
anchors.top: !root.isERC721Transfer ? tabBar.bottom: parent.top
|
||||||
anchors.topMargin: Style.current.bigPadding
|
anchors.topMargin: !root.isERC721Transfer ? Style.current.bigPadding: 0
|
||||||
height: currentIndex == 0 ? networksSimpleRoutingPage.height + networksSimpleRoutingPage.anchors.margins + Style.current.bigPadding:
|
height: currentIndex == 0 ? networksSimpleRoutingPage.height + networksSimpleRoutingPage.anchors.margins + Style.current.bigPadding:
|
||||||
advancedNetworkRoutingPage.height + advancedNetworkRoutingPage.anchors.margins + Style.current.bigPadding
|
advancedNetworkRoutingPage.height + advancedNetworkRoutingPage.anchors.margins + Style.current.bigPadding
|
||||||
width: parent.width
|
width: parent.width
|
||||||
currentIndex: tabBar.currentIndex === 0 ? 0 : 1
|
currentIndex: root.isERC721Transfer ? 0: tabBar.currentIndex === 0 ? 0 : 1
|
||||||
|
|
||||||
Rectangle {
|
Rectangle {
|
||||||
id: simple
|
id: simple
|
||||||
|
@ -76,6 +78,7 @@ Item {
|
||||||
anchors.margins: Style.current.padding
|
anchors.margins: Style.current.padding
|
||||||
width: stackLayout.width - Style.current.bigPadding
|
width: stackLayout.width - Style.current.bigPadding
|
||||||
isBridgeTx: root.isBridgeTx
|
isBridgeTx: root.isBridgeTx
|
||||||
|
isERC721Transfer: root.isERC721Transfer
|
||||||
amountToSend: root.amountToSend
|
amountToSend: root.amountToSend
|
||||||
minReceiveCryptoDecimals: root.minReceiveCryptoDecimals
|
minReceiveCryptoDecimals: root.minReceiveCryptoDecimals
|
||||||
isLoading: root.isLoading
|
isLoading: root.isLoading
|
||||||
|
@ -85,7 +88,7 @@ Item {
|
||||||
errorType: root.errorType
|
errorType: root.errorType
|
||||||
toNetworksList: root.toNetworksList
|
toNetworksList: root.toNetworksList
|
||||||
weiToEth: function(wei) {
|
weiToEth: function(wei) {
|
||||||
if(root.selectedAsset !== undefined)
|
if(!!selectedAsset && root.selectedAsset !== undefined)
|
||||||
return parseFloat(store.getWei2Eth(wei, root.selectedAsset.decimals))
|
return parseFloat(store.getWei2Eth(wei, root.selectedAsset.decimals))
|
||||||
}
|
}
|
||||||
formatCurrencyAmount: root.currencyStore.formatCurrencyAmount
|
formatCurrencyAmount: root.currencyStore.formatCurrencyAmount
|
||||||
|
@ -119,7 +122,7 @@ Item {
|
||||||
isBridgeTx: root.isBridgeTx
|
isBridgeTx: root.isBridgeTx
|
||||||
errorType: root.errorType
|
errorType: root.errorType
|
||||||
weiToEth: function(wei) {
|
weiToEth: function(wei) {
|
||||||
if(selectedAsset !== undefined)
|
if(!!selectedAsset && selectedAsset !== undefined)
|
||||||
return parseFloat(store.getWei2Eth(wei, selectedAsset.decimals))
|
return parseFloat(store.getWei2Eth(wei, selectedAsset.decimals))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,6 +20,7 @@ RowLayout {
|
||||||
property int minReceiveCryptoDecimals: 0
|
property int minReceiveCryptoDecimals: 0
|
||||||
property bool isLoading: false
|
property bool isLoading: false
|
||||||
property bool isBridgeTx: false
|
property bool isBridgeTx: false
|
||||||
|
property bool isERC721Transfer: false
|
||||||
property var selectedAccount
|
property var selectedAccount
|
||||||
property var toNetworksList
|
property var toNetworksList
|
||||||
property var weiToEth: function(wei) {}
|
property var weiToEth: function(wei) {}
|
||||||
|
@ -100,6 +101,8 @@ RowLayout {
|
||||||
implicitWidth: 410
|
implicitWidth: 410
|
||||||
title: model.chainName
|
title: model.chainName
|
||||||
subTitle: {
|
subTitle: {
|
||||||
|
if(root.isERC721Transfer)
|
||||||
|
return ""
|
||||||
let amountOut = root.weiToEth(model.amountOut)
|
let amountOut = root.weiToEth(model.amountOut)
|
||||||
return root.formatCurrencyAmount(amountOut, store.selectedAssetSymbol, {"minDecimals": root.minReceiveCryptoDecimals})
|
return root.formatCurrencyAmount(amountOut, store.selectedAssetSymbol, {"minDecimals": root.minReceiveCryptoDecimals})
|
||||||
}
|
}
|
||||||
|
@ -140,7 +143,7 @@ RowLayout {
|
||||||
onClicked: gasRectangle.toggle()
|
onClicked: gasRectangle.toggle()
|
||||||
}
|
}
|
||||||
onCheckedChanged: {
|
onCheckedChanged: {
|
||||||
store.setDisabledChains(chainId, !gasRectangle.checked)
|
store.setRouteDisabledChains(chainId, !gasRectangle.checked)
|
||||||
if(checked)
|
if(checked)
|
||||||
root.reCalculateSuggestedRoute()
|
root.reCalculateSuggestedRoute()
|
||||||
}
|
}
|
||||||
|
@ -150,7 +153,7 @@ RowLayout {
|
||||||
height: card.height
|
height: card.height
|
||||||
}
|
}
|
||||||
Component.onCompleted: {
|
Component.onCompleted: {
|
||||||
store.setDisabledChains(chainId, !gasRectangle.checked)
|
store.setRouteDisabledChains(chainId, !gasRectangle.checked)
|
||||||
if(index === (repeater.count -1))
|
if(index === (repeater.count -1))
|
||||||
root.reCalculateSuggestedRoute()
|
root.reCalculateSuggestedRoute()
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,6 +16,7 @@ Loader {
|
||||||
id: root
|
id: root
|
||||||
|
|
||||||
property var store
|
property var store
|
||||||
|
property bool isERC721Transfer
|
||||||
property bool isBridgeTx: false
|
property bool isBridgeTx: false
|
||||||
property bool interactive: true
|
property bool interactive: true
|
||||||
property var selectedAsset
|
property var selectedAsset
|
||||||
|
@ -35,10 +36,12 @@ Loader {
|
||||||
onSelectedRecipientChanged: {
|
onSelectedRecipientChanged: {
|
||||||
root.isLoading()
|
root.isLoading()
|
||||||
d.waitTimer.restart()
|
d.waitTimer.restart()
|
||||||
|
if(!isERC721Transfer) {
|
||||||
if(!root.isBridgeTx)
|
if(!root.isBridgeTx)
|
||||||
root.store.updatePreferredChains(root.selectedRecipient.preferredSharingChainIds)
|
root.store.updateRoutePreferredChains(root.selectedRecipient.preferredSharingChainIds)
|
||||||
else
|
else
|
||||||
root.store.setAllNetworksAsPreferredChains()
|
root.store.setAllNetworksAsRoutePreferredChains()
|
||||||
|
}
|
||||||
if(!!root.selectedRecipient && root.selectedRecipientType !== TabAddressSelectorView.Type.None) {
|
if(!!root.selectedRecipient && root.selectedRecipientType !== TabAddressSelectorView.Type.None) {
|
||||||
switch(root.selectedRecipientType) {
|
switch(root.selectedRecipientType) {
|
||||||
case TabAddressSelectorView.Type.SavedAddress: {
|
case TabAddressSelectorView.Type.SavedAddress: {
|
||||||
|
@ -88,10 +91,10 @@ Loader {
|
||||||
if(!!root.item.input)
|
if(!!root.item.input)
|
||||||
root.item.input.text = root.resolvedENSAddress
|
root.item.input.text = root.resolvedENSAddress
|
||||||
root.addressText = root.resolvedENSAddress
|
root.addressText = root.resolvedENSAddress
|
||||||
store.splitAndFormatAddressPrefix(root.address, root.isBridgeTx)
|
store.splitAndFormatAddressPrefix(root.address, !root.isBridgeTx && !isERC721Transfer)
|
||||||
} else {
|
} else {
|
||||||
let address = d.getAddress()
|
let address = d.getAddress()
|
||||||
let result = store.splitAndFormatAddressPrefix(address, root.isBridgeTx)
|
let result = store.splitAndFormatAddressPrefix(address, !root.isBridgeTx && !isERC721Transfer)
|
||||||
if(!!result.address) {
|
if(!!result.address) {
|
||||||
root.addressText = result.address
|
root.addressText = result.address
|
||||||
if(!!root.item.input)
|
if(!!root.item.input)
|
||||||
|
|
|
@ -983,7 +983,8 @@ QtObject {
|
||||||
ENSRelease,
|
ENSRelease,
|
||||||
ENSSetPubKey,
|
ENSSetPubKey,
|
||||||
StickersBuy,
|
StickersBuy,
|
||||||
Bridge
|
Bridge,
|
||||||
|
ERC721Transfer
|
||||||
}
|
}
|
||||||
|
|
||||||
enum ErrorType {
|
enum ErrorType {
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 83d13548458c60d14eba6efdd92a928f9f0050a1
|
Subproject commit ea29c034658d8b82c24fde0e369060642b38d4c3
|
Loading…
Reference in New Issue