index.js 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. import Vue from 'vue';
  2. import Vuex from 'vuex';
  3. import $axios from '@lib/axios.js';
  4. const api = {
  5. integralCreate: '/api/integral/integral/create',
  6. integralUpdate: '/api/integral/integral/update',
  7. integralDelete: '/api/integral/integral/delete',
  8. integralQuery: '/api/integral/integral/query'
  9. };
  10. Vue.use(Vuex);
  11. const state = () => ({
  12. Total: 0,
  13. integralList: [],
  14. dict: {}
  15. });
  16. const actions = {
  17. async integralCreate ({ commit }, payload) {
  18. const res = await $axios.post(api.integralCreate, payload);
  19. return res;
  20. },
  21. async integralUpdate ({ commit }, payload) {
  22. const res = await $axios.post(api.integralUpdate, { ...payload, id: payload._id });
  23. return res;
  24. },
  25. async integralDelete ({ commit }, { id }) {
  26. const res = await $axios.delete(`${api.integralDelete}/${id}`);
  27. return res;
  28. },
  29. async integralQuery ({ commit }, { filter, paging } = {}) {
  30. const res = await $axios.get(api.integralQuery, { ...filter, skip: paging.page, limit: paging.size });
  31. commit('integralQuery', res);
  32. return res;
  33. }
  34. };
  35. const mutations = {
  36. integralQuery(state, payload) {
  37. state.integralList = payload.data;
  38. state.Total = payload.total;
  39. }
  40. };
  41. export default new Vuex.Store({
  42. state,
  43. actions,
  44. mutations,
  45. modules: {}
  46. });