modal 반영 1차

main
minuk926 3 years ago
parent 462017bfdd
commit c12d4b49ce

@ -61,6 +61,7 @@
"react-perfect-scrollbar": "^1.5.8", "react-perfect-scrollbar": "^1.5.8",
"react-quill": "^2.0.0-beta.4", "react-quill": "^2.0.0-beta.4",
"react-redux": "^7.2.6", "react-redux": "^7.2.6",
"react-resizable": "^3.0.4",
"react-router-dom": "^6.2.1", "react-router-dom": "^6.2.1",
"react-scripts": "^4.0.3", "react-scripts": "^4.0.3",
"react-slick": "^0.28.1", "react-slick": "^0.28.1",

@ -59,6 +59,7 @@
<body> <body>
<noscript>You need to enable JavaScript to run this app.</noscript> <noscript>You need to enable JavaScript to run this app.</noscript>
<div id="root"></div> <div id="root"></div>
<div id="modal"></div>
<!-- <!--
This HTML file is a template. This HTML file is a template.
If you open it directly in the browser, you will see an empty page. If you open it directly in the browser, you will see an empty page.

@ -18,6 +18,9 @@ const ParkingReview = Loadable(lazy(() => import('views/biz/parking/Review')));
const ParkingDetails = Loadable(lazy(() => import('views/biz/parking/ModalDetails'))); const ParkingDetails = Loadable(lazy(() => import('views/biz/parking/ModalDetails')));
const ParkingRegister = Loadable(lazy(() => import('views/biz/parking/Regist'))); const ParkingRegister = Loadable(lazy(() => import('views/biz/parking/Regist')));
// component
const ModalForm = Loadable(lazy(() => import('views/form/Modal')));
// ==============================|| MAIN ROUTING ||============================== // // ==============================|| MAIN ROUTING ||============================== //
const MainRoutes = { const MainRoutes = {
@ -96,14 +99,20 @@ const MainRoutes = {
path: '/user/juror', path: '/user/juror',
element: <Board /> element: <Board />
}, },
{
path: '/parking/details',
element: <ParkingDetails />
},
// ----------------------------------------
{ {
path: '/sample-page', path: '/sample-page',
element: <SamplePage /> element: <SamplePage />
}, },
{ {
path: '/parking/details', path: '/modalForm',
element: <ParkingDetails /> element: <ModalForm />
} }
] ]
}; };

@ -1,8 +1,8 @@
import PropTypes from 'prop-types'; import PropTypes from 'prop-types';
import React, { forwardRef } from 'react'; import React, { forwardRef, useState } from 'react';
// material-ui // material-ui
import { Button, CardContent, CardActions, Divider, Grid, IconButton, Modal, Typography } from '@mui/material'; import { Button, CardContent, CardActions, Divider, Grid, IconButton, Modal, Typography, Card } from '@mui/material';
// project imports // project imports
import MainCard from 'ui-component/cards/MainCard'; import MainCard from 'ui-component/cards/MainCard';
@ -10,6 +10,8 @@ import MainCard from 'ui-component/cards/MainCard';
// assets // assets
import CloseIcon from '@mui/icons-material/Close'; import CloseIcon from '@mui/icons-material/Close';
import SimpleModal from 'views/form/Modal/SimpleModal'; import SimpleModal from 'views/form/Modal/SimpleModal';
import Board from '../board/Board';
// import DraggableResizeModal from 'views/form/Modal/DraggableResizeModal';
// generate random // generate random
function rand() { function rand() {
@ -28,43 +30,47 @@ function getModalStyle() {
}; };
} }
const ModalDetails = forwardRef(({ modalStyle, handleClose }, ref) => ( const ModalDetails = () => {
<div ref={ref} tabIndex={-1}> // getModalStyle is not a pure function, we roll the style only on the first render
<MainCard const [modalStyle] = useState(getModalStyle);
style={modalStyle}
sx={{ const [open, setOpen] = useState(true);
position: 'absolute', const handleOpen = () => {
width: { xs: 280, lg: 450 }, setOpen(true);
top: '50%', };
left: '50%',
transform: 'translate(-50%, -50%)' const handleClose = () => {
}} setOpen(false);
title="Title" };
content={false}
secondary={ const [resizeOpen, setResizeOpen] = useState(false);
<IconButton onClick={handleClose} size="large"> const handleOpenResizeToggle = (evt) => {
<CloseIcon fontSize="small" /> setResizeOpen(!resizeOpen);
</IconButton> };
}
> return (
<CardContent> <MainCard>
<Typography variant="body1">Laboris non ad et aute sint aliquip mollit voluptate velit dolore magna fugiat ex.</Typography> <Grid container justifyContent="flex-end">
<Typography variant="body2" sx={{ mt: 2 }}> <Button variant="contained" type="button" onClick={handleOpen}>
Commodo amet veniam nostrud mollit quis sint qui nulla elit esse excepteur ullamco esse magna. Nisi duis aute est in mollit irure Open Modal
enim tempor in. </Button>
</Typography> <Modal open={open} onClose={handleClose} aria-labelledby="simple-modal-title" aria-describedby="simple-modal-description">
</CardContent> {/* <Body modalStyle={modalStyle} handleClose={handleClose} /> */}
<Divider /> <Board />
<CardActions> {/* dkdkkd */}
<SimpleModal /> </Modal>
</CardActions> </Grid>
</MainCard> </MainCard>
</div>
));
ModalDetails.propTypes = { // <DraggableResizeModal title=" 2" open={resizeOpen} isResize width={450} height={450} onClose={handleOpenResizeToggle}>
modalStyle: PropTypes.object, // test2
handleClose: PropTypes.func // </DraggableResizeModal>
);
}; };
// ModalDetails.propTypes = {
// modalStyle: PropTypes.object,
// handleClose: PropTypes.func
// };
export default ModalDetails; export default ModalDetails;

