2022-12-19 15:59:14 -08:00
|
|
|
import { useQuery } from '@tanstack/react-query';
|
|
|
|
|
import { controller } from '/@/renderer/api/controller';
|
|
|
|
|
import { queryKeys } from '/@/renderer/api/query-keys';
|
2023-04-27 21:25:57 -07:00
|
|
|
import type { SongListQuery } from '/@/renderer/api/types';
|
|
|
|
|
import { getServerById } from '/@/renderer/store';
|
|
|
|
|
import type { QueryHookArgs } from '/@/renderer/lib/react-query';
|
2022-12-19 15:59:14 -08:00
|
|
|
|
2023-11-01 03:51:03 -07:00
|
|
|
export const useSongList = (args: QueryHookArgs<SongListQuery>, imageSize?: number) => {
|
2023-07-01 19:10:05 -07:00
|
|
|
const { query, options, serverId } = args || {};
|
|
|
|
|
const server = getServerById(serverId);
|
2022-12-19 15:59:14 -08:00
|
|
|
|
2023-07-01 19:10:05 -07:00
|
|
|
return useQuery({
|
2024-02-19 08:53:50 -08:00
|
|
|
cacheTime: 1000 * 60,
|
2023-07-01 19:10:05 -07:00
|
|
|
enabled: !!server?.id,
|
|
|
|
|
queryFn: ({ signal }) => {
|
|
|
|
|
if (!server) throw new Error('Server not found');
|
2023-11-01 03:51:03 -07:00
|
|
|
return controller.getSongList({
|
|
|
|
|
apiClientProps: { server, signal },
|
|
|
|
|
query: { ...query, imageSize },
|
|
|
|
|
});
|
2023-07-01 19:10:05 -07:00
|
|
|
},
|
2023-11-01 03:51:03 -07:00
|
|
|
queryKey: queryKeys.songs.list(server?.id || '', { ...query, imageSize }),
|
2023-07-01 19:10:05 -07:00
|
|
|
...options,
|
|
|
|
|
});
|
2022-12-19 15:59:14 -08:00
|
|
|
};
|