Files
stripstream/src/components/reader/ClientBookReader.tsx
Froidefond Julien 7d0f1c4457
Some checks failed
Deploy with Docker Compose / deploy (push) Has been cancelled
feat: add multi-provider support (Komga + Stripstream Librarian)
- 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>
2026-03-11 11:48:17 +01:00

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>
);
}