Stepper
Overview
To understand the Stepper
component better, please refer to the MUI Stepper Documentation.
We've upgraded the basic Stepper component to improve both its aesthetics and features. Below is a quick summary of the improvements made.
This guide focuses exclusively on the new properties we've added. Feel free to use any of the standard props provided by MUI's Stepper component in addition.
StepIcon
The StepperCustomDot
component, situated at src/components/stepper-dot/index.tsx
, is designed to customize the visual representation of each step within the Stepper
. It adjusts icons based on the step's state.
To use the StepperCustomDot
within a stepper, you can incorporate it in the stepIcon
prop of slots
in the StepLabel
component. Here's a basic example of using StepperCustomDot
within a Stepper
component:
import StepperCustomDot from '@components/stepper-dot';
<Stepper activeStep={activeStep} orientation='vertical'>
{steps.map((step, index) => (
<Step key={index}>
<StepLabel
slots={{
stepIcon: StepperCustomDot
}}
>
{/* Step content here */}
</StepLabel>
</Step>
))}
</Stepper>
Component States
Error State: Displays an icon indicating an error in the step.
Completed State: Shows a filled circle icon, marking the step as completed.
Active State: Highlights the dot, indicating it is the current active step.
StepperWrapper
The StepperWrapper
component, situated at src/@core/styles/stepper.ts
, is designed to enhance the appearance of MUI's Stepper
component.
Styling the Stepper
We leverage MUI's styled
function to create the StepperWrapper
, injecting theme-based styles for responsive design and visual enhancements. This approach ensures that the stepper adheres to the application's design language and behaves responsively across devices.
StepperWrapper
encapsulates styles targeting different parts of the stepper, including horizontal and vertical alignments, step icons, labels, numbers, titles, subtitles, and connector lines. It makes extensive use of theme breakpoints for responsive design, typography for consistent font styling, and color variables for state-based styling.
Example Code
// MUI imports
import Box from '@mui/material/Box'
import { styled } from '@mui/material/styles'
import type { BoxProps } from '@mui/material/Box'
const StepperWrapper = styled(Box)<BoxProps>(({ theme }) => ({
// Responsive and state-based style definitions...
})) as typeof Box
export default StepperWrapper
This snippet creates a StepperWrapper
component applying predefined styles to enhance the default Stepper
component's appearance and functionality.
Implementing the Styled Stepper
To utilize the StepperWrapper
, simply wrap the Stepper
component within this wrapper.
Example Usage
import StepperWrapper from '@core/styles/stepper.ts'
import Stepper from '@mui/material/Stepper'
const MyComponent = () => {
// States and functions...
return (
<div>
<StepperWrapper>
<Stepper activeStep={activeStep}>
{/* Step components */}
</Stepper>
</StepperWrapper>
{/* Additional content */}
</Card>
)
}
export default MyComponent
By incorporating the StepperWrapper
, users can easily enhance their stepper component's responsiveness and visual appeal, aligning it with their application's overall design theme.