35 lines
741 B
TypeScript
35 lines
741 B
TypeScript
import {
|
|
Button as MUIButton,
|
|
buttonClasses as muiButtonClasses,
|
|
SxProps,
|
|
Theme,
|
|
} from '@mui/material';
|
|
import { FC, useMemo } from 'react';
|
|
|
|
import { BLACK, DISABLED, GREY } from '../lib/consts/DEFAULT_THEME';
|
|
|
|
const ContainedButton: FC<ContainedButtonProps> = ({ sx, ...restProps }) => {
|
|
const combinedSx = useMemo<SxProps<Theme>>(
|
|
() => ({
|
|
backgroundColor: GREY,
|
|
color: BLACK,
|
|
textTransform: 'none',
|
|
|
|
'&:hover': {
|
|
backgroundColor: `${GREY}F0`,
|
|
},
|
|
|
|
[`&.${muiButtonClasses.disabled}`]: {
|
|
backgroundColor: DISABLED,
|
|
},
|
|
|
|
...sx,
|
|
}),
|
|
[sx],
|
|
);
|
|
|
|
return <MUIButton variant="contained" {...restProps} sx={combinedSx} />;
|
|
};
|
|
|
|
export default ContainedButton;
|