fix: use proper reading_status filters for Stripstream home page
All checks were successful
Build, Push & Deploy / deploy (push) Successful in 7m13s

The Stripstream provider was showing all books and first library's series
instead of using reading status filters. Now ongoingBooks uses
reading_status=reading, ongoing series are derived from books being read,
and latest series are fetched from all libraries.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-03-14 21:19:35 +01:00
parent fc9c220be6
commit b0d56948a3

View File

@@ -195,34 +195,58 @@ export class StripstreamProvider implements IMediaProvider {
} }
async getHomeData(): Promise<HomeData> { async getHomeData(): Promise<HomeData> {
// Stripstream has no "in-progress" filter — show recent books and first library's series
const homeOpts = { revalidate: CACHE_TTL_MED, tags: [HOME_CACHE_TAG] }; const homeOpts = { revalidate: CACHE_TTL_MED, tags: [HOME_CACHE_TAG] };
const [booksPage, libraries] = await Promise.allSettled([ const [ongoingBooksPage, booksPage, libraries] = await Promise.allSettled([
this.client.fetch<StripstreamBooksPage>("books", { limit: "10", reading_status: "reading" }, homeOpts),
this.client.fetch<StripstreamBooksPage>("books", { limit: "10" }, homeOpts), this.client.fetch<StripstreamBooksPage>("books", { limit: "10" }, homeOpts),
this.client.fetch<StripstreamLibraryResponse[]>("libraries", undefined, { revalidate: CACHE_TTL_LONG, tags: [HOME_CACHE_TAG] }), this.client.fetch<StripstreamLibraryResponse[]>("libraries", undefined, { revalidate: CACHE_TTL_LONG, tags: [HOME_CACHE_TAG] }),
]); ]);
const ongoingBooks = ongoingBooksPage.status === "fulfilled"
? ongoingBooksPage.value.items.map(StripstreamAdapter.toNormalizedBook)
: [];
const books = booksPage.status === "fulfilled" const books = booksPage.status === "fulfilled"
? booksPage.value.items.map(StripstreamAdapter.toNormalizedBook) ? booksPage.value.items.map(StripstreamAdapter.toNormalizedBook)
: []; : [];
// Derive ongoing series from ongoing books (series with at least one book being read)
const ongoingSeriesNames = ongoingBooksPage.status === "fulfilled"
? Array.from(new Set(ongoingBooksPage.value.items.filter((b) => b.series).map((b) => b.series!)))
: [];
let ongoingSeries: NormalizedSeries[] = [];
let latestSeries: NormalizedSeries[] = []; let latestSeries: NormalizedSeries[] = [];
if (libraries.status === "fulfilled" && libraries.value.length > 0) { if (libraries.status === "fulfilled" && libraries.value.length > 0) {
try { const libs = libraries.value;
const seriesPage = await this.client.fetch<StripstreamSeriesPage>(
`libraries/${libraries.value[0].id}/series`, // Fetch all series from all libraries for ongoing matching and latest
{ limit: "10" }, const allSeriesResults = await Promise.allSettled(
homeOpts libs.map((lib) =>
); this.client.fetch<StripstreamSeriesPage>(
latestSeries = seriesPage.items.map(StripstreamAdapter.toNormalizedSeries); `libraries/${lib.id}/series`,
} catch { { limit: "200" },
latestSeries = []; homeOpts
} )
)
);
const allSeries = allSeriesResults
.filter((r): r is PromiseFulfilledResult<StripstreamSeriesPage> => r.status === "fulfilled")
.flatMap((r) => r.value.items);
ongoingSeries = allSeries
.filter((s) => ongoingSeriesNames.includes(s.name))
.map(StripstreamAdapter.toNormalizedSeries)
.slice(0, 10);
latestSeries = allSeries
.map(StripstreamAdapter.toNormalizedSeries)
.slice(0, 10);
} }
return { return {
ongoing: latestSeries, ongoing: ongoingSeries,
ongoingBooks: books, ongoingBooks: ongoingBooks,
recentlyRead: books, recentlyRead: books,
onDeck: [], onDeck: [],
latestSeries, latestSeries,