fix(@desktop/wallet): Show networks for Bridge txs (#11898)
This commit is contained in:
parent
ca5b07af42
commit
faf4933262
|
@ -166,15 +166,23 @@ QtObject:
|
||||||
QtProperty[int] status:
|
QtProperty[int] status:
|
||||||
read = getStatus
|
read = getStatus
|
||||||
|
|
||||||
proc getChainId*(self: ActivityEntry): int {.slot.} =
|
proc getChainIdIn*(self: ActivityEntry): int {.slot.} =
|
||||||
if self.metadata.payloadType == backend.PayloadType.MultiTransaction:
|
|
||||||
error "getChainId: ActivityEntry is not a transaction"
|
|
||||||
return 0
|
|
||||||
|
|
||||||
if self.isInTransactionType():
|
|
||||||
return self.metadata.chainIdIn.get(ChainId(0)).int
|
return self.metadata.chainIdIn.get(ChainId(0)).int
|
||||||
|
|
||||||
|
QtProperty[int] chainIdIn:
|
||||||
|
read = getChainIdIn
|
||||||
|
|
||||||
|
proc getChainIdOut*(self: ActivityEntry): int {.slot.} =
|
||||||
return self.metadata.chainIdOut.get(ChainId(0)).int
|
return self.metadata.chainIdOut.get(ChainId(0)).int
|
||||||
|
|
||||||
|
QtProperty[int] chainIdOut:
|
||||||
|
read = getChainIdOut
|
||||||
|
|
||||||
|
proc getChainId*(self: ActivityEntry): int {.slot.} =
|
||||||
|
if self.isInTransactionType():
|
||||||
|
return self.getChainIdIn()
|
||||||
|
return self.getChainIdOut()
|
||||||
|
|
||||||
QtProperty[int] chainId:
|
QtProperty[int] chainId:
|
||||||
read = getChainId
|
read = getChainId
|
||||||
|
|
||||||
|
|
|
@ -43,11 +43,11 @@ Item {
|
||||||
id: d
|
id: d
|
||||||
readonly property bool isIncoming: transactionType === Constants.TransactionType.Received
|
readonly property bool isIncoming: transactionType === Constants.TransactionType.Received
|
||||||
readonly property string networkShortName: root.isTransactionValid ? RootStore.getNetworkShortName(transaction.chainId) : ""
|
readonly property string networkShortName: root.isTransactionValid ? RootStore.getNetworkShortName(transaction.chainId) : ""
|
||||||
readonly property string networkIcon: isTransactionValid ? RootStore.getNetworkIcon(transaction.chainId) : ""
|
readonly property string networkIcon: isTransactionValid ? RootStore.getNetworkIcon(transaction.chainId) : "network/Network=Custom"
|
||||||
readonly property int blockNumber: root.isTransactionValid ? RootStore.hex2Dec(root.transaction.blockNumber) : 0
|
readonly property int blockNumber: root.isTransactionValid ? RootStore.hex2Dec(root.transaction.blockNumber) : 0
|
||||||
readonly property int toBlockNumber: 0 // TODO fill when bridge data is implemented
|
readonly property int toBlockNumber: 0 // TODO fill when bridge data is implemented
|
||||||
readonly property string toNetworkIcon: "" // TODO fill when bridge data is implemented
|
readonly property string networkShortNameOut: networkShortName
|
||||||
readonly property string toNetworkShortName: "" // TODO fill when bridge data is implemented
|
readonly property string networkShortNameIn: transactionHeader.isMultiTransaction ? RootStore.getNetworkShortName(transaction.chainIdOut) : ""
|
||||||
readonly property string symbol: isTransactionValid ? transaction.symbol : ""
|
readonly property string symbol: isTransactionValid ? transaction.symbol : ""
|
||||||
readonly property string inSymbol: isTransactionValid ? transaction.inSymbol : ""
|
readonly property string inSymbol: isTransactionValid ? transaction.inSymbol : ""
|
||||||
readonly property string outSymbol: isTransactionValid ? transaction.outSymbol : ""
|
readonly property string outSymbol: isTransactionValid ? transaction.outSymbol : ""
|
||||||
|
@ -77,7 +77,6 @@ Item {
|
||||||
readonly property real feeEthValue: root.isTransactionValid ? RootStore.getGasEthValue(transaction.totalFees.amount, 1) : 0 // TODO use directly?
|
readonly property real feeEthValue: root.isTransactionValid ? RootStore.getGasEthValue(transaction.totalFees.amount, 1) : 0 // TODO use directly?
|
||||||
readonly property real feeFiatValue: root.isTransactionValid ? RootStore.getFiatValue(d.feeEthValue, Constants.ethToken, RootStore.currentCurrency) : 0 // TODO use directly?
|
readonly property real feeFiatValue: root.isTransactionValid ? RootStore.getFiatValue(d.feeEthValue, Constants.ethToken, RootStore.currentCurrency) : 0 // TODO use directly?
|
||||||
readonly property int transactionType: root.isTransactionValid ? transaction.txType : Constants.TransactionType.Send
|
readonly property int transactionType: root.isTransactionValid ? transaction.txType : Constants.TransactionType.Send
|
||||||
readonly property string toNetworkName: "" // TODO fill network name for bridge
|
|
||||||
|
|
||||||
property string decodedInputData: ""
|
property string decodedInputData: ""
|
||||||
property bool loadingInputDate: false
|
property bool loadingInputDate: false
|
||||||
|
@ -200,21 +199,25 @@ Item {
|
||||||
Layout.fillHeight: true
|
Layout.fillHeight: true
|
||||||
title: qsTr("From")
|
title: qsTr("From")
|
||||||
subTitle: {
|
subTitle: {
|
||||||
|
if (!root.isTransactionValid)
|
||||||
|
return ""
|
||||||
switch(d.transactionType) {
|
switch(d.transactionType) {
|
||||||
case Constants.TransactionType.Swap:
|
case Constants.TransactionType.Swap:
|
||||||
return !!d.outSymbol ? d.outSymbol : " "
|
return !!d.outSymbol ? d.outSymbol : " "
|
||||||
case Constants.TransactionType.Bridge:
|
case Constants.TransactionType.Bridge:
|
||||||
return transactionHeader.networkName
|
return transactionHeader.networkNameOut
|
||||||
default:
|
default:
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
asset.name: {
|
asset.name: {
|
||||||
|
if (!root.isTransactionValid)
|
||||||
|
return ""
|
||||||
switch(d.transactionType) {
|
switch(d.transactionType) {
|
||||||
case Constants.TransactionType.Swap:
|
case Constants.TransactionType.Swap:
|
||||||
return Constants.tokenIcon(d.outSymbol)
|
return Constants.tokenIcon(d.outSymbol)
|
||||||
case Constants.TransactionType.Bridge:
|
case Constants.TransactionType.Bridge:
|
||||||
return !!d.networkIcon ? Style.svg(d.networkIcon) : ""
|
return Style.svg(RootStore.getNetworkIcon(root.transaction.chainIdOut)) ?? Style.svg("network/Network=Custom")
|
||||||
default:
|
default:
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
|
@ -231,7 +234,7 @@ Item {
|
||||||
case Constants.TransactionType.Swap:
|
case Constants.TransactionType.Swap:
|
||||||
return !!d.inSymbol ? d.inSymbol : " "
|
return !!d.inSymbol ? d.inSymbol : " "
|
||||||
case Constants.TransactionType.Bridge:
|
case Constants.TransactionType.Bridge:
|
||||||
return d.toNetworkName
|
return transactionHeader.networkNameIn ?? " "
|
||||||
default:
|
default:
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
|
@ -241,7 +244,7 @@ Item {
|
||||||
case Constants.TransactionType.Swap:
|
case Constants.TransactionType.Swap:
|
||||||
return Constants.tokenIcon(d.inSymbol)
|
return Constants.tokenIcon(d.inSymbol)
|
||||||
case Constants.TransactionType.Bridge:
|
case Constants.TransactionType.Bridge:
|
||||||
return !!d.toNetworkIcon ? Style.svg(d.toNetworkIcon) : ""
|
return Style.svg(RootStore.getNetworkIcon(root.transaction.chainIdIn)) ?? Style.svg("network/Network=Custom")
|
||||||
default:
|
default:
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
|
@ -258,7 +261,7 @@ Item {
|
||||||
rootStore: WalletStores.RootStore
|
rootStore: WalletStores.RootStore
|
||||||
onButtonClicked: {
|
onButtonClicked: {
|
||||||
if (d.transactionType === Constants.TransactionType.Swap || d.transactionType === Constants.TransactionType.Bridge) {
|
if (d.transactionType === Constants.TransactionType.Swap || d.transactionType === Constants.TransactionType.Bridge) {
|
||||||
addressMenu.openEthAddressMenu(this, addresses[0], d.networkShortName)
|
addressMenu.openEthAddressMenu(this, addresses[0], d.networkShortNameOut)
|
||||||
} else {
|
} else {
|
||||||
addressMenu.openSenderMenu(this, addresses[0], d.networkShortName)
|
addressMenu.openSenderMenu(this, addresses[0], d.networkShortName)
|
||||||
}
|
}
|
||||||
|
@ -323,11 +326,11 @@ Item {
|
||||||
}
|
}
|
||||||
TransactionDataTile {
|
TransactionDataTile {
|
||||||
width: parent.width
|
width: parent.width
|
||||||
title: qsTr("%1 Tx hash").arg(d.toNetworkName)
|
title: qsTr("%1 Tx hash").arg(transactionHeader.networkNameIn)
|
||||||
subTitle: "" // TODO fill tx hash for Bridge
|
subTitle: "" // TODO fill tx hash for Bridge
|
||||||
visible: !!subTitle
|
visible: !!subTitle
|
||||||
buttonIconName: "more"
|
buttonIconName: "more"
|
||||||
onButtonClicked: addressMenu.openTxMenu(this, subTitle, d.toNetworkShortName)
|
onButtonClicked: addressMenu.openTxMenu(this, subTitle, d.networkShortNameIn)
|
||||||
}
|
}
|
||||||
TransactionContractTile {
|
TransactionContractTile {
|
||||||
// Used for Bridge and Swap to display 'From' network Protocol contract address
|
// Used for Bridge and Swap to display 'From' network Protocol contract address
|
||||||
|
@ -353,8 +356,8 @@ Item {
|
||||||
// Used for Bridge to display 'To' network Protocol contract address
|
// Used for Bridge to display 'To' network Protocol contract address
|
||||||
address: "" // TODO fill protocol contract address for 'to' network for Bridge
|
address: "" // TODO fill protocol contract address for 'to' network for Bridge
|
||||||
symbol: "" // TODO fill protocol name for Bridge
|
symbol: "" // TODO fill protocol name for Bridge
|
||||||
networkName: d.toNetworkName
|
networkName: transactionHeader.networknameOut
|
||||||
shortNetworkName: d.toNetworkShortName
|
shortNetworkName: d.networkShortNameOut
|
||||||
visible: !!subTitle && d.transactionType === Constants.TransactionType.Bridge
|
visible: !!subTitle && d.transactionType === Constants.TransactionType.Bridge
|
||||||
}
|
}
|
||||||
TransactionContractTile {
|
TransactionContractTile {
|
||||||
|
@ -383,8 +386,8 @@ Item {
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
networkName: d.toNetworkName
|
networkName: transactionHeader.networkNameIn
|
||||||
shortNetworkName: d.toNetworkShortName
|
shortNetworkName: d.networkShortNameIn
|
||||||
visible: root.isTransactionValid && !!subTitle
|
visible: root.isTransactionValid && !!subTitle
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,6 +60,8 @@ StatusListItem {
|
||||||
readonly property double feeFiatValue: 0.0 // TODO fill when bridge data is implemented
|
readonly property double feeFiatValue: 0.0 // TODO fill when bridge data is implemented
|
||||||
readonly property string networkColor: isModelDataValid ? rootStore.getNetworkColor(modelData.chainId) : ""
|
readonly property string networkColor: isModelDataValid ? rootStore.getNetworkColor(modelData.chainId) : ""
|
||||||
readonly property string networkName: isModelDataValid ? rootStore.getNetworkFullName(modelData.chainId) : ""
|
readonly property string networkName: isModelDataValid ? rootStore.getNetworkFullName(modelData.chainId) : ""
|
||||||
|
readonly property string networkNameIn: isMultiTransaction ? rootStore.getNetworkFullName(modelData.chainIdIn) : ""
|
||||||
|
readonly property string networkNameOut: isMultiTransaction ? rootStore.getNetworkFullName(modelData.chainIdOut) : ""
|
||||||
readonly property string addressNameTo: isModelDataValid ? walletRootStore.getNameForAddress(modelData.recipient) : ""
|
readonly property string addressNameTo: isModelDataValid ? walletRootStore.getNameForAddress(modelData.recipient) : ""
|
||||||
readonly property string addressNameFrom: isModelDataValid ? walletRootStore.getNameForAddress(modelData.sender) : ""
|
readonly property string addressNameFrom: isModelDataValid ? walletRootStore.getNameForAddress(modelData.sender) : ""
|
||||||
readonly property bool isNFT: isModelDataValid && modelData.isNFT
|
readonly property bool isNFT: isModelDataValid && modelData.isNFT
|
||||||
|
@ -268,17 +270,16 @@ StatusListItem {
|
||||||
}
|
}
|
||||||
|
|
||||||
// SUMMARY ADRESSES
|
// SUMMARY ADRESSES
|
||||||
const toNetworkName = "" // TODO fill when bridge data is implemented
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case Constants.TransactionType.Swap:
|
case Constants.TransactionType.Swap:
|
||||||
details += qsTr("From") + endl + modelData.outSymbol + endl2
|
details += qsTr("From") + endl + modelData.outSymbol + endl2
|
||||||
details += qsTr("To") + endl + modelData.inSymbol + endl2
|
details += qsTr("To") + endl + modelData.inSymbol + endl2
|
||||||
details += qsTr("In") + endl + root.fromAddress + endl2
|
details += qsTr("In") + endl + modelData.sender + endl2
|
||||||
break
|
break
|
||||||
case Constants.TransactionType.Bridge:
|
case Constants.TransactionType.Bridge:
|
||||||
details += qsTr("From") + endl + root.networkName + endl2
|
details += qsTr("From") + endl + networkNameOut + endl2
|
||||||
details += qsTr("To") + endl + toNetworkName + endl2
|
details += qsTr("To") + endl + networkNameIn + endl2
|
||||||
details += qsTr("In") + endl + modelData.from + endl2
|
details += qsTr("In") + endl + modelData.sender + endl2
|
||||||
break
|
break
|
||||||
case Constants.TransactionType.ContractDeployment:
|
case Constants.TransactionType.ContractDeployment:
|
||||||
details += qsTr("From") + endl + modelData.sender + endl2
|
details += qsTr("From") + endl + modelData.sender + endl2
|
||||||
|
@ -306,7 +307,7 @@ StatusListItem {
|
||||||
}
|
}
|
||||||
const bridgeTxHash = "" // TODO fill tx hash for Bridge
|
const bridgeTxHash = "" // TODO fill tx hash for Bridge
|
||||||
if (!!bridgeTxHash) {
|
if (!!bridgeTxHash) {
|
||||||
details += qsTr("%1 Tx hash").arg(toNetworkName) + endl + bridgeTxHash + endl2
|
details += qsTr("%1 Tx hash").arg(networkNameOut) + endl + bridgeTxHash + endl2
|
||||||
}
|
}
|
||||||
const protocolFromContractAddress = "" // TODO fill protocol contract address for 'from' network for Bridge and Swap
|
const protocolFromContractAddress = "" // TODO fill protocol contract address for 'from' network for Bridge and Swap
|
||||||
if (!!protocolName && !!protocolFromContractAddress) {
|
if (!!protocolName && !!protocolFromContractAddress) {
|
||||||
|
@ -320,7 +321,7 @@ StatusListItem {
|
||||||
}
|
}
|
||||||
const protocolToContractAddress = "" // TODO fill protocol contract address for 'to' network for Bridge
|
const protocolToContractAddress = "" // TODO fill protocol contract address for 'to' network for Bridge
|
||||||
if (!!protocolToContractAddress && !!protocolName) {
|
if (!!protocolToContractAddress && !!protocolName) {
|
||||||
details += qsTr("%1 %2 contract address").arg(toNetworkName).arg(protocolName) + endl
|
details += qsTr("%1 %2 contract address").arg(networkNameOut).arg(protocolName) + endl
|
||||||
details += protocolToContractAddress + endl2
|
details += protocolToContractAddress + endl2
|
||||||
}
|
}
|
||||||
const swapContractAddress = "" // TODO fill swap contract address for Swap
|
const swapContractAddress = "" // TODO fill swap contract address for Swap
|
||||||
|
@ -334,7 +335,7 @@ StatusListItem {
|
||||||
break
|
break
|
||||||
case Constants.TransactionType.Bridge:
|
case Constants.TransactionType.Bridge:
|
||||||
if (!!bridgeContractAddress) {
|
if (!!bridgeContractAddress) {
|
||||||
details += qsTr("%1 %2 contract address").arg(toNetworkName).arg(modelData.symbol) + endl
|
details += qsTr("%1 %2 contract address").arg(networkNameOut).arg(modelData.symbol) + endl
|
||||||
details += bridgeContractAddress + endl2
|
details += bridgeContractAddress + endl2
|
||||||
}
|
}
|
||||||
break
|
break
|
||||||
|
@ -351,7 +352,7 @@ StatusListItem {
|
||||||
if (type === Constants.TransactionType.Bridge) {
|
if (type === Constants.TransactionType.Bridge) {
|
||||||
details += qsTr("Included in Block on %1").arg(networkName) + endl
|
details += qsTr("Included in Block on %1").arg(networkName) + endl
|
||||||
details += rootStore.hex2Dec(modelData.blockNumber) + endl2
|
details += rootStore.hex2Dec(modelData.blockNumber) + endl2
|
||||||
details += qsTr("Included in Block on %1").arg(toNetworkName) + endl
|
details += qsTr("Included in Block on %1").arg(networkNameOut) + endl
|
||||||
const bridgeBlockNumber = 0 // TODO fill when bridge data is implemented
|
const bridgeBlockNumber = 0 // TODO fill when bridge data is implemented
|
||||||
details += rootStore.hex2Dec(bridgeBlockNumber) + endl2
|
details += rootStore.hex2Dec(bridgeBlockNumber) + endl2
|
||||||
} else {
|
} else {
|
||||||
|
@ -430,8 +431,8 @@ StatusListItem {
|
||||||
details += valuesString + endl2
|
details += valuesString + endl2
|
||||||
}
|
}
|
||||||
|
|
||||||
// Remove unicode characters
|
// Remove no-break space
|
||||||
details = details.replace(/[^\x00-\x7F]/g, " ");
|
details = details.replace(/[\xA0]/g, " ");
|
||||||
// Remove empty new lines at the end
|
// Remove empty new lines at the end
|
||||||
return details.replace(/[\r\n\s]*$/, '')
|
return details.replace(/[\r\n\s]*$/, '')
|
||||||
}
|
}
|
||||||
|
@ -453,13 +454,12 @@ StatusListItem {
|
||||||
return qsTr("%1 at %2 via %3").arg(inTransactionValue).arg(toAddress).arg(networkName)
|
return qsTr("%1 at %2 via %3").arg(inTransactionValue).arg(toAddress).arg(networkName)
|
||||||
case Constants.TransactionType.Swap:
|
case Constants.TransactionType.Swap:
|
||||||
if (allAccounts)
|
if (allAccounts)
|
||||||
return qsTr("%1 to %2 via %3 in %4").arg(outTransactionValue).arg(inTransactionValue).arg(networkName).arg(toAddress)
|
return qsTr("%1 to %2 via %3 in %4").arg(outTransactionValue).arg(inTransactionValue).arg(networkName).arg(fromAddress)
|
||||||
return qsTr("%1 to %2 via %3").arg(outTransactionValue).arg(inTransactionValue).arg(networkName)
|
return qsTr("%1 to %2 via %3").arg(outTransactionValue).arg(inTransactionValue).arg(networkName)
|
||||||
case Constants.TransactionType.Bridge:
|
case Constants.TransactionType.Bridge:
|
||||||
let toNetworkName = "" // TODO fill when Bridge data is implemented
|
|
||||||
if (allAccounts)
|
if (allAccounts)
|
||||||
return qsTr("%1 from %2 to %3 in %4").arg(inTransactionValue).arg(networkName).arg(toNetworkName).arg(toAddress)
|
return qsTr("%1 from %2 to %3 in %4").arg(inTransactionValue).arg(networkNameOut).arg(networkNameIn).arg(fromAddress)
|
||||||
return qsTr("%1 from %2 to %3").arg(inTransactionValue).arg(networkName).arg(toNetworkName)
|
return qsTr("%1 from %2 to %3").arg(inTransactionValue).arg(networkNameOut).arg(networkNameIn)
|
||||||
case Constants.TransactionType.ContractDeployment:
|
case Constants.TransactionType.ContractDeployment:
|
||||||
const name = addressNameTo || addressNameFrom
|
const name = addressNameTo || addressNameFrom
|
||||||
return !!modelData.contract ? qsTr("Contract %1 via %2 on %3").arg(Utils.compactAddress(modelData.contract, 4)).arg(name).arg(networkName)
|
return !!modelData.contract ? qsTr("Contract %1 via %2 on %3").arg(Utils.compactAddress(modelData.contract, 4)).arg(name).arg(networkName)
|
||||||
|
|
Loading…
Reference in New Issue