Files
FastGPT/packages/web/hooks/useStep.tsx
Archer c031e6dcc9 4.6.7-alpha commit (#743)
Co-authored-by: Archer <545436317@qq.com>
Co-authored-by: heheer <71265218+newfish-cmyk@users.noreply.github.com>
2024-01-19 11:17:28 +08:00

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
};
};