import React, { useState, useCallback } from 'react'; import { useHistory } from 'react-router-dom'; import { AppBar, Dialog, Toolbar, Typography, IconButton, Divider, Slide, useMediaQuery, useTheme } from '@material-ui/core'; import { makeStyles } from '@material-ui/core/styles'; import CloseIcon from '@material-ui/icons/Close'; import { TransitionProps } from '@material-ui/core/transitions'; interface PropTypes { title: string; } const useStyles = makeStyles(theme => ({ root: { backgroundColor: theme.palette.background.default }, content: { padding: theme.spacing(3, 0, 0, 0) }, toolbar: { display: 'flex', } })); const Transition = React.forwardRef(function Transition( props: TransitionProps & { children?: React.ReactElement }, ref: React.Ref, ) { return ; }); const ModalScreen: React.FC = ({ title, children }) => { const [isOpen, setIsOpen] = useState(true); const classes = useStyles(); const theme = useTheme(); const isMobile = useMediaQuery(theme.breakpoints.down('sm')); const history = useHistory(); const handleClose = useCallback(() => setIsOpen(false), [setIsOpen]); const onExited = useCallback(() => history.goBack(), [history]) return ( { title }
{ children }
); }; export default ModalScreen;