mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-14 08:15:02 -05:00
[web] Fix for Spotify playlist not being played properly
If a Spotify playlist is containing unplayable tracks (e.g., wrong market), the position of the subsequent tracks in the playlist must be changed accordingly. Moreover, the album property was provided for no reason.
This commit is contained in:
parent
3b81791cd0
commit
6a2f85e04f
@ -1,6 +1,12 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="media">
|
<div class="media">
|
||||||
<div class="media-content fd-has-action is-clipped" @click="play">
|
<div
|
||||||
|
class="media-content is-clipped"
|
||||||
|
:class="{
|
||||||
|
'is-clickable': track.is_playable
|
||||||
|
}"
|
||||||
|
@click="play"
|
||||||
|
>
|
||||||
<h1
|
<h1
|
||||||
class="title is-6"
|
class="title is-6"
|
||||||
:class="{ 'has-text-grey-light': !track.is_playable }"
|
:class="{ 'has-text-grey-light': !track.is_playable }"
|
||||||
@ -37,10 +43,12 @@ import webapi from '@/webapi'
|
|||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'SpotifyListItemTrack',
|
name: 'SpotifyListItemTrack',
|
||||||
props: ['track', 'position', 'album', 'context_uri'],
|
props: ['track', 'position', 'context_uri'],
|
||||||
methods: {
|
methods: {
|
||||||
play() {
|
play() {
|
||||||
webapi.player_play_uri(this.context_uri, false, this.position)
|
if (this.track.is_playable) {
|
||||||
|
webapi.player_play_uri(this.context_uri, false, this.position)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -43,7 +43,6 @@
|
|||||||
:key="track.id"
|
:key="track.id"
|
||||||
:track="track"
|
:track="track"
|
||||||
:position="index"
|
:position="index"
|
||||||
:album="album"
|
|
||||||
:context_uri="album.uri"
|
:context_uri="album.uri"
|
||||||
>
|
>
|
||||||
<template #actions>
|
<template #actions>
|
||||||
|
@ -25,11 +25,10 @@
|
|||||||
"
|
"
|
||||||
/>
|
/>
|
||||||
<spotify-list-item-track
|
<spotify-list-item-track
|
||||||
v-for="(track, index) in tracks"
|
v-for="track in tracks"
|
||||||
:key="track.id"
|
:key="track.id"
|
||||||
:track="track"
|
:track="track"
|
||||||
:album="track.album"
|
:position="track.position"
|
||||||
:position="index"
|
|
||||||
:context_uri="playlist.uri"
|
:context_uri="playlist.uri"
|
||||||
>
|
>
|
||||||
<template #actions>
|
<template #actions>
|
||||||
@ -67,6 +66,7 @@ import store from '@/store'
|
|||||||
import webapi from '@/webapi'
|
import webapi from '@/webapi'
|
||||||
import SpotifyWebApi from 'spotify-web-api-js'
|
import SpotifyWebApi from 'spotify-web-api-js'
|
||||||
import { VueEternalLoading } from '@ts-pro/vue-eternal-loading'
|
import { VueEternalLoading } from '@ts-pro/vue-eternal-loading'
|
||||||
|
import { mdiAxe } from '@mdi/js'
|
||||||
|
|
||||||
const PAGE_SIZE = 50
|
const PAGE_SIZE = 50
|
||||||
|
|
||||||
@ -147,12 +147,20 @@ export default {
|
|||||||
},
|
},
|
||||||
|
|
||||||
append_tracks(data) {
|
append_tracks(data) {
|
||||||
this.tracks = data.items.reduce((tracks, item) => {
|
let position = Math.max(
|
||||||
if (item.track) {
|
-1,
|
||||||
tracks.push(item.track)
|
...this.tracks.map((item) => item.position).filter((item) => item)
|
||||||
|
)
|
||||||
|
// Filters out null tracks and adds a position to the playable tracks
|
||||||
|
data.items.forEach((item) => {
|
||||||
|
const track = item.track
|
||||||
|
if (track) {
|
||||||
|
if (track.is_playable) {
|
||||||
|
track.position = ++position
|
||||||
|
}
|
||||||
|
this.tracks.push(track)
|
||||||
}
|
}
|
||||||
return tracks
|
})
|
||||||
}, this.tracks)
|
|
||||||
this.total = data.total
|
this.total = data.total
|
||||||
this.offset += data.limit
|
this.offset += data.limit
|
||||||
},
|
},
|
||||||
|
@ -46,7 +46,6 @@
|
|||||||
v-for="track in tracks.items"
|
v-for="track in tracks.items"
|
||||||
:key="track.id"
|
:key="track.id"
|
||||||
:track="track"
|
:track="track"
|
||||||
:album="track.album"
|
|
||||||
:position="0"
|
:position="0"
|
||||||
:context_uri="track.uri"
|
:context_uri="track.uri"
|
||||||
>
|
>
|
||||||
|
Loading…
Reference in New Issue
Block a user