You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
64 lines
1.3 KiB
64 lines
1.3 KiB
import React, {useEffect, useRef, useState} from "react";
|
|
import ReactDOM from "react-dom";
|
|
import styled from "styled-components";
|
|
|
|
const Modal = ({show, onClose, children, title}) => {
|
|
|
|
const handleCloseClick = (e) => {
|
|
e.preventDefault();
|
|
onClose();
|
|
};
|
|
|
|
const modalContent = show ? (
|
|
<StyledModalOverlay>
|
|
<StyledModal>
|
|
<StyledModalHeader>
|
|
<a href="#" onClick={handleCloseClick}>
|
|
x
|
|
</a>
|
|
</StyledModalHeader>
|
|
{title && <StyledModalTitle>{title}</StyledModalTitle>}
|
|
<StyledModalBody>{children}</StyledModalBody>
|
|
</StyledModal>
|
|
</StyledModalOverlay>
|
|
) : null;
|
|
|
|
|
|
return (
|
|
modalContent
|
|
);
|
|
|
|
};
|
|
|
|
const StyledModalBody = styled.div`
|
|
padding-top: 10px;
|
|
`;
|
|
|
|
const StyledModalHeader = styled.div`
|
|
display: flex;
|
|
justify-content: flex-end;
|
|
font-size: 25px;
|
|
`;
|
|
|
|
const StyledModal = styled.div`
|
|
background: white;
|
|
width: 500px;
|
|
height: 600px;
|
|
border-radius: 15px;
|
|
padding: 15px;
|
|
`;
|
|
const StyledModalTitle = styled.div
|
|
const StyledModalOverlay = styled.div`
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
width: 100%;
|
|
height: 100%;
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
background-color: rgba(0, 0, 0, 0.5);
|
|
`;
|
|
|
|
export default Modal;
|