import * as React from 'react'; import { SxProps } from '@mui/system'; import { OverridableStringUnion } from '@mui/types'; import { InternalStandardProps as StandardProps, Theme } from '..'; import { SwitchBaseProps } from '../internal/SwitchBase'; import { RadioClasses } from './radioClasses'; export interface RadioPropsSizeOverrides {} export interface RadioPropsColorOverrides {} export interface RadioProps extends StandardProps { /** * The icon to display when the component is checked. * @default */ checkedIcon?: React.ReactNode; /** * Override or extend the styles applied to the component. */ classes?: Partial; /** * The color of the component. * It supports both default and custom theme colors, which can be added as shown in the * [palette customization guide](https://mui.com/material-ui/customization/palette/#custom-colors). * @default 'primary' */ color?: OverridableStringUnion< 'primary' | 'secondary' | 'error' | 'info' | 'success' | 'warning' | 'default', RadioPropsColorOverrides >; /** * If `true`, the component is disabled. */ disabled?: boolean; /** * The icon to display when the component is unchecked. * @default */ icon?: React.ReactNode; /** * The size of the component. * `small` is equivalent to the dense radio styling. * @default 'medium' */ size?: OverridableStringUnion<'small' | 'medium', RadioPropsSizeOverrides>; /** * The system prop that allows defining system overrides as well as additional CSS styles. */ sx?: SxProps; } /** * * Demos: * * - [Radio Group](https://mui.com/material-ui/react-radio-button/) * * API: * * - [Radio API](https://mui.com/material-ui/api/radio/) * - inherits [ButtonBase API](https://mui.com/material-ui/api/button-base/) */ export default function Radio(props: RadioProps): JSX.Element;