Also added a new state to try to make UI dev mode work again, but it has other issues, like #1128, that need to be addressed before UI dev mode can be used again.feature/default_network_editable
parent
89af0ef408
commit
6b56d6ba98
File diff suppressed because one or more lines are too long
@ -0,0 +1,49 @@ |
||||
const Component = require('react').Component |
||||
const h = require('react-hyperscript') |
||||
const inherits = require('util').inherits |
||||
const ethUtil = require('ethereumjs-util') |
||||
const BN = ethUtil.BN |
||||
|
||||
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 |
||||
const decimalValue = decimalize(value) |
||||
|
||||
return ( |
||||
h('input', { |
||||
value: decimalValue, |
||||
onChange: (event) => { |
||||
const hexString = hexify(event.target.value) |
||||
onChange(hexString) |
||||
}, |
||||
}) |
||||
) |
||||
} |
||||
|
||||
function hexify (decimalString) { |
||||
const hexBN = new BN(decimalString, 10) |
||||
return '0x' + hexBN.toString('hex') |
||||
} |
||||
|
||||
function decimalize (input) { |
||||
const strippedInput = ethUtil.stripHexPrefix(input) |
||||
const inputBN = new BN(strippedInput, 'hex') |
||||
return inputBN.toString(10) |
||||
} |
||||
|
Loading…
Reference in new issue