remaining.ts 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390
  1. import { Layout } from '@/utils/routerHelper'
  2. const { t } = useI18n()
  3. /**
  4. * redirect: noredirect 当设置 noredirect 的时候该路由在面包屑导航中不可被点击
  5. * name:'router-name' 设定路由的名字,一定要填写不然使用<keep-alive>时会出现各种问题
  6. * meta : {
  7. hidden: true 当设置 true 的时候该路由不会再侧边栏出现 如404,login等页面(默认 false)
  8. alwaysShow: true 当你一个路由下面的 children 声明的路由大于1个时,自动会变成嵌套的模式,
  9. 只有一个时,会将那个子路由当做根路由显示在侧边栏,
  10. 若你想不管路由下面的 children 声明的个数都显示你的根路由,
  11. 你可以设置 alwaysShow: true,这样它就会忽略之前定义的规则,
  12. 一直显示根路由(默认 false)
  13. title: 'title' 设置该路由在侧边栏和面包屑中展示的名字
  14. icon: 'svg-name' 设置该路由的图标
  15. noCache: true 如果设置为true,则不会被 <keep-alive> 缓存(默认 false)
  16. breadcrumb: false 如果设置为false,则不会在breadcrumb面包屑中显示(默认 true)
  17. affix: true 如果设置为true,则会一直固定在tag项中(默认 false)
  18. noTagsView: true 如果设置为true,则不会出现在tag中(默认 false)
  19. activeMenu: '/dashboard' 显示高亮的路由路径
  20. followAuth: '/dashboard' 跟随哪个路由进行权限过滤
  21. canTo: true 设置为true即使hidden为true,也依然可以进行路由跳转(默认 false)
  22. }
  23. **/
  24. const remainingRouter: AppRouteRecordRaw[] = [
  25. {
  26. path: '/redirect',
  27. component: Layout,
  28. name: 'Redirect',
  29. children: [
  30. {
  31. path: '/redirect/:path(.*)',
  32. name: 'Redirect',
  33. component: () => import('@/views/Redirect/Redirect.vue'),
  34. meta: {}
  35. }
  36. ],
  37. meta: {
  38. hidden: true,
  39. noTagsView: true
  40. }
  41. },
  42. {
  43. path: '/',
  44. component: Layout,
  45. redirect: '/index',
  46. name: 'Home',
  47. meta: {},
  48. children: [
  49. {
  50. path: 'index',
  51. component: () => import('@/views/Home/Index.vue'),
  52. name: 'Index',
  53. meta: {
  54. title: t('router.home'),
  55. icon: 'ep:home-filled',
  56. noCache: false,
  57. affix: true
  58. }
  59. }
  60. ]
  61. },
  62. {
  63. path: '/user',
  64. component: Layout,
  65. name: 'UserInfo',
  66. meta: {
  67. hidden: true
  68. },
  69. children: [
  70. {
  71. path: 'profile',
  72. component: () => import('@/views/Profile/Index.vue'),
  73. name: 'Profile',
  74. meta: {
  75. canTo: true,
  76. hidden: true,
  77. noTagsView: false,
  78. icon: 'ep:user',
  79. title: t('common.profile')
  80. }
  81. },
  82. {
  83. path: 'notify-message',
  84. component: () => import('@/views/system/notify/my/index.vue'),
  85. name: 'MyNotifyMessage',
  86. meta: {
  87. canTo: true,
  88. hidden: true,
  89. noTagsView: false,
  90. icon: 'ep:message',
  91. title: '我的站内信'
  92. }
  93. }
  94. ]
  95. },
  96. {
  97. path: '/dict',
  98. component: Layout,
  99. name: 'dict',
  100. meta: {
  101. hidden: true
  102. },
  103. children: [
  104. {
  105. path: 'type/data/:dictType',
  106. component: () => import('@/views/system/dict/data/index.vue'),
  107. name: 'SystemDictData',
  108. meta: {
  109. title: '字典数据',
  110. noCache: true,
  111. hidden: true,
  112. canTo: true,
  113. icon: '',
  114. activeMenu: '/system/dict'
  115. }
  116. }
  117. ]
  118. },
  119. {
  120. path: '/codegen',
  121. component: Layout,
  122. name: 'CodegenEdit',
  123. meta: {
  124. hidden: true
  125. },
  126. children: [
  127. {
  128. path: 'edit',
  129. component: () => import('@/views/infra/codegen/EditTable.vue'),
  130. name: 'InfraCodegenEditTable',
  131. meta: {
  132. noCache: true,
  133. hidden: true,
  134. canTo: true,
  135. icon: 'ep:edit',
  136. title: '修改生成配置',
  137. activeMenu: 'infra/codegen/index'
  138. }
  139. }
  140. ]
  141. },
  142. {
  143. path: '/job',
  144. component: Layout,
  145. name: 'JobL',
  146. meta: {
  147. hidden: true
  148. },
  149. children: [
  150. {
  151. path: 'job-log',
  152. component: () => import('@/views/infra/job/logger/index.vue'),
  153. name: 'InfraJobLog',
  154. meta: {
  155. noCache: true,
  156. hidden: true,
  157. canTo: true,
  158. icon: 'ep:edit',
  159. title: '调度日志',
  160. activeMenu: 'infra/job/index'
  161. }
  162. }
  163. ]
  164. },
  165. {
  166. path: '/login',
  167. component: () => import('@/views/Login/Login.vue'),
  168. name: 'Login',
  169. meta: {
  170. hidden: true,
  171. title: t('router.login'),
  172. noTagsView: true
  173. }
  174. },
  175. {
  176. path: '/sso',
  177. component: () => import('@/views/Login/Login.vue'),
  178. name: 'SSOLogin',
  179. meta: {
  180. hidden: true,
  181. title: t('router.login'),
  182. noTagsView: true
  183. }
  184. },
  185. {
  186. path: '/trade/order',
  187. component: Layout,
  188. name: 'order',
  189. meta: {
  190. hidden: true
  191. },
  192. children: [
  193. {
  194. path: 'detail',
  195. name: 'TradeOrderDetail',
  196. component: () => import('@/views/mall/trade/order/tradeOrderDetail.vue'),
  197. meta: { title: '订单详情', hidden: true }
  198. }
  199. ]
  200. },
  201. {
  202. path: '/403',
  203. component: () => import('@/views/Error/403.vue'),
  204. name: 'NoAccess',
  205. meta: {
  206. hidden: true,
  207. title: '403',
  208. noTagsView: true
  209. }
  210. },
  211. {
  212. path: '/404',
  213. component: () => import('@/views/Error/404.vue'),
  214. name: 'NoFound',
  215. meta: {
  216. hidden: true,
  217. title: '404',
  218. noTagsView: true
  219. }
  220. },
  221. {
  222. path: '/500',
  223. component: () => import('@/views/Error/500.vue'),
  224. name: 'Error',
  225. meta: {
  226. hidden: true,
  227. title: '500',
  228. noTagsView: true
  229. }
  230. },
  231. {
  232. path: '/bpm',
  233. component: Layout,
  234. name: 'bpm',
  235. meta: {
  236. hidden: true
  237. },
  238. children: [
  239. {
  240. path: '/manager/form/edit',
  241. component: () => import('@/views/bpm/form/editor/index.vue'),
  242. name: 'BpmFormEditor',
  243. meta: {
  244. noCache: true,
  245. hidden: true,
  246. canTo: true,
  247. title: '设计流程表单',
  248. activeMenu: '/bpm/manager/form'
  249. }
  250. },
  251. {
  252. path: '/manager/model/edit',
  253. component: () => import('@/views/bpm/model/editor/index.vue'),
  254. name: 'BpmModelEditor',
  255. meta: {
  256. noCache: true,
  257. hidden: true,
  258. canTo: true,
  259. title: '设计流程',
  260. activeMenu: '/bpm/manager/model'
  261. }
  262. },
  263. {
  264. path: '/manager/definition',
  265. component: () => import('@/views/bpm/definition/index.vue'),
  266. name: 'BpmProcessDefinition',
  267. meta: {
  268. noCache: true,
  269. hidden: true,
  270. canTo: true,
  271. title: '流程定义',
  272. activeMenu: '/bpm/manager/model'
  273. }
  274. },
  275. {
  276. path: '/manager/task-assign-rule',
  277. component: () => import('@/views/bpm/taskAssignRule/index.vue'),
  278. name: 'BpmTaskAssignRuleList',
  279. meta: {
  280. noCache: true,
  281. hidden: true,
  282. canTo: true,
  283. title: '任务分配规则'
  284. }
  285. },
  286. {
  287. path: '/process-instance/create',
  288. component: () => import('@/views/bpm/processInstance/create/index.vue'),
  289. name: 'BpmProcessInstanceCreate',
  290. meta: {
  291. noCache: true,
  292. hidden: true,
  293. canTo: true,
  294. title: '发起流程',
  295. activeMenu: 'bpm/processInstance/create'
  296. }
  297. },
  298. {
  299. path: '/process-instance/detail',
  300. component: () => import('@/views/bpm/processInstance/detail/index.vue'),
  301. name: 'BpmProcessInstanceDetail',
  302. meta: {
  303. noCache: true,
  304. hidden: true,
  305. canTo: true,
  306. title: '流程详情',
  307. activeMenu: 'bpm/processInstance/detail'
  308. }
  309. },
  310. {
  311. path: '/bpm/oa/leave/create',
  312. component: () => import('@/views/bpm/oa/leave/create.vue'),
  313. name: 'OALeaveCreate',
  314. meta: {
  315. noCache: true,
  316. hidden: true,
  317. canTo: true,
  318. title: '发起 OA 请假',
  319. activeMenu: '/bpm/oa/leave'
  320. }
  321. },
  322. {
  323. path: '/bpm/oa/leave/detail',
  324. component: () => import('@/views/bpm/oa/leave/detail.vue'),
  325. name: 'OALeaveDetail',
  326. meta: {
  327. noCache: true,
  328. hidden: true,
  329. canTo: true,
  330. title: '查看 OA 请假',
  331. activeMenu: '/bpm/oa/leave'
  332. }
  333. }
  334. ]
  335. },
  336. {
  337. path: '/property',
  338. component: Layout,
  339. name: 'property',
  340. meta: {
  341. hidden: true
  342. },
  343. children: [
  344. {
  345. path: 'value/:propertyId(\\d+)',
  346. component: () => import('@/views/mall/product/property/value/index.vue'),
  347. name: 'ProductPropertyValue',
  348. meta: { title: '商品属性值', icon: '', activeMenu: '/product/property' }
  349. }
  350. ]
  351. },
  352. {
  353. path: '/product',
  354. component: Layout,
  355. name: 'ProductManagementEdit',
  356. meta: {
  357. hidden: true
  358. },
  359. children: [
  360. {
  361. path: 'productManagementAdd', // TODO @puhui999:最好拆成 add 和 edit 两个路由;添加商品;修改商品
  362. component: () => import('@/views/mall/product/spu/addForm.vue'),
  363. name: 'ProductManagementAdd',
  364. meta: {
  365. noCache: true,
  366. hidden: true,
  367. canTo: true,
  368. icon: 'ep:edit',
  369. title: '添加商品',
  370. activeMenu: '/product/product-management'
  371. }
  372. }
  373. ]
  374. }
  375. ]
  376. export default remainingRouter