Skip to main content

Image

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 Image custom input component, found at src/@core/components/custom-inputs/image.tsx.

Types

src/@core/components/custom-inputs/types
// Types of Custom Inputs with Images
export type CustomInputImgData = {
alt?: string
value: string
img: ReactNode
isSelected?: boolean
}
export type CustomInputImgProps = {
name: string
color?: ThemeColor
gridProps: Grid2Props
data: CustomInputImgData
} & (
| {
type: 'checkbox'
selected: string[]
handleChange: (value: string) => void
}
| {
type: 'radio'
selected: string
handleChange: (value: string | ChangeEvent<HTMLInputElement>) => void
}
)

This configuration supports both radio and checkbox types and allows for extensive customization to match the specific needs of your application.

Usage Example

Here's an example of how to implement the CustomInputImg component:

// Import types and components
import type { CustomInputImgData } from '@core/components/custom-inputs/types'
import CustomInputImg from '@core/components/custom-inputs/CustomCheckboxImg'

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

export default Component