aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDan <danjm.com@gmail.com>2017-10-19 02:08:53 +0800
committerChi Kei Chan <chikeichan@gmail.com>2017-10-20 03:34:14 +0800
commit89af385a352daf66ad1a6fb3bba75676fd3b9e7f (patch)
tree6ea44ae9356a3215588c51e256a87fac357063c1
parentbd11e60b8c128dd69ba1bcf58d25fa9323d91a33 (diff)
downloadtangerine-wallet-browser-89af385a352daf66ad1a6fb3bba75676fd3b9e7f.tar
tangerine-wallet-browser-89af385a352daf66ad1a6fb3bba75676fd3b9e7f.tar.gz
tangerine-wallet-browser-89af385a352daf66ad1a6fb3bba75676fd3b9e7f.tar.bz2
tangerine-wallet-browser-89af385a352daf66ad1a6fb3bba75676fd3b9e7f.tar.lz
tangerine-wallet-browser-89af385a352daf66ad1a6fb3bba75676fd3b9e7f.tar.xz
tangerine-wallet-browser-89af385a352daf66ad1a6fb3bba75676fd3b9e7f.tar.zst
tangerine-wallet-browser-89af385a352daf66ad1a6fb3bba75676fd3b9e7f.zip
Fix handling of arithmetic on token gas in confirm-send-token.
-rw-r--r--ui/app/components/pending-tx/confirm-send-token.js49
-rw-r--r--ui/app/conversion-util.js8
-rw-r--r--ui/app/selectors.js11
3 files changed, 47 insertions, 21 deletions
diff --git a/ui/app/components/pending-tx/confirm-send-token.js b/ui/app/components/pending-tx/confirm-send-token.js
index 92bba8f62..de716a26a 100644
--- a/ui/app/components/pending-tx/confirm-send-token.js
+++ b/ui/app/components/pending-tx/confirm-send-token.js
@@ -11,12 +11,22 @@ const Identicon = require('../identicon')
const ethUtil = require('ethereumjs-util')
const BN = ethUtil.BN
const hexToBn = require('../../../../app/scripts/lib/hex-to-bn')
-const { conversionUtil } = require('../../conversion-util')
+const {
+ conversionUtil,
+ multiplyCurrencies,
+ addCurrencies,
+} = require('../../conversion-util')
const MIN_GAS_PRICE_GWEI_BN = new BN(1)
const GWEI_FACTOR = new BN(1e9)
const MIN_GAS_PRICE_BN = MIN_GAS_PRICE_GWEI_BN.mul(GWEI_FACTOR)
+const {
+ getSelectedTokenExchangeRate,
+ getTokenExchangeRate,
+ getSelectedAddress,
+} = require('../../selectors')
+
module.exports = connect(mapStateToProps, mapDispatchToProps)(ConfirmSendToken)
function mapStateToProps (state, ownProps) {
@@ -28,10 +38,8 @@ function mapStateToProps (state, ownProps) {
identities,
} = state.metamask
const accounts = state.metamask.accounts
- const selectedAddress = state.metamask.selectedAddress || Object.keys(accounts)[0]
- const tokenExchangeRates = state.metamask.tokenExchangeRates
- const pair = `${symbol.toLowerCase()}_eth`
- const { rate: tokenExchangeRate = 0 } = tokenExchangeRates[pair] || {}
+ const selectedAddress = getSelectedAddress(state)
+ const tokenExchangeRate = getTokenExchangeRate(state, symbol)
return {
conversionRate,
@@ -86,17 +94,14 @@ ConfirmSendToken.prototype.getGasFee = function () {
const txParams = txMeta.txParams || {}
const { decimals } = token
- // Gas
const gas = txParams.gas
- const gasBn = hexToBn(gas)
-
- // Gas Price
const gasPrice = txParams.gasPrice || MIN_GAS_PRICE_BN.toString(16)
- const gasPriceBn = hexToBn(gasPrice)
- const txFeeBn = gasBn.mul(gasPriceBn)
-
+ const gasTotal = multiplyCurrencies(gas, gasPrice, {
+ multiplicandBase: 16,
+ multiplierBase: 16,
+ })
- const USD = conversionUtil(txFeeBn, {
+ const USD = conversionUtil(gasTotal, {
fromNumericBase: 'BN',
toNumericBase: 'dec',
fromDenomination: 'WEI',
@@ -105,7 +110,7 @@ ConfirmSendToken.prototype.getGasFee = function () {
numberOfDecimals: 2,
conversionRate,
})
- const ETH = conversionUtil(txFeeBn, {
+ const ETH = conversionUtil(gasTotal, {
fromNumericBase: 'BN',
toNumericBase: 'dec',
fromDenomination: 'WEI',
@@ -114,12 +119,22 @@ ConfirmSendToken.prototype.getGasFee = function () {
numberOfDecimals: 6,
conversionRate,
})
+ const tokenGas = multiplyCurrencies(gas, gasPrice, {
+ toNumericBase: 'dec',
+ multiplicandBase: 16,
+ multiplierBase: 16,
+ toCurrency: 'BAT',
+ conversionRate: tokenExchangeRate,
+ invertConversionRate: true,
+ fromDenomination: 'WEI',
+ numberOfDecimals: decimals || 4,
+ })
return {
fiat: +Number(USD).toFixed(2),
eth: ETH,
token: tokenExchangeRate
- ? +(ETH * tokenExchangeRate).toFixed(decimals)
+ ? tokenGas
: null,
}
}
@@ -196,6 +211,8 @@ ConfirmSendToken.prototype.renderTotalPlusGas = function () {
const { fiat: fiatAmount, token: tokenAmount } = this.getAmount()
const { fiat: fiatGas, token: tokenGas } = this.getGasFee()
+ const tokenTotal = addCurrencies(tokenAmount, tokenGas || '0')
+
return fiatAmount && fiatGas
? (
h('section.flex-row.flex-center.confirm-screen-total-box ', [
@@ -206,7 +223,7 @@ ConfirmSendToken.prototype.renderTotalPlusGas = function () {
h('div.confirm-screen-section-column', [
h('div.confirm-screen-row-info', `$${fiatAmount + fiatGas} USD`),
- h('div.confirm-screen-row-detail', `${tokenAmount + tokenGas} ${symbol}`),
+ h('div.confirm-screen-row-detail', `${tokenTotal} ${symbol}`),
]),
])
)
diff --git a/ui/app/conversion-util.js b/ui/app/conversion-util.js
index e008ee1cb..51c7bd355 100644
--- a/ui/app/conversion-util.js
+++ b/ui/app/conversion-util.js
@@ -147,16 +147,16 @@ const addCurrencies = (a, b, options = {}) => {
const multiplyCurrencies = (a, b, options = {}) => {
const {
- toNumericBase,
- numberOfDecimals,
multiplicandBase,
multiplierBase,
+ ...conversionOptions,
} = options
+
const value = (new BigNumber(a, multiplicandBase)).times(b, multiplierBase);
+
return converter({
value,
- toNumericBase,
- numberOfDecimals,
+ ...conversionOptions,
})
}
diff --git a/ui/app/selectors.js b/ui/app/selectors.js
index 9d4e6eb67..8806a516f 100644
--- a/ui/app/selectors.js
+++ b/ui/app/selectors.js
@@ -6,6 +6,7 @@ const selectors = {
getSelectedAccount,
getSelectedToken,
getSelectedTokenExchangeRate,
+ getTokenExchangeRate,
conversionRateSelector,
transactionsSelector,
accountsWithSendEtherInfoSelector,
@@ -57,7 +58,15 @@ function getSelectedTokenExchangeRate (state) {
return tokenExchangeRate
}
-function conversionRateSelector (state) {
+function getTokenExchangeRate (state, tokenSymbol) {
+ const pair = `${tokenSymbol.toLowerCase()}_eth`
+ const tokenExchangeRates = state.metamask.tokenExchangeRates
+ const { rate: tokenExchangeRate = 0 } = tokenExchangeRates[pair] || {}
+
+ return tokenExchangeRate
+}
+
+function conversionRateSelector (state) {
return state.metamask.conversionRate
}