2018-08-11 01:47:10 -04:00
|
|
|
<template>
|
|
|
|
<div id="app">
|
|
|
|
<navbar-top />
|
|
|
|
<vue-progress-bar class="fd-progress-bar" />
|
|
|
|
<transition name="fade">
|
|
|
|
<router-view v-show="!show_burger_menu" />
|
|
|
|
</transition>
|
|
|
|
<notifications v-show="!show_burger_menu" />
|
|
|
|
<navbar-bottom v-show="!show_burger_menu" />
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import NavbarTop from '@/components/NavbarTop'
|
|
|
|
import NavbarBottom from '@/components/NavbarBottom'
|
|
|
|
import Notifications from '@/components/Notifications'
|
|
|
|
import webapi from '@/webapi'
|
|
|
|
import * as types from '@/store/mutation_types'
|
|
|
|
import ReconnectingWebSocket from 'reconnectingwebsocket'
|
|
|
|
|
|
|
|
export default {
|
|
|
|
name: 'App',
|
|
|
|
components: { NavbarTop, NavbarBottom, Notifications },
|
|
|
|
template: '<App/>',
|
|
|
|
|
|
|
|
data () {
|
|
|
|
return {
|
2018-10-26 14:14:30 -04:00
|
|
|
token_timer_id: 0,
|
|
|
|
reconnect_attempts: 0
|
2018-08-11 01:47:10 -04:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
computed: {
|
|
|
|
show_burger_menu () {
|
|
|
|
return this.$store.state.show_burger_menu
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
created: function () {
|
|
|
|
this.connect()
|
|
|
|
|
|
|
|
// Start the progress bar on app start
|
|
|
|
this.$Progress.start()
|
|
|
|
|
|
|
|
// Hook the progress bar to start before we move router-view
|
|
|
|
this.$router.beforeEach((to, from, next) => {
|
|
|
|
if (to.meta.show_progress) {
|
|
|
|
if (to.meta.progress !== undefined) {
|
|
|
|
let meta = to.meta.progress
|
|
|
|
this.$Progress.parseMeta(meta)
|
|
|
|
}
|
|
|
|
this.$Progress.start()
|
|
|
|
}
|
|
|
|
next()
|
|
|
|
})
|
|
|
|
|
|
|
|
// hook the progress bar to finish after we've finished moving router-view
|
|
|
|
this.$router.afterEach((to, from) => {
|
|
|
|
if (to.meta.show_progress) {
|
|
|
|
this.$Progress.finish()
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
methods: {
|
|
|
|
connect: function () {
|
|
|
|
this.$store.dispatch('add_notification', { text: 'Connecting to forked-daapd', type: 'info', topic: 'connection', timeout: 2000 })
|
|
|
|
|
|
|
|
webapi.config().then(({ data }) => {
|
|
|
|
this.$store.commit(types.UPDATE_CONFIG, data)
|
|
|
|
this.$store.commit(types.HIDE_SINGLES, data.hide_singles)
|
|
|
|
document.title = data.library_name
|
|
|
|
|
|
|
|
this.open_ws()
|
|
|
|
this.$Progress.finish()
|
|
|
|
}).catch(() => {
|
|
|
|
this.$store.dispatch('add_notification', { text: 'Failed to connect to forked-daapd', type: 'danger', topic: 'connection' })
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
open_ws: function () {
|
|
|
|
if (this.$store.state.config.websocket_port <= 0) {
|
|
|
|
this.$store.dispatch('add_notification', { text: 'Missing websocket port', type: 'danger' })
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
const vm = this
|
|
|
|
|
|
|
|
var socket = new ReconnectingWebSocket(
|
|
|
|
'ws://' + window.location.hostname + ':' + vm.$store.state.config.websocket_port,
|
|
|
|
'notify',
|
2018-10-26 14:14:30 -04:00
|
|
|
{ reconnectInterval: 3000 }
|
2018-08-11 01:47:10 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
socket.onopen = function () {
|
|
|
|
vm.$store.dispatch('add_notification', { text: 'Connection to server established', type: 'primary', topic: 'connection', timeout: 2000 })
|
2018-10-26 14:14:30 -04:00
|
|
|
vm.reconnect_attempts = 0
|
2018-08-11 01:47:10 -04:00
|
|
|
socket.send(JSON.stringify({ notify: ['update', 'player', 'options', 'outputs', 'volume', 'spotify'] }))
|
|
|
|
|
|
|
|
vm.update_outputs()
|
|
|
|
vm.update_player_status()
|
|
|
|
vm.update_library_stats()
|
|
|
|
vm.update_queue()
|
|
|
|
vm.update_spotify()
|
|
|
|
}
|
|
|
|
socket.onclose = function () {
|
|
|
|
// vm.$store.dispatch('add_notification', { text: 'Connection closed', type: 'danger', timeout: 2000 })
|
|
|
|
}
|
|
|
|
socket.onerror = function () {
|
2018-10-26 14:14:30 -04:00
|
|
|
vm.reconnect_attempts++
|
|
|
|
vm.$store.dispatch('add_notification', { text: 'Connection lost. Reconnecting ... (' + vm.reconnect_attempts + ')', type: 'danger', topic: 'connection' })
|
2018-08-11 01:47:10 -04:00
|
|
|
}
|
|
|
|
socket.onmessage = function (response) {
|
|
|
|
var data = JSON.parse(response.data)
|
|
|
|
if (data.notify.includes('update')) {
|
|
|
|
vm.update_library_stats()
|
|
|
|
}
|
|
|
|
if (data.notify.includes('player') || data.notify.includes('options') || data.notify.includes('volume')) {
|
|
|
|
vm.update_player_status()
|
|
|
|
}
|
|
|
|
if (data.notify.includes('outputs') || data.notify.includes('volume')) {
|
|
|
|
vm.update_outputs()
|
|
|
|
}
|
|
|
|
if (data.notify.includes('queue')) {
|
|
|
|
vm.update_queue()
|
|
|
|
}
|
|
|
|
if (data.notify.includes('spotify')) {
|
|
|
|
vm.update_spotify()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
update_library_stats: function () {
|
|
|
|
webapi.library_stats().then(({ data }) => {
|
|
|
|
this.$store.commit(types.UPDATE_LIBRARY_STATS, data)
|
|
|
|
})
|
|
|
|
webapi.library_count('media_kind is audiobook').then(({ data }) => {
|
|
|
|
this.$store.commit(types.UPDATE_LIBRARY_AUDIOBOOKS_COUNT, data)
|
|
|
|
})
|
|
|
|
webapi.library_count('media_kind is podcast').then(({ data }) => {
|
|
|
|
this.$store.commit(types.UPDATE_LIBRARY_PODCASTS_COUNT, data)
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
update_outputs: function () {
|
|
|
|
webapi.outputs().then(({ data }) => {
|
|
|
|
this.$store.commit(types.UPDATE_OUTPUTS, data.outputs)
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
update_player_status: function () {
|
|
|
|
webapi.player_status().then(({ data }) => {
|
|
|
|
this.$store.commit(types.UPDATE_PLAYER_STATUS, data)
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
update_queue: function () {
|
|
|
|
webapi.queue().then(({ data }) => {
|
|
|
|
this.$store.commit(types.UPDATE_QUEUE, data)
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
update_spotify: function () {
|
|
|
|
webapi.spotify().then(({ data }) => {
|
|
|
|
this.$store.commit(types.UPDATE_SPOTIFY, data)
|
|
|
|
|
|
|
|
if (this.token_timer_id > 0) {
|
|
|
|
window.clearTimeout(this.token_timer_id)
|
|
|
|
this.token_timer_id = 0
|
|
|
|
}
|
|
|
|
if (data.webapi_token_expires_in > 0 && data.webapi_token) {
|
|
|
|
this.token_timer_id = window.setTimeout(this.update_spotify, 1000 * data.webapi_token_expires_in)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
watch: {
|
|
|
|
'$route' (to, from) {
|
|
|
|
this.$store.commit(types.SHOW_BURGER_MENU, false)
|
|
|
|
},
|
|
|
|
'show_burger_menu' () {
|
|
|
|
if (this.show_burger_menu) {
|
|
|
|
document.querySelector('html').classList.add('is-clipped')
|
|
|
|
} else {
|
|
|
|
document.querySelector('html').classList.remove('is-clipped')
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style>
|
|
|
|
</style>
|