123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178 |
- import Vue from 'vue'
- import router from './router'
- import store from './store'
- import NProgress from 'nprogress' // progress bar
- import 'nprogress/nprogress.css' // progress bar style
- import notification from 'ant-design-vue/es/notification'
- import { ACCESS_TOKEN,INDEX_MAIN_PAGE_PATH, OAUTH2_LOGIN_PAGE_PATH } from '@/store/mutation-types'
- import { generateIndexRouter, isOAuth2AppEnv } from '@/utils/util'
- // 修改框架
- import cookie from 'js-cookie'
- import { getAction, postAction } from '@api/manage'
- NProgress.configure({ showSpinner: false }) // NProgress Configuration
- const whiteList = ['/user/login', '/user/register', '/user/register-result','/user/alteration'] // no redirect whitelist
- whiteList.push(OAUTH2_LOGIN_PAGE_PATH)
- whiteList.push('/iot-sso/login')
- router.beforeEach((to, from, next) => {
- //update-begin---author:scott ---date:2022-10-13 for:[jeecg-boot/issues/4091]多级路由缓存问题 #4091-----------
- //解决三级菜单无法缓存问题
- //参考: https://blog.csdn.net/qq_37322135/article/details/126013301
- //参考: https://blog.csdn.net/cwin8951/article/details/106644118
- if (to.matched && to.matched.length>3) {
- to.matched.splice(2, to.matched.length - 3)
- }
- // console.log(to)
- // let param = {}
- // param.eiToken = ''
- // param.username = 'iotedge@iotedge.sense'
- // param.token = cookie.get('EIToken')
- // param.username = cookie.get('WISEUser')
- var loginType = cookie.get('EIName')
- console.log(loginType)
- if(loginType === 'sso'){
- store.dispatch('TzLogin').then(response => {
- // 有EIToken
- // console.log('pppppppppresult', response)
- if (to.path === '/user/login' || to.path === OAUTH2_LOGIN_PAGE_PATH) {
- next({ path: INDEX_MAIN_PAGE_PATH })
- NProgress.done()
- } else {
- if (store.getters.permissionList.length === 0) {
- store.dispatch('GetPermissionList').then(res => {
- const menuData = res.result.menu;
- //console.log(res.message)
- if (menuData === null || menuData === "" || menuData === undefined) {
- return;
- }
- let constRoutes = [];
- constRoutes = generateIndexRouter(menuData);
- // 添加主界面路由
- store.dispatch('UpdateAppRouter', { constRoutes }).then(() => {
- // 根据roles权限生成可访问的路由表
- // 动态添加可访问路由表
- router.addRoutes(store.getters.addRouters)
- const redirect = decodeURIComponent(from.query.redirect || to.path)
- if (to.path === redirect) {
- // hack方法 确保addRoutes已完成 ,set the replace: true so the navigation will not leave a history record
- next({ ...to, replace: true })
- } else {
- // 跳转到目的路由
- next({ path: redirect })
- }
- })
- })
- .catch(() => {
- /* notification.error({
- message: '系统提示',
- description: '请求用户信息失败,请重试!'
- })*/
- store.dispatch('Logout').then(() => {
- next({ path: '/user/login', query: { redirect: to.fullPath } })
- })
- })
- } else {
- next()
- }
- }
- })
- .catch(() => {
- // 没有EIToken-判断有没有token
- if (whiteList.indexOf(to.path) !== -1) {
- // 在免登录白名单,如果进入的页面是login页面并且当前是OAuth2app环境,就进入OAuth2登录页面
- if (to.path === '/user/login' && isOAuth2AppEnv()) {
- next({path: OAUTH2_LOGIN_PAGE_PATH})
- } else {
- // 在免登录白名单,直接进入
- next()
- }
- NProgress.done()
- } else {
- // 如果当前是在OAuth2APP环境,就跳转到OAuth2登录页面
- let path = isOAuth2AppEnv() ? OAUTH2_LOGIN_PAGE_PATH : '/user/login'
- next({ path: path, query: { redirect: to.fullPath } })
- NProgress.done() // if current page is login will not trigger afterEach hook, so manually handle it
- }
- })
- }
- if(loginType === 'system' || !loginType){
- if (Vue.ls.get(ACCESS_TOKEN)) {
- /* has token */
- if (to.path === '/user/login' || to.path === OAUTH2_LOGIN_PAGE_PATH) {
- next({ path: INDEX_MAIN_PAGE_PATH })
- NProgress.done()
- } else {
- if (store.getters.permissionList.length === 0) {
- store.dispatch('GetPermissionList').then(res => {
- const menuData = res.result.menu;
- //console.log(res.message)
- if (menuData === null || menuData === "" || menuData === undefined) {
- return;
- }
- let constRoutes = [];
- constRoutes = generateIndexRouter(menuData);
- // 添加主界面路由
- store.dispatch('UpdateAppRouter', { constRoutes }).then(() => {
- // 根据roles权限生成可访问的路由表
- // 动态添加可访问路由表
- router.addRoutes(store.getters.addRouters)
- const redirect = decodeURIComponent(from.query.redirect || to.path)
- if (to.path === redirect) {
- // hack方法 确保addRoutes已完成 ,set the replace: true so the navigation will not leave a history record
- next({ ...to, replace: true })
- } else {
- // 跳转到目的路由
- next({ path: redirect })
- }
- })
- })
- .catch(() => {
- /* notification.error({
- message: '系统提示',
- description: '请求用户信息失败,请重试!'
- })*/
- store.dispatch('Logout').then(() => {
- next({ path: '/user/login', query: { redirect: to.fullPath } })
- })
- })
- } else {
- // 从添加页面跳转其他页面后需要删除联锁添加页面
- if(from.path === '/interLock/summary/add' && !from.meta.replace){
- // 为了解决循环设置了replace
- from.meta.replace = true
- next({ ...to, replace: true })
- from.meta.replace = false
- } else {
- next()
- }
- // next()
- }
- }
- } else {
- if (whiteList.indexOf(to.path) !== -1) {
- // 在免登录白名单,如果进入的页面是login页面并且当前是OAuth2app环境,就进入OAuth2登录页面
- if (to.path === '/user/login' && isOAuth2AppEnv()) {
- next({path: OAUTH2_LOGIN_PAGE_PATH})
- } else {
- // 在免登录白名单,直接进入
- next()
- }
- NProgress.done()
- } else {
- // 如果当前是在OAuth2APP环境,就跳转到OAuth2登录页面
- let path = isOAuth2AppEnv() ? OAUTH2_LOGIN_PAGE_PATH : '/user/login'
- next({ path: path, query: { redirect: to.fullPath } })
- NProgress.done() // if current page is login will not trigger afterEach hook, so manually handle it
- }
- }
- }
- })
- router.afterEach(() => {
- NProgress.done() // finish progress bar
- })
|