permission.js 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. import router from './router'
  2. import store from './store'
  3. import { Message } from 'element-ui'
  4. import NProgress from 'nprogress' // progress bar
  5. import 'nprogress/nprogress.css' // progress bar style
  6. import { getToken } from '@/utils/auth' // get token from cookie
  7. import getPageTitle from '@/utils/get-page-title'
  8. NProgress.configure({ showSpinner: false }) // NProgress Configuration
  9. const whiteList = ['/login', '/auth-redirect', '/file-manage', '/my-file-manage'] // no redirect whitelist
  10. // store.commit('permission/SET_ROUTES', [])
  11. router.beforeEach(async(to, from, next) => {
  12. // start progress bar
  13. NProgress.start()
  14. // set page title
  15. document.title = getPageTitle(to.meta.title)
  16. // next()
  17. // determine whether the user has logged in
  18. const hasToken = getToken()
  19. if (hasToken) {
  20. if (to.path === '/login') {
  21. // if is logged in, redirect to the home page
  22. next({ path: '/' })
  23. NProgress.done() // hack: https://github.com/PanJiaChen/vue-element-admin/pull/2939
  24. } else {
  25. next()
  26. }
  27. } else {
  28. /* has no token*/
  29. if (whiteList.indexOf(to.path) !== -1) {
  30. // in the free login whitelist, go directly
  31. next()
  32. } else {
  33. // other pages that do not have permission to access are redirected to the login page.
  34. next(`/login?redirect=${to.path}`)
  35. NProgress.done()
  36. }
  37. }
  38. })
  39. router.afterEach(() => {
  40. // finish progress bar
  41. NProgress.done()
  42. })