feat: adding a carou for books on going

This commit is contained in:
Julien Froidefond
2025-02-26 09:17:52 +01:00
parent c79214853a
commit 73ef9de818
3 changed files with 40 additions and 6 deletions

View File

@@ -2,10 +2,11 @@ import { HeroSection } from "./HeroSection";
import { MediaRow } from "./MediaRow"; import { MediaRow } from "./MediaRow";
import { KomgaBook, KomgaSeries } from "@/types/komga"; import { KomgaBook, KomgaSeries } from "@/types/komga";
import { RefreshButton } from "@/components/library/RefreshButton"; import { RefreshButton } from "@/components/library/RefreshButton";
import { BookOpenCheck, History, Sparkles, Clock } from "lucide-react"; import { BookOpenCheck, History, Sparkles, Clock, LibraryBig, BookOpen } from "lucide-react";
interface HomeData { interface HomeData {
ongoing: KomgaSeries[]; ongoing: KomgaSeries[];
ongoingBooks: KomgaBook[];
recentlyRead: KomgaBook[]; recentlyRead: KomgaBook[];
onDeck: KomgaBook[]; onDeck: KomgaBook[];
latestSeries: KomgaSeries[]; latestSeries: KomgaSeries[];
@@ -49,7 +50,7 @@ export function HomeContent({ data, refreshHome }: HomeContentProps) {
title: metadata.title, title: metadata.title,
number: metadata.number, number: metadata.number,
}, },
readProgress, readProgress: readProgress || { page: 0 },
media media
})); }));
}; };
@@ -69,9 +70,17 @@ export function HomeContent({ data, refreshHome }: HomeContentProps) {
<div className="space-y-12"> <div className="space-y-12">
{data.ongoing && data.ongoing.length > 0 && ( {data.ongoing && data.ongoing.length > 0 && (
<MediaRow <MediaRow
title="Continuer la lecture" title="Continuer la série"
items={optimizeSeriesData(data.ongoing)} items={optimizeSeriesData(data.ongoing)}
icon={<BookOpenCheck className="w-6 h-6" />} icon={<LibraryBig className="w-6 h-6" />}
/>
)}
{data.ongoingBooks && data.ongoingBooks.length > 0 && (
<MediaRow
title="Continuer la lecture"
items={optimizeBookData(data.ongoingBooks)}
icon={<BookOpen className="w-6 h-6" />}
/> />
)} )}

View File

@@ -18,6 +18,12 @@ interface OptimizedSeries extends BaseItem {
} }
interface OptimizedBook extends BaseItem { interface OptimizedBook extends BaseItem {
readProgress:{
page: number
}
media: {
pagesCount: number;
}
metadata: { metadata: {
title: string; title: string;
number?: string; number?: string;
@@ -128,6 +134,8 @@ function MediaCard({ item, onClick }: MediaCardProps) {
readBooks={isSeries ? item.booksReadCount : undefined} readBooks={isSeries ? item.booksReadCount : undefined}
totalBooks={isSeries ? item.booksCount : undefined} totalBooks={isSeries ? item.booksCount : undefined}
isCompleted={isSeries ? item.booksCount === item.booksReadCount : undefined} isCompleted={isSeries ? item.booksCount === item.booksReadCount : undefined}
currentPage={isSeries ? undefined : item.readProgress?.page}
totalPages={isSeries ? undefined : item.media?.pagesCount}
/> />
{/* Overlay avec les informations au survol */} {/* Overlay avec les informations au survol */}
<div className="absolute inset-0 bg-black/60 opacity-0 hover:opacity-100 transition-opacity duration-200 flex flex-col justify-end p-3"> <div className="absolute inset-0 bg-black/60 opacity-0 hover:opacity-100 transition-opacity duration-200 flex flex-col justify-end p-3">

View File

@@ -7,6 +7,7 @@ import { AppError } from "../../utils/errors";
interface HomeData { interface HomeData {
ongoing: KomgaSeries[]; ongoing: KomgaSeries[];
ongoingBooks: KomgaBook[]; // Nouveau champ
recentlyRead: KomgaBook[]; recentlyRead: KomgaBook[];
onDeck: KomgaBook[]; onDeck: KomgaBook[];
latestSeries: KomgaSeries[]; latestSeries: KomgaSeries[];
@@ -15,8 +16,7 @@ interface HomeData {
export class HomeService extends BaseApiService { export class HomeService extends BaseApiService {
static async getHomeData(): Promise<HomeData> { static async getHomeData(): Promise<HomeData> {
try { try {
// Appels API parallèles avec cache individuel const [ongoing, ongoingBooks, recentlyRead, onDeck, latestSeries] = await Promise.all([
const [ongoing, recentlyRead, onDeck, latestSeries] = await Promise.all([
this.fetchWithCache<LibraryResponse<KomgaSeries>>( this.fetchWithCache<LibraryResponse<KomgaSeries>>(
"home-ongoing", "home-ongoing",
async () => async () =>
@@ -32,6 +32,21 @@ export class HomeService extends BaseApiService {
}), }),
"HOME" "HOME"
), ),
this.fetchWithCache<LibraryResponse<KomgaBook>>(
"home-ongoing-books",
async () =>
this.fetchFromApi<LibraryResponse<KomgaBook>>({
path: "books",
params: {
read_status: "IN_PROGRESS",
sort: "readProgress.readDate,desc",
page: "0",
size: "10",
media_status: "READY",
},
}),
"HOME"
),
this.fetchWithCache<LibraryResponse<KomgaBook>>( this.fetchWithCache<LibraryResponse<KomgaBook>>(
"home-recently-read", "home-recently-read",
async () => async () =>
@@ -75,6 +90,7 @@ export class HomeService extends BaseApiService {
return { return {
ongoing: ongoing.content || [], ongoing: ongoing.content || [],
ongoingBooks: ongoingBooks.content || [], // Nouveau champ
recentlyRead: recentlyRead.content || [], recentlyRead: recentlyRead.content || [],
onDeck: onDeck.content || [], onDeck: onDeck.content || [],
latestSeries: latestSeries.content || [], latestSeries: latestSeries.content || [],
@@ -88,6 +104,7 @@ export class HomeService extends BaseApiService {
try { try {
const cacheService = await getServerCacheService(); const cacheService = await getServerCacheService();
await cacheService.delete("home-ongoing"); await cacheService.delete("home-ongoing");
await cacheService.delete("home-ongoing-books"); // Nouvelle clé de cache
await cacheService.delete("home-recently-read"); await cacheService.delete("home-recently-read");
await cacheService.delete("home-on-deck"); await cacheService.delete("home-on-deck");
await cacheService.delete("home-latest-series"); await cacheService.delete("home-latest-series");