Some checks failed
Deploy with Docker Compose / deploy (push) Has been cancelled
- Introduce provider abstraction layer (IMediaProvider, KomgaProvider, StripstreamProvider) - Add Stripstream Librarian as second media provider with full feature parity - Migrate all pages and components from direct Komga services to provider factory - Remove dead service code (BaseApiService, HomeService, LibraryService, SearchService, TestService) - Fix library/series page-based pagination for both providers (Komga 0-indexed, Stripstream 1-indexed) - Fix unread filter and search on library page for both providers - Fix read progress display for Stripstream (reading_status mapping) - Fix series read status (books_read_count) for Stripstream - Add global search with series results for Stripstream (series_hits from Meilisearch) - Fix thumbnail proxy to return 404 gracefully instead of JSON on upstream error - Replace duration-based cache debug detection with x-nextjs-cache header Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
38 lines
973 B
TypeScript
38 lines
973 B
TypeScript
"use client";
|
|
|
|
import { useState } from "react";
|
|
import { useRouter } from "next/navigation";
|
|
import type { NormalizedBook } from "@/lib/providers/types";
|
|
import { PhotoswipeReader } from "./PhotoswipeReader";
|
|
import { Button } from "@/components/ui/button";
|
|
|
|
interface ClientBookReaderProps {
|
|
book: NormalizedBook;
|
|
pages: number[];
|
|
}
|
|
|
|
export function ClientBookReader({ book, pages }: ClientBookReaderProps) {
|
|
const router = useRouter();
|
|
const [isReading, setIsReading] = useState(false);
|
|
|
|
const handleStartReading = () => {
|
|
setIsReading(true);
|
|
};
|
|
|
|
const handleCloseReader = () => {
|
|
setIsReading(false);
|
|
//Fetch une nouvelle route pour rafraichir les différents caches
|
|
router.back();
|
|
};
|
|
|
|
if (isReading) {
|
|
return <PhotoswipeReader book={book} pages={pages} onClose={handleCloseReader} />;
|
|
}
|
|
|
|
return (
|
|
<Button onClick={handleStartReading} size="lg" className="w-full md:w-auto">
|
|
Commencer la lecture
|
|
</Button>
|
|
);
|
|
}
|