mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-29 17:55:24 +00:00

* 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>
81 lines
1.8 KiB
TypeScript
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);
|