mirror of
https://github.com/jellyfin/jellyfin-web
synced 2025-03-30 19:56:21 +00:00
Add items helper
This commit is contained in:
parent
2e99ca1e4a
commit
d1f2f1caa0
1 changed files with 158 additions and 0 deletions
158
src/utils/items.ts
Normal file
158
src/utils/items.ts
Normal file
|
@ -0,0 +1,158 @@
|
|||
import { ItemFields } from '@jellyfin/sdk/lib/generated-client/models/item-fields';
|
||||
import { ImageType } from '@jellyfin/sdk/lib/generated-client/models/image-type';
|
||||
import { ItemSortBy } from '@jellyfin/sdk/lib/models/api/item-sort-by';
|
||||
import { SortOrder } from '@jellyfin/sdk/lib/generated-client/models/sort-order';
|
||||
import * as userSettings from 'scripts/settings/userSettings';
|
||||
import { EpisodeFilter, FeatureFilters, LibraryViewSettings, ParentId, VideoBasicFilter, ViewMode } from '../types/library';
|
||||
import { LibraryTab } from 'types/libraryTab';
|
||||
|
||||
export const getVideoBasicFilter = (libraryViewSettings: LibraryViewSettings) => {
|
||||
let isHd;
|
||||
|
||||
if (libraryViewSettings.Filters?.VideoBasicFilter?.includes(VideoBasicFilter.IsHD)) {
|
||||
isHd = true;
|
||||
}
|
||||
|
||||
if (libraryViewSettings.Filters?.VideoBasicFilter?.includes(VideoBasicFilter.IsSD)) {
|
||||
isHd = false;
|
||||
}
|
||||
|
||||
return {
|
||||
isHd,
|
||||
is4K: libraryViewSettings.Filters?.VideoBasicFilter?.includes(VideoBasicFilter.Is4K) ?
|
||||
true :
|
||||
undefined,
|
||||
is3D: libraryViewSettings.Filters?.VideoBasicFilter?.includes(VideoBasicFilter.Is3D) ?
|
||||
true :
|
||||
undefined
|
||||
};
|
||||
};
|
||||
|
||||
export const getFeatureFilters = (libraryViewSettings: LibraryViewSettings) => {
|
||||
return {
|
||||
hasSubtitles: libraryViewSettings.Filters?.Features?.includes(FeatureFilters.HasSubtitles) ?
|
||||
true :
|
||||
undefined,
|
||||
hasTrailer: libraryViewSettings.Filters?.Features?.includes(FeatureFilters.HasTrailer) ?
|
||||
true :
|
||||
undefined,
|
||||
hasSpecialFeature: libraryViewSettings.Filters?.Features?.includes(
|
||||
FeatureFilters.HasSpecialFeature
|
||||
) ?
|
||||
true :
|
||||
undefined,
|
||||
hasThemeSong: libraryViewSettings.Filters?.Features?.includes(FeatureFilters.HasThemeSong) ?
|
||||
true :
|
||||
undefined,
|
||||
hasThemeVideo: libraryViewSettings.Filters?.Features?.includes(
|
||||
FeatureFilters.HasThemeVideo
|
||||
) ?
|
||||
true :
|
||||
undefined
|
||||
};
|
||||
};
|
||||
|
||||
export const getEpisodeFilter = (
|
||||
viewType: LibraryTab,
|
||||
libraryViewSettings: LibraryViewSettings
|
||||
) => {
|
||||
return {
|
||||
parentIndexNumber: libraryViewSettings.Filters?.EpisodeFilter?.includes(
|
||||
EpisodeFilter.ParentIndexNumber
|
||||
) ?
|
||||
0 :
|
||||
undefined,
|
||||
isMissing:
|
||||
viewType === LibraryTab.Episodes ?
|
||||
!!libraryViewSettings.Filters?.EpisodeFilter?.includes(EpisodeFilter.IsMissing) :
|
||||
undefined,
|
||||
isUnaired: libraryViewSettings.Filters?.EpisodeFilter?.includes(EpisodeFilter.IsUnaired) ?
|
||||
true :
|
||||
undefined
|
||||
};
|
||||
};
|
||||
|
||||
const getItemFieldsEnum = (
|
||||
viewType: LibraryTab,
|
||||
libraryViewSettings: LibraryViewSettings
|
||||
) => {
|
||||
const itemFields: ItemFields[] = [];
|
||||
|
||||
if (viewType !== LibraryTab.Networks) {
|
||||
itemFields.push(ItemFields.BasicSyncInfo, ItemFields.MediaSourceCount);
|
||||
}
|
||||
|
||||
if (libraryViewSettings.ImageType === ImageType.Primary) {
|
||||
itemFields.push(ItemFields.PrimaryImageAspectRatio);
|
||||
}
|
||||
|
||||
if (viewType === LibraryTab.Networks) {
|
||||
itemFields.push(
|
||||
ItemFields.DateCreated,
|
||||
ItemFields.PrimaryImageAspectRatio
|
||||
);
|
||||
}
|
||||
|
||||
return itemFields;
|
||||
};
|
||||
|
||||
export const getFieldsQuery = (
|
||||
viewType: LibraryTab,
|
||||
libraryViewSettings: LibraryViewSettings
|
||||
) => {
|
||||
return {
|
||||
fields: getItemFieldsEnum(viewType, libraryViewSettings)
|
||||
};
|
||||
};
|
||||
|
||||
export const getLimitQuery = () => {
|
||||
return {
|
||||
limit: userSettings.libraryPageSize(undefined) || undefined
|
||||
};
|
||||
};
|
||||
|
||||
export const getAlphaPickerQuery = (libraryViewSettings: LibraryViewSettings) => {
|
||||
const alphabetValue = libraryViewSettings.Alphabet !== null ?
|
||||
libraryViewSettings.Alphabet : undefined;
|
||||
|
||||
return {
|
||||
nameLessThan: alphabetValue === '#' ? 'A' : undefined,
|
||||
nameStartsWith: alphabetValue === '#' ? undefined : alphabetValue
|
||||
};
|
||||
};
|
||||
|
||||
export const getFiltersQuery = (
|
||||
viewType: LibraryTab,
|
||||
libraryViewSettings: LibraryViewSettings
|
||||
) => {
|
||||
return {
|
||||
...getFeatureFilters(libraryViewSettings),
|
||||
...getEpisodeFilter(viewType, libraryViewSettings),
|
||||
...getVideoBasicFilter(libraryViewSettings),
|
||||
seriesStatus: libraryViewSettings?.Filters?.SeriesStatus,
|
||||
videoTypes: libraryViewSettings?.Filters?.VideoTypes,
|
||||
filters: libraryViewSettings?.Filters?.Status,
|
||||
genres: libraryViewSettings?.Filters?.Genres,
|
||||
officialRatings: libraryViewSettings?.Filters?.OfficialRatings,
|
||||
tags: libraryViewSettings?.Filters?.Tags,
|
||||
years: libraryViewSettings?.Filters?.Years,
|
||||
studioIds: libraryViewSettings?.Filters?.StudioIds
|
||||
};
|
||||
};
|
||||
|
||||
export const getSettingsKey = (viewType: LibraryTab, parentId: ParentId) => {
|
||||
return `${viewType} - ${parentId}`;
|
||||
};
|
||||
|
||||
export const getDefaultLibraryViewSettings = (): LibraryViewSettings => {
|
||||
return {
|
||||
ShowTitle: true,
|
||||
ShowYear: false,
|
||||
ViewMode: ViewMode.GridView,
|
||||
ImageType: ImageType.Primary,
|
||||
CardLayout: false,
|
||||
SortBy: ItemSortBy.SortName,
|
||||
SortOrder: SortOrder.Ascending,
|
||||
StartIndex: 0
|
||||
};
|
||||
};
|
Loading…
Add table
Add a link
Reference in a new issue