feat(@desktop/wallet): Use estimated latest block for details (#12092)

This commit is contained in:
Cuteivist 2023-09-11 10:08:53 +02:00 committed by GitHub
parent 624b758c85
commit 63eacf0817
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 70 additions and 16 deletions

View File

@ -97,6 +97,9 @@ method getChainIdForChat*(self: AccessInterface): int {.base.} =
method getLatestBlockNumber*(self: AccessInterface, chainId: int): string {.base.} = method getLatestBlockNumber*(self: AccessInterface, chainId: int): string {.base.} =
raise newException(ValueError, "No implementation available") raise newException(ValueError, "No implementation available")
method getEstimatedLatestBlockNumber*(self: AccessInterface, chainId: int): string {.base.} =
raise newException(ValueError, "No implementation available")
method fetchDecodedTxData*(self: AccessInterface, txHash: string, data: string) {.base.} = method fetchDecodedTxData*(self: AccessInterface, txHash: string, data: string) {.base.} =
raise newException(ValueError, "No implementation available") raise newException(ValueError, "No implementation available")

View File

@ -374,6 +374,9 @@ method getChainIdForChat*(self: Module): int =
method getLatestBlockNumber*(self: Module, chainId: int): string = method getLatestBlockNumber*(self: Module, chainId: int): string =
return self.transactionService.getLatestBlockNumber(chainId) return self.transactionService.getLatestBlockNumber(chainId)
method getEstimatedLatestBlockNumber*(self: Module, chainId: int): string =
return self.transactionService.getEstimatedLatestBlockNumber(chainId)
method fetchDecodedTxData*(self: Module, txHash: string, data: string) = method fetchDecodedTxData*(self: Module, txHash: string, data: string) =
self.transactionService.fetchDecodedTxData(txHash, data) self.transactionService.fetchDecodedTxData(txHash, data)

View File

@ -151,6 +151,9 @@ QtObject:
proc getLatestBlockNumber*(self: View, chainId: int): string {.slot.} = proc getLatestBlockNumber*(self: View, chainId: int): string {.slot.} =
return self.delegate.getLatestBlockNumber(chainId) return self.delegate.getLatestBlockNumber(chainId)
proc getEstimatedLatestBlockNumber*(self: View, chainId: int): string {.slot.} =
return self.delegate.getEstimatedLatestBlockNumber(chainId)
proc fetchDecodedTxData*(self: View, txHash: string, data: string) {.slot.} = proc fetchDecodedTxData*(self: View, txHash: string, data: string) {.slot.} =
self.delegate.fetchDecodedTxData(txHash, data) self.delegate.fetchDecodedTxData(txHash, data)

View File

@ -446,6 +446,12 @@ QtObject:
return response.result{"number"}.getStr return response.result{"number"}.getStr
except Exception as e: except Exception as e:
error "Error getting latest block number", message = e.msg error "Error getting latest block number", message = e.msg
proc getEstimatedLatestBlockNumber*(self: Service, chainId: int): string =
try:
return $eth.getEstimatedLatestBlockNumber(chainId).result
except Exception as e:
error "Error getting estimated latest block number", message = e.msg
return "" return ""
proc getMultiTransactions*(transactionIDs: seq[int]): seq[MultiTransactionDto] = proc getMultiTransactions*(transactionIDs: seq[int]): seq[MultiTransactionDto] =

View File

@ -1,5 +1,6 @@
import json, stint, tables import json, stint, tables
import ./core, ./response_type import ./core, ./response_type
from ./gen import rpc
export response_type export response_type
@ -31,3 +32,6 @@ proc suggestedFees*(chainId: int): RpcResponse[JsonNode] {.raises: [Exception].}
proc suggestedRoutes*(account: string, amount: string, token: string, disabledFromChainIDs, disabledToChainIDs, preferredChainIDs: seq[int], sendType: int, lockedInAmounts: var Table[string, string]): RpcResponse[JsonNode] {.raises: [Exception].} = proc suggestedRoutes*(account: string, amount: string, token: string, disabledFromChainIDs, disabledToChainIDs, preferredChainIDs: seq[int], sendType: int, lockedInAmounts: var Table[string, string]): RpcResponse[JsonNode] {.raises: [Exception].} =
let payload = %* [sendType, account, amount, token, disabledFromChainIDs, disabledToChainIDs, preferredChainIDs, 1 , lockedInAmounts] let payload = %* [sendType, account, amount, token, disabledFromChainIDs, disabledToChainIDs, preferredChainIDs, 1 , lockedInAmounts]
return core.callPrivateRPC("wallet_getSuggestedRoutes", payload) return core.callPrivateRPC("wallet_getSuggestedRoutes", payload)
rpc(getEstimatedLatestBlockNumber, "wallet"):
chainId: int

View File

@ -165,9 +165,15 @@ QtObject {
} }
function getLatestBlockNumber(chainId) { function getLatestBlockNumber(chainId) {
// NOTE returns hex
return walletSection.getLatestBlockNumber(chainId) return walletSection.getLatestBlockNumber(chainId)
} }
function getEstimatedLatestBlockNumber(chainId) {
// NOTE returns decimal
return walletSection.getEstimatedLatestBlockNumber(chainId)
}
function setFilterAddress(address) { function setFilterAddress(address) {
walletSection.setFilterAddress(address) walletSection.setFilterAddress(address)
} }

