永康嘉持电器有限公司前端
小小儁爺
2024-10-10 5a990bb9b8328d23f0aad25c4488f167831a266c
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
import { asyncRoutes, commonRoutes } from '@/router'
/**
 * 把后台返回菜单组装成routes要求的格式
 * @param {*} routes
 * @param {*} menu
 */
export function getAsyncRoutes(routes, menu) {
  // routes 是route.js的路由
  // menu   是接口返回的路由
  // menu  中flag  "0" 表示 true  "1"表示false
  const menuCode = []// 将后端code取出存成数组形式
  const menuNameAndCode = []// 将后端code与name取出存成数组形式
  menu.forEach(item => {
    if (item.flag === '0') {
      menuCode.push(item.code)
      menuNameAndCode.push({ code: item.code, name: item.name, seq: item.seq })
      if (item.children && item.children.length > 0) {
        item.children.forEach(it => {
          if (it.flag === '0') {
            menuCode.push(it.code)
 
            menuNameAndCode.push({ code: it.code, name: it.name, hidden: it.is_show === 'N', buttoncode: it.buttoncode, datacode: it.datacode, seq: it.seq })
          }
        })
      }
    }
  })
 
  const newRoutes = [] // 新路由
 
  routes.forEach(item => {
    if (menuCode.includes(item.code) && item.children && item.children.length > 0) {
      item.meta.title = menuNameAndCode.find(item2 => item2.code === item.code).name
      item.meta.seq = menuNameAndCode.find(item2 => item2.code === item.code).seq
 
      const children = []
      let flag = false// 判断是否有children存进去
      item.children.forEach(it => {
        if (menuCode.includes(it.code)) {
          const t = menuNameAndCode.find(item2 => item2.code === it.code)
          it.meta.title = t.name
          it.meta.buttoncode = t.buttoncode
          it.meta.datacode = t.datacode
          it.hidden = t.hidden
          it.seq = t.seq
          children.push(it)
          flag = true
        }
      })
      if (flag) {
        newRoutes.push({
          alwaysShow: item.alwaysShow,
          code: item.code,
          name: item.name,
          path: item.path,
          redirect: item.redirect,
          component: item.component,
          children: children.sort((a, b) => a.seq - b.seq),
          meta: item.meta
        })
      }
    }
  })
  newRoutes.sort((a, b) => a.meta.seq - b.meta.seq)
 
  newRoutes.push({ path: '*', redirect: '/404', hidden: true })
 
  return newRoutes
}
const state = {
  routes: commonRoutes,
  addRouters: []
}
 
const mutations = {
  SET_ROUTES: (state, routes) => {
    state.addRouters = routes
    state.routes = commonRoutes.concat(routes)
  }
}
 
const actions = {
  generateRoutes({ commit }, menu) {
    return new Promise(resolve => {
      const newRoutes = getAsyncRoutes(asyncRoutes, menu)
 
      commit('SET_ROUTES', newRoutes)
      resolve(newRoutes)
    })
  }
}
 
export default {
  namespaced: true,
  state,
  mutations,
  actions
}