nextcloud-app-radio/src/store.js
2020-11-12 11:37:30 +01:00

118 lines
2.6 KiB
JavaScript

import Vue from 'vue'
import Vuex from 'vuex'
import axios from '@nextcloud/axios'
import { generateUrl } from '@nextcloud/router'
Vue.use(Vuex)
export default new Vuex.Store({
state: {
player: {
isPlaying: false,
isBuffering: false,
isMute: false,
isPaused: false,
volume: 0.5,
oldVolume: 0,
title: '',
},
menu: 'top',
},
mutations: {
isPlaying(state, playerState) {
state.player.isPlaying = playerState
},
isBuffering(state, bufferingState) {
state.player.isBuffering = bufferingState
},
changeVolume(state, volume) {
state.player.volume = volume
},
toggleMute(state) {
if (state.player.isMute) {
state.player.volume = state.player.oldVolume
state.player.isMute = false
} else {
state.player.oldVolume = state.player.volume
state.player.volume = 0
state.player.isMute = true
}
},
togglePlay(state) {
if (state.player.isPlaying) {
state.player.isPlaying = false
state.player.isPaused = true
} else {
state.player.isPlaying = true
state.player.isPaused = false
}
},
setTitle(state, title) {
state.player.title = title
},
setMenuState(state, menuState) {
axios.post(generateUrl('/apps/radio/settings/menuState'), {
menuState,
})
},
getMenuState(state) {
axios
.get(generateUrl('/apps/radio/settings/menuState'))
.then(async response => {
const {
data: { menuState: value },
} = response
state.menu = value
})
},
setVolumeState(state, volumeState) {
axios.post(generateUrl('/apps/radio/settings/volumeState'), {
volumeState,
})
},
getVolumeState(state) {
axios
.get(generateUrl('/apps/radio/settings/volumeState'))
.then(async response => {
const {
data: { volumeState: value },
} = response
state.player.volume = value
})
},
},
actions: {
isPlaying(context, playerState) {
context.commit('isPlaying', playerState)
},
isBuffering(context, bufferingState) {
context.commit('isBuffering', bufferingState)
},
changeVolume(context, volume) {
context.commit('changeVolume', volume)
},
toggleMute(context) {
context.commit('toggleMute')
},
togglePlay(context) {
context.commit('togglePlay')
},
setTitle(context, title) {
context.commit('setTitle', title)
},
setMenuState(context, menuState) {
context.commit('setMenuState', menuState)
},
getMenuState(context) {
context.commit('getMenuState')
},
setVolumeState(context, volumeState) {
context.commit('setVolumeState', volumeState)
},
getVolumeState(context) {
context.commit('getVolumeState')
},
},
})