owntone-server/web-src/src/pages/PagePodcasts.vue

190 lines
4.9 KiB
Vue
Raw Normal View History

<template>
<div>
<content-with-heading v-if="new_episodes.items.length > 0">
<template #heading-left>
<p class="title is-4">New episodes</p>
</template>
<template #heading-right>
<div class="buttons is-centered">
<a class="button is-small" @click="mark_all_played">
<span class="icon">
<i class="mdi mdi-pencil" />
</span>
<span>Mark All Played</span>
</a>
</div>
</template>
<template #content>
<list-item-track
v-for="track in new_episodes.items"
:key="track.id"
:track="track"
@click="play_track(track)"
>
<template #progress>
2022-02-19 00:18:01 -05:00
<progress-bar :max="track.length_ms" :value="track.seek_ms" />
</template>
<template #actions>
<a @click="open_track_dialog(track)">
<span class="icon has-text-dark"
><i class="mdi mdi-dots-vertical mdi-18px"
/></span>
</a>
</template>
</list-item-track>
<modal-dialog-track
:show="show_track_details_modal"
:track="selected_track"
@close="show_track_details_modal = false"
@play-count-changed="reload_new_episodes"
/>
</template>
</content-with-heading>
<content-with-heading>
<template #heading-left>
<p class="title is-4">Podcasts</p>
<p class="heading">{{ albums.total }} podcasts</p>
</template>
<template #heading-right>
<div class="buttons is-centered">
<a v-if="rss.tracks > 0" class="button is-small" @click="update_rss">
<span class="icon">
<i class="mdi mdi-refresh" />
</span>
<span>Update</span>
</a>
2020-04-12 03:37:32 -04:00
<a class="button is-small" @click="open_add_podcast_dialog">
<span class="icon">
<i class="mdi mdi-rss" />
</span>
2020-04-12 03:37:32 -04:00
<span>Add Podcast</span>
</a>
</div>
</template>
<template #content>
<list-albums
:albums="albums.items"
@play-count-changed="reload_new_episodes()"
@podcast-deleted="reload_podcasts()"
/>
2020-04-12 03:37:32 -04:00
<modal-dialog-add-rss
:show="show_url_modal"
@close="show_url_modal = false"
@podcast-added="reload_podcasts()"
/>
</template>
</content-with-heading>
</div>
</template>
<script>
2022-02-19 00:18:01 -05:00
import ContentWithHeading from '@/templates/ContentWithHeading.vue'
import ListItemTrack from '@/components/ListItemTrack.vue'
import ListAlbums from '@/components/ListAlbums.vue'
import ModalDialogTrack from '@/components/ModalDialogTrack.vue'
import ModalDialogAddRss from '@/components/ModalDialogAddRss.vue'
import ProgressBar from '@/components/ProgressBar.vue'
import * as types from '@/store/mutation_types'
import webapi from '@/webapi'
2022-02-19 00:18:01 -05:00
const dataObject = {
load: function (to) {
return Promise.all([
webapi.library_albums('podcast'),
webapi.library_podcasts_new_episodes()
])
},
set: function (vm, response) {
vm.albums = response[0].data
vm.new_episodes = response[1].data.tracks
}
}
export default {
name: 'PagePodcasts',
2022-02-19 00:18:01 -05:00
components: {
ContentWithHeading,
ListItemTrack,
ListAlbums,
ModalDialogTrack,
ModalDialogAddRss,
ProgressBar
},
beforeRouteEnter(to, from, next) {
dataObject.load(to).then((response) => {
next((vm) => dataObject.set(vm, response))
})
},
beforeRouteUpdate(to, from, next) {
const vm = this
dataObject.load(to).then((response) => {
dataObject.set(vm, response)
next()
})
},
data() {
return {
albums: { items: [] },
new_episodes: { items: [] },
show_url_modal: false,
show_track_details_modal: false,
selected_track: {}
}
},
computed: {
rss() {
return this.$store.state.rss_count
}
},
methods: {
play_track: function (track) {
webapi.player_play_uri(track.uri, false)
},
open_track_dialog: function (track) {
this.selected_track = track
this.show_track_details_modal = true
},
mark_all_played: function () {
this.new_episodes.items.forEach((ep) => {
webapi.library_track_update(ep.id, { play_count: 'increment' })
})
this.new_episodes.items = {}
},
2020-04-12 03:37:32 -04:00
open_add_podcast_dialog: function (item) {
this.show_url_modal = true
},
reload_new_episodes: function () {
webapi.library_podcasts_new_episodes().then(({ data }) => {
this.new_episodes = data.tracks
})
},
reload_podcasts: function () {
webapi.library_albums('podcast').then(({ data }) => {
this.albums = data
this.reload_new_episodes()
})
},
update_rss: function () {
this.$store.commit(types.UPDATE_DIALOG_SCAN_KIND, 'rss')
this.$store.commit(types.SHOW_UPDATE_DIALOG, true)
}
}
}
</script>
<style></style>