2017-02-17 21:44:09 +01:00
|
|
|
const Component = require('react').Component
|
|
|
|
const h = require('react-hyperscript')
|
|
|
|
const inherits = require('util').inherits
|
|
|
|
const ethUtil = require('ethereumjs-util')
|
|
|
|
const BN = ethUtil.BN
|
2017-02-28 01:33:58 +01:00
|
|
|
const extend = require('xtend')
|
2017-02-17 21:44:09 +01:00
|
|
|
|
|
|
|
module.exports = HexAsDecimalInput
|
|
|
|
|
|
|
|
inherits(HexAsDecimalInput, Component)
|
|
|
|
function HexAsDecimalInput () {
|
|
|
|
Component.call(this)
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Hex as Decimal Input
|
|
|
|
*
|
|
|
|
* A component for allowing easy, decimal editing
|
|
|
|
* of a passed in hex string value.
|
|
|
|
*
|
|
|
|
* On change, calls back its `onChange` function parameter
|
|
|
|
* and passes it an updated hex string.
|
|
|
|
*/
|
|
|
|
|
|
|
|
HexAsDecimalInput.prototype.render = function () {
|
|
|
|
const props = this.props
|
|
|
|
const { value, onChange } = props
|
2017-02-28 01:33:58 +01:00
|
|
|
const toEth = props.toEth
|
|
|
|
const suffix = props.suffix
|
|
|
|
const decimalValue = decimalize(value, toEth)
|
|
|
|
const style = props.style
|
2017-02-17 21:44:09 +01:00
|
|
|
|
|
|
|
return (
|
2017-02-28 01:33:58 +01:00
|
|
|
h('.flex-row', {
|
2017-02-27 22:53:43 +01:00
|
|
|
style: {
|
2017-02-28 01:33:58 +01:00
|
|
|
alignItems: 'flex-end',
|
|
|
|
lineHeight: '13px',
|
|
|
|
fontFamily: 'Montserrat Light',
|
|
|
|
textRendering: 'geometricPrecision',
|
2017-02-27 22:53:43 +01:00
|
|
|
},
|
2017-02-28 01:33:58 +01:00
|
|
|
}, [
|
|
|
|
h('input.ether-balance.ether-balance-amount', {
|
2017-03-01 23:37:51 +01:00
|
|
|
type: 'number',
|
2017-02-28 01:33:58 +01:00
|
|
|
style: extend({
|
|
|
|
display: 'block',
|
|
|
|
textAlign: 'right',
|
|
|
|
backgroundColor: 'transparent',
|
2017-02-28 03:18:39 +01:00
|
|
|
border: '1px solid #bdbdbd',
|
2017-03-01 23:37:51 +01:00
|
|
|
|
2017-02-28 01:33:58 +01:00
|
|
|
}, style),
|
|
|
|
value: decimalValue,
|
|
|
|
onChange: (event) => {
|
2017-03-01 23:37:51 +01:00
|
|
|
const hexString = (event.target.value === '') ? '' : hexify(event.target.value)
|
2017-02-28 01:33:58 +01:00
|
|
|
onChange(hexString)
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
h('div', {
|
|
|
|
style: {
|
|
|
|
color: ' #AEAEAE',
|
|
|
|
fontSize: '12px',
|
|
|
|
marginLeft: '5px',
|
2017-02-28 19:23:47 +01:00
|
|
|
marginRight: '6px',
|
2017-02-28 01:55:58 +01:00
|
|
|
width: '20px',
|
2017-02-28 01:33:58 +01:00
|
|
|
},
|
|
|
|
}, suffix),
|
|
|
|
])
|
2017-02-17 21:44:09 +01:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
function hexify (decimalString) {
|
|
|
|
const hexBN = new BN(decimalString, 10)
|
|
|
|
return '0x' + hexBN.toString('hex')
|
|
|
|
}
|
|
|
|
|
2017-02-28 01:33:58 +01:00
|
|
|
function decimalize (input, toEth) {
|
2017-03-01 23:37:51 +01:00
|
|
|
if (input === '') {
|
|
|
|
return ''
|
|
|
|
} else {
|
|
|
|
const strippedInput = ethUtil.stripHexPrefix(input)
|
|
|
|
const inputBN = new BN(strippedInput, 'hex')
|
|
|
|
return inputBN.toString(10)
|
|
|
|
}
|
2017-02-17 21:44:09 +01:00
|
|
|
}
|