2019-01-12 03:33:27 +00:00
|
|
|
|
import Slider from '../index';
|
|
|
|
|
import '../assets/index.less';
|
|
|
|
|
const { Range } = Slider;
|
|
|
|
|
function log(value) {
|
2018-03-29 06:32:43 +00:00
|
|
|
|
console.log(value); //eslint-disable-line
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const CustomizedRange = {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
data() {
|
2018-03-29 06:32:43 +00:00
|
|
|
|
return {
|
|
|
|
|
lowerBound: 20,
|
|
|
|
|
upperBound: 40,
|
|
|
|
|
value: [20, 40],
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
|
|
|
|
methods: {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
onLowerBoundChange(e) {
|
|
|
|
|
this.lowerBound = +e.target.value;
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
onUpperBoundChange(e) {
|
|
|
|
|
this.upperBound = +e.target.value;
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
onSliderChange(value) {
|
|
|
|
|
log(value);
|
|
|
|
|
this.value = value;
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
handleApply() {
|
|
|
|
|
this.value = [this.lowerBound, this.upperBound];
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
render() {
|
2018-03-29 06:32:43 +00:00
|
|
|
|
return (
|
|
|
|
|
<div>
|
|
|
|
|
<label>LowerBound: </label>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
<input type="number" value={this.lowerBound} onChange={this.onLowerBoundChange} />
|
2018-03-29 06:32:43 +00:00
|
|
|
|
<br />
|
|
|
|
|
<label>UpperBound: </label>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
<input type="number" value={this.upperBound} onChange={this.onUpperBoundChange} />
|
2018-03-29 06:32:43 +00:00
|
|
|
|
<br />
|
|
|
|
|
<button onClick={this.handleApply}>Apply</button>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
<br />
|
|
|
|
|
<br />
|
2018-03-29 06:32:43 +00:00
|
|
|
|
<Range allowCross={false} value={this.value} onChange={this.onSliderChange} />
|
|
|
|
|
</div>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|
2018-03-29 06:32:43 +00:00
|
|
|
|
|
|
|
|
|
const DynamicBounds = {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
data() {
|
2018-03-29 06:32:43 +00:00
|
|
|
|
return {
|
|
|
|
|
min: 0,
|
|
|
|
|
max: 100,
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
|
|
|
|
methods: {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
onSliderChange(value) {
|
|
|
|
|
log(value);
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
onMinChange(e) {
|
|
|
|
|
this.min = +e.target.value || 0;
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
onMaxChange(e) {
|
|
|
|
|
this.max = +e.target.value || 100;
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
render() {
|
2018-03-29 06:32:43 +00:00
|
|
|
|
return (
|
|
|
|
|
<div>
|
|
|
|
|
<label>Min: </label>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
<input type="number" value={this.min} onInput={this.onMinChange} />
|
2018-03-29 06:32:43 +00:00
|
|
|
|
<br />
|
|
|
|
|
<label>Max: </label>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
<input type="number" value={this.max} onInput={this.onMaxChange} />
|
|
|
|
|
<br />
|
|
|
|
|
<br />
|
|
|
|
|
<Range
|
|
|
|
|
defaultValue={[20, 50]}
|
|
|
|
|
min={this.min}
|
|
|
|
|
max={this.max}
|
2018-03-29 06:32:43 +00:00
|
|
|
|
onChange={this.onSliderChange}
|
|
|
|
|
/>
|
|
|
|
|
</div>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|
2018-03-29 06:32:43 +00:00
|
|
|
|
|
|
|
|
|
const ControlledRange = {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
data() {
|
2018-03-29 06:32:43 +00:00
|
|
|
|
return {
|
|
|
|
|
value: [20, 40, 60, 80],
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
|
|
|
|
methods: {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
handleChange(value) {
|
|
|
|
|
this.value = value;
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
render() {
|
|
|
|
|
return <Range value={this.value} onChange={this.handleChange} />;
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|
2018-03-29 06:32:43 +00:00
|
|
|
|
|
|
|
|
|
const ControlledRangeDisableAcross = {
|
|
|
|
|
props: {
|
|
|
|
|
pushable: [Number, Boolean],
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
data() {
|
2018-03-29 06:32:43 +00:00
|
|
|
|
return {
|
|
|
|
|
value: [20, 40, 60, 80],
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
|
|
|
|
methods: {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
handleChange(value) {
|
|
|
|
|
this.value = value;
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
render() {
|
2018-03-29 06:32:43 +00:00
|
|
|
|
const rangeRange = {
|
|
|
|
|
props: {
|
|
|
|
|
value: this.value,
|
|
|
|
|
allowCross: false,
|
|
|
|
|
...this.$props,
|
|
|
|
|
},
|
|
|
|
|
on: {
|
|
|
|
|
change: this.handleChange,
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|
|
|
|
|
return <Range {...rangeRange} />;
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|
2018-03-29 06:32:43 +00:00
|
|
|
|
|
|
|
|
|
const PureRenderRange = {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
data() {
|
2018-03-29 06:32:43 +00:00
|
|
|
|
return {
|
|
|
|
|
foo: false,
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
|
|
|
|
methods: {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
handleChange(value) {
|
|
|
|
|
console.log(value);
|
|
|
|
|
this.foo = !this.foo;
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
render() {
|
|
|
|
|
return (
|
|
|
|
|
<Range defaultValue={[20, 40, 60, 80]} onChange={this.handleChange} allowCross={false} />
|
|
|
|
|
);
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|
2018-03-29 06:32:43 +00:00
|
|
|
|
|
|
|
|
|
export default {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
render() {
|
|
|
|
|
const style = { width: '400px', margin: '50px' };
|
|
|
|
|
const pStyle = { margin: '20px 0' };
|
2018-03-29 06:32:43 +00:00
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<div>
|
|
|
|
|
<div style={style}>
|
|
|
|
|
<p style={pStyle}>Basic Range,`allowCross=false`</p>
|
|
|
|
|
<Range allowCross={false} defaultValue={[0, 20]} onChange={log} />
|
|
|
|
|
</div>
|
|
|
|
|
<div style={style}>
|
|
|
|
|
<p style={pStyle}>Basic Range,`step=20` </p>
|
|
|
|
|
<Range step={20} defaultValue={[20, 20]} onBeforeChange={log} />
|
|
|
|
|
</div>
|
|
|
|
|
<div style={style}>
|
|
|
|
|
<p style={pStyle}>Basic Range,`step=20, dots` </p>
|
|
|
|
|
<Range dots step={20} defaultValue={[20, 40]} onAfterChange={log} />
|
|
|
|
|
</div>
|
|
|
|
|
<div style={style}>
|
|
|
|
|
<p style={pStyle}>Basic Range,disabled</p>
|
|
|
|
|
<Range allowCross={false} defaultValue={[0, 20]} onChange={log} disabled />
|
|
|
|
|
</div>
|
|
|
|
|
<div style={style}>
|
|
|
|
|
<p style={pStyle}>Controlled Range</p>
|
|
|
|
|
<ControlledRange />
|
|
|
|
|
</div>
|
|
|
|
|
<div style={style}>
|
|
|
|
|
<p style={pStyle}>Controlled Range, not allow across</p>
|
|
|
|
|
<ControlledRangeDisableAcross />
|
|
|
|
|
</div>
|
|
|
|
|
<div style={style}>
|
|
|
|
|
<p style={pStyle}>Controlled Range, not allow across, pushable=5</p>
|
|
|
|
|
<ControlledRangeDisableAcross pushable={5} />
|
|
|
|
|
</div>
|
|
|
|
|
<div style={style}>
|
|
|
|
|
<p style={pStyle}>Multi Range</p>
|
|
|
|
|
<Range count={3} defaultValue={[20, 40, 60, 80]} pushable />
|
|
|
|
|
</div>
|
|
|
|
|
<div style={style}>
|
|
|
|
|
<p style={pStyle}>Multi Range with custom track and handle style</p>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
<Range
|
|
|
|
|
count={3}
|
|
|
|
|
defaultValue={[20, 40, 60, 80]}
|
|
|
|
|
pushable
|
2018-03-29 06:32:43 +00:00
|
|
|
|
trackStyle={[{ backgroundColor: 'red' }, { backgroundColor: 'green' }]}
|
|
|
|
|
handleStyle={[{ backgroundColor: 'yellow' }, { backgroundColor: 'gray' }]}
|
|
|
|
|
railStyle={{ backgroundColor: 'black' }}
|
|
|
|
|
/>
|
|
|
|
|
</div>
|
|
|
|
|
<div style={style}>
|
|
|
|
|
<p style={pStyle}>Customized Range</p>
|
|
|
|
|
<CustomizedRange />
|
|
|
|
|
</div>
|
|
|
|
|
<div style={style}>
|
|
|
|
|
<p style={pStyle}>Range with dynamic `max` `min`</p>
|
|
|
|
|
<DynamicBounds />
|
|
|
|
|
</div>
|
|
|
|
|
<div style={style}>
|
|
|
|
|
<p style={pStyle}>Range as child component</p>
|
|
|
|
|
<PureRenderRange />
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
2018-03-29 06:32:43 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|