reacto(bookreader): split and correct bug in thumbnails

This commit is contained in:
Julien Froidefond
2025-02-16 14:29:16 +01:00
parent e2232fc405
commit 9b27c19f52
9 changed files with 640 additions and 543 deletions

View File

@@ -0,0 +1,51 @@
import { useState, useCallback, useEffect } from "react";
import { KomgaBook } from "@/types/komga";
interface UseThumbnailsProps {
book: KomgaBook;
currentPage: number;
}
export const useThumbnails = ({ book, currentPage }: UseThumbnailsProps) => {
const [loadedThumbnails, setLoadedThumbnails] = useState<{ [key: number]: boolean }>({});
const [visibleThumbnails, setVisibleThumbnails] = useState<number[]>([]);
const handleThumbnailLoad = useCallback((pageNumber: number) => {
setLoadedThumbnails((prev) => ({ ...prev, [pageNumber]: true }));
}, []);
const getThumbnailUrl = useCallback(
(pageNumber: number) => {
return `/api/komga/images/books/${book.id}/pages/${pageNumber}/thumbnail`;
},
[book.id]
);
// Mettre à jour les thumbnails visibles autour de la page courante
useEffect(() => {
const windowSize = 10; // Nombre de pages à charger de chaque côté
const start = Math.max(1, currentPage - windowSize);
const end = currentPage + windowSize;
const newVisibleThumbnails = Array.from({ length: end - start + 1 }, (_, i) => start + i);
setVisibleThumbnails(newVisibleThumbnails);
}, [currentPage]);
const scrollToActiveThumbnail = useCallback(() => {
const thumbnail = document.getElementById(`thumbnail-${currentPage}`);
if (thumbnail) {
thumbnail.scrollIntoView({
behavior: "smooth",
block: "nearest",
inline: "center",
});
}
}, [currentPage]);
return {
loadedThumbnails,
handleThumbnailLoad,
getThumbnailUrl,
visibleThumbnails,
scrollToActiveThumbnail,
};
};