aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDan <danjm.com@gmail.com>2017-08-29 07:06:10 +0800
committerDan <danjm.com@gmail.com>2017-08-29 22:56:32 +0800
commitcd351e8aef59f314c170d0436d98aaf111db1c00 (patch)
tree202bab151cfebad2b199ea6d8b05489eedc5cfd8
parentdc72c4cc918934b8dafc253ca5e7c9674551aa51 (diff)
downloadtangerine-wallet-browser-cd351e8aef59f314c170d0436d98aaf111db1c00.tar
tangerine-wallet-browser-cd351e8aef59f314c170d0436d98aaf111db1c00.tar.gz
tangerine-wallet-browser-cd351e8aef59f314c170d0436d98aaf111db1c00.tar.bz2
tangerine-wallet-browser-cd351e8aef59f314c170d0436d98aaf111db1c00.tar.lz
tangerine-wallet-browser-cd351e8aef59f314c170d0436d98aaf111db1c00.tar.xz
tangerine-wallet-browser-cd351e8aef59f314c170d0436d98aaf111db1c00.tar.zst
tangerine-wallet-browser-cd351e8aef59f314c170d0436d98aaf111db1c00.zip
Move getTaxBN and bnMultiplyByFraction to util.js
-rw-r--r--ui/app/send.js30
-rw-r--r--ui/app/util.js24
2 files changed, 29 insertions, 25 deletions
diff --git a/ui/app/send.js b/ui/app/send.js
index ae779790d..f50af386c 100644
--- a/ui/app/send.js
+++ b/ui/app/send.js
@@ -10,12 +10,14 @@ const BN = ethUtil.BN
const hexToBn = require('../../app/scripts/lib/hex-to-bn')
const numericBalance = require('./util').numericBalance
const addressSummary = require('./util').addressSummary
+const bnMultiplyByFraction = require('./util').bnMultiplyByFraction
const isHex = require('./util').isHex
const EthBalance = require('./components/eth-balance')
const EnsInput = require('./components/ens-input')
const FiatValue = require('./components/fiat-value.js')
const GasTooltip = require('./components/gas-tooltip.js')
const { getSelectedIdentity } = require('./selectors')
+const getTxFeeBn = require('./util').getTxFeeBn
const ARAGON = '960b236A07cf122663c4303350609A66A7B288C0'
@@ -67,7 +69,6 @@ function SendTransactionScreen () {
this.back = this.back.bind(this)
this.back = this.back.bind(this)
this.closeTooltip = this.closeTooltip.bind(this)
- this.getTxFeeBn = this.getTxFeeBn.bind(this)
this.onSubmit = this.onSubmit.bind(this)
this.onSubmit = this.onSubmit.bind(this)
this.recipientDidChange = this.recipientDidChange.bind(this)
@@ -76,28 +77,6 @@ function SendTransactionScreen () {
this.toggleTooltip = this.toggleTooltip.bind(this)
}
-SendTransactionScreen.prototype.bnMultiplyByFraction = function (targetBN, numerator, denominator) {
- const numBN = new BN(numerator)
- const denomBN = new BN(denominator)
- return targetBN.mul(numBN).div(denomBN)
-}
-
-SendTransactionScreen.prototype.getTxFeeBn = function (gas, gasPrice = MIN_GAS_PRICE_BN.toString(16)) {
- const { blockGasLimit } = this.props;
- const gasBn = hexToBn(gas)
- const gasLimit = new BN(parseInt(blockGasLimit))
- const safeGasLimit = this.bnMultiplyByFraction(gasLimit, 19, 20).toString(10)
-
-
- // Gas Price
- const gasPriceBn = hexToBn(gasPrice)
- const txFeeBn = gasBn.mul(gasPriceBn)
-
- const fiatMultiplier = hexToBn((1000000000).toString(16))
- const txFeeAsFiatBn = txFeeBn.mul(fiatMultiplier)
- return txFeeAsFiatBn;
-}
-
SendTransactionScreen.prototype.render = function () {
this.persistentFormParentId = 'send-tx-form'
@@ -113,6 +92,7 @@ SendTransactionScreen.prototype.render = function () {
conversionRate,
currentCurrency,
} = props
+ const { blockGasLimit } = this.state
console.log({ selectedIdentity, identities })
console.log("SendTransactionScreen state:", this.state)
@@ -265,7 +245,7 @@ SendTransactionScreen.prototype.render = function () {
h('div.large-input.send-screen-gas-input', {}, [
currentCurrency === 'USD'
? h(FiatValue, {
- value: this.getTxFeeBn(this.state.newTx.gas.toString(16), this.state.newTx.gasPrice.toString(16)).toString(16),
+ value: getTxFeeBn(this.state.newTx.gas.toString(16), this.state.newTx.gasPrice.toString(16), blockGasLimit).toString(16),
conversionRate,
currentCurrency,
style: {
@@ -276,7 +256,7 @@ SendTransactionScreen.prototype.render = function () {
}
})
: h(EthBalance, {
- value: this.getTxFeeBn(this.state.newTx.gas.toString(16), this.state.newTx.gasPrice.toString(16)).toString(16),
+ value: getTxFeeBn(this.state.newTx.gas.toString(16), this.state.newTx.gasPrice.toString(16), blockGasLimit).toString(16),
currentCurrency,
conversionRate,
showFiat: false,
diff --git a/ui/app/util.js b/ui/app/util.js
index 4dd0e30f3..4b48db0ca 100644
--- a/ui/app/util.js
+++ b/ui/app/util.js
@@ -1,4 +1,5 @@
const ethUtil = require('ethereumjs-util')
+const hexToBn = require('../../app/scripts/lib/hex-to-bn')
const vreme = new (require('vreme'))()
// formatData :: ( date: <Unix Timestamp> ) -> String
@@ -43,6 +44,8 @@ module.exports = {
bnTable: bnTable,
isHex: isHex,
formatDate,
+ bnMultiplyByFraction,
+ getTxFeeBn,
}
function valuesFor (obj) {
@@ -222,3 +225,24 @@ function readableDate (ms) {
function isHex (str) {
return Boolean(str.match(/^(0x)?[0-9a-fA-F]+$/))
}
+
+function bnMultiplyByFraction (targetBN, numerator, denominator) {
+ const numBN = new ethUtil.BN(numerator)
+ const denomBN = new ethUtil.BN(denominator)
+ return targetBN.mul(numBN).div(denomBN)
+}
+
+function getTxFeeBn (gas, gasPrice = MIN_GAS_PRICE_BN.toString(16), blockGasLimit) {
+ const gasBn = hexToBn(gas)
+ const gasLimit = new ethUtil.BN(parseInt(blockGasLimit))
+ const safeGasLimit = bnMultiplyByFraction(gasLimit, 19, 20).toString(10)
+
+ // Gas Price
+ const gasPriceBn = hexToBn(gasPrice)
+ const txFeeBn = gasBn.mul(gasPriceBn)
+
+ const fiatMultiplier = hexToBn((1000000000).toString(16))
+ const txFeeAsFiatBn = txFeeBn.mul(fiatMultiplier)
+
+ return txFeeAsFiatBn;
+}