Sid Gifari File Manager
🏠 Root
/
home
/
genremedia08
/
musicjukebox.overlookedtracks.com
/
resources
/
client
/
web-player
/
playlists
/
requests
/
Editing: use-add-tracks-to-playlist.ts
import {BackendResponse} from '@common/http/backend-response/backend-response'; import {Playlist} from '@app/web-player/playlists/playlist'; import {useMutation} from '@tanstack/react-query'; import {toast} from '@common/ui/toast/toast'; import {message} from '@common/i18n/message'; import {apiClient, queryClient} from '@common/http/query-client'; import {Track} from '@app/web-player/tracks/track'; import {showHttpErrorToast} from '@common/utils/http/show-http-error-toast'; interface Response extends BackendResponse { playlist: Playlist; } interface Payload { playlistId: number; tracks: Track[]; } export function useAddTracksToPlaylist() { return useMutation((payload: Payload) => addTracks(payload), { onSuccess: (response, {tracks}) => { toast( message('Added [one 1 track|other :count tracks] to playlist', { values: {count: tracks.length}, }) ); queryClient.invalidateQueries(['playlists', response.playlist.id]); queryClient.invalidateQueries([ 'tracks', 'playlist', response.playlist.id, ]); }, onError: r => showHttpErrorToast(r), }); } function addTracks(payload: Payload): Promise<Response> { const backendPayload = { ids: payload.tracks.map(track => track.id), }; return apiClient .post(`playlists/${payload.playlistId}/tracks/add`, backendPayload) .then(r => r.data); }
Save
Cancel