classes.js 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. import Vue from 'vue';
  2. import Vuex from 'vuex';
  3. import _ from 'lodash';
  4. import axios from 'axios';
  5. Vue.use(Vuex);
  6. const api = {
  7. interface: `/api/train/class`,
  8. divide: `/api/train/class/divide`,
  9. };
  10. const state = () => ({});
  11. const mutations = {};
  12. const actions = {
  13. async query({ commit }, { skip = 0, limit, ...info } = {}) {
  14. const res = await this.$axios.$get(`${api.interface}`, { skip, limit, ...info });
  15. return res;
  16. },
  17. async create({ commit }, payload) {
  18. const res = await this.$axios.$post(`${api.interface}`, payload);
  19. return res;
  20. },
  21. async fetch({ commit }, payload) {
  22. const res = await this.$axios.$get(`${api.interface}/${payload}`);
  23. return res;
  24. },
  25. async update({ commit }, { id, ...data }) {
  26. const res = await this.$axios.$post(`${api.interface}/update/${id}`, data);
  27. return res;
  28. },
  29. async delete({ commit }, payload) {
  30. const res = await this.$axios.$delete(`${api.interface}/${payload}`);
  31. return res;
  32. },
  33. //分班
  34. async divide({ commit }, payload) {
  35. const res = await this.$axios.$post(`${api.divide}`, payload);
  36. return res;
  37. },
  38. async mergeRequest({ commit, dispatch }, { method, data }) {
  39. let toRequest = () => {
  40. let res = [];
  41. res.push(dispatch(method, data));
  42. };
  43. let result = await axios.all(toRequest());
  44. let arr = _.flattenDeep(_.flattenDeep(result).map(item => item.data));
  45. return arr;
  46. },
  47. };
  48. export default {
  49. namespaced: true,
  50. state,
  51. mutations,
  52. actions,
  53. };