diff --git a/src/components/inputs/NumberInput.jsx b/src/components/inputs/NumberInput.jsx index 2be980b..d575d53 100644 --- a/src/components/inputs/NumberInput.jsx +++ b/src/components/inputs/NumberInput.jsx @@ -31,7 +31,7 @@ class NumberInput extends React.Component { } static getDerivedStateFromProps(props, state) { - if (!state.editing) { + if (!state.editing && props.value !== state.value) { return { value: props.value, dirtyValue: props.value, @@ -49,12 +49,17 @@ class NumberInput extends React.Component { if(this.isValid(value) && hasChanged) { this.props.onChange(value) this.setState({ - dirtyValue: newValue, + value: newValue, + }); + } + else if (!this.isValid(value) && hasChanged) { + this.setState({ + value: undefined, }); } this.setState({ - value: newValue, + dirtyValue: newValue === "" ? undefined : newValue, }) } @@ -144,8 +149,14 @@ class NumberInput extends React.Component { this.props.min !== undefined && this.props.max !== undefined && this.props.allowRange ) { - const dirtyValue = this.state.dirtyValue === undefined ? this.props.default : this.state.dirtyValue - const value = this.state.value === undefined ? "" : this.state.value; + const value = this.state.editing ? this.state.dirtyValue : this.state.value; + let inputValue; + if (this.state.editingRange) { + inputValue = this.state.value; + } + else { + inputValue = value; + } return