Implement MangaCard

This commit is contained in:
she11sh0cked 2020-12-25 17:42:22 +01:00
parent 5597ad66b4
commit 8d689a749b
2 changed files with 71 additions and 0 deletions

View File

@ -0,0 +1,66 @@
import React from 'react';
import { makeStyles } from '@material-ui/core/styles';
import Card from '@material-ui/core/Card';
import CardActionArea from '@material-ui/core/CardActionArea';
import CardMedia from '@material-ui/core/CardMedia';
import Typography from '@material-ui/core/Typography';
const useStyles = makeStyles({
root: {
height: '100%',
width: '100%',
display: 'flex',
},
wrapper: {
position: 'relative',
height: '100%',
},
gradient: {
position: 'absolute',
top: 0,
width: '100%',
height: '100%',
background: 'linear-gradient(to bottom, transparent, #000000)',
opacity: 0.5,
},
title: {
position: 'absolute',
bottom: 0,
padding: '0.5em',
color: 'white',
},
image: {
height: '100%',
width: '100%',
},
});
interface IProps {
manga: IManga
}
export default function MangaCard(props: IProps) {
const {
manga: {
name, imageUrl,
},
} = props;
const classes = useStyles();
return (
<Card className={classes.root}>
<CardActionArea>
<div className={classes.wrapper}>
<CardMedia
className={classes.image}
component="img"
alt="Nagatoro"
image={imageUrl}
title="Nagatoro"
/>
<div className={classes.gradient} />
<Typography className={classes.title} variant="h5" component="h2">{name}</Typography>
</div>
</CardActionArea>
</Card>
);
}

View File

@ -14,3 +14,8 @@ interface ISource {
iconUrl: string iconUrl: string
supportsLatest: boolean supportsLatest: boolean
} }
interface IManga {
name: string
imageUrl: string
}