Files
FastGPT/packages/web/components/common/MySlider/InputSlider.tsx
Archer b520988c64 V4.8.17 feature (#3485)
* feat: add third party account config (#3443)

* temp

* editor workflow variable style

* add team to dispatch

* i18n

* delete console

* change openai account position

* fix

* fix

* fix

* fix

* fix

* 4.8.17 test (#3461)

* perf: external provider config

* perf: ui

* feat: add template config (#3434)

* change template position

* template config

* delete console

* delete

* fix

* fix

* perf: Mongo visutal field (#3464)

* remve invalid code

* perf: team member visutal code

* perf: virtual search; perf: search test data

* fix: ts

* fix: image response headers

* perf: template code

* perf: auth layout;perf: auto save (#3472)

* perf: auth layout

* perf: auto save

* perf: auto save

* fix: template guide display & http input support external variables (#3475)

* fix: template guide display

* http editor support external workflow variables

* perf: auto save;fix: ifelse checker line break; (#3478)

* perf: auto save

* perf: auto save

* fix: ifelse checker line break

* perf: doc

* perf: doc

* fix: update var type error

* 4.8.17 test (#3479)

* perf: auto save

* perf: auto save

* perf: template code

* 4.8.17 test (#3480)

* perf: auto save

* perf: auto save

* perf: model price model

* feat: add react memo

* perf: model provider filter

* fix: ts (#3481)

* perf: auto save

* perf: auto save

* fix: ts

* simple app tool select (#3473)

* workflow plugin userguide & simple tool ui

* simple tool filter

* reuse component

* change component to hook

* fix

* perf: too selector modal (#3484)

* perf: auto save

* perf: auto save

* perf: markdown render

* perf: too selector

* fix: app version require tmbId

* perf: templates refresh

* perf: templates refresh

* hide auto save error tip

* perf: toolkit guide

---------

Co-authored-by: heheer <heheer@sealos.io>
2024-12-27 20:05:12 +08:00

81 lines
1.8 KiB
TypeScript

import React, { useMemo } from 'react';
import { Slider, SliderTrack, SliderThumb, HStack, SliderMark } from '@chakra-ui/react';
import MyNumberInput from '../Input/NumberInput';
const InputSlider = ({
onChange,
value,
max = 100,
min = 0,
step = 1,
isDisabled
}: {
value?: number;
onChange: (index: number) => void;
max: number;
min: number;
step?: number;
isDisabled?: boolean;
}) => {
const markList = useMemo(() => {
const valLen = max - min;
return [
valLen * 0.007 + min,
valLen * 0.2 + min,
valLen * 0.4 + min,
valLen * 0.6 + min,
valLen * 0.8 + min,
valLen * 0.985 + min
];
}, []);
return (
<HStack zIndex={10} spacing={3}>
<Slider
max={max}
min={min}
step={step}
value={value}
focusThumbOnChange={false}
onChange={onChange}
isDisabled={isDisabled}
>
<SliderTrack bg={'myGray.100'} h={'4px'} />
{markList.map((val, i) => (
<SliderMark
key={i}
value={val}
w={'2px'}
h={'2px'}
bg={'#A4A4A4'}
borderRadius={'2px'}
opacity={0.4}
transform={'translateY(-50%)'}
/>
))}
<SliderThumb
bg={'primary.500'}
border={'4px solid'}
borderColor={'#dee7f6'}
w={'18px'}
h={'18px'}
boxShadow={'none'}
// transform={'translate(-50%, -50%) !important'}
/>
</Slider>
<MyNumberInput
size={'sm'}
width={'150px'}
min={min}
max={max}
step={step}
value={value}
isDisabled={isDisabled}
onChange={(e) => onChange(e ?? min)}
/>
</HStack>
);
};
export default React.memo(InputSlider);