mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-23 23:18:36 +08:00
30 lines
822 B
TypeScript
30 lines
822 B
TypeScript
import React, { useState } from 'react';
|
|
import { FrownOutlined, SmileOutlined } from '@ant-design/icons';
|
|
import { Slider } from 'antd';
|
|
|
|
interface IconSliderProps {
|
|
max: number;
|
|
min: number;
|
|
}
|
|
|
|
const IconSlider: React.FC<IconSliderProps> = (props) => {
|
|
const { max, min } = props;
|
|
const [value, setValue] = useState(0);
|
|
|
|
const mid = Number(((max - min) / 2).toFixed(5));
|
|
const preColorCls = value >= mid ? '' : 'icon-wrapper-active';
|
|
const nextColorCls = value >= mid ? 'icon-wrapper-active' : '';
|
|
|
|
return (
|
|
<div className="icon-wrapper">
|
|
<FrownOutlined className={preColorCls} />
|
|
<Slider {...props} onChange={setValue} value={value} />
|
|
<SmileOutlined className={nextColorCls} />
|
|
</div>
|
|
);
|
|
};
|
|
|
|
const App: React.FC = () => <IconSlider min={0} max={20} />;
|
|
|
|
export default App;
|