|
@ -17,10 +17,8 @@ function parseValue(value) { |
|
|
return value.toString().replace(/,/g, '.') |
|
|
return value.toString().replace(/,/g, '.') |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
function format(unit: Unit, value: Value) { |
|
|
function format(unit: Unit, value: number) { |
|
|
let v = value === '' ? 0 : Number(value) |
|
|
return formatCurrencyUnit(unit, value, { |
|
|
v *= 10 ** unit.magnitude |
|
|
|
|
|
return formatCurrencyUnit(unit, v, { |
|
|
|
|
|
disableRounding: true, |
|
|
disableRounding: true, |
|
|
showAllDigits: false, |
|
|
showAllDigits: false, |
|
|
}) |
|
|
}) |
|
@ -28,13 +26,13 @@ function format(unit: Unit, value: Value) { |
|
|
|
|
|
|
|
|
function unformat(unit, value) { |
|
|
function unformat(unit, value) { |
|
|
if (value === 0 || value === '') { |
|
|
if (value === 0 || value === '') { |
|
|
return 0 |
|
|
return '0' |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
let v = parseCurrencyUnit(unit, value.toString()) |
|
|
let v = parseCurrencyUnit(unit, value.toString()) |
|
|
v /= 10 ** unit.magnitude |
|
|
v /= 10 ** unit.magnitude |
|
|
|
|
|
|
|
|
return v |
|
|
return v.toString() |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const Currencies = styled(Box)` |
|
|
const Currencies = styled(Box)` |
|
@ -50,19 +48,17 @@ const Currency = styled(Box).attrs({ |
|
|
pr: 1, |
|
|
pr: 1, |
|
|
})`` |
|
|
})`` |
|
|
|
|
|
|
|
|
type Value = string | number |
|
|
|
|
|
|
|
|
|
|
|
type Props = { |
|
|
type Props = { |
|
|
onChange: Function, |
|
|
onChange: Function, |
|
|
renderRight: any, |
|
|
renderRight: any, |
|
|
unit: Unit, |
|
|
unit: Unit, |
|
|
units: Array<Unit>, |
|
|
units: Array<Unit>, |
|
|
value: Value, |
|
|
value: number, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
type State = { |
|
|
type State = { |
|
|
isFocus: boolean, |
|
|
isFocus: boolean, |
|
|
value: Value, |
|
|
displayValue: string, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
class InputCurrency extends PureComponent<Props, State> { |
|
|
class InputCurrency extends PureComponent<Props, State> { |
|
@ -75,43 +71,46 @@ class InputCurrency extends PureComponent<Props, State> { |
|
|
|
|
|
|
|
|
state = { |
|
|
state = { |
|
|
isFocus: false, |
|
|
isFocus: false, |
|
|
value: this.props.value, |
|
|
displayValue: '0', |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
componentWillMount() { |
|
|
|
|
|
const { value, unit } = this.props |
|
|
|
|
|
const displayValue = format(unit, value) |
|
|
|
|
|
this.setState({ displayValue }) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
componentWillReceiveProps(nextProps: Props) { |
|
|
componentWillReceiveProps(nextProps: Props) { |
|
|
if (this.props.value !== nextProps.value) { |
|
|
if (this.props.value !== nextProps.value) { |
|
|
const { isFocus } = this.state |
|
|
const { isFocus } = this.state |
|
|
const value = isFocus ? nextProps.value : format(nextProps.unit, nextProps.value) |
|
|
const displayValue = isFocus |
|
|
this.setState({ |
|
|
? (nextProps.value / 10 ** nextProps.unit.magnitude).toString() |
|
|
value, |
|
|
: format(nextProps.unit, nextProps.value) |
|
|
}) |
|
|
this.setState({ displayValue }) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
handleChange = (v: Value) => { |
|
|
handleChange = (v: string) => { |
|
|
|
|
|
// const { displayValue } = this.state
|
|
|
v = parseValue(v) |
|
|
v = parseValue(v) |
|
|
|
|
|
|
|
|
|
|
|
if (v.startsWith('00')) { |
|
|
|
|
|
return |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
// Check if value is valid Number
|
|
|
// Check if value is valid Number
|
|
|
if (isNaN(Number(v))) { |
|
|
if (isNaN(Number(v))) { |
|
|
return |
|
|
return |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
this.emitOnChange(v) |
|
|
this.emitOnChange(v) |
|
|
this.setState({ |
|
|
this.setState({ displayValue: v || '0' }) |
|
|
value: v, |
|
|
|
|
|
}) |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
handleBlur = () => { |
|
|
handleBlur = () => { |
|
|
const { unit } = this.props |
|
|
const { unit, value } = this.props |
|
|
const { value } = this.state |
|
|
|
|
|
|
|
|
|
|
|
const v = format(unit, value) |
|
|
const v = format(unit, value) |
|
|
|
|
|
this.setState({ isFocus: false, displayValue: v }) |
|
|
this.setState({ |
|
|
|
|
|
isFocus: false, |
|
|
|
|
|
value: v, |
|
|
|
|
|
}) |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
handleFocus = () => { |
|
|
handleFocus = () => { |
|
@ -119,22 +118,22 @@ class InputCurrency extends PureComponent<Props, State> { |
|
|
|
|
|
|
|
|
this.setState(prev => ({ |
|
|
this.setState(prev => ({ |
|
|
isFocus: true, |
|
|
isFocus: true, |
|
|
value: unformat(unit, prev.value), |
|
|
displayValue: unformat(unit, prev.displayValue), |
|
|
})) |
|
|
})) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
emitOnChange = (v: Value) => { |
|
|
emitOnChange = (v: string) => { |
|
|
const { onChange, unit } = this.props |
|
|
const { onChange, unit } = this.props |
|
|
const { value } = this.state |
|
|
const { displayValue } = this.state |
|
|
|
|
|
|
|
|
if (value.toString() !== v.toString()) { |
|
|
if (displayValue.toString() !== v.toString()) { |
|
|
onChange(Number(v), unit) |
|
|
const satoshiValue = Number(v) * 10 ** unit.magnitude |
|
|
|
|
|
onChange(satoshiValue, unit) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
renderListUnits = () => { |
|
|
renderListUnits = () => { |
|
|
const { unit, units, onChange } = this.props |
|
|
const { unit, units, onChange, value } = this.props |
|
|
const { value } = this.state |
|
|
|
|
|
|
|
|
|
|
|
if (units.length <= 1) { |
|
|
if (units.length <= 1) { |
|
|
return null |
|
|
return null |
|
@ -158,13 +157,13 @@ class InputCurrency extends PureComponent<Props, State> { |
|
|
|
|
|
|
|
|
render() { |
|
|
render() { |
|
|
const { renderRight } = this.props |
|
|
const { renderRight } = this.props |
|
|
const { value } = this.state |
|
|
const { displayValue } = this.state |
|
|
|
|
|
|
|
|
return ( |
|
|
return ( |
|
|
<Input |
|
|
<Input |
|
|
{...this.props} |
|
|
{...this.props} |
|
|
ff="Rubik" |
|
|
ff="Rubik" |
|
|
value={value} |
|
|
value={displayValue} |
|
|
onChange={this.handleChange} |
|
|
onChange={this.handleChange} |
|
|
onFocus={this.handleFocus} |
|
|
onFocus={this.handleFocus} |
|
|
onBlur={this.handleBlur} |
|
|
onBlur={this.handleBlur} |
|
|