mirror of
https://github.com/a-nyx/maputnik-with-pmtiles.git
synced 2025-01-02 19:58:09 +01:00
Added range slider to <NumberInput />
This commit is contained in:
parent
3d2a1d5d19
commit
cdd5d27908
3 changed files with 38 additions and 8 deletions
|
@ -68,7 +68,34 @@ class NumberInput extends React.Component {
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
return <input
|
let rangeEl;
|
||||||
|
|
||||||
|
if(
|
||||||
|
this.props.hasOwnProperty("min") && this.props.hasOwnProperty("max") &&
|
||||||
|
this.props.min !== undefined && this.props.max !== undefined &&
|
||||||
|
this.props.allowRange
|
||||||
|
) {
|
||||||
|
rangeEl = (
|
||||||
|
<input
|
||||||
|
style={{width: "calc(100% - 4em)", flexShrink: "0"}}
|
||||||
|
key="range"
|
||||||
|
type="range"
|
||||||
|
step="0.01"
|
||||||
|
max={this.props.max}
|
||||||
|
min={this.props.min}
|
||||||
|
spellCheck="false"
|
||||||
|
className="maputnik-number"
|
||||||
|
value={this.state.value || this.props.default}
|
||||||
|
onChange={e => this.changeValue(e.target.value)}
|
||||||
|
onBlur={this.resetValue}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return <div style={{display: "flex"}}>
|
||||||
|
{rangeEl}
|
||||||
|
<input
|
||||||
|
key="text"
|
||||||
spellCheck="false"
|
spellCheck="false"
|
||||||
className="maputnik-number"
|
className="maputnik-number"
|
||||||
placeholder={this.props.default}
|
placeholder={this.props.default}
|
||||||
|
@ -76,6 +103,7 @@ class NumberInput extends React.Component {
|
||||||
onChange={e => this.changeValue(e.target.value)}
|
onChange={e => this.changeValue(e.target.value)}
|
||||||
onBlur={this.resetValue}
|
onBlur={this.resetValue}
|
||||||
/>
|
/>
|
||||||
|
</div>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -16,6 +16,7 @@ class MaxZoomBlock extends React.Component {
|
||||||
data-wd-key="max-zoom"
|
data-wd-key="max-zoom"
|
||||||
>
|
>
|
||||||
<NumberInput
|
<NumberInput
|
||||||
|
allowRange={true}
|
||||||
value={this.props.value}
|
value={this.props.value}
|
||||||
onChange={this.props.onChange}
|
onChange={this.props.onChange}
|
||||||
min={latest.layer.maxzoom.minimum}
|
min={latest.layer.maxzoom.minimum}
|
||||||
|
|
|
@ -16,6 +16,7 @@ class MinZoomBlock extends React.Component {
|
||||||
data-wd-key="min-zoom"
|
data-wd-key="min-zoom"
|
||||||
>
|
>
|
||||||
<NumberInput
|
<NumberInput
|
||||||
|
allowRange={true}
|
||||||
value={this.props.value}
|
value={this.props.value}
|
||||||
onChange={this.props.onChange}
|
onChange={this.props.onChange}
|
||||||
min={latest.layer.minzoom.minimum}
|
min={latest.layer.minzoom.minimum}
|
||||||
|
|
Loading…
Reference in a new issue