use random backdrop image on item details pages
This commit is contained in:
parent
b735379a78
commit
aec90cbc96
3 changed files with 60 additions and 25 deletions
|
@ -65,6 +65,7 @@
|
||||||
- [Merlin Sievers](https://github.com/dann-merlin)
|
- [Merlin Sievers](https://github.com/dann-merlin)
|
||||||
- [Fishbigger](https://github.com/fishbigger)
|
- [Fishbigger](https://github.com/fishbigger)
|
||||||
- [sleepycatcoding](https://github.com/sleepycatcoding)
|
- [sleepycatcoding](https://github.com/sleepycatcoding)
|
||||||
|
- [TheMelmacian](https://github.com/TheMelmacian)
|
||||||
|
|
||||||
# Emby Contributors
|
# Emby Contributors
|
||||||
|
|
||||||
|
|
|
@ -36,6 +36,7 @@ import Dashboard from '../../utils/dashboard';
|
||||||
import ServerConnections from '../../components/ServerConnections';
|
import ServerConnections from '../../components/ServerConnections';
|
||||||
import confirm from '../../components/confirm/confirm';
|
import confirm from '../../components/confirm/confirm';
|
||||||
import { download } from '../../scripts/fileDownloader';
|
import { download } from '../../scripts/fileDownloader';
|
||||||
|
import { getRandomItemBackdropImageUrl } from '../../utils/url';
|
||||||
|
|
||||||
function autoFocus(container) {
|
function autoFocus(container) {
|
||||||
import('../../components/autoFocuser').then(({ default: autoFocuser }) => {
|
import('../../components/autoFocuser').then(({ default: autoFocuser }) => {
|
||||||
|
@ -501,34 +502,12 @@ function renderDetailPageBackdrop(page, item, apiClient) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
let imgUrl;
|
|
||||||
let hasbackdrop = false;
|
let hasbackdrop = false;
|
||||||
const itemBackdropElement = page.querySelector('#itemBackdrop');
|
const itemBackdropElement = page.querySelector('#itemBackdrop');
|
||||||
|
|
||||||
if (item.BackdropImageTags?.length) {
|
const imgUrl = getRandomItemBackdropImageUrl(apiClient, item, { maxWitdh: dom.getScreenWidth() });
|
||||||
imgUrl = apiClient.getScaledImageUrl(item.Id, {
|
|
||||||
type: 'Backdrop',
|
if (imgUrl) {
|
||||||
maxWidth: dom.getScreenWidth(),
|
|
||||||
index: 0,
|
|
||||||
tag: item.BackdropImageTags[0]
|
|
||||||
});
|
|
||||||
imageLoader.lazyImage(itemBackdropElement, imgUrl);
|
|
||||||
hasbackdrop = true;
|
|
||||||
} else if (item.ParentBackdropItemId && item.ParentBackdropImageTags && item.ParentBackdropImageTags.length) {
|
|
||||||
imgUrl = apiClient.getScaledImageUrl(item.ParentBackdropItemId, {
|
|
||||||
type: 'Backdrop',
|
|
||||||
maxWidth: dom.getScreenWidth(),
|
|
||||||
index: 0,
|
|
||||||
tag: item.ParentBackdropImageTags[0]
|
|
||||||
});
|
|
||||||
imageLoader.lazyImage(itemBackdropElement, imgUrl);
|
|
||||||
hasbackdrop = true;
|
|
||||||
} else if (item.ImageTags?.Primary) {
|
|
||||||
imgUrl = apiClient.getScaledImageUrl(item.Id, {
|
|
||||||
type: 'Primary',
|
|
||||||
maxWidth: dom.getScreenWidth(),
|
|
||||||
tag: item.ImageTags.Primary
|
|
||||||
});
|
|
||||||
imageLoader.lazyImage(itemBackdropElement, imgUrl);
|
imageLoader.lazyImage(itemBackdropElement, imgUrl);
|
||||||
hasbackdrop = true;
|
hasbackdrop = true;
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -1,3 +1,7 @@
|
||||||
|
import { BaseItemDto } from '@jellyfin/sdk/lib/generated-client';
|
||||||
|
import { randomInt } from './number';
|
||||||
|
import { ApiClient } from 'jellyfin-apiclient';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the url search string.
|
* Gets the url search string.
|
||||||
* This function should be used instead of location.search alone, because the app router
|
* This function should be used instead of location.search alone, because the app router
|
||||||
|
@ -33,3 +37,54 @@ export const getParameterByName = (name: string, url?: string | null | undefined
|
||||||
// eslint-disable-next-line compat/compat
|
// eslint-disable-next-line compat/compat
|
||||||
return new URLSearchParams(url).get(name) || '';
|
return new URLSearchParams(url).get(name) || '';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export interface ScaleImageOptions {
|
||||||
|
maxWidth?: number;
|
||||||
|
width?: number;
|
||||||
|
maxHeight?: number;
|
||||||
|
height?: number;
|
||||||
|
fillWidth?: number;
|
||||||
|
fillHeight?: number;
|
||||||
|
quality?: number;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the url of a random backdrop image of an item.
|
||||||
|
* If the item has no backdrop image, the url of a random backdrop image of the parent item is returned.
|
||||||
|
* Falls back to the primary image (cover) of the item, if neither the item nor it's parent have at least one backdrop image.
|
||||||
|
* 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 options Optional; allows to scale the backdrop image.
|
||||||
|
* @returns The url of a random backdrop image of the provided item.
|
||||||
|
*/
|
||||||
|
export const getRandomItemBackdropImageUrl = (apiClient: ApiClient, item: BaseItemDto, options: ScaleImageOptions = {}): string | undefined => {
|
||||||
|
let imgUrl;
|
||||||
|
|
||||||
|
if (item.BackdropImageTags && item.BackdropImageTags.length) {
|
||||||
|
const backdropImgIndex = randomInt(0, item.BackdropImageTags.length - 1);
|
||||||
|
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
||||||
|
imgUrl = apiClient.getScaledImageUrl(item.Id!, {
|
||||||
|
type: 'Backdrop',
|
||||||
|
index: backdropImgIndex,
|
||||||
|
tag: item.BackdropImageTags[backdropImgIndex],
|
||||||
|
...options
|
||||||
|
});
|
||||||
|
} else if (item.ParentBackdropItemId && item.ParentBackdropImageTags && item.ParentBackdropImageTags.length) {
|
||||||
|
const backdropImgIndex = randomInt(0, item.ParentBackdropImageTags.length - 1);
|
||||||
|
imgUrl = apiClient.getScaledImageUrl(item.ParentBackdropItemId, {
|
||||||
|
type: 'Backdrop',
|
||||||
|
index: backdropImgIndex,
|
||||||
|
tag: item.ParentBackdropImageTags[backdropImgIndex],
|
||||||
|
...options
|
||||||
|
});
|
||||||
|
} else if (item.ImageTags && item.ImageTags.Primary) {
|
||||||
|
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
||||||
|
imgUrl = apiClient.getScaledImageUrl(item.Id!, {
|
||||||
|
type: 'Primary',
|
||||||
|
tag: item.ImageTags.Primary,
|
||||||
|
...options
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return imgUrl;
|
||||||
|
};
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue