Update:Remove playlist if all items are removed

This commit is contained in:
advplyr 2022-11-27 12:04:49 -06:00
parent c957e9483e
commit 531f947754
2 changed files with 30 additions and 8 deletions

View File

@ -215,13 +215,19 @@ export default {
this.$axios this.$axios
.$delete(routepath) .$delete(routepath)
.then((updatedPlaylist) => { .then((updatedPlaylist) => {
if (!updatedPlaylist.items.length) {
console.log(`All items removed so playlist was removed`, updatedPlaylist)
this.$toast.success(this.$strings.ToastPlaylistRemoveSuccess)
} else {
console.log(`Item removed from playlist`, updatedPlaylist) console.log(`Item removed from playlist`, updatedPlaylist)
this.$toast.success('Item removed from playlist') this.$toast.success('Item removed from playlist')
this.processingRemove = false }
}) })
.catch((error) => { .catch((error) => {
console.error('Failed to remove item from playlist', error) console.error('Failed to remove item from playlist', error)
this.$toast.error('Failed to remove item from playlist') this.$toast.error('Failed to remove item from playlist')
})
.finally(() => {
this.processingRemove = false this.processingRemove = false
}) })
} }

View File

@ -100,9 +100,18 @@ class PlaylistController {
playlist.removeItem(itemToRemove.libraryItemId, itemToRemove.episodeId) playlist.removeItem(itemToRemove.libraryItemId, itemToRemove.episodeId)
const jsonExpanded = playlist.toJSONExpanded(this.db.libraryItems) const jsonExpanded = playlist.toJSONExpanded(this.db.libraryItems)
// Playlist is removed when there are no items
if (!playlist.items.length) {
Logger.info(`[PlaylistController] Playlist "${playlist.name}" has no more items - removing it`)
await this.db.removeEntity('playlist', playlist.id)
SocketAuthority.emitter('playlist_removed', jsonExpanded)
} else {
await this.db.updateEntity('playlist', playlist) await this.db.updateEntity('playlist', playlist)
SocketAuthority.emitter('playlist_updated', jsonExpanded) SocketAuthority.emitter('playlist_updated', jsonExpanded)
res.json(playlist.toJSONExpanded(this.db.libraryItems)) }
res.json(jsonExpanded)
} }
// POST: api/playlists/:id/batch/add // POST: api/playlists/:id/batch/add
@ -152,9 +161,16 @@ class PlaylistController {
const jsonExpanded = playlist.toJSONExpanded(this.db.libraryItems) const jsonExpanded = playlist.toJSONExpanded(this.db.libraryItems)
if (hasUpdated) { if (hasUpdated) {
// Playlist is removed when there are no items
if (!playlist.items.length) {
Logger.info(`[PlaylistController] Playlist "${playlist.name}" has no more items - removing it`)
await this.db.removeEntity('playlist', playlist.id)
SocketAuthority.emitter('playlist_removed', jsonExpanded)
} else {
await this.db.updateEntity('playlist', playlist) await this.db.updateEntity('playlist', playlist)
SocketAuthority.emitter('playlist_updated', jsonExpanded) SocketAuthority.emitter('playlist_updated', jsonExpanded)
} }
}
res.json(jsonExpanded) res.json(jsonExpanded)
} }