2018-08-11 01:47:10 -04:00
|
|
|
<template>
|
2020-04-17 10:24:49 -04:00
|
|
|
<section>
|
|
|
|
<div v-if="now_playing.id > 0" class="fd-is-fullheight">
|
|
|
|
<div class="fd-is-expanded">
|
2022-02-19 00:39:14 -05:00
|
|
|
<cover-artwork
|
2020-04-20 13:09:07 -04:00
|
|
|
:artwork_url="now_playing.artwork_url"
|
|
|
|
:artist="now_playing.artist"
|
|
|
|
:album="now_playing.album"
|
2022-02-19 00:39:14 -05:00
|
|
|
class="fd-cover-image fd-has-action"
|
|
|
|
@click="open_dialog(now_playing)"
|
|
|
|
/>
|
2020-04-18 00:57:55 -04:00
|
|
|
</div>
|
2020-04-17 10:24:49 -04:00
|
|
|
<div class="fd-has-padding-left-right">
|
|
|
|
<div class="container has-text-centered">
|
|
|
|
<p class="control has-text-centered fd-progress-now-playing">
|
2022-02-19 00:39:14 -05:00
|
|
|
<Slider
|
2022-04-03 07:54:01 -04:00
|
|
|
ref="slider"
|
2022-02-19 00:39:14 -05:00
|
|
|
v-model="item_progress_ms"
|
2022-02-19 00:18:01 -05:00
|
|
|
:min="0"
|
|
|
|
:max="state.item_length_ms"
|
|
|
|
:step="1000"
|
|
|
|
:tooltips="false"
|
|
|
|
:disabled="state.state === 'stop'"
|
2022-02-19 00:39:14 -05:00
|
|
|
:classes="{ target: 'seek-slider' }"
|
2022-02-19 00:18:01 -05:00
|
|
|
@change="seek"
|
2022-04-03 07:54:01 -04:00
|
|
|
@start="start_dragging"
|
|
|
|
@end="end_dragging"
|
2022-02-19 00:39:14 -05:00
|
|
|
/>
|
2022-02-19 00:18:01 -05:00
|
|
|
<!--range-slider
|
2020-04-17 10:24:49 -04:00
|
|
|
class="seek-slider fd-has-action"
|
|
|
|
min="0"
|
|
|
|
:max="state.item_length_ms"
|
|
|
|
:value="item_progress_ms"
|
|
|
|
:disabled="state.state === 'stop'"
|
|
|
|
step="1000"
|
|
|
|
@change="seek" >
|
2022-02-19 00:18:01 -05:00
|
|
|
</range-slider-->
|
2020-04-17 10:24:49 -04:00
|
|
|
</p>
|
|
|
|
<p class="content">
|
2022-02-19 00:39:14 -05:00
|
|
|
<span
|
2022-04-15 13:47:36 -04:00
|
|
|
>{{ $filters.durationInHours(item_progress_ms) }} /
|
|
|
|
{{ $filters.durationInHours(now_playing.length_ms) }}</span
|
2022-02-19 00:39:14 -05:00
|
|
|
>
|
2020-04-17 10:24:49 -04:00
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="fd-has-padding-left-right">
|
|
|
|
<div class="container has-text-centered fd-has-margin-top">
|
|
|
|
<h1 class="title is-5">
|
|
|
|
{{ now_playing.title }}
|
|
|
|
</h1>
|
|
|
|
<h2 class="title is-6">
|
|
|
|
{{ now_playing.artist }}
|
|
|
|
</h2>
|
2022-02-19 00:39:14 -05:00
|
|
|
<h2
|
|
|
|
v-if="composer"
|
|
|
|
class="subtitle is-6 has-text-grey has-text-weight-bold"
|
|
|
|
>
|
|
|
|
{{ composer }}
|
2020-04-17 10:24:49 -04:00
|
|
|
</h2>
|
|
|
|
<h3 class="subtitle is-6">
|
|
|
|
{{ now_playing.album }}
|
|
|
|
</h3>
|
|
|
|
</div>
|
2020-04-18 00:57:55 -04:00
|
|
|
</div>
|
|
|
|
</div>
|
2020-05-01 03:29:30 -04:00
|
|
|
<div v-else class="fd-is-fullheight">
|
2022-02-19 00:39:14 -05:00
|
|
|
<div
|
|
|
|
class="fd-is-expanded fd-has-padding-left-right"
|
|
|
|
style="flex-direction: column"
|
|
|
|
>
|
2020-05-01 03:29:30 -04:00
|
|
|
<div class="content has-text-centered">
|
2022-02-19 00:39:14 -05:00
|
|
|
<h1 class="title is-5">Your play queue is empty</h1>
|
|
|
|
<p>Add some tracks by browsing your library</p>
|
2020-05-01 03:29:30 -04:00
|
|
|
</div>
|
2018-08-11 01:47:10 -04:00
|
|
|
</div>
|
|
|
|
</div>
|
2022-02-19 00:39:14 -05:00
|
|
|
<modal-dialog-queue-item
|
|
|
|
:show="show_details_modal"
|
|
|
|
:item="selected_item"
|
|
|
|
@close="show_details_modal = false"
|
|
|
|
/>
|
2018-08-11 01:47:10 -04:00
|
|
|
</section>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2022-02-19 00:18:01 -05:00
|
|
|
import ModalDialogQueueItem from '@/components/ModalDialogQueueItem.vue'
|
|
|
|
//import RangeSlider from 'vue-range-slider'
|
|
|
|
import Slider from '@vueform/slider'
|
|
|
|
import CoverArtwork from '@/components/CoverArtwork.vue'
|
2018-08-11 01:47:10 -04:00
|
|
|
import webapi from '@/webapi'
|
|
|
|
import * as types from '@/store/mutation_types'
|
|
|
|
|
|
|
|
export default {
|
|
|
|
name: 'PageNowPlaying',
|
2022-02-19 00:18:01 -05:00
|
|
|
components: {
|
|
|
|
ModalDialogQueueItem,
|
2022-02-19 00:39:14 -05:00
|
|
|
// RangeSlider,
|
2022-02-19 00:18:01 -05:00
|
|
|
Slider,
|
|
|
|
CoverArtwork
|
|
|
|
},
|
2018-08-11 01:47:10 -04:00
|
|
|
|
2022-02-19 00:39:14 -05:00
|
|
|
data() {
|
2018-08-11 01:47:10 -04:00
|
|
|
return {
|
|
|
|
item_progress_ms: 0,
|
2018-11-09 23:16:25 -05:00
|
|
|
interval_id: 0,
|
2022-04-03 07:54:01 -04:00
|
|
|
is_dragged: false,
|
2018-12-16 03:53:57 -05:00
|
|
|
|
|
|
|
show_details_modal: false,
|
|
|
|
selected_item: {}
|
2018-08-11 01:47:10 -04:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
computed: {
|
2022-02-19 00:39:14 -05:00
|
|
|
state() {
|
2018-08-11 01:47:10 -04:00
|
|
|
return this.$store.state.player
|
|
|
|
},
|
2019-08-23 13:40:17 -04:00
|
|
|
|
2022-02-19 00:39:14 -05:00
|
|
|
now_playing() {
|
2018-08-11 01:47:10 -04:00
|
|
|
return this.$store.getters.now_playing
|
2018-10-27 14:57:42 -04:00
|
|
|
},
|
2018-11-09 23:16:25 -05:00
|
|
|
|
2022-02-19 00:39:14 -05:00
|
|
|
settings_option_show_composer_now_playing() {
|
2019-08-23 13:40:17 -04:00
|
|
|
return this.$store.getters.settings_option_show_composer_now_playing
|
|
|
|
},
|
|
|
|
|
2022-02-19 00:39:14 -05:00
|
|
|
settings_option_show_composer_for_genre() {
|
2019-08-23 13:40:17 -04:00
|
|
|
return this.$store.getters.settings_option_show_composer_for_genre
|
|
|
|
},
|
|
|
|
|
2022-02-19 00:39:14 -05:00
|
|
|
composer() {
|
2019-08-23 13:40:17 -04:00
|
|
|
if (this.settings_option_show_composer_now_playing) {
|
2022-02-19 00:39:14 -05:00
|
|
|
if (
|
|
|
|
!this.settings_option_show_composer_for_genre ||
|
|
|
|
(this.now_playing.genre &&
|
|
|
|
this.settings_option_show_composer_for_genre
|
|
|
|
.toLowerCase()
|
2019-08-23 13:40:17 -04:00
|
|
|
.split(',')
|
2022-02-19 00:39:14 -05:00
|
|
|
.findIndex(
|
|
|
|
(elem) =>
|
|
|
|
this.now_playing.genre.toLowerCase().indexOf(elem.trim()) >= 0
|
|
|
|
) >= 0)
|
|
|
|
) {
|
2019-08-23 13:40:17 -04:00
|
|
|
return this.now_playing.composer
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null
|
2018-08-11 01:47:10 -04:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2022-02-19 00:39:14 -05:00
|
|
|
watch: {
|
|
|
|
state() {
|
|
|
|
if (this.interval_id > 0) {
|
|
|
|
window.clearTimeout(this.interval_id)
|
|
|
|
this.interval_id = 0
|
|
|
|
}
|
|
|
|
this.item_progress_ms = this.state.item_progress_ms
|
|
|
|
if (this.state.state === 'play') {
|
|
|
|
this.interval_id = window.setInterval(this.tick, 1000)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2022-04-03 07:54:01 -04:00
|
|
|
mounted: function () {
|
|
|
|
console.log(this.$refs.slider)
|
|
|
|
},
|
|
|
|
|
2022-02-19 00:39:14 -05:00
|
|
|
created() {
|
|
|
|
this.item_progress_ms = this.state.item_progress_ms
|
|
|
|
webapi.player_status().then(({ data }) => {
|
|
|
|
this.$store.commit(types.UPDATE_PLAYER_STATUS, data)
|
|
|
|
if (this.state.state === 'play') {
|
|
|
|
this.interval_id = window.setInterval(this.tick, 1000)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
unmounted() {
|
|
|
|
if (this.interval_id > 0) {
|
|
|
|
window.clearTimeout(this.interval_id)
|
|
|
|
this.interval_id = 0
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2018-08-11 01:47:10 -04:00
|
|
|
methods: {
|
|
|
|
tick: function () {
|
2022-04-03 07:54:01 -04:00
|
|
|
if (!this.is_dragged) {
|
|
|
|
this.item_progress_ms += 1000
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
start_dragging: function () {
|
|
|
|
console.log('@start')
|
|
|
|
this.is_dragged = true
|
|
|
|
},
|
|
|
|
|
|
|
|
end_dragging: function () {
|
|
|
|
console.log('@end')
|
|
|
|
this.is_dragged = false
|
2018-08-11 01:47:10 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
seek: function (newPosition) {
|
2020-04-17 00:23:28 -04:00
|
|
|
webapi.player_seek_to_pos(newPosition).catch(() => {
|
2018-08-11 01:47:10 -04:00
|
|
|
this.item_progress_ms = this.state.item_progress_ms
|
|
|
|
})
|
2018-10-27 14:57:42 -04:00
|
|
|
},
|
|
|
|
|
2018-12-16 03:53:57 -05:00
|
|
|
open_dialog: function (item) {
|
|
|
|
this.selected_item = item
|
|
|
|
this.show_details_modal = true
|
2018-08-11 01:47:10 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
2022-02-19 00:39:14 -05:00
|
|
|
<style></style>
|