
Security News
Socket Security Analysis Is Now One Click Away on npm
npm now links to Socket's security analysis on every package page. Here's what you'll find when you click through.
chakra-ui-steps
Advanced tools
Steps component designed to work seamlessly with Chakra UI. An interactive demo along with code examples can be viewed here.

Yarn:
yarn add chakra-ui-steps
NPM:
npm i chakra-ui-steps
NOTE: This v1.4.0 of this component requires @chakra-ui/react >= v1.6.7 to work correctly. You can follow the installation instructions here. If you aren't able to update your chakra version you can still use v1.3.0
In order to get started you will need to extend the default Chakra theme with the provided StepsStyleConfig object, like so:
import { ChakraProvider, extendTheme } from '@chakra-ui/react';
import { StepsStyleConfig as Steps } from 'chakra-ui-steps';
const theme = extendTheme({
components: {
Steps,
},
});
export const App = () => {
return (
<ChakraProvider theme={theme}>
<YourApp />
</ChakraProvider>
);
};
Once that's done you should be good to go!
import { Step, Steps, useSteps } from 'chakra-ui-steps';
const content = (
<Flex py={4}>
<LoremIpsum p={1} />
</Flex>
);
const steps = [
{ label: 'Step 1', content },
{ label: 'Step 2', content },
{ label: 'Step 3', content },
];
export const StepsExample = () => {
const { nextStep, prevStep, setStep, reset, activeStep } = useSteps({
initialStep: 0,
});
return (
<Flex flexDir="column" width="100%">
<Steps activeStep={activeStep}>
{steps.map(({ label, content }) => (
<Step label={label} key={label}>
{content}
</Step>
))}
</Steps>
{activeStep === steps.length ? (
<Flex p={4}>
<Button mx="auto" size="sm" onClick={reset}>
Reset
</Button>
</Flex>
) : (
<Flex width="100%" justify="flex-end">
<Button
isDisabled={activeStep === 0}
mr={4}
onClick={prevStep}
size="sm"
variant="ghost"
>
Prev
</Button>
<Button size="sm" onClick={nextStep}>
{activeStep === steps.length - 1 ? 'Finish' : 'Next'}
</Button>
</Flex>
)}
</Flex>
);
};
If you would like to customize the appearance of the Steps component you can do so using the multi part component styling approach as described here. The parts available for styling are:
connector;
description;
icon;
iconLabel;
label;
labelContainer;
step;
stepContainer;
stepIconContainer;
steps;
The default styles for each part can be found here. Below is an example of how you might change the stroke width of the icons:
import { StepsStyleConfig } from 'chakra-ui-steps';
const CustomSteps = {
...StepsStyleConfig,
baseStyle: props => {
return {
...StepsStyleConfig.baseStyle(props),
icon: {
...StepsStyleConfig.baseStyle(props).icon,
// your custom styles here
strokeWidth: '1px',
},
};
},
};
const theme = extendTheme({
components: {
Steps: CustomSteps,
},
});
Note: Both the
StepandStepscomponent extend the Chakra UIBoxcomponent so they accept all the default styling props.
Steps| Prop | Type | Required | Description | Default |
|---|---|---|---|---|
activeStep | number | yes | Currently active step | 0 |
colorScheme | string | no | Sets the color accent of the Steps component show | green |
orientation | string | no | Sets the orientation of the Steps component | horizontal |
responsive | boolean | no | Sets whether the component auto switches to vertical orientation on mobile | true |
checkIcon | React.ComponentType | no | Allows you to provide a custom check icon | undefined |
onClickStep | () => void | no | If defined, allows you to click on the step icons | undefined |
labelOrientation | string | no | Switch between horizontal and vertical label orientation | undefined |
Step| Prop | Type | Required | Description | Default |
|---|---|---|---|---|
label | string | no | Sets the title of the step | '' |
description | string | no | Provides extra info about the step | '' |
icon | React.ComponentType | no | Custom icon to overwrite the default numerical indicator of the step | undefined |
isCompletedStep | boolean | no | Individually control each step state, defaults to active step | undefined |
FAQs
Steps component designed to work seamlessly with Chakra UI
The npm package chakra-ui-steps receives a total of 20,531 weekly downloads. As such, chakra-ui-steps popularity was classified as popular.
We found that chakra-ui-steps demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
npm now links to Socket's security analysis on every package page. Here's what you'll find when you click through.

Security News
A compromised npm publish token was used to push a malicious postinstall script in cline@2.3.0, affecting the popular AI coding agent CLI with 90k weekly downloads.

Product
Socket is now scanning AI agent skills across multiple languages and ecosystems, detecting malicious behavior before developers install, starting with skills.sh's 60,000+ skills.