mirror of
https://github.com/a-nyx/maputnik-with-pmtiles.git
synced 2025-01-08 05:10:56 +01:00
80 lines
1.8 KiB
JavaScript
80 lines
1.8 KiB
JavaScript
import React from 'react'
|
|
import PropTypes from 'prop-types'
|
|
|
|
class NumberInput extends React.Component {
|
|
static propTypes = {
|
|
value: PropTypes.number,
|
|
default: PropTypes.number,
|
|
min: PropTypes.number,
|
|
max: PropTypes.number,
|
|
onChange: PropTypes.func,
|
|
}
|
|
|
|
constructor(props) {
|
|
super(props)
|
|
this.state = {
|
|
value: props.value
|
|
}
|
|
}
|
|
|
|
UNSAFE_componentWillReceiveProps(nextProps) {
|
|
this.setState({ value: nextProps.value })
|
|
}
|
|
|
|
changeValue(newValue) {
|
|
const value = parseFloat(newValue)
|
|
|
|
const hasChanged = this.state.value !== value
|
|
if(this.isValid(value) && hasChanged) {
|
|
this.props.onChange(value)
|
|
} else {
|
|
this.setState({ value: newValue })
|
|
}
|
|
}
|
|
|
|
isValid(v) {
|
|
const value = parseFloat(v)
|
|
if(isNaN(value)) {
|
|
return false
|
|
}
|
|
|
|
if(!isNaN(this.props.min) && value < this.props.min) {
|
|
return false
|
|
}
|
|
|
|
if(!isNaN(this.props.max) && value > this.props.max) {
|
|
return false
|
|
}
|
|
|
|
return true
|
|
}
|
|
|
|
resetValue() {
|
|
// Reset explicitly to default value if value has been cleared
|
|
if(this.state.value === "") {
|
|
return this.changeValue(this.props.default)
|
|
}
|
|
|
|
// If set value is invalid fall back to the last valid value from props or at last resort the default value
|
|
if(!this.isValid(this.state.value)) {
|
|
if(this.isValid(this.props.value)) {
|
|
this.changeValue(this.props.value)
|
|
} else {
|
|
this.changeValue(this.props.default)
|
|
}
|
|
}
|
|
}
|
|
|
|
render() {
|
|
return <input
|
|
spellCheck="false"
|
|
className="maputnik-number"
|
|
placeholder={this.props.default}
|
|
value={this.state.value}
|
|
onChange={e => this.changeValue(e.target.value)}
|
|
onBlur={this.resetValue.bind(this)}
|
|
/>
|
|
}
|
|
}
|
|
|
|
export default NumberInput
|