|
|
@ -3,6 +3,8 @@ const h = require('react-hyperscript') |
|
|
|
const inherits = require('util').inherits |
|
|
|
const inherits = require('util').inherits |
|
|
|
const PendingTxDetails = require('./pending-tx-details') |
|
|
|
const PendingTxDetails = require('./pending-tx-details') |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const ethUtil = require('ethereumjs-util') |
|
|
|
|
|
|
|
const BN = ethUtil.BN |
|
|
|
|
|
|
|
|
|
|
|
module.exports = PendingTx |
|
|
|
module.exports = PendingTx |
|
|
|
|
|
|
|
|
|
|
@ -14,7 +16,6 @@ function PendingTx () { |
|
|
|
PendingTx.prototype.render = function () { |
|
|
|
PendingTx.prototype.render = function () { |
|
|
|
var state = this.props |
|
|
|
var state = this.props |
|
|
|
var txData = state.txData |
|
|
|
var txData = state.txData |
|
|
|
|
|
|
|
|
|
|
|
return ( |
|
|
|
return ( |
|
|
|
|
|
|
|
|
|
|
|
h('div', { |
|
|
|
h('div', { |
|
|
@ -39,10 +40,8 @@ PendingTx.prototype.render = function () { |
|
|
|
margin: '14px 25px', |
|
|
|
margin: '14px 25px', |
|
|
|
}, |
|
|
|
}, |
|
|
|
}, [ |
|
|
|
}, [ |
|
|
|
h('button.confirm', { |
|
|
|
|
|
|
|
onClick: state.sendTransaction, |
|
|
|
this.buttonDeligator(), |
|
|
|
style: { background: 'rgb(251,117,1)' }, |
|
|
|
|
|
|
|
}, 'Accept'), |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
h('button.cancel', { |
|
|
|
h('button.cancel', { |
|
|
|
onClick: state.cancelTransaction, |
|
|
|
onClick: state.cancelTransaction, |
|
|
@ -53,3 +52,31 @@ PendingTx.prototype.render = function () { |
|
|
|
) |
|
|
|
) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
PendingTx.prototype.buttonDeligator = function () { |
|
|
|
|
|
|
|
var state = this.props |
|
|
|
|
|
|
|
var txData = state.txData |
|
|
|
|
|
|
|
var txParams = txData.txParams || {} |
|
|
|
|
|
|
|
var address = txParams.from || state.selectedAddress |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var account = state.accounts[address] |
|
|
|
|
|
|
|
var balance = account ? account.balance : '0x0' |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var gasCost = new BN(ethUtil.stripHexPrefix(txParams.gas || txData.estimatedGas), 16) |
|
|
|
|
|
|
|
var gasPrice = new BN(ethUtil.stripHexPrefix(txParams.gasPrice || '0x4a817c800'), 16) |
|
|
|
|
|
|
|
var txFee = gasCost.mul(gasPrice) |
|
|
|
|
|
|
|
var txValue = new BN(ethUtil.stripHexPrefix(txParams.value || '0x0'), 16) |
|
|
|
|
|
|
|
var maxCost = txValue.add(txFee) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var balanceBn = new BN(ethUtil.stripHexPrefix(balance), 16) |
|
|
|
|
|
|
|
if (maxCost.gt(balanceBn)) { |
|
|
|
|
|
|
|
return h('button.confirm', { |
|
|
|
|
|
|
|
onClick: state.sendTransaction, |
|
|
|
|
|
|
|
style: { background: 'rgb(251,117,1)' }, |
|
|
|
|
|
|
|
}, 'Buy') |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
return h('button.confirm', { |
|
|
|
|
|
|
|
onClick: state.sendTransaction, |
|
|
|
|
|
|
|
style: { background: 'rgb(251,117,1)' }, |
|
|
|
|
|
|
|
}, 'Accept') |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|