AdaKing88
2023-08-23 9cad48db6c56c3e2796a9d6da881817ef13b6eca
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
import { shallowRef } from 'vue'
// API
import { GetPermission } from "@a/account";
// utils
import { formatTree } from "@/utils/format";
import axios from "axios";
/** 格式化菜单数据生成路由 */
const formatRouterMenu = (data) => {
  // 检测数据是否存在
  if (data && (!Array.isArray(data) || data.length === 0)) {
    return false;
  }
 
  data.map((item) => {
    if (item.component) {
      item.component = shallowRef(require(`@/views/${item.component}`).default)
    }
 
    if (item.children) {
      formatRouterMenu(item.children)
    }
    return item
  })
  return data
  // 监听存储数据
  // const router = [];
  // 遍历菜单
  // data.forEach((item) => {
  // const router_obj = {};
  // // id
  // router_obj.id = item.id;
 
  // // path
  // router_obj.path = item.path;
  // // name
  // router_obj.name = item.router;
  // // hidden
  // if (item.hidden === "1") {
  //   router_obj.hidden = true;
  // }
  // // redirect
  // if (item.redirect) {
  //   router_obj.redirect = item.redirect;
  // }
  // router_obj.parent_id = item.parent_id;
  // if (item.children) {
  //   router_obj.children = item.children;
  // }
 
  // // meta
  // router_obj.meta = {
  //   // 菜单名称
  //   title: item.name,
  //   // 菜单图标
  //   icon: item.icon,
  //   // 是否缓存页面
  //   keepAlive: item.keep === "1" ? true : false,
  // };
  // // component
  // router_obj.component = shallowRef(require(`@/${item.component}`).default);
 
  // 添加至router数组
  // router.push(router_obj);
  // });
  // 树状格式化
  // const tree_data = formatTree(router, "id", "parent_id", "children", 0);
  // 返回数据  
  // return tree_data;
};
 
const state = {
  async_router: [],
  elem: "",
  user_type: "",
};
const getters = {
  async_router: (state) => state.async_router,
  elem: (state) => state.elem,
  user_type: (state) => state.user_type,
};
const mutations = {
  SET_ROUTER(state, value) {
    state.async_router = value;
  },
  SET_ELEM(state, value) {
    state.elem = value;
  },
  SET_USERTYPE(state, value) {
    state.user_type = value;
  },
};
const actions = {
  getRouterAction(context) {
    return new Promise((resolve, reject) => {
      GetPermission()
        .then((response) => {
          const data = response.result.menu;
          let menuData = data.filter(item => {
            return item.route === '1'
          });
          // 格式化菜单数据生成路由
          const menu = formatRouterMenu(menuData);
          // 存储路由
          context.commit("SET_ROUTER", menu);
          // 存储元素权限
          // context.commit("SET_ELEM", response.data.elem_data);
          // 更新用户类型
          // context.commit("SET_USERTYPE", response.data.user);
          resolve(response);
        })
        .catch((error) => {
          reject(error);
        });
    });
  },
};
export default {
  namespaced: true,
  state,
  getters,
  mutations,
  actions,
};