Skip to main content

Vertical

Overview

You may refer to the custom-inputs examples from the here.

We have created custom radio and checkbox components to save your time and make it easier for you. You can find detailed explanations of the Radio component in the MUI Radio Docs and the Checkbox component in the MUI Checkbox Docs.

We have already added these components in the MUI components. More information on how to create Themeable component of MUI can be found here.

The Vertical Custom Input is a component designed to provide a vertically aligned user interface for radio and checkbox inputs which is located at src/@core/components/custom-inputs/Vertical.tsx.

Types

src/@core/components/custom-inputs/types
// Types of Vertical Custom Inputs
export type CustomInputVerticalData = {
value: string
title?: ReactNode
content?: ReactNode
isSelected?: boolean
asset?: ReactNode
}
export type CustomInputVerticalProps = {
name: string
color?: ThemeColor
gridProps?: Grid2Props
data: CustomInputVerticalData
} & (
| {
type: 'checkbox'
selected: string[]
handleChange: (value: string) => void
}
| {
type: 'radio'
selected: string
handleChange: (value: string | ChangeEvent<HTMLInputElement>) => void
}
)

Usage Example

Here's an example of how the CustomInputVertical component can be implemented in a project:

// Import components and types
import type { CustomInputVerticalData } from '@core/components/custom-inputs/types'
import CustomInputVertical from '@core/components/custom-inputs/Vertical'

const data: CustomInputVerticalData[] = [
{
title: 'I am the Builder',
value: 'builder',
content: 'List property as Builder, list your project and get highest reach.',
asset: 'tabler-home',
isSelected: true
}
// Additional data objects
]

const Component = () => {
return (
...
<CustomInputVertical
type='radio'
key={index}
gridProps={{ size: { xs: 12, sm: 4 } }}
selected={selectedOption}
name='custom-radios-basic'
handleChange={handleOptionChange}
data={item}
/>
...
);
};

export default Component