diff --git a/src/helpers.ts b/src/helpers.ts index 9003e704..515209e9 100644 --- a/src/helpers.ts +++ b/src/helpers.ts @@ -4,6 +4,7 @@ import type { MediaSourceInfo, BaseItemDto, BaseItemPerson, + TvShowsApiGetEpisodesRequest, UserDto } from '@jellyfin/sdk/lib/generated-client'; import { JellyfinApi } from './components/jellyfinApi'; @@ -590,23 +591,17 @@ export async function getItemsForPlayback( /** * Get episodes for a show given by seriesId - * @param userId - userid to use * @param seriesId - series to look up * @param query - query parameters to build on * @returns episode items */ export function getEpisodesForPlayback( - userId: string, seriesId: string, - query: ItemQuery = {} + query: TvShowsApiGetEpisodesRequest ): Promise { - query.UserId = userId; - query.Fields = requiredItemFields; - query.ExcludeLocationTypes = 'Virtual'; - return JellyfinApi.authAjax(`Shows/${seriesId}/Episodes`, { dataType: 'json', - query: query, + query: { ...query, fields: requiredItemFields }, type: 'GET' }); } @@ -704,15 +699,11 @@ export async function translateRequestedItems( return result; } - const episodesResult = await getEpisodesForPlayback( - userId, - episode.SeriesId, - { - IsMissing: false, - IsVirtualUnaired: false, - UserId: userId - } - ); + const episodesResult = await getEpisodesForPlayback(episode.SeriesId, { + isMissing: false, + seriesId: episode.SeriesId, + userId: userId + }); let foundItem = false;