mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-05 12:50:29 +02:00
67 lines
2.1 KiB
TypeScript
67 lines
2.1 KiB
TypeScript
import { useRef, useEffect, MutableRefObject, useState } from 'react';
|
|
import PdfDocument from '../PdfDocument';
|
|
import { ScaledSize } from '../types';
|
|
|
|
export interface ScrollSaver {
|
|
container: MutableRefObject<HTMLElement>;
|
|
scaledSize: ScaledSize;
|
|
pdfId: string;
|
|
rememberScroll: boolean;
|
|
onActivePageChange: (activePage: number)=> void;
|
|
pdfDocument: PdfDocument;
|
|
pageGap: number;
|
|
}
|
|
|
|
const useScrollSaver = ({ container, scaledSize, pdfId, rememberScroll, onActivePageChange, pdfDocument, pageGap }: ScrollSaver) => {
|
|
const currentScaleSize = useRef(scaledSize);
|
|
const [currentActivePage, setCurrentActivePage] = useState(1);
|
|
const currentActivePageRef = useRef(currentActivePage);
|
|
|
|
useEffect(() => {
|
|
let scrollTimer: number = null;
|
|
const containerElement = container.current;
|
|
|
|
const saveScroll = () => {
|
|
if (!currentScaleSize.current) return;
|
|
const scale = currentScaleSize.current.scale;
|
|
const pdfScrollTop = container.current.scrollTop / scale;
|
|
if (rememberScroll && pdfId) {
|
|
sessionStorage.setItem(`pdf.${pdfId}.scrollTop`, `${pdfScrollTop}`);
|
|
}
|
|
if (onActivePageChange && currentScaleSize.current) {
|
|
const activePage = pdfDocument.getActivePageNo(currentScaleSize.current, pageGap, container.current.scrollTop);
|
|
if (currentActivePageRef.current !== activePage) {
|
|
// console.log('Active page changed', activePage, container.current.scrollTop);
|
|
currentActivePageRef.current = activePage;
|
|
onActivePageChange(activePage);
|
|
setCurrentActivePage(activePage);
|
|
}
|
|
}
|
|
};
|
|
|
|
const onScroll = () => {
|
|
if (scrollTimer) {
|
|
clearTimeout(scrollTimer);
|
|
scrollTimer = null;
|
|
}
|
|
scrollTimer = window.setTimeout(saveScroll, 200);
|
|
};
|
|
|
|
containerElement.addEventListener('scroll', onScroll);
|
|
|
|
return () => {
|
|
containerElement.removeEventListener('scroll', onScroll);
|
|
if (scrollTimer) {
|
|
clearTimeout(scrollTimer);
|
|
scrollTimer = null;
|
|
}
|
|
};
|
|
}, [container, pdfId, rememberScroll, currentScaleSize, onActivePageChange, pdfDocument, pageGap]);
|
|
|
|
useEffect(() => {
|
|
currentScaleSize.current = scaledSize;
|
|
}, [scaledSize]);
|
|
};
|
|
|
|
export default useScrollSaver;
|