2022-04-15 14:24:30 +00:00
|
|
|
import { secondsToHis } from '@/utils'
|
2022-05-14 18:49:45 +00:00
|
|
|
import { httpService } from '@/services'
|
2022-04-15 14:24:30 +00:00
|
|
|
|
2022-04-24 08:50:45 +00:00
|
|
|
export const albumInfoService = {
|
2022-05-14 18:49:45 +00:00
|
|
|
async fetch (album: Album) {
|
2022-04-15 14:24:30 +00:00
|
|
|
if (!album.info) {
|
2022-05-14 18:49:45 +00:00
|
|
|
const info = await httpService.get<AlbumInfo | null>(`album/${album.id}/info`)
|
2022-04-15 14:24:30 +00:00
|
|
|
|
|
|
|
if (info) {
|
|
|
|
this.merge(album, info)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return album
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Merge the (fetched) info into an album.
|
|
|
|
*/
|
2022-05-14 18:49:45 +00:00
|
|
|
merge: (album: Album, info: AlbumInfo) => {
|
2022-04-15 14:24:30 +00:00
|
|
|
// Convert the duration into i:s
|
|
|
|
if (info.tracks) {
|
|
|
|
info.tracks.forEach(track => {
|
|
|
|
track.fmtLength = secondsToHis(track.length)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// If the album cover is not in a nice form, discard.
|
|
|
|
if (typeof info.image !== 'string') {
|
|
|
|
info.image = null
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set the album cover on the client side to the retrieved image from server.
|
|
|
|
if (info.image) {
|
|
|
|
album.cover = info.image
|
|
|
|
}
|
|
|
|
|
|
|
|
album.info = info
|
|
|
|
}
|
|
|
|
}
|