Add genre list query
This commit is contained in:
parent
b4301486f3
commit
223cf469f4
5 changed files with 69 additions and 4 deletions
|
@ -187,9 +187,14 @@ const getMusicFolderList = async (args: MusicFolderListArgs) => {
|
||||||
return (apiController('getMusicFolderList') as ControllerEndpoint['getMusicFolderList'])?.(args);
|
return (apiController('getMusicFolderList') as ControllerEndpoint['getMusicFolderList'])?.(args);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const getGenreList = async (args: GenreListArgs) => {
|
||||||
|
return (apiController('getGenreList') as ControllerEndpoint['getGenreList'])?.(args);
|
||||||
|
};
|
||||||
|
|
||||||
export const controller = {
|
export const controller = {
|
||||||
getAlbumDetail,
|
getAlbumDetail,
|
||||||
getAlbumList,
|
getAlbumList,
|
||||||
|
getGenreList,
|
||||||
getMusicFolderList,
|
getMusicFolderList,
|
||||||
getSongList,
|
getSongList,
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,10 +1,16 @@
|
||||||
import { jfNormalize } from '/@/renderer/api/jellyfin.api';
|
import { jfNormalize } from '/@/renderer/api/jellyfin.api';
|
||||||
import type { JFAlbum, JFMusicFolderList, JFSong } from '/@/renderer/api/jellyfin.types';
|
import type {
|
||||||
|
JFAlbum,
|
||||||
|
JFGenreList,
|
||||||
|
JFMusicFolderList,
|
||||||
|
JFSong,
|
||||||
|
} from '/@/renderer/api/jellyfin.types';
|
||||||
import { ndNormalize } from '/@/renderer/api/navidrome.api';
|
import { ndNormalize } from '/@/renderer/api/navidrome.api';
|
||||||
import type { NDAlbum, NDSong } from '/@/renderer/api/navidrome.types';
|
import type { NDAlbum, NDGenreList, NDSong } from '/@/renderer/api/navidrome.types';
|
||||||
import { SSMusicFolderList } from '/@/renderer/api/subsonic.types';
|
import { SSGenreList, SSMusicFolderList } from '/@/renderer/api/subsonic.types';
|
||||||
import type {
|
import type {
|
||||||
RawAlbumListResponse,
|
RawAlbumListResponse,
|
||||||
|
RawGenreListResponse,
|
||||||
RawMusicFolderListResponse,
|
RawMusicFolderListResponse,
|
||||||
RawSongListResponse,
|
RawSongListResponse,
|
||||||
} from '/@/renderer/api/types';
|
} from '/@/renderer/api/types';
|
||||||
|
@ -79,8 +85,35 @@ const musicFolderList = (
|
||||||
return musicFolders;
|
return musicFolders;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const genreList = (data: RawGenreListResponse | undefined, server: ServerListItem | null) => {
|
||||||
|
let genres;
|
||||||
|
switch (server?.type) {
|
||||||
|
case 'jellyfin':
|
||||||
|
genres = (data as JFGenreList)?.Items.map((item) => ({
|
||||||
|
id: String(item.Id),
|
||||||
|
name: item.Name,
|
||||||
|
}));
|
||||||
|
break;
|
||||||
|
case 'navidrome':
|
||||||
|
genres = (data as NDGenreList)?.map((item) => ({
|
||||||
|
id: String(item.id),
|
||||||
|
name: item.name,
|
||||||
|
}));
|
||||||
|
break;
|
||||||
|
case 'subsonic':
|
||||||
|
genres = (data as SSGenreList)?.map((item) => ({
|
||||||
|
id: item.value,
|
||||||
|
name: item.value,
|
||||||
|
}));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return genres;
|
||||||
|
};
|
||||||
|
|
||||||
export const normalize = {
|
export const normalize = {
|
||||||
albumList,
|
albumList,
|
||||||
|
genreList,
|
||||||
musicFolderList,
|
musicFolderList,
|
||||||
songList,
|
songList,
|
||||||
};
|
};
|
||||||
|
|
|
@ -39,6 +39,7 @@ import {
|
||||||
SSAlbumArtistList,
|
SSAlbumArtistList,
|
||||||
SSAlbumArtistDetail,
|
SSAlbumArtistDetail,
|
||||||
SSMusicFolderList,
|
SSMusicFolderList,
|
||||||
|
SSGenreList,
|
||||||
} from '/@/renderer/api/subsonic.types';
|
} from '/@/renderer/api/subsonic.types';
|
||||||
|
|
||||||
export enum SortOrder {
|
export enum SortOrder {
|
||||||
|
@ -253,7 +254,7 @@ type BaseEndpointArgs = {
|
||||||
};
|
};
|
||||||
|
|
||||||
// Genre List
|
// Genre List
|
||||||
export type RawGenreListResponse = NDGenreList | JFGenreList | undefined;
|
export type RawGenreListResponse = NDGenreList | JFGenreList | SSGenreList | undefined;
|
||||||
|
|
||||||
export type GenreListResponse = BasePaginatedResponse<Genre[]> | null | undefined;
|
export type GenreListResponse = BasePaginatedResponse<Genre[]> | null | undefined;
|
||||||
|
|
||||||
|
|
1
src/renderer/features/genres/index.ts
Normal file
1
src/renderer/features/genres/index.ts
Normal file
|
@ -0,0 +1 @@
|
||||||
|
export * from './queries/genre-list-query';
|
25
src/renderer/features/genres/queries/genre-list-query.ts
Normal file
25
src/renderer/features/genres/queries/genre-list-query.ts
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
import { useCallback } from 'react';
|
||||||
|
import { useQuery } from '@tanstack/react-query';
|
||||||
|
import { controller } from '/@/renderer/api/controller';
|
||||||
|
import { queryKeys } from '/@/renderer/api/query-keys';
|
||||||
|
import type { GenreListQuery, RawGenreListResponse } from '/@/renderer/api/types';
|
||||||
|
import type { QueryOptions } from '/@/renderer/lib/react-query';
|
||||||
|
import { useCurrentServer } from '/@/renderer/store';
|
||||||
|
import { api } from '/@/renderer/api';
|
||||||
|
|
||||||
|
export const useGenreList = (query: GenreListQuery, options?: QueryOptions) => {
|
||||||
|
const server = useCurrentServer();
|
||||||
|
|
||||||
|
return useQuery({
|
||||||
|
cacheTime: 1000 * 60 * 60 * 2,
|
||||||
|
enabled: !!server?.id,
|
||||||
|
queryFn: ({ signal }) => controller.getGenreList({ query, server, signal }),
|
||||||
|
queryKey: queryKeys.genres.list(server?.id || ''),
|
||||||
|
select: useCallback(
|
||||||
|
(data: RawGenreListResponse | undefined) => api.normalize.genreList(data, server),
|
||||||
|
[server],
|
||||||
|
),
|
||||||
|
staleTime: 1000 * 60 * 60,
|
||||||
|
...options,
|
||||||
|
});
|
||||||
|
};
|
Reference in a new issue