mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-02 15:59:38 +08:00
42 lines
908 B
JavaScript
42 lines
908 B
JavaScript
import React from 'react';
|
|
import RcSlider from 'rc-slider';
|
|
|
|
export default class Slider extends React.Component {
|
|
static defaultProps = {
|
|
prefixCls: 'ant-slider',
|
|
tipTransitionName: 'zoom-down',
|
|
}
|
|
|
|
render() {
|
|
const { isIncluded, marks, index, defaultIndex, ...rest } = this.props;
|
|
|
|
if (isIncluded !== undefined) {
|
|
// 兼容 `isIncluded`
|
|
rest.included = isIncluded;
|
|
}
|
|
|
|
if (Array.isArray(marks)) {
|
|
// 兼容当 marks 为数组的情况
|
|
rest.min = 0;
|
|
rest.max = marks.length - 1;
|
|
rest.step = 1;
|
|
|
|
if (index !== undefined) {
|
|
rest.value = index;
|
|
}
|
|
if (defaultIndex !== undefined) {
|
|
rest.defaultValue = defaultIndex;
|
|
}
|
|
|
|
rest.marks = {};
|
|
marks.forEach((val, idx) => {
|
|
rest.marks[idx] = val;
|
|
});
|
|
} else {
|
|
rest.marks = marks;
|
|
}
|
|
|
|
return <RcSlider {...rest} />;
|
|
}
|
|
}
|