permission.js 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. import router from './router'
  2. import { useNProgress } from '@/hooks/web/useNProgress'
  3. import { useTitle } from '@/hooks/web/useTitle'
  4. import { getToken, getIsEnterprise } from '@/utils/auth'
  5. import { useDictStore } from '@/store/dict'
  6. import { useUserStore } from '@/store/user'
  7. import Confirm from '@/plugins/confirm'
  8. import fullScreen from '@/plugins/fullScreen'
  9. const { start, done } = useNProgress()
  10. // loginType:1.enterprise: 企业路由
  11. // 2.personal: 个人路由
  12. // 3.common: 没有限制访问权限
  13. // 3.personalCommon: 无需登录也能访问的页面
  14. // 路由守卫
  15. router.beforeEach(async (to, from, next) => {
  16. localStorage.setItem('routerTest', to.path) // 本地环境保存代码热更新会导致路径缺失问题
  17. const tokenIndex = getIsEnterprise() ? 1: 2
  18. start()
  19. // loadStart()
  20. if (to.path === '/enterpriseVerification') {
  21. const res = JSON.parse(localStorage.getItem('emailLoginInfo') || "false")
  22. const obj = res ? { ...res, type: 'emailLogin' } : {}
  23. useUserStore().changeRole(obj)
  24. next()
  25. } else if (getToken(tokenIndex)) {
  26. // 强制修改密码
  27. if (localStorage.getItem('entUpdatePassword') === 'needChange') fullScreen('entUpdatePassword')
  28. // 企业信息完成度提示
  29. else if (localStorage.getItem('checkEnterpriseBaseInfoFalseHref')) {
  30. const href = localStorage.getItem('checkEnterpriseBaseInfoFalseHref')
  31. localStorage.setItem('checkEnterpriseBaseInfoFalseHref', '')
  32. localStorage.setItem('checkEnterpriseBaseInfoFalseHref', '')
  33. localStorage.setItem('entUpdatePassword', '')
  34. if (to.path !== '/recruit/enterprise/entInfoSetting') {
  35. setTimeout(() => {
  36. Confirm('系统提示', '企业信息设置未完善,是否前往完善?').then(() => {
  37. window.location.href = href
  38. })
  39. }, 4000)
  40. }
  41. }
  42. if (to.path === '/login') {
  43. next({ path: '/recruitHome' })
  44. } else {
  45. // 获取字典信息
  46. const dictStore = useDictStore()
  47. dictStore.getDictTypeData()
  48. next()
  49. // const type = localStorage.getItem('loginType')
  50. // // 判断企业路由和个人路由,防止互串
  51. // if (!type) { removeToken(); next(`/login?redirect=${to.fullPath}`) }
  52. // else if (to.meta?.loginType === 'common' || to.meta?.loginType === 'personalCommon') next()
  53. // // else if (type === 'enterprise' && to.meta?.loginType === 'personalCommon') next({ path: `/${type}` }) // 企业端不能访问任何个人端路由
  54. // // else if (type === 'personal' && to.meta?.loginType === 'personalCommon') next()
  55. // else if (to.meta?.loginType === type) next()
  56. // else next({ path: `/${type}` })
  57. }
  58. } else {
  59. if (to.meta?.loginType === 'personalCommon' || to.meta?.loginType === 'common') { // 路由不重定向
  60. next()
  61. } else if (to.meta?.loginType === 'enterprise') { // 没有企业token->去个人首页
  62. next({ path: '/recruitHome' })
  63. } else {
  64. next(`/login?redirect=${to.fullPath}`) // 否则全部重定向到登录页
  65. }
  66. }
  67. })
  68. router.afterEach((to) => {
  69. useTitle(to?.meta?.title)
  70. done() // 结束Progress
  71. // loadDone()
  72. })