65 lines
2.1 KiB
JavaScript
65 lines
2.1 KiB
JavaScript
|
import LoadingState from '../../models/loadingStates';
|
||
|
import route from '../../../../../vendor/tightenco/ziggy/src/js/route';
|
||
|
|
||
|
export const serverModule = {
|
||
|
state: {
|
||
|
servers: {},
|
||
|
serverIDs: [],
|
||
|
currentServerID: '',
|
||
|
serverLoadingState: '',
|
||
|
},
|
||
|
mutations: {
|
||
|
setCurrentServer (state, serverID) {
|
||
|
state.currentServerID = serverID;
|
||
|
},
|
||
|
setServers (state, servers) {
|
||
|
servers.forEach(s => {
|
||
|
state.servers[s.identifier] = s;
|
||
|
if (!!state.serverIDs.indexOf(s.identifier)) {
|
||
|
state.serverIDs.push(s.identifier)
|
||
|
}
|
||
|
});
|
||
|
},
|
||
|
removeServer (state, serverID) {
|
||
|
delete state.servers[serverID];
|
||
|
state.serverIDs.remove(serverID);
|
||
|
},
|
||
|
setServerLoadingState (state, s) {
|
||
|
state.serverLoadingState = s;
|
||
|
}
|
||
|
},
|
||
|
actions: {
|
||
|
loadServers({ commit }) {
|
||
|
commit('setServerLoadingState', LoadingState.LOADING);
|
||
|
window.axios.get(route('api.client.index'))
|
||
|
.then(response => {
|
||
|
commit('setServers', response.data.data.map(o => o.attributes));
|
||
|
commit('setServerLoadingState', LoadingState.DONE);
|
||
|
})
|
||
|
.catch(err => {
|
||
|
console.error(err);
|
||
|
const response = err.response;
|
||
|
if (response.data && _.isObject(response.data.errors)) {
|
||
|
response.data.errors.forEach(function (error) {
|
||
|
this.error(error.detail);
|
||
|
});
|
||
|
}
|
||
|
})
|
||
|
.finally(() => {
|
||
|
this.loading = false;
|
||
|
});
|
||
|
},
|
||
|
},
|
||
|
getters: {
|
||
|
currentServer (state) {
|
||
|
return state.servers[state.route.params.serverID];
|
||
|
},
|
||
|
isServersLoading (state) {
|
||
|
return state.serverLoadingState === LoadingState.LOADING;
|
||
|
},
|
||
|
serverList (state) {
|
||
|
return state.serverIDs.map(k => state.servers[k]);
|
||
|
}
|
||
|
}
|
||
|
};
|