-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstore.js
88 lines (82 loc) · 2.23 KB
/
store.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
import Vue from 'vue';
import Vuex from 'vuex';
import authService from './authService';
Vue.use(Vuex);
export default new Vuex.Store({
state: {
loggedUser: null,
searchResults: [],
searchText: '',
searchOrder: '',
},
getters: {
userFavorites(state) {
if (state.loggedUser) {
return state.loggedUser.favorites;
}
return [];
},
},
actions: {
logUserWithToken(context, token) {
// Vérification auprès du serveur si ce token est valide
return authService.authenticate(token)
.then((user) => {
context.commit('changeUser', user);
})
.catch((err) => {
// Token invalide ou expiré, on ne fait rien de spécial ici, si ce n'est que l'utilisateur devra se reconnecter manuellement
// (éventuellement, on peut émettre un warning dans la console pour le dev ...)
console.warn(err);
});
},
logoutUser(context) {
context.commit('changeUser', null);
},
removeFavorite(context, track) {
authService.removeFavorite(track).then(() => {
context.commit('removeUserFavorite', track);
}).catch((err) => {
console.error(err);
});
},
addFavorite(context, track) {
authService.addFavorite(track).then(() => {
context.commit('addUserFavorite', track);
}).catch((err) => {
console.error(err);
});
},
},
mutations: {
changeUser(state, user) {
state.loggedUser = user;
},
removeUserFavorite(state, track) {
const index = state.loggedUser.favorites.findIndex(t => t.id === track.id);
state.loggedUser.favorites.splice(index, 1);
},
addUserFavorite(state, track) {
state.loggedUser.favorites.push({
id: track.id,
title: track.title,
artist: {
name: track.artist.name,
},
album: {
title: track.album.title,
cover: track.album.cover,
},
});
},
setSearchResult(state, searchResults) {
state.searchResults = searchResults;
},
setSearchText(state, searchText) {
state.searchText = searchText;
},
setSearchOrder(state, searchOrder) {
state.searchOrder = searchOrder;
},
},
});