|
@ -18,12 +18,13 @@ function parseValue(value) { |
|
|
return value.toString().replace(/,/g, '.') |
|
|
return value.toString().replace(/,/g, '.') |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
function format(unit: Unit, value: number, { isFocused, showAllDigits }) { |
|
|
function format(unit: Unit, value: number, { isFocused, showAllDigits, subMagnitude }) { |
|
|
// FIXME do we need locale for the input too ?
|
|
|
// FIXME do we need locale for the input too ?
|
|
|
return formatCurrencyUnit(unit, value, { |
|
|
return formatCurrencyUnit(unit, value, { |
|
|
useGrouping: !isFocused, |
|
|
useGrouping: !isFocused, |
|
|
disableRounding: true, |
|
|
disableRounding: true, |
|
|
showAllDigits: !!showAllDigits && !isFocused, |
|
|
showAllDigits: !!showAllDigits && !isFocused, |
|
|
|
|
|
subMagnitude: value < 1 ? subMagnitude : 0, |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -53,6 +54,7 @@ type Props = { |
|
|
units: Unit[], |
|
|
units: Unit[], |
|
|
value: number, |
|
|
value: number, |
|
|
showAllDigits?: boolean, |
|
|
showAllDigits?: boolean, |
|
|
|
|
|
subMagnitude: number, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
type State = { |
|
|
type State = { |
|
@ -68,6 +70,7 @@ class InputCurrency extends PureComponent<Props, State> { |
|
|
units: [], |
|
|
units: [], |
|
|
value: 0, |
|
|
value: 0, |
|
|
showAllDigits: false, |
|
|
showAllDigits: false, |
|
|
|
|
|
subMagnitude: 0, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
state = { |
|
|
state = { |
|
@ -94,6 +97,7 @@ class InputCurrency extends PureComponent<Props, State> { |
|
|
: format(nextProps.unit, nextProps.value, { |
|
|
: format(nextProps.unit, nextProps.value, { |
|
|
isFocused, |
|
|
isFocused, |
|
|
showAllDigits: nextProps.showAllDigits, |
|
|
showAllDigits: nextProps.showAllDigits, |
|
|
|
|
|
subMagnitude: nextProps.subMagnitude, |
|
|
}), |
|
|
}), |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
@ -135,11 +139,13 @@ class InputCurrency extends PureComponent<Props, State> { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
syncInput = ({ isFocused }: { isFocused: boolean }) => { |
|
|
syncInput = ({ isFocused }: { isFocused: boolean }) => { |
|
|
const { value, showAllDigits, unit } = this.props |
|
|
const { value, showAllDigits, subMagnitude, unit } = this.props |
|
|
this.setState({ |
|
|
this.setState({ |
|
|
isFocused, |
|
|
isFocused, |
|
|
displayValue: |
|
|
displayValue: |
|
|
value === '' || value === 0 ? '' : format(unit, value, { isFocused, showAllDigits }), |
|
|
value === '' || value === 0 |
|
|
|
|
|
? '' |
|
|
|
|
|
: format(unit, value, { isFocused, showAllDigits, subMagnitude }), |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -183,7 +189,7 @@ class InputCurrency extends PureComponent<Props, State> { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
render() { |
|
|
render() { |
|
|
const { renderRight, showAllDigits, unit } = this.props |
|
|
const { renderRight, showAllDigits, unit, subMagnitude } = this.props |
|
|
const { displayValue } = this.state |
|
|
const { displayValue } = this.state |
|
|
|
|
|
|
|
|
return ( |
|
|
return ( |
|
@ -195,7 +201,7 @@ class InputCurrency extends PureComponent<Props, State> { |
|
|
onFocus={this.handleFocus} |
|
|
onFocus={this.handleFocus} |
|
|
onBlur={this.handleBlur} |
|
|
onBlur={this.handleBlur} |
|
|
renderRight={renderRight || this.renderListUnits()} |
|
|
renderRight={renderRight || this.renderListUnits()} |
|
|
placeholder={format(unit, 0, { isFocused: false, showAllDigits })} |
|
|
placeholder={format(unit, 0, { isFocused: false, showAllDigits, subMagnitude })} |
|
|
/> |
|
|
/> |
|
|
) |
|
|
) |
|
|
} |
|
|
} |
|
|