anvil/striker-ui/components/Panels/Panel.tsx

121 lines
2.5 KiB
TypeScript
Raw Normal View History

import { Box, BoxProps, GlobalStyles, PaperProps, styled } from '@mui/material';
import { FC } from 'react';
import {
BORDER_RADIUS,
PANEL_BACKGROUND,
TEXT,
} from '../../lib/consts/DEFAULT_THEME';
const PREFIX = 'Panel';
const classes = {
paper: `${PREFIX}-paper`,
square: `${PREFIX}-square`,
topSquare: `${PREFIX}-topSquare`,
bottomSquare: `${PREFIX}-bottomSquare`,
};
const StyledBox = styled(Box)(() => ({
margin: '1em',
position: 'relative',
[`& .${classes.paper}`]: {
backgroundColor: PANEL_BACKGROUND,
height: '100%',
opacity: 0.8,
padding: '2.1em',
position: 'relative',
width: '100%',
zIndex: 10,
},
[`& .${classes.square}`]: {
content: '""',
position: 'absolute',
2021-04-30 17:39:28 +00:00
width: '2.1em',
height: '2.1em',
border: '1px',
borderColor: TEXT,
borderWidth: '1px',
borderRadius: BORDER_RADIUS,
borderStyle: 'solid',
padding: 0,
margin: 0,
},
[`& .${classes.topSquare}`]: {
2021-04-30 21:48:10 +00:00
top: '-.3em',
left: '-.3em',
},
[`& .${classes.bottomSquare}`]: {
2021-04-30 21:48:10 +00:00
bottom: '-.3em',
right: '-.3em',
},
}));
type PanelOptionalPropsWithDefault = {
paperProps?: BoxProps;
};
type PanelOptionalProps = PanelOptionalPropsWithDefault;
type PanelProps = PaperProps & PanelOptionalProps;
const PANEL_DEFAULT_PROPS: Required<PanelOptionalPropsWithDefault> = {
paperProps: {},
};
const styledScrollbars = (
<GlobalStyles
styles={{
'*::-webkit-scrollbar': {
width: '.6em',
},
'*::-webkit-scrollbar-track': {
backgroundColor: PANEL_BACKGROUND,
},
'*::-webkit-scrollbar-thumb': {
backgroundColor: TEXT,
outline: '1px solid transparent',
borderRadius: BORDER_RADIUS,
},
}}
/>
);
const Panel: FC<PanelProps> = ({
children,
classes: rootClasses,
className: rootClassName,
paperProps: {
className: paperClassName,
...restPaperProps
} = PANEL_DEFAULT_PROPS.paperProps,
sx: rootSx,
...restRootProps
}) => (
<StyledBox
{...{
classes: rootClasses,
className: rootClassName,
sx: rootSx,
...restRootProps,
}}
>
{styledScrollbars}
<Box className={`${classes.square} ${classes.topSquare}`} />
<Box className={`${classes.square} ${classes.bottomSquare}`} />
<Box {...restPaperProps} className={`${classes.paper} ${paperClassName}`}>
{children}
</Box>
</StyledBox>
);
Panel.defaultProps = PANEL_DEFAULT_PROPS;
2022-10-04 20:52:18 +00:00
export { classes as panelClasses };
export default Panel;