73 lines
2.1 KiB
JavaScript
73 lines
2.1 KiB
JavaScript
import axios from 'axios'
|
|
import logger from '@/logging'
|
|
|
|
export default {
|
|
namespaced: true,
|
|
state: {
|
|
tracks: [],
|
|
count: 0
|
|
},
|
|
mutations: {
|
|
track: (state, {id, value}) => {
|
|
if (value) {
|
|
if (state.tracks.indexOf(id) === -1) {
|
|
state.tracks.push(id)
|
|
}
|
|
} else {
|
|
let i = state.tracks.indexOf(id)
|
|
if (i > -1) {
|
|
state.tracks.splice(i, 1)
|
|
}
|
|
}
|
|
state.count = state.tracks.length
|
|
},
|
|
reset (state) {
|
|
state.tracks = []
|
|
state.count = 0
|
|
}
|
|
},
|
|
getters: {
|
|
isFavorite: (state) => (id) => {
|
|
return state.tracks.indexOf(id) > -1
|
|
}
|
|
},
|
|
actions: {
|
|
set ({commit, state}, {id, value}) {
|
|
commit('track', {id, value})
|
|
if (value) {
|
|
return axios.post('favorites/tracks/', {'track': id}).then((response) => {
|
|
logger.default.info('Successfully added track to favorites')
|
|
}, (response) => {
|
|
logger.default.info('Error while adding track to favorites')
|
|
commit('track', {id, value: !value})
|
|
})
|
|
} else {
|
|
return axios.post('favorites/tracks/remove/', {'track': id}).then((response) => {
|
|
logger.default.info('Successfully removed track from favorites')
|
|
}, (response) => {
|
|
logger.default.info('Error while removing track from favorites')
|
|
commit('track', {id, value: !value})
|
|
})
|
|
}
|
|
},
|
|
toggle ({getters, dispatch}, id) {
|
|
dispatch('set', {id, value: !getters['isFavorite'](id)})
|
|
},
|
|
fetch ({dispatch, state, commit, rootState}, url) {
|
|
// will fetch favorites by batches from API to have them locally
|
|
let params = {
|
|
user: rootState.auth.profile.id,
|
|
page_size: 50,
|
|
ordering: '-creation_date'
|
|
}
|
|
let promise = axios.get('favorites/tracks/all/', {params: params})
|
|
return promise.then((response) => {
|
|
logger.default.info('Fetched a batch of ' + response.data.results.length + ' favorites')
|
|
response.data.results.forEach(result => {
|
|
commit('track', {id: result.track, value: true})
|
|
})
|
|
})
|
|
}
|
|
}
|
|
}
|