医疗随访基础模板项目前端

permission.js 2.4KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. import router from './router'
  2. import { ElMessage } from 'element-plus'
  3. import NProgress from 'nprogress'
  4. import 'nprogress/nprogress.css'
  5. import { getToken } from '@/utils/auth'
  6. import { isHttp } from '@/utils/validate'
  7. import { isRelogin } from '@/utils/request'
  8. import useUserStore from '@/store/modules/user'
  9. import useSystemStore from '@/store/main/system/system'
  10. import useSettingsStore from '@/store/modules/settings'
  11. import usePermissionStore from '@/store/modules/permission'
  12. import useSelectStore from '@/store/commonSelect/common'
  13. NProgress.configure({ showSpinner: false })
  14. const whiteList = ['/login', '/register', '/chat/login', '/chat/index', '/chat/user' , '/LeaveAmessage' , '/fillOut']
  15. router.beforeEach((to, from, next) => {
  16. NProgress.start()
  17. if (getToken()) {
  18. to.meta.title && useSettingsStore().setTitle(to.meta.title)
  19. /* has token*/
  20. if (to.path === '/login') {
  21. next({ path: '/' })
  22. NProgress.done()
  23. } else {
  24. if (useUserStore().roles.length === 0) {
  25. isRelogin.show = true
  26. // 判断当前用户是否已拉取完user_info信息
  27. useSystemStore().setSystemConfig().then(() => {
  28. });
  29. useUserStore()
  30. .getInfo()
  31. .then(() => {
  32. isRelogin.show = false
  33. usePermissionStore()
  34. .generateRoutes()
  35. .then( async (accessRoutes) => {
  36. // 根据roles权限生成可访问的路由表
  37. accessRoutes.forEach((route) => {
  38. if (!isHttp(route.path)) {
  39. router.addRoute(route) // 动态添加可访问路由表
  40. }
  41. })
  42. await useSelectStore().getSelectData()
  43. next({ ...to, replace: true }) // hack方法 确保addRoutes已完成
  44. })
  45. })
  46. .catch((err) => {
  47. useUserStore()
  48. .logOut()
  49. .then(() => {
  50. ElMessage.error(err)
  51. next({ path: '/' })
  52. })
  53. })
  54. } else {
  55. next()
  56. }
  57. }
  58. } else {
  59. // 没有token
  60. if (whiteList.indexOf(to.path) !== -1) {
  61. // 在免登录白名单,直接进入
  62. next()
  63. } else {
  64. next(`/login?redirect=${to.fullPath}`) // 否则全部重定向到登录页
  65. NProgress.done()
  66. }
  67. }
  68. })
  69. router.afterEach(() => {
  70. NProgress.done()
  71. })