mirror of
https://github.com/labring/FastGPT.git
synced 2025-10-24 11:10:42 +00:00

Co-authored-by: Archer <545436317@qq.com> Co-authored-by: heheer <71265218+newfish-cmyk@users.noreply.github.com>
99 lines
2.2 KiB
TypeScript
99 lines
2.2 KiB
TypeScript
import {
|
|
Box,
|
|
Flex,
|
|
IconButton,
|
|
Step,
|
|
StepDescription,
|
|
StepIcon,
|
|
StepIndicator,
|
|
StepNumber,
|
|
StepSeparator,
|
|
StepStatus,
|
|
StepTitle,
|
|
Stepper,
|
|
css,
|
|
useSteps
|
|
} from '@chakra-ui/react';
|
|
import React, { useCallback, useState } from 'react';
|
|
|
|
export const useMyStep = ({
|
|
defaultStep = 0,
|
|
steps = []
|
|
}: {
|
|
defaultStep?: number;
|
|
steps: { title?: string; description?: string }[];
|
|
}) => {
|
|
const { activeStep, goToNext, goToPrevious } = useSteps({
|
|
index: defaultStep,
|
|
count: steps.length
|
|
});
|
|
|
|
const MyStep = useCallback(
|
|
() => (
|
|
<Stepper
|
|
size={['xs', 'sm']}
|
|
index={activeStep}
|
|
colorScheme="primary"
|
|
gap={5}
|
|
css={css({
|
|
'.chakra-step__indicator': {
|
|
borderWidth: '0 !important'
|
|
}
|
|
})}
|
|
>
|
|
{steps.map((step, index) => (
|
|
<Step key={step.title}>
|
|
<StepIndicator>
|
|
<StepStatus
|
|
complete={<StepIcon />}
|
|
incomplete={
|
|
<Flex
|
|
bg={'myGray.250'}
|
|
color={'myGray.500'}
|
|
w={'100%'}
|
|
h={'100%'}
|
|
lineHeight={'100%'}
|
|
borderRadius={'50%'}
|
|
alignItems={'center'}
|
|
justifyContent={'center'}
|
|
>
|
|
{index + 1}
|
|
</Flex>
|
|
}
|
|
active={
|
|
<Flex
|
|
bg={'primary.500'}
|
|
color={'white'}
|
|
w={'100%'}
|
|
h={'100%'}
|
|
lineHeight={'100%'}
|
|
borderRadius={'50%'}
|
|
alignItems={'center'}
|
|
justifyContent={'center'}
|
|
>
|
|
{index + 1}
|
|
</Flex>
|
|
}
|
|
/>
|
|
</StepIndicator>
|
|
|
|
<Box flexShrink="0">
|
|
<StepTitle>{step.title}</StepTitle>
|
|
</Box>
|
|
|
|
<StepSeparator />
|
|
</Step>
|
|
))}
|
|
</Stepper>
|
|
),
|
|
[steps, activeStep]
|
|
);
|
|
|
|
return {
|
|
activeStep,
|
|
goToNext,
|
|
goToPrevious,
|
|
MyStep
|
|
};
|
|
};
|