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.

182 lines
10 KiB

10 months ago
9 months ago
8 months ago
9 months ago
8 months ago
9 months ago
8 months ago
8 months ago
6 months ago
8 months ago
8 months ago
8 months ago
6 months ago
8 months ago
8 months ago
8 months ago
9 months ago
8 months ago
8 months ago
9 months ago
8 months ago
8 months ago
9 months ago
8 months ago
9 months ago
8 months ago
9 months ago
8 months ago
9 months ago
8 months ago
9 months ago
8 months ago
9 months ago
8 months ago
9 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.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  33. { path: "/productionPicking", name: "productionPicking", component: resolve => require(["@/views/modules/production-issue/productionPicking.vue"], resolve), meta: { transition: 'instant', preload: true, keepAlive: true } },
  34. { path: "/productionPickingDetail/:outboundNo", name: "productionPickingDetail", component: resolve => require(["@/views/modules/production-issue/productionPickingDetail.vue"], resolve), meta: { transition: 'instant', preload: true, keepAlive: true } },
  35. //生产退料
  36. {path: "/productionreturn",name: "productionreturn", component: resolve => require(["@/views/modules/production-issue/productionReturnPDA.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  37. {path: '/production-issue/pick/:orderNo',
  38. name: 'ProductionIssuePick',component: resolve => require(["@/views/modules/production-issue/pick.vue"], resolve),
  39. meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  40. // 生产入库
  41. {path: "/productionInbound",name: "productionInbound", component: resolve => require(["@/views/modules/production-inbound/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  42. // 委外
  43. {path: "/outsource",name: "outsource", component: resolve => require(["@/views/modules/outsourcing-issue/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  44. { path: "/outsourcingPicking", name: "outsourcingPicking", component: resolve => require(["@/views/modules/outsourcing-issue/outsourcingPicking.vue"], resolve), meta: { transition: 'instant', preload: true, keepAlive: true } },
  45. { path: "/outsourcingPickingDetail/:outsourcingNo", name: "outsourcingPickingDetail", component: resolve => require(["@/views/modules/outsourcing-issue/outsourcingPickingDetail.vue"], resolve), meta: { transition: 'instant', preload: true, keepAlive: true } },
  46. // 客户订单发货
  47. {path: "/saleshipping",name: "saleshipping", component: resolve => require(["@/views/modules/sales-delivery/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  48. // 销售退货
  49. {path: "/salereturn",name: "salereturn", component: resolve => require(["@/views/modules/sales-return/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  50. {path: "/salereturn-inbound",name: "salereturn-inbound", component: resolve => require(["@/views/modules/sales-return/sales-return-inbound.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  51. {path: "/salereturn-scrap",name: "salereturn-scrap", component: resolve => require(["@/views/modules/sales-return/sales-return-scrap.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  52. // 其他出入库
  53. {path: "/otherinout",name: "otherinout", component: resolve => require(["@/views/modules/other-transaction/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  54. // Material Requisition
  55. {path: "/mrissue",name: "mrissue", component: resolve => require(["@/views/modules/mr-issue/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  56. // 盘点
  57. {path: "/stocktaking",name: "stocktaking", component: resolve => require(["@/views/modules/inventory/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  58. // 运输任务
  59. {path: "/transportation",name: "transportation", component: resolve => require(["@/views/modules/transport-task/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  60. // V2
  61. // handlingunit
  62. /*
  63. {path: "/handlingunit",name: "handlingunit", component: resolve => require(["@/views/modules/v2/handling-unit/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  64. // 生产发料
  65. {path: "/productionissue",name: "productionissue", component: resolve => require(["@/views/modules/v2/production-issue/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  66. // 生产入库
  67. {path: "/productionInbound",name: "productionwhse", component: resolve => require(["@/views/modules/v2/production-receipt/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  68. // 委外
  69. {path: "/outsource",name: "outsource", component: resolve => require(["@/views/modules/v2/outsourcing-issue/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  70. // 客户订单发货
  71. {path: "/saleshipping",name: "saleshipping", component: resolve => require(["@/views/modules/v2/sales-shipment/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  72. // 销售退货
  73. {path: "/salereturn",name: "salereturn", component: resolve => require(["@/views/modules/v2/sales-return/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  74. // 其他出入库
  75. {path: "/otherinout",name: "otherinout", component: resolve => require(["@/views/modules/v2/other-transaction/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  76. // Material Requisition
  77. {path: "/mrissue",name: "mrissue", component: resolve => require(["@/views/modules/v2/mr-issue/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  78. // 盘点
  79. {path: "/stocktaking",name: "stocktaking", component: resolve => require(["@/views/modules/inventory/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  80. // 运输任务
  81. {path: "/transportation",name: "transportation", component: resolve => require(["@/views/modules/v2/transport-task/index.vue"], resolve), meta: { transition: 'instant' ,preload: true,keepAlive: true}},
  82. */
  83. ]
  84. // 主入口路由(需嵌套上左右整体布局)
  85. const mainRoutes = {
  86. path: '/',
  87. component: _import('main'),
  88. name: 'main',
  89. redirect: { name: 'home' },
  90. meta: { title: '主入口整体布局' },
  91. children: [
  92. { path: '/home', component: _import('common/home'), name: 'home', meta: { title: '首页' } },
  93. ],
  94. beforeEnter (to, from, next) {
  95. let token =Vue.cookie.get('token')
  96. if (!token || !/\S/.test(token)) {
  97. clearLoginInfo()
  98. next({ name: 'login' })
  99. }
  100. next()
  101. }
  102. }
  103. const router = new Router({
  104. mode: 'history',
  105. scrollBehavior() {
  106. return { x: 0, y: 0 }
  107. },
  108. isAddDynamicMenuRoutes: false, // 是否已经添加动态(菜单)路由
  109. routes: globalRoutes.concat(mainRoutes)
  110. })
  111. router.beforeEach((to, from, next) => {
  112. // 添加动态(菜单)路由
  113. // 1. 已经添加 or 全局路由, 直接访问
  114. // 2. 获取菜单列表, 添加并保存本地存储
  115. if (router.options.isAddDynamicMenuRoutes || fnCurrentRouteType(to, globalRoutes) === 'global') {
  116. next()
  117. } else {
  118. http({
  119. url: http.adornUrl('/sys/menu/nav'),
  120. method: 'get',
  121. params: {'l': i18n.locale,menuType: "pc"}
  122. }).then(({data}) => {
  123. if (data && data.code === 0) {
  124. //fnAddDynamicMenuRoutes(data.menuList)
  125. //router.options.isAddDynamicMenuRoutes = true
  126. sessionStorage.setItem('menuList', JSON.stringify(data.menuList || '[]'))
  127. sessionStorage.setItem('permissions', JSON.stringify(data.permissions || '[]'))
  128. //next({ ...to, replace: true })
  129. }
  130. }).catch((e) => {
  131. console.log(`%c${e} 请求菜单列表和权限失败,跳转至登录页!!`, 'color:blue')
  132. router.push({ name: 'login' })
  133. })
  134. router.options.isAddDynamicMenuRoutes = true
  135. next({ ...to, replace: true })
  136. }
  137. })
  138. /**
  139. * 判断当前路由类型, global: 全局路由, main: 主入口路由
  140. * @param {*} route 当前路由
  141. */
  142. function fnCurrentRouteType (route, globalRoutes = []) {
  143. var temp = []
  144. for (var i = 0; i < globalRoutes.length; i++) {
  145. if (route.path === globalRoutes[i].path) {
  146. return 'global'
  147. } else if (globalRoutes[i].children && globalRoutes[i].children.length >= 1) {
  148. temp = temp.concat(globalRoutes[i].children)
  149. }
  150. }
  151. return temp.length >= 1 ? fnCurrentRouteType(route, temp) : 'main'
  152. }
  153. export default router