57 lines
1.2 KiB
TypeScript
57 lines
1.2 KiB
TypeScript
import React, { ReactChild } from "react";
|
|
import Modal, { Props } from "react-modal";
|
|
import { useThemeUI, Close } from "theme-ui";
|
|
|
|
type ModalProps = Props & {
|
|
children: ReactChild | ReactChild[],
|
|
allowClose: boolean
|
|
}
|
|
function StyledModal({
|
|
isOpen,
|
|
onRequestClose,
|
|
children,
|
|
allowClose,
|
|
style,
|
|
...props
|
|
}: ModalProps ) {
|
|
const { theme } = useThemeUI();
|
|
|
|
return (
|
|
<Modal
|
|
isOpen={isOpen}
|
|
onRequestClose={onRequestClose}
|
|
style={{
|
|
overlay: { backgroundColor: "rgba(0, 0, 0, 0.73)", zIndex: 100 },
|
|
content: {
|
|
backgroundColor: theme.colors?.background,
|
|
top: "50%",
|
|
left: "50%",
|
|
right: "auto",
|
|
bottom: "auto",
|
|
marginRight: "-50%",
|
|
transform: "translate(-50%, -50%)",
|
|
maxHeight: "100%",
|
|
...style,
|
|
} as React.CSSProperties,
|
|
}}
|
|
{...props}
|
|
>
|
|
{children}
|
|
{allowClose && (
|
|
<Close
|
|
m={0}
|
|
sx={{ position: "absolute", top: 0, right: 0 }}
|
|
onClick={onRequestClose}
|
|
/>
|
|
)}
|
|
</Modal>
|
|
);
|
|
}
|
|
|
|
StyledModal.defaultProps = {
|
|
allowClose: true,
|
|
style: {}
|
|
};
|
|
|
|
export default StyledModal;
|