Player: track loading state better

This commit is contained in:
boyska 2023-03-19 12:57:58 +00:00
parent d88b9bdd87
commit 4b6cd1f41e

View file

@ -1,8 +1,9 @@
<template> <template>
<f7-toolbar v-if="status != 'empty'"> <f7-toolbar v-if="status != 'empty'">
<f7-link @click="onPlay" v-if="status == 'pause'">Play</f7-link> <f7-preloader v-if="loading" />
<f7-link @click="onPause" v-if="status == 'playing'">Pause</f7-link> <f7-link @click="onPlay" v-if="!loading && status == 'pause'">Play</f7-link>
{{title}} <f7-link @click="onPause" v-if="!loading && status == 'playing'">Pause</f7-link>
<div slot="before-inner" v-if="!loading">{{title}}</div>
</f7-toolbar> </f7-toolbar>
</template> </template>
@ -28,22 +29,18 @@ export default {
eventBus.$off('play:now') eventBus.$off('play:now')
}, },
mounted () { mounted () {
// XXX: should track events from this.player, instead of manually setting
const t = this const t = this
eventBus.$on('play:now', function (url, metadata) { eventBus.$on('play:now', function (url, metadata) {
t.play(url, metadata) t.play(url, metadata)
t.status = 'playing'
}) })
eventBus.$on('play:pause', function() { eventBus.$on('play:pause', function() {
if(t.player) { if(t.player) {
t.player.pause() t.player.pause()
t.status = 'pause'
} }
}) })
eventBus.$on('play:resume', function() { eventBus.$on('play:resume', function() {
if(t.player) { if(t.player) {
t.player.play() t.player.play()
t.status = 'playing'
} }
}) })
}, },
@ -54,23 +51,36 @@ export default {
onPause() { onPause() {
eventBus.$emit('play:pause') eventBus.$emit('play:pause')
}, },
updateStatusFromPlayer () {
this.status = this.player.playing() ? 'playing' : 'pause'
},
play (url, metadata) { play (url, metadata) {
this.loading = true
let newPlayer = new Howl({ let newPlayer = new Howl({
autoSuspend: false, autoSuspend: false,
html5: true, html5: true,
preload: true, preload: true,
src: [url], src: [url],
}) })
newPlayer.play() const t = this
if(this.player) { for(const eventName of ['pause', 'play', 'end']) {
this.player.stop() newPlayer.on(eventName, this.updateStatusFromPlayer)
} }
this.player = newPlayer newPlayer.once('play', function setProperData() {
if(t.player) {
t.player.stop()
t.player.unload()
}
t.player = newPlayer
if(metadata !== undefined) { if(metadata !== undefined) {
this.title = metadata.title t.title = metadata.title
this.live = metadata.live t.live = metadata.live
} }
t.loading = false
t.updateStatusFromPlayer()
})
newPlayer.play()
}, },
stop () { stop () {
if (this.player) { if (this.player) {