mirror of
https://github.com/austinried/subtracks.git
synced 2025-12-27 17:19:27 +01:00
79 lines
2.0 KiB
TypeScript
79 lines
2.0 KiB
TypeScript
import { selectMusic } from '@app/state/music'
|
|
import { selectSettings } from '@app/state/settings'
|
|
import { Store, useStore } from '@app/state/store'
|
|
import { SubsonicApiClient } from '@app/subsonic/api'
|
|
import { GetCoverArtParams } from '@app/subsonic/params'
|
|
import { useCallback } from 'react'
|
|
|
|
export const useArtistInfo = (id: string) => {
|
|
const artistInfo = useStore(useCallback((state: Store) => state.artistInfo[id], [id]))
|
|
const fetchArtistInfo = useStore(selectMusic.fetchArtistInfo)
|
|
|
|
if (!artistInfo) {
|
|
fetchArtistInfo(id)
|
|
}
|
|
|
|
return artistInfo
|
|
}
|
|
|
|
export const useAlbumWithSongs = (id: string) => {
|
|
const album = useStore(useCallback((state: Store) => state.albumsWithSongs[id], [id]))
|
|
const fetchAlbum = useStore(selectMusic.fetchAlbumWithSongs)
|
|
|
|
if (!album) {
|
|
fetchAlbum(id)
|
|
}
|
|
|
|
return album
|
|
}
|
|
|
|
export const usePlaylistWithSongs = (id: string) => {
|
|
const playlist = useStore(useCallback((state: Store) => state.playlistsWithSongs[id], [id]))
|
|
const fetchPlaylist = useStore(selectMusic.fetchPlaylistWithSongs)
|
|
|
|
if (!playlist) {
|
|
fetchPlaylist(id)
|
|
}
|
|
|
|
return playlist
|
|
}
|
|
|
|
export const useStarred = (id: string, type: string) => {
|
|
return useStore(
|
|
useCallback(
|
|
(state: Store) => {
|
|
switch (type) {
|
|
case 'song':
|
|
return state.starredSongs[id]
|
|
case 'album':
|
|
return state.starredAlbums[id]
|
|
case 'artist':
|
|
return state.starredArtists[id]
|
|
default:
|
|
return false
|
|
}
|
|
},
|
|
[type, id],
|
|
),
|
|
)
|
|
}
|
|
|
|
export const useCoverArtUri = () => {
|
|
const server = useStore(selectSettings.activeServer)
|
|
|
|
if (!server) {
|
|
return () => undefined
|
|
}
|
|
|
|
const client = new SubsonicApiClient(server)
|
|
|
|
return (coverArt?: string, size: 'thumbnail' | 'original' = 'thumbnail') => {
|
|
const params: GetCoverArtParams = { id: coverArt || '-1' }
|
|
if (size === 'thumbnail') {
|
|
params.size = '256'
|
|
}
|
|
|
|
return client.getCoverArtUri(params)
|
|
}
|
|
}
|