From 03a2f3e4eff638a948d787ad9dc22aba0393360e Mon Sep 17 00:00:00 2001 From: Erialos Date: Wed, 9 Nov 2022 14:56:48 -0700 Subject: [PATCH 1/2] Fix - Delegate/Redelegate decimal issue The options for delegation and redelegation in the "Delegation" area for the Dashboard or Wallet details, when clicked only represented the amount with 2 decimals. Often this was rounding up and when a user chooses to redelegate, if they enter in the amount shown can run into an issue where they cannot submit the transaction due to the share amount being incorrect. --- src/views/Dashboard.vue | 8 ++++++-- src/views/WalletAccountDetail.vue | 4 +++- src/views/WalletDelegations.vue | 8 ++++++-- .../components/OperationModal/components/Delegate.vue | 4 +++- .../components/OperationModal/components/Redelegate.vue | 4 +++- 5 files changed, 21 insertions(+), 7 deletions(-) diff --git a/src/views/Dashboard.vue b/src/views/Dashboard.vue index 1293cbad..8e93c636 100644 --- a/src/views/Dashboard.vue +++ b/src/views/Dashboard.vue @@ -469,7 +469,7 @@ import { } from 'bootstrap-vue' import { formatNumber, formatTokenAmount, isToken, percent, timeIn, toDay, toDuration, tokenFormatter, getLocalAccounts, - getStakingValidatorOperator, + getStakingValidatorOperator, formatToken, } from '@/libs/utils' import OperationModal from '@/views/components/OperationModal/index.vue' import Ripple from 'vue-ripple-directive' @@ -580,10 +580,12 @@ export default { stakingList() { return this.delegations.map(x => { const rewards = this.rewards.find(r => r.validator_address === x.delegation.validator_address) + const conf = this.$http.getSelectedConfig() + const decimal = conf.assets.exponent || '6' return { valAddress: x.delegation.validator_address, validator: getStakingValidatorOperator(this.$store.state.chains.selected.chain_name, x.delegation.validator_address), - delegation: this.formatToken([x.balance]), + delegation: formatToken(x.balance, {}, decimal), rewards: rewards ? this.formatToken(rewards.reward) : '', action: '', } @@ -697,6 +699,8 @@ export default { return '-' }, fetchAccount(address) { + const conf = this.$http.getSelectedConfig() + const decimal = conf.assets.exponent || '6' this.address = address this.$http.getBankAccountBalance(address).then(bal => { this.walletBalances = this.formatToken(bal) diff --git a/src/views/WalletAccountDetail.vue b/src/views/WalletAccountDetail.vue index fbfaa725..a66e7f49 100644 --- a/src/views/WalletAccountDetail.vue +++ b/src/views/WalletAccountDetail.vue @@ -621,12 +621,14 @@ export default { }, deleTable() { const re = [] + const conf = this.$http.getSelectedConfig() + const decimal = conf.assets.exponent || '6' if (this.reward.rewards && this.delegations && this.delegations.length > 0) { this.delegations.forEach(e => { const reward = this.reward.rewards.find(r => r.validator_address === e.delegation.validator_address) re.push({ validator: getStakingValidatorOperator(this.$http.config.chain_name, e.delegation.validator_address, 8), - token: formatToken(e.balance, {}, 2), + token: formatToken(e.balance, {}, decimal), reward: tokenFormatter(reward.reward, this.denoms), action: e.delegation.validator_address, }) diff --git a/src/views/WalletDelegations.vue b/src/views/WalletDelegations.vue index 6d9dcbc8..3d97efa1 100644 --- a/src/views/WalletDelegations.vue +++ b/src/views/WalletDelegations.vue @@ -119,6 +119,8 @@ export default { }, computed: { formatedDelegations() { + const conf = this.$http.getSelectedConfig() + const decimal = conf.assets.exponent || '6' return this.delegations.map(x => ({ validator: { logo: x.chain.logo, @@ -128,13 +130,15 @@ export default { }, delegator: x.keyname, delegator_address: x.delegation.delegator_address, - delegation: formatToken(x.balance), + delegation: formatToken(x.balance, {}, decimal), reward: this.findReward(x.delegation.delegator_address, x.delegation.validator_address), // action: '', })) }, groupedDelegations() { const group = {} + const conf = this.$http.getSelectedConfig() + const decimal = conf.assets.exponent || '6' this.delegations.forEach(x => { const d = { validator: { @@ -145,7 +149,7 @@ export default { }, delegator: x.keyname, delegator_address: x.delegation.delegator_address, - delegation: formatToken(x.balance), + delegation: formatToken(x.balance, {}, decimal), reward: this.findReward(x.delegation.delegator_address, x.delegation.validator_address), // action: '', } diff --git a/src/views/components/OperationModal/components/Delegate.vue b/src/views/components/OperationModal/components/Delegate.vue index 4d32d812..3d308833 100644 --- a/src/views/components/OperationModal/components/Delegate.vue +++ b/src/views/components/OperationModal/components/Delegate.vue @@ -235,7 +235,9 @@ export default { return formatTokenDenom(this.token) }, format(v) { - return formatToken(v, this.IBCDenom, 6) + const conf = this.$http.getSelectedConfig() + const decimal = conf.assets.exponent || '6' + return formatToken(v, this.IBCDenom, decimal) }, }, } diff --git a/src/views/components/OperationModal/components/Redelegate.vue b/src/views/components/OperationModal/components/Redelegate.vue index a347d4f9..05b57f74 100644 --- a/src/views/components/OperationModal/components/Redelegate.vue +++ b/src/views/components/OperationModal/components/Redelegate.vue @@ -179,8 +179,10 @@ export default { return options }, tokenOptions() { + const conf = this.$http.getSelectedConfig() + const decimal = conf.assets.exponent || '6' if (!this.delegations) return [] - return this.delegations.filter(x => x.delegation.validator_address === this.validatorAddress).map(x => ({ value: x.balance.denom, label: formatToken(x.balance) })) + return this.delegations.filter(x => x.delegation.validator_address === this.validatorAddress).map(x => ({ value: x.balance.denom, label: formatToken(x.balance, {}, decimal) })) }, msg() { return [{ From b966213acebd58414172b9d8bf0df4b3770e26da Mon Sep 17 00:00:00 2001 From: Erialos Date: Thu, 10 Nov 2022 09:05:11 -0700 Subject: [PATCH 2/2] Fixed improper use of the asset array I did not implement the chain config correctly with the assets part being an array. To test I removed the `|| '6'` and then added it to look in `assets[0]`. It returned the proper decimal for the chain config. --- src/views/Dashboard.vue | 4 ++-- src/views/WalletAccountDetail.vue | 2 +- src/views/WalletDelegations.vue | 4 ++-- src/views/components/OperationModal/components/Delegate.vue | 2 +- src/views/components/OperationModal/components/Redelegate.vue | 2 +- 5 files changed, 7 insertions(+), 7 deletions(-) diff --git a/src/views/Dashboard.vue b/src/views/Dashboard.vue index 8e93c636..97e2399d 100644 --- a/src/views/Dashboard.vue +++ b/src/views/Dashboard.vue @@ -581,7 +581,7 @@ export default { return this.delegations.map(x => { const rewards = this.rewards.find(r => r.validator_address === x.delegation.validator_address) const conf = this.$http.getSelectedConfig() - const decimal = conf.assets.exponent || '6' + const decimal = conf.assets[0].exponent || '6' return { valAddress: x.delegation.validator_address, validator: getStakingValidatorOperator(this.$store.state.chains.selected.chain_name, x.delegation.validator_address), @@ -700,7 +700,7 @@ export default { }, fetchAccount(address) { const conf = this.$http.getSelectedConfig() - const decimal = conf.assets.exponent || '6' + const decimal = conf.assets[0].exponent || '6' this.address = address this.$http.getBankAccountBalance(address).then(bal => { this.walletBalances = this.formatToken(bal) diff --git a/src/views/WalletAccountDetail.vue b/src/views/WalletAccountDetail.vue index a66e7f49..c4e85aa8 100644 --- a/src/views/WalletAccountDetail.vue +++ b/src/views/WalletAccountDetail.vue @@ -622,7 +622,7 @@ export default { deleTable() { const re = [] const conf = this.$http.getSelectedConfig() - const decimal = conf.assets.exponent || '6' + const decimal = conf.assets[0].exponent || '6' if (this.reward.rewards && this.delegations && this.delegations.length > 0) { this.delegations.forEach(e => { const reward = this.reward.rewards.find(r => r.validator_address === e.delegation.validator_address) diff --git a/src/views/WalletDelegations.vue b/src/views/WalletDelegations.vue index 3d97efa1..f7840fb4 100644 --- a/src/views/WalletDelegations.vue +++ b/src/views/WalletDelegations.vue @@ -120,7 +120,7 @@ export default { computed: { formatedDelegations() { const conf = this.$http.getSelectedConfig() - const decimal = conf.assets.exponent || '6' + const decimal = conf.assets[0].exponent || '6' return this.delegations.map(x => ({ validator: { logo: x.chain.logo, @@ -138,7 +138,7 @@ export default { groupedDelegations() { const group = {} const conf = this.$http.getSelectedConfig() - const decimal = conf.assets.exponent || '6' + const decimal = conf.assets[0].exponent || '6' this.delegations.forEach(x => { const d = { validator: { diff --git a/src/views/components/OperationModal/components/Delegate.vue b/src/views/components/OperationModal/components/Delegate.vue index 3d308833..3e04a910 100644 --- a/src/views/components/OperationModal/components/Delegate.vue +++ b/src/views/components/OperationModal/components/Delegate.vue @@ -236,7 +236,7 @@ export default { }, format(v) { const conf = this.$http.getSelectedConfig() - const decimal = conf.assets.exponent || '6' + const decimal = conf.assets[0].exponent || '6' return formatToken(v, this.IBCDenom, decimal) }, }, diff --git a/src/views/components/OperationModal/components/Redelegate.vue b/src/views/components/OperationModal/components/Redelegate.vue index 05b57f74..4bcba09d 100644 --- a/src/views/components/OperationModal/components/Redelegate.vue +++ b/src/views/components/OperationModal/components/Redelegate.vue @@ -180,7 +180,7 @@ export default { }, tokenOptions() { const conf = this.$http.getSelectedConfig() - const decimal = conf.assets.exponent || '6' + const decimal = conf.assets[0].exponent || '6' if (!this.delegations) return [] return this.delegations.filter(x => x.delegation.validator_address === this.validatorAddress).map(x => ({ value: x.balance.denom, label: formatToken(x.balance, {}, decimal) })) },