You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

176 lines
8.6 KiB

10 months ago
10 months ago
8 months ago
10 months ago
8 months ago
10 months ago
8 months ago
8 months ago
8 months ago
8 months ago
10 months ago
8 months ago
8 months ago
10 months ago
8 months ago
8 months ago
10 months ago
8 months ago
10 months ago
8 months ago
10 months ago
8 months ago
10 months ago
8 months ago
10 months ago
8 months ago
10 months ago
8 months ago
10 months ago
8 months ago
10 months ago
8 months ago
10 months ago
  1. /**
  2. * 全站路由配置
  3. *
  4. * 建议:
  5. * 1. 代码中路由统一使用name属性跳转(不使用path属性)
  6. */
  7. import Vue from 'vue'
  8. import Router from 'vue-router'
  9. import http from '@/utils/httpRequest'
  10. import { isURL } from '@/utils/validate'
  11. import { clearLoginInfo } from '@/utils'
  12. import i18n from '@/i18n/i18n'
  13. Vue.use(Router)
  14. // 拦截重复导航
  15. // 开发环境不使用懒加载, 因为懒加载页面太多的话会造成webpack热更新太慢, 所以只有生产环境使用懒加载
  16. const _import = require('./import-' + process.env.NODE_ENV)
  17. // 全局路由(无需嵌套上左右整体布局)
  18. const globalRoutes = [
  19. { path: '/404', component: _import('common/404'), name: '404', meta: { title: '404未找到' } },
  20. { path: '/login', component: _import('common/login'), name: 'login', meta: { title: '登录' } },
  21. // 采购入库
  22. {path: "/porecv",name: "porecv", component: resolve => require(["@/views/modules/recv/po-recv.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  23. {path: "/recv",name: "recv", component: resolve => require(["@/views/modules/recv/recv.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  24. {path: "/qualifiedStorage",name: "qualifiedStorage", component: resolve => require(["@/views/modules/recv/qualifiedStorage.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  25. {path: "/inspectionResults",name: "inspectionResults",
  26. component: resolve => require(["@/views/modules/recv/inspectionResults.vue"], resolve),
  27. meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  28. // V1
  29. // handlingunit
  30. {path: "/handlingunit",name: "handlingunit", component: resolve => require(["@/views/modules/handling-unit/handling-unit-management.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  31. // 生产发料
  32. {path: "/productionissue",name: "productionissue", component: resolve => require(["@/views/modules/production-issue/production-issue-pda.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  33. {path: '/production-issue/pick/:orderNo',
  34. name: 'ProductionIssuePick',component: resolve => require(["@/views/modules/production-issue/pick.vue"], resolve),
  35. meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  36. // 生产入库
  37. {path: "/productionInbound",name: "productionwhse", component: resolve => require(["@/views/modules/production-inbound/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  38. {path: '/production-inbound/receive/:orderNo',
  39. name: 'ProductionIssuePick',component: resolve => require(["@/views/modules/production-inbound/receive.vue"], resolve),
  40. meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  41. // 委外
  42. {path: "/outsource",name: "outsource", component: resolve => require(["@/views/modules/outsourcing-issue/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  43. // 客户订单发货
  44. {path: "/saleshipping",name: "saleshipping", component: resolve => require(["@/views/modules/sales-delivery/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  45. // 销售退货
  46. {path: "/salereturn",name: "salereturn", component: resolve => require(["@/views/modules/sales-return/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  47. // 其他出入库
  48. {path: "/otherinout",name: "otherinout", component: resolve => require(["@/views/modules/other-transaction/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  49. // Material Requisition
  50. {path: "/mrissue",name: "mrissue", component: resolve => require(["@/views/modules/mr-issue/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  51. // 盘点
  52. {path: "/stocktaking",name: "stocktaking", component: resolve => require(["@/views/modules/inventory/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  53. // 运输任务
  54. {path: "/transportation",name: "transportation", component: resolve => require(["@/views/modules/transport-task/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  55. // V2
  56. // handlingunit
  57. /*
  58. {path: "/handlingunit",name: "handlingunit", component: resolve => require(["@/views/modules/v2/handling-unit/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  59. // 生产发料
  60. {path: "/productionissue",name: "productionissue", component: resolve => require(["@/views/modules/v2/production-issue/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  61. // 生产入库
  62. {path: "/productionInbound",name: "productionwhse", component: resolve => require(["@/views/modules/v2/production-receipt/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  63. // 委外
  64. {path: "/outsource",name: "outsource", component: resolve => require(["@/views/modules/v2/outsourcing-issue/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  65. // 客户订单发货
  66. {path: "/saleshipping",name: "saleshipping", component: resolve => require(["@/views/modules/v2/sales-shipment/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  67. // 销售退货
  68. {path: "/salereturn",name: "salereturn", component: resolve => require(["@/views/modules/v2/sales-return/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  69. // 其他出入库
  70. {path: "/otherinout",name: "otherinout", component: resolve => require(["@/views/modules/v2/other-transaction/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  71. // Material Requisition
  72. {path: "/mrissue",name: "mrissue", component: resolve => require(["@/views/modules/v2/mr-issue/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  73. // 盘点
  74. {path: "/stocktaking",name: "stocktaking", component: resolve => require(["@/views/modules/inventory/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  75. // 运输任务
  76. {path: "/transportation",name: "transportation", component: resolve => require(["@/views/modules/v2/transport-task/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  77. */
  78. ]
  79. // 主入口路由(需嵌套上左右整体布局)
  80. const mainRoutes = {
  81. path: '/',
  82. component: _import('main'),
  83. name: 'main',
  84. redirect: { name: 'home' },
  85. meta: { title: '主入口整体布局' },
  86. children: [
  87. { path: '/home', component: _import('common/home'), name: 'home', meta: { title: '首页' } },
  88. ],
  89. beforeEnter (to, from, next) {
  90. let token =Vue.cookie.get('token')
  91. if (!token || !/\S/.test(token)) {
  92. clearLoginInfo()
  93. next({ name: 'login' })
  94. }
  95. next()
  96. }
  97. }
  98. const router = new Router({
  99. mode: 'history',
  100. scrollBehavior() {
  101. return { x: 0, y: 0 }
  102. },
  103. isAddDynamicMenuRoutes: false, // 是否已经添加动态(菜单)路由
  104. routes: globalRoutes.concat(mainRoutes)
  105. })
  106. router.beforeEach((to, from, next) => {
  107. // 添加动态(菜单)路由
  108. // 1. 已经添加 or 全局路由, 直接访问
  109. // 2. 获取菜单列表, 添加并保存本地存储
  110. if (router.options.isAddDynamicMenuRoutes || fnCurrentRouteType(to, globalRoutes) === 'global') {
  111. next()
  112. } else {
  113. http({
  114. url: http.adornUrl('/sys/menu/nav'),
  115. method: 'get',
  116. params: {'l': i18n.locale,menuType: "pc"}
  117. }).then(({data}) => {
  118. if (data && data.code === 0) {
  119. //fnAddDynamicMenuRoutes(data.menuList)
  120. //router.options.isAddDynamicMenuRoutes = true
  121. sessionStorage.setItem('menuList', JSON.stringify(data.menuList || '[]'))
  122. sessionStorage.setItem('permissions', JSON.stringify(data.permissions || '[]'))
  123. //next({ ...to, replace: true })
  124. }
  125. }).catch((e) => {
  126. console.log(`%c${e} 请求菜单列表和权限失败,跳转至登录页!!`, 'color:blue')
  127. router.push({ name: 'login' })
  128. })
  129. router.options.isAddDynamicMenuRoutes = true
  130. next({ ...to, replace: true })
  131. }
  132. })
  133. /**
  134. * 判断当前路由类型, global: 全局路由, main: 主入口路由
  135. * @param {*} route 当前路由
  136. */
  137. function fnCurrentRouteType (route, globalRoutes = []) {
  138. var temp = []
  139. for (var i = 0; i < globalRoutes.length; i++) {
  140. if (route.path === globalRoutes[i].path) {
  141. return 'global'
  142. } else if (globalRoutes[i].children && globalRoutes[i].children.length >= 1) {
  143. temp = temp.concat(globalRoutes[i].children)
  144. }
  145. }
  146. return temp.length >= 1 ? fnCurrentRouteType(route, temp) : 'main'
  147. }
  148. export default router