0b690577da
* Load next chapter when scrolling to the bottom (Webtoon, Continues Vertical) * Load next chapter when scrolling to the bottom (Paged reader) * Added missing types to IReaderProps * Move load next chapter when at last page to VerticalReader * Dependency fix * Use react history for loading next page
62 lines
1.8 KiB
TypeScript
62 lines
1.8 KiB
TypeScript
/* eslint-disable @typescript-eslint/no-unused-vars */
|
|
/*
|
|
* Copyright (C) Contributors to the Suwayomi project
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at https://mozilla.org/MPL/2.0/. */
|
|
|
|
import { makeStyles } from '@material-ui/core/styles';
|
|
import React, { useEffect } from 'react';
|
|
import { useHistory } from 'react-router-dom';
|
|
import Page from '../Page';
|
|
|
|
const useStyles = makeStyles({
|
|
reader: {
|
|
display: 'flex',
|
|
flexDirection: 'column',
|
|
justifyContent: 'center',
|
|
margin: '0 auto',
|
|
width: '100%',
|
|
},
|
|
});
|
|
|
|
export default function VerticalReader(props: IReaderProps) {
|
|
const {
|
|
pages, settings, setCurPage, curPage, manga, chapter,
|
|
} = props;
|
|
|
|
const classes = useStyles();
|
|
const history = useHistory();
|
|
|
|
const handleLoadNextonEnding = () => {
|
|
if ((window.innerHeight + window.scrollY) >= document.body.offsetHeight) {
|
|
setCurPage(0);
|
|
history.push(`/manga/${manga.id}/chapter/${chapter.index + 1}`);
|
|
}
|
|
};
|
|
useEffect(() => {
|
|
if (settings.loadNextonEnding) { window.addEventListener('scroll', handleLoadNextonEnding); }
|
|
|
|
return () => {
|
|
window.removeEventListener('scroll', handleLoadNextonEnding);
|
|
};
|
|
}, []);
|
|
|
|
return (
|
|
<div className={classes.reader}>
|
|
{
|
|
pages.map((page) => (
|
|
<Page
|
|
key={page.index}
|
|
index={page.index}
|
|
src={page.src}
|
|
setCurPage={setCurPage}
|
|
settings={settings}
|
|
/>
|
|
))
|
|
}
|
|
</div>
|
|
);
|
|
}
|