diff options
Diffstat (limited to 'src/components/SolutionCard/SolutionCard.js')
-rw-r--r-- | src/components/SolutionCard/SolutionCard.js | 103 |
1 files changed, 103 insertions, 0 deletions
diff --git a/src/components/SolutionCard/SolutionCard.js b/src/components/SolutionCard/SolutionCard.js new file mode 100644 index 0000000..7cca74c --- /dev/null +++ b/src/components/SolutionCard/SolutionCard.js @@ -0,0 +1,103 @@ +import React, { useState } from 'react'; + +import { + Typography, + Card, + CardHeader, + CardContent, + IconButton, + Avatar, + Grid, + Menu, + MenuItem, +} from "@material-ui/core"; + +import { makeStyles } from "@material-ui/core/styles"; +import TimerIcon from '@material-ui/icons/Timer'; +import MoreVertIcon from '@material-ui/icons/MoreVert'; + +import { del } from "../../requests"; + + +const DATE_FORMAT = { + month: 'long', + day: 'numeric', + year: 'numeric', + hour: '2-digit', + minute: '2-digit', +}; + +const useStyles = makeStyles(theme => ({ + root: { + padding: theme.spacing(1), + + '& .MuiTypography-h3': { + color: theme.palette.secondary.main, + margin: theme.spacing(2), + }, + }, +})); + +const SolutionCard = ({ data, removeThisCard }) => { + const classes = useStyles(); + const [anchorEl, setAnchorEl] = useState(null); + + const author = data.author? data.author.username : 'anonymous'; + const date = new Date(data.date); + + const handleOpenMenu = event => { + setAnchorEl(event.currentTarget); + }; + + const handleClose = () => { + setAnchorEl(null); + }; + + const handleDelete = () => { + del(`solutions/${data.id}/`); + handleClose(); + removeThisCard(data.id); + }; + + return ( + <Card elevation={5} className={classes.root}> + <CardHeader + avatar={ + author === 'anonymous'? + (<Avatar/>) + : + (<Avatar>{author[0].toUpperCase()}</Avatar>) + } + title={author} + subheader={date.toLocaleString('default', DATE_FORMAT)} + action={( + <IconButton onClick={handleOpenMenu}> + <MoreVertIcon /> + </IconButton> + )} + /> + <Menu + anchorEl={anchorEl} + open={Boolean(anchorEl)} + keepMounted + onClose={handleClose} + > + <MenuItem onClick={handleDelete}>Delete</MenuItem> + </Menu> + <CardContent> + <Grid container direction="row" justify="center" alignItems="center"> + <Grid item> + <TimerIcon/> + </Grid> + <Grid item> + <Typography variant="h3"> + { data.result } + </Typography> + </Grid> + </Grid> + </CardContent> + </Card> + ) +}; + +export default SolutionCard; |