Fixed getTracklist with private playlists

This commit is contained in:
RemixDev 2022-03-08 16:11:08 +01:00
parent c02ddfbc9f
commit 141341c28d
1 changed files with 16 additions and 4 deletions

View File

@ -1,5 +1,5 @@
// @ts-expect-error // @ts-expect-error
import { Deezer } from 'deezer-js' import { Deezer, utils as dzUtils } from 'deezer-js'
import { ApiHandler } from '../../../types' import { ApiHandler } from '../../../types'
import { sessionDZ } from '../../../app' import { sessionDZ } from '../../../app'
@ -62,9 +62,20 @@ const handler: ApiHandler['handler'] = async (req, res) => {
break break
} }
default: { default: {
const releaseAPI = await dz.api[`get_${list_type}`](list_id) let releaseAPI, releaseTracksAPI
let releaseTracksAPI = await dz.api[`get_${list_type}_tracks`](list_id) try {
releaseAPI = await dz.api[`get_${list_type}`](list_id)
releaseTracksAPI = await dz.api[`get_${list_type}_tracks`](list_id)
releaseTracksAPI = releaseTracksAPI.data releaseTracksAPI = releaseTracksAPI.data
} catch {
if (list_type === 'playlist') {
releaseAPI = dzUtils.map_playlist(await (await dz.gw.get_playlist_page(list_id)).DATA)
releaseTracksAPI = await dz.gw.get_playlist_tracks(list_id)
} else {
releaseAPI = {}
releaseTracksAPI = []
}
}
const tracks: any[] = [] const tracks: any[] = []
const showdiscs = const showdiscs =
@ -74,6 +85,7 @@ const handler: ApiHandler['handler'] = async (req, res) => {
let current_disk = 0 let current_disk = 0
releaseTracksAPI.forEach((track: any) => { releaseTracksAPI.forEach((track: any) => {
if (track.SNG_ID) track = dzUtils.map_track(track)
if (showdiscs && parseInt(track.disk_number) !== current_disk) { if (showdiscs && parseInt(track.disk_number) !== current_disk) {
current_disk = parseInt(track.disk_number) current_disk = parseInt(track.disk_number)
tracks.push({ type: 'disc_separator', number: current_disk }) tracks.push({ type: 'disc_separator', number: current_disk })