View File

@ -163,7 +163,8 @@ Item {
WalletTxProgressBlock { WalletTxProgressBlock {
id: progressBlock id: progressBlock
width: Math.min(513, root.width) width: Math.min(513, root.width)
readonly property int latestBlockNumber: root.isTransactionValid && !pending && !error ? RootStore.hex2Dec(WalletStores.RootStore.getLatestBlockNumber(root.transaction.chainId)) : 0 readonly property int latestBlockNumber: root.isTransactionValid && !pending && !error ? WalletStores.RootStore.getEstimatedLatestBlockNumber(root.transaction.chainId) : 0
readonly property int latestBlockNumberIn: root.isTransactionValid && !pending && !error && transactionHeader.isMultiTransaction && d.isBridge ? WalletStores.RootStore.getEstimatedLatestBlockNumber(root.transaction.chainIdIn) : 0
error: transactionHeader.transactionStatus === Constants.TransactionStatus.Failed error: transactionHeader.transactionStatus === Constants.TransactionStatus.Failed
pending: transactionHeader.transactionStatus === Constants.TransactionStatus.Pending pending: transactionHeader.transactionStatus === Constants.TransactionStatus.Pending
outNetworkLayer: root.isTransactionValid ? Number(RootStore.getNetworkLayer(transactionHeader.isMultiTransaction ? root.transaction.chainIdOut : root.transaction.chainId)) : 0 outNetworkLayer: root.isTransactionValid ? Number(RootStore.getNetworkLayer(transactionHeader.isMultiTransaction ? root.transaction.chainIdOut : root.transaction.chainId)) : 0
@ -173,7 +174,7 @@ Item {
outChainName: transactionHeader.isMultiTransaction ? transactionHeader.networkNameOut : transactionHeader.networkName outChainName: transactionHeader.isMultiTransaction ? transactionHeader.networkNameOut : transactionHeader.networkName
inChainName: transactionHeader.isMultiTransaction && d.isBridge ? transactionHeader.networkNameIn : "" inChainName: transactionHeader.isMultiTransaction && d.isBridge ? transactionHeader.networkNameIn : ""
outNetworkConfirmations: root.isTransactionValid && latestBlockNumber > 0 ? latestBlockNumber - d.blockNumber : 0 outNetworkConfirmations: root.isTransactionValid && latestBlockNumber > 0 ? latestBlockNumber - d.blockNumber : 0
inNetworkConfirmations: root.isTransactionValid && latestBlockNumber > 0 ? latestBlockNumber - d.blockNumber : 0 inNetworkConfirmations: root.isTransactionValid && latestBlockNumberIn > 0 ? latestBlockNumberIn - d.blockNumber : 0
} }
Separator { Separator {

View File

@ -240,39 +240,65 @@ StatusListItem {
} }
// PROGRESS // PROGRESS
const networkLayer = rootStore.getNetworkLayer(modelData.chainId) === 1 const networkLayer = rootStore.getNetworkLayer(modelData.chainId)
// A block on layer1 is every 12s
const confirmationTimeStamp = WalletUtils.calculateConfirmationTimestamp(networkLayer, modelData.timestamp) const isBridge = type === Constants.TransactionType.Bridge
const finalisationTimeStamp = WalletUtils.calculateFinalisationTimestamp(networkLayer, modelData.timestamp)
switch(transactionStatus) { switch(transactionStatus) {
case Constants.TransactionStatus.Pending: case Constants.TransactionStatus.Pending:
details += qsTr("Status") + endl details += qsTr("Status") + endl
details += qsTr("Pending on %1").arg(root.networkName) + endl2 details += qsTr("Pending on %1").arg(root.networkName) + endl2
if (isBridge) {
details += qsTr("Pending on %1").arg(root.networkNameIn) + endl2
}
break break
case Constants.TransactionStatus.Failed: case Constants.TransactionStatus.Failed:
details += qsTr("Status") + endl details += qsTr("Status") + endl
details += qsTr("Failed on %1").arg(root.networkName) + endl2 details += qsTr("Failed on %1").arg(root.networkName) + endl2
if (isBridge) {
details += qsTr("Failed on %1").arg(root.networkNameIn) + endl2
}
break break
case Constants.TransactionStatus.Complete: { case Constants.TransactionStatus.Complete: {
const confirmationTimeStamp = WalletUtils.calculateConfirmationTimestamp(networkLayer, modelData.timestamp)
const timestampString = LocaleUtils.formatDateTime(modelData.timestamp * 1000, Locale.LongFormat) const timestampString = LocaleUtils.formatDateTime(modelData.timestamp * 1000, Locale.LongFormat)
details += qsTr("Status") + endl details += qsTr("Status") + endl
const epoch = parseFloat(Math.abs(walletRootStore.getLatestBlockNumber(modelData.chainId) - detailsObj.blockNumber).toFixed(0)).toLocaleString() details += qsTr("Signed on %1").arg(root.networkName) + endl + timestampString + endl2
details += qsTr("Signed") + endl + root.timestampString + endl2 details += qsTr("Confirmed on %1").arg(root.networkName) + endl
details += qsTr("Signed") + endl + timestampString + endl2
details += qsTr("Confirmed") + endl
details += LocaleUtils.formatDateTime(confirmationTimeStamp * 1000, Locale.LongFormat) + endl2 details += LocaleUtils.formatDateTime(confirmationTimeStamp * 1000, Locale.LongFormat) + endl2
if (isBridge) {
const networkInLayer = rootStore.getNetworkLayer(modelData.chainIdIn)
const confirmationTimeStampIn = WalletUtils.calculateConfirmationTimestamp(networkInLayer, modelData.timestamp)
details += qsTr("Signed on %1").arg(root.networkNameIn) + endl + timestampString + endl2
details += qsTr("Confirmed on %1").arg(root.networkNameIn) + endl
details += LocaleUtils.formatDateTime(confirmationTimeStampIn * 1000, Locale.LongFormat) + endl2
}
break break
} }
case Constants.TransactionStatus.Finalised: { case Constants.TransactionStatus.Finalised: {
const timestampString = LocaleUtils.formatDateTime(modelData.timestamp * 1000, Locale.LongFormat) const timestampString = LocaleUtils.formatDateTime(modelData.timestamp * 1000, Locale.LongFormat)
const confirmationTimeStamp = WalletUtils.calculateConfirmationTimestamp(networkLayer, modelData.timestamp)
const finalisationTimeStamp = WalletUtils.calculateFinalisationTimestamp(networkLayer, modelData.timestamp)
details += qsTr("Status") + endl details += qsTr("Status") + endl
const epoch = Math.abs(walletRootStore.getLatestBlockNumber(modelData.chainId) - detailsObj.blockNumber) const epoch = Math.abs(walletRootStore.getEstimatedLatestBlockNumber(modelData.chainId) - detailsObj.blockNumber)
details += qsTr("Finalised in epoch %1").arg(epoch.toFixed(0)) + endl2 details += qsTr("Finalised in epoch %1 on %2").arg(epoch.toFixed(0)).arg(root.networkName) + endl2
details += qsTr("Signed") + endl + timestampString + endl2 details += qsTr("Signed on %1").arg(root.networkName) + endl + timestampString + endl2
details += qsTr("Confirmed") + endl details += qsTr("Confirmed on %1").arg(root.networkName) + endl
details += LocaleUtils.formatDateTime(confirmationTimeStamp * 1000, Locale.LongFormat) + endl2 details += LocaleUtils.formatDateTime(confirmationTimeStamp * 1000, Locale.LongFormat) + endl2
details += qsTr("Finalised") + endl details += qsTr("Finalised on %1").arg(root.networkName) + endl
details += LocaleUtils.formatDateTime(finalisationTimeStamp * 1000, Locale.LongFormat) + endl2 details += LocaleUtils.formatDateTime(finalisationTimeStamp * 1000, Locale.LongFormat) + endl2
if (isBridge) {
const networkInLayer = rootStore.getNetworkLayer(modelData.chainIdIn)
const confirmationTimeStampIn = WalletUtils.calculateConfirmationTimestamp(networkInLayer, modelData.timestamp)
const finalisationTimeStampIn = WalletUtils.calculateFinalisationTimestamp(networkInLayer, modelData.timestamp)
const epochIn = Math.abs(walletRootStore.getEstimatedLatestBlockNumber(modelData.chainIdIn) - detailsObj.blockNumber)
details += qsTr("Finalised in epoch %1 on %2").arg(epochIn.toFixed(0)).arg(root.networkNameIn) + endl2
details += qsTr("Signed on %1").arg(root.networkNameIn) + endl + timestampString + endl2
details += qsTr("Confirmed on %1").arg(root.networkNameIn) + endl
details += LocaleUtils.formatDateTime(confirmationTimeStampIn * 1000, Locale.LongFormat) + endl2
details += qsTr("Finalised on %1").arg(root.networkNameIn) + endl
details += LocaleUtils.formatDateTime(finalisationTimeStampIn * 1000, Locale.LongFormat) + endl2
}
break break
} }
default: default:
@ -356,7 +382,9 @@ StatusListItem {
if (type !== Constants.TransactionType.Bridge) { if (type !== Constants.TransactionType.Bridge) {
details += qsTr("Network") + endl + networkName + endl2 details += qsTr("Network") + endl + networkName + endl2
} }
details += qsTr("Token format") + endl + modelData.tokenType.toUpperCase() + endl2 if (!!detailsObj.tokenType) {
details += qsTr("Token format") + endl + detailsObj.tokenType.toUpperCase() + endl2
}
details += qsTr("Nonce") + endl + detailsObj.nonce + endl2 details += qsTr("Nonce") + endl + detailsObj.nonce + endl2
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