feat: adding a carou for books on going
This commit is contained in:
@@ -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" />}
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
|
|
||||||
|
|||||||
@@ -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">
|
||||||
|
|||||||
@@ -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");
|
||||||
|
|||||||
Reference in New Issue
Block a user