permission.js 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import Vue from 'vue'
  2. import router from './router'
  3. import store from './store'
  4. import NProgress from 'nprogress' // progress bar
  5. import 'nprogress/nprogress.css' // progress bar style
  6. // import { Message } from 'ant-design-vue'
  7. import { getToken } from "./utils/auth"
  8. NProgress.configure({ showSpinner: false })// NProgress Configuration
  9. const whiteList = ['/login']// no redirect whitelist
  10. router.beforeEach((to, from, next) => {
  11. NProgress.start() // start progress bar
  12. if (getToken()) {
  13. /* has token */
  14. if (to.path === '/login') {
  15. next({ path: '/' })
  16. NProgress.done()
  17. } else {
  18. if (store.getters.roles.length === 0) {
  19. store.dispatch('GetInfo').then(res => {
  20. const roles = ['editor', 'develop']
  21. store.dispatch('GenerateRoutes', { roles }).then(() => { // 根据roles权限生成可访问的路由表
  22. console.log( 'dispatch::GenerateRoutes succeeded.' )
  23. router.addRoutes(store.getters.addRouters) // 动态添加可访问路由表
  24. next({ ...to, replace: true }) // hack方法 确保addRoutes已完成 ,set the replace: true so the navigation will not leave a history record
  25. })
  26. }).catch((err) => {
  27. store.dispatch('FedLogout').then(() => {
  28. console.log(err)
  29. Vue.$message.error('This is a message of error');
  30. })
  31. })
  32. } else {
  33. next()
  34. }
  35. }
  36. } else {
  37. if (whiteList.indexOf(to.path) !== -1) { // 在免登录白名单,直接进入
  38. next()
  39. } else {
  40. next('/login')
  41. NProgress.done() // if current page is login will not trigger afterEach hook, so manually handle it
  42. }
  43. }
  44. })
  45. router.afterEach(() => {
  46. NProgress.done() // finish progress bar
  47. })