@ -81,7 +81,8 @@ const ParkingReview = () => {
description: 'dddddd', description: 'dddddd',
valueGetter: (params) => `${params.row.msSdate} ~ ${params.row.msEdate}`, valueGetter: (params) => `${params.row.msSdate} ~ ${params.row.msEdate}`,
renderCell: (params) => ( renderCell: (params) => (
<Link underline="hover" href="/parking/details" target="_blank"> // <Link underline="hover" href="/parking/details" target="_blank">
<Link underline="hover" target="_blank">
{params.value} {params.value}
</Link> </Link>
) )

@ -0,0 +1,40 @@
import * as React from 'react';
import Box from '@mui/material/Box';
import Button from '@mui/material/Button';
import Typography from '@mui/material/Typography';
import Modal from '@mui/material/Modal';
const style = {
position: 'absolute',
top: '50%',
left: '50%',
transform: 'translate(-50%, -50%)',
width: 400,
bgcolor: 'background.paper',
border: '2px solid #000',
boxShadow: 24,
p: 4
};
export default function BasicModal() {
const [open, setOpen] = React.useState(false);
const handleOpen = () => setOpen(true);
const handleClose = () => setOpen(false);
return (
<div>
<Button onClick={handleOpen}>Open BasicModal</Button>
<Modal hideBackdrop open={open} onClose={handleClose} aria-labelledby="modal-modal-title" aria-describedby="modal-modal-description">
<Box sx={style}>
<Typography id="modal-modal-title" variant="h6" component="h2">
Text in a modal
</Typography>
<Typography id="modal-modal-description" sx={{ mt: 2 }}>
Duis mollis, est non commodo luctus, nisi erat porttitor ligula.
</Typography>
<Button onClick={handleClose}>Close Modal</Button>
</Box>
</Modal>
</div>
);
}

@ -0,0 +1,46 @@
import { useState } from 'react';
import { makeStyles } from '@mui/styles';
import { Button } from '@mui/material';
import DraggableResizeModal from './DraggableResizeModal';
const useStyles = makeStyles((theme) => ({
modal: {
'& > *': {
margin: theme.spacing(1)
},
padding: theme.spacing(2)
}
}));
function DraggableModal() {
const classes = useStyles();
const [open, setOpen] = useState(false);
const [resizeOpen, setResizeOpen] = useState(false);
const handleOpenToggle = (evt) => {
setOpen(!open);
};
const handleOpenResizeToggle = (evt) => {
setResizeOpen(!resizeOpen);
};
return (
<div className={classes.modal}>
<Button variant="outlined" color="primary" onClick={handleOpenToggle}>
Open Draggable Modal
</Button>
<Button variant="outlined" color="primary" onClick={handleOpenResizeToggle}>
Open Draggable(+resize) Modal
</Button>
<DraggableResizeModal title="모달 테스트1" open={open} width={450} height={450} onClose={handleOpenToggle}>
test1
</DraggableResizeModal>
<DraggableResizeModal title="모달 테스트2" open={resizeOpen} isResize width={450} height={450} onClose={handleOpenResizeToggle}>
test2
</DraggableResizeModal>
</div>
);
}
export default DraggableModal;

@ -0,0 +1,164 @@
import React, { useEffect, useState } from 'react';
import { Paper, makeStyles, withStyles, IconButton, Typography, Divider } from '@mui/material';
import { Close as CloseIcon, Remove as RemoveIcon, WebAsset as WebAssetIcon } from '@mui/icons-material';
import Draggable from 'react-draggable';
import { ResizableBox } from 'react-resizable';
import PropTypes from 'prop-types';
const styles = (theme) => ({
modal: {
margin: 0,
padding: theme.spacing(2),
cursor: 'move',
userSelect: 'none',
minWidth: 200
},
title: {
fontWeight: 'bold'
},
closeButton: {
position: 'fixed',
right: theme.spacing(1),
top: theme.spacing(1),
color: theme.palette.grey[500]
},
minimize: {
position: 'fixed',
right: theme.spacing(6),
top: theme.spacing(1),
color: theme.palette.grey[500]
}
});
// modal
const ModalTitle = withStyles(styles)((props) => {
const { children, classes, width, isMinimized, onMinimized, onClose, ...other } = props;
return (
<div className={classes.modal} {...other} style={{ width }}>
<Typography variant="h6" className={classes.title}>
{children}
</Typography>
{onClose ? (
<IconButton aria-label="close" className={classes.closeButton} onClick={onClose}>
<CloseIcon />
</IconButton>
) : null}
{onMinimized ? (
<IconButton aria-label="close" className={classes.minimize} onClick={onMinimized}>
{isMinimized ? <WebAssetIcon /> : <RemoveIcon />}
</IconButton>
) : null}
</div>
);
});
const useContentStyles = (width, height) =>
makeStyles((theme) => ({
resizable: {
padding: theme.spacing(2),
position: 'relative',
'& .react-resizable-handle': {
position: 'absolute',
userSelect: 'none',
width: 20,
height: 20,
bottom: 0,
right: 0,
background:
"url('')",
'background-position': 'bottom right',
padding: '0 3px 3px 0',
'background-repeat': 'no-repeat',
'background-origin': 'content-box',
'box-sizing': 'border-box',
cursor: 'se-resize'
}
},
content: {
padding: theme.spacing(2),
maxHeight: height,
maxWidth: width
}
}));
// modal content isResize
const ModalContent = ({ width, height, isResize, children }) => {
const classes = useContentStyles(width, height)();
return (
<>
{isResize ? (
<ResizableBox height={height} width={width} className={classes.resizable}>
{children}
</ResizableBox>
) : (
<Paper className={classes.content}>{children}</Paper>
)}
</>
);
};
const PaperComponent = (props) => (
<Draggable handle="#draggable-modal-title">
<Paper {...props} />
</Draggable>
);
const useStyles = makeStyles((theme) => ({
modal: {
position: 'fixed',
top: '10%',
left: '10%',
zIndex: 1300,
userSelect: 'none'
}
}));
const Modal = ({ title, children, width, height, isResize, onClose }) => {
const classes = useStyles();
const [isMinimized, setIsMinimized] = useState(false);
const handleMinimized = (evt) => {
setIsMinimized(!isMinimized);
};
useEffect(() => () => {}, []);
return (
<PaperComponent className={classes.modal}>
<ModalTitle id="draggable-modal-title" onClose={onClose} width={width} isMinimized={isMinimized} onMinimized={handleMinimized}>
{title}
</ModalTitle>
<Divider />
{!isMinimized && (
<ModalContent width={width} height={height} isResize={isResize}>
{children}
</ModalContent>
)}
</PaperComponent>
);
};
// open mount unmount
const DraggableResizeModal = ({ open, ...other }) => <>{open && <Modal {...other} />}</>;
// property
DraggableResizeModal.defaultProps = {
title: '목록',
isResize: false,
width: 500,
height: 500
};
// property
DraggableResizeModal.propTypes = {
title: PropTypes.string,
open: PropTypes.bool.isRequired,
onClose: PropTypes.func,
isResize: PropTypes.bool,
width: PropTypes.number,
height: PropTypes.number
};
export default DraggableResizeModal;

@ -0,0 +1,44 @@
import * as React from 'react';
import PropTypes from 'prop-types';
import Box from '@mui/material/Box';
import Button from '@mui/material/Button';
import Typography from '@mui/material/Typography';
import Modal from '@mui/material/Modal';
const style = {
position: 'absolute',
top: '50%',
left: '50%',
transform: 'translate(-50%, -50%)',
width: 400,
bgcolor: 'background.paper',
border: '2px solid #000',
boxShadow: 24,
p: 4
};
export default function GridModal({ children }) {
const [open, setOpen] = React.useState(false);
const handleOpen = () => setOpen(true);
const handleClose = () => setOpen(false);
return (
<div>
<Button onClick={handleOpen}>Grid Modal(List)</Button>
<Modal hideBackdrop open={open} onClose={handleClose} aria-labelledby="modal-modal-title" aria-describedby="modal-modal-description">
<Box sx={style}>
<Typography id="modal-modal-title" variant="h2" component="h2">
Text in a modal
</Typography>
{children}
<Button onClick={handleClose}>Close Modal</Button>
</Box>
</Modal>
</div>
);
}
GridModal.propTypes = {
children: PropTypes.node
};

@ -0,0 +1,82 @@
import * as React from 'react';
import Box from '@mui/material/Box';
import Modal from '@mui/material/Modal';
import Button from '@mui/material/Button';
import CloseIcon from '@mui/icons-material/Close';
import { IconButton } from '@mui/material';
const style = {
position: 'absolute',
top: '50%',
left: '50%',
transform: 'translate(-50%, -50%)',
width: 400,
bgcolor: 'background.paper',
border: '2px solid #000',
boxShadow: 24,
pt: 2,
px: 4,
pb: 3
};
function ChildModal() {
const [open, setOpen] = React.useState(false);
const handleOpen = () => {
setOpen(true);
};
const handleClose = () => {
setOpen(false);
};
return (
<>
<Button onClick={handleOpen}>Open Child Modal</Button>
<Modal hideBackdrop open={open} onClose={handleClose} aria-labelledby="child-modal-title" aria-describedby="child-modal-description">
<Box sx={{ ...style, width: 200 }}>
<h2 id="child-modal-title">Text in a child modal</h2>
<p id="child-modal-description">Lorem ipsum, dolor sit amet consectetur adipisicing elit.</p>
<Button onClick={handleClose}>Close Child Modal</Button>
</Box>
</Modal>
</>
);
}
export default function NestedModal() {
const [open, setOpen] = React.useState(false);
const handleOpen = () => {
setOpen(true);
};
const handleClose = () => {
setOpen(false);
};
return (
<div
tabIndex={-1}
sx={{
position: 'absolute',
width: { xs: 280, lg: 450 },
top: '50%',
left: '50%',
transform: 'translate(-50%, -50%)'
}}
>
<Button onClick={handleOpen}>Open Nested modal</Button>
<Modal
hideBackdrop
open={open}
onClose={handleClose}
aria-labelledby="parent-modal-title"
aria-describedby="parent-modal-description"
>
<Box content sx={{ ...style, width: 400 }}>
<h2 id="parent-modal-title">Text in a modal</h2>
<p id="parent-modal-description">Duis mollis, est non commodo luctus, nisi erat porttitor ligula.</p>
<ChildModal />
<Button onClick={handleClose}>Close Modal</Button>
</Box>
</Modal>
</div>
);
}

@ -39,7 +39,7 @@ const Body = React.forwardRef(({ modalStyle, handleClose }, ref) => (
transform: 'translate(-50%, -50%)' transform: 'translate(-50%, -50%)'
}} }}
title="Title" title="Title"
content={false} content
secondary={ secondary={
<IconButton onClick={handleClose} size="large"> <IconButton onClick={handleClose} size="large">
<CloseIcon fontSize="small" /> <CloseIcon fontSize="small" />

@ -3,13 +3,19 @@ import SimpleModal from './SimpleModal';
import ServerModal from './ServerModal'; import ServerModal from './ServerModal';
import MainCard from 'ui-component/cards/MainCard'; import MainCard from 'ui-component/cards/MainCard';
import SecondaryAction from 'ui-component/cards/CardSecondaryAction'; import SecondaryAction from 'ui-component/cards/CardSecondaryAction';
import NestedModal from './NestedModal';
import BasicModal from './BasicModal';
import GridModal from './GridModal';
// ==============================|| MODAL PAGE ||============================== // // ==============================|| MODAL PAGE ||============================== //
const Modal = () => ( const Modal = () => (
<MainCard title="Simple Modal" secondary={<SecondaryAction link="https://next.material-ui.com/components/modal/" />}> <MainCard title="Modal Sample" secondary={<SecondaryAction link="https://next.material-ui.com/components/modal/" />}>
<ServerModal /> {/* <ServerModal /> */}
<SimpleModal /> {/* <SimpleModal /> */}
<BasicModal />
<NestedModal />
<GridModal />
</MainCard> </MainCard>
); );

Loading…
Cancel
Save