mirror of
https://github.com/qier222/YesPlayMusic.git
synced 2025-02-28 20:17:25 +08:00
34 lines
982 B
TypeScript
34 lines
982 B
TypeScript
import { fetchArtist } from '@/web/api/artist'
|
|
import { IpcChannels } from '@/shared/IpcChannels'
|
|
import { CacheAPIs } from '@/shared/CacheAPIs'
|
|
import { ArtistApiNames } from '@/shared/api/Artist'
|
|
import { useQuery } from '@tanstack/react-query'
|
|
import reactQueryClient from '@/web/utils/reactQueryClient'
|
|
|
|
export default function useArtists(ids: number[]) {
|
|
return useQuery(
|
|
['fetchArtists', ids],
|
|
() =>
|
|
Promise.all(
|
|
ids.map(async id => {
|
|
const queryData = reactQueryClient.getQueryData([ArtistApiNames.FetchArtist, { id }])
|
|
if (queryData) return queryData
|
|
|
|
const cache = await window.ipcRenderer?.invoke(IpcChannels.GetApiCache, {
|
|
api: CacheAPIs.Artist,
|
|
query: {
|
|
id,
|
|
},
|
|
})
|
|
if (cache) return cache
|
|
|
|
return fetchArtist({ id })
|
|
})
|
|
),
|
|
{
|
|
enabled: !!ids && ids.length > 0,
|
|
staleTime: 5 * 60 * 1000, // 5 mins
|
|
}
|
|
)
|
|
}
|