tachiyomi-extensions-inspector/webUI/react/src/components/ChapterCard.tsx

71 lines
2.3 KiB
TypeScript
Raw Normal View History

2021-01-19 17:50:28 +01:00
import React from 'react';
import { makeStyles } from '@material-ui/core/styles';
import Card from '@material-ui/core/Card';
import CardContent from '@material-ui/core/CardContent';
import Button from '@material-ui/core/Button';
import Typography from '@material-ui/core/Typography';
const useStyles = makeStyles((theme) => ({
root: {
display: 'flex',
justifyContent: 'space-between',
alignItems: 'center',
padding: 16,
},
bullet: {
display: 'inline-block',
margin: '0 2px',
transform: 'scale(0.8)',
},
title: {
fontSize: 14,
},
pos: {
marginBottom: 12,
},
icon: {
width: theme.spacing(7),
height: theme.spacing(7),
flex: '0 0 auto',
marginRight: 16,
},
}));
2021-01-19 18:32:57 +01:00
interface IProps{
chapter: IChapter
}
export default function ChapterCard(props: IProps) {
2021-01-19 17:50:28 +01:00
const classes = useStyles();
2021-01-19 18:32:57 +01:00
const { chapter } = props;
2021-01-19 17:50:28 +01:00
2021-01-19 21:34:12 +01:00
const dateStr = chapter.date_upload && new Date(chapter.date_upload).toISOString().slice(0, 10);
2021-01-19 17:50:28 +01:00
return (
<>
<li>
<Card>
<CardContent className={classes.root}>
<div style={{ display: 'flex' }}>
<div style={{ display: 'flex', flexDirection: 'column' }}>
<Typography variant="h5" component="h2">
2021-01-19 18:32:57 +01:00
{chapter.name}
{chapter.chapter_number > 0 && ` : ${chapter.chapter_number}`}
2021-01-19 17:50:28 +01:00
</Typography>
<Typography variant="caption" display="block" gutterBottom>
2021-01-19 18:32:57 +01:00
{chapter.scanlator}
{chapter.scanlator && ' '}
2021-01-19 21:34:12 +01:00
{dateStr}
2021-01-19 17:50:28 +01:00
</Typography>
</div>
</div>
<div style={{ display: 'flex' }}>
2021-01-19 22:35:24 +01:00
<Button variant="outlined" style={{ marginLeft: 20 }} onClick={() => { window.location.href = `/manga/${chapter.mangaId}/chapter/${chapter.id}`; }}>open</Button>
2021-01-19 17:50:28 +01:00
</div>
</CardContent>
</Card>
</li>
</>
);
}