1
0
Fork 0
mirror of https://github.com/jellyfin/jellyfin-web synced 2025-03-30 19:56:21 +00:00

apply suggested changes from code review

This commit is contained in:
TheMelmacian 2023-09-12 11:07:27 +02:00
parent 2b547f5a53
commit 5d6756778b
3 changed files with 13 additions and 13 deletions

View file

@ -1,6 +1,7 @@
import { BaseItemDto } from '@jellyfin/sdk/lib/generated-client';
import type { BaseItemDto } from '@jellyfin/sdk/lib/generated-client/models/base-item-dto';
import type { ApiClient } from 'jellyfin-apiclient';
import { ImageType } from '@jellyfin/sdk/lib/generated-client/models/image-type';
import { randomInt } from '../number';
import { ApiClient } from 'jellyfin-apiclient';
export interface ScaleImageOptions {
maxWidth?: number;
@ -19,15 +20,15 @@ export interface ScaleImageOptions {
* Returns undefined if no usable image was found.
* @param apiClient The ApiClient to generate the url.
* @param item The item for which the backdrop image is requested.
* @param random If set to true and the item has more than one backdrop, a random image is returned.
* @param options Optional; allows to scale the backdrop image.
* @param random If set to true and the item has more than one backdrop, a random image is returned.
* @returns The url of the first or a random backdrop image of the provided item.
*/
export const getItemBackdropImageUrl = (apiClient: ApiClient, item: BaseItemDto, random = false, options: ScaleImageOptions = {}): string | undefined => {
export const getItemBackdropImageUrl = (apiClient: ApiClient, item: BaseItemDto, options: ScaleImageOptions = {}, random = false): string | undefined => {
if (item.Id && item.BackdropImageTags?.length) {
const backdropImgIndex = random ? randomInt(0, item.BackdropImageTags.length - 1) : 0;
return apiClient.getScaledImageUrl(item.Id, {
type: 'Backdrop',
type: ImageType.Backdrop,
index: backdropImgIndex,
tag: item.BackdropImageTags[backdropImgIndex],
...options
@ -35,18 +36,17 @@ export const getItemBackdropImageUrl = (apiClient: ApiClient, item: BaseItemDto,
} else if (item.ParentBackdropItemId && item.ParentBackdropImageTags?.length) {
const backdropImgIndex = random ? randomInt(0, item.ParentBackdropImageTags.length - 1) : 0;
return apiClient.getScaledImageUrl(item.ParentBackdropItemId, {
type: 'Backdrop',
type: ImageType.Backdrop,
index: backdropImgIndex,
tag: item.ParentBackdropImageTags[backdropImgIndex],
...options
});
} else if (item.Id && item.ImageTags?.Primary) {
return apiClient.getScaledImageUrl(item.Id, {
type: 'Primary',
type: ImageType.Primary,
tag: item.ImageTags.Primary,
...options
});
} else {
return undefined;
}
return undefined;
};