| | |
| | | |
| | | NProgress.configure({ showSpinner: false }); |
| | | |
| | | const whiteList = ['/homePage']; |
| | | const whiteList = ['/homePage','/fillForm','/checkProgress','/certPdf']; |
| | | |
| | | router.beforeEach((to, from, next) => { |
| | | NProgress.start() |
| | | if (getToken()) { |
| | | to.meta.title && useSettingsStore().setTitle(to.meta.title) |
| | | /* has token*/ |
| | | // if (to.path === '/homePage') { |
| | | // next({ path: '/' }) |
| | | // NProgress.done() |
| | | // } else { |
| | | // if (useUserStore().roles.length === 0) { |
| | | // isRelogin.show = true |
| | | // // 判断当前用户是否已拉取完user_info信息 |
| | | // useUserStore().getInfo().then(() => { |
| | | // isRelogin.show = false |
| | | // usePermissionStore().generateRoutes().then(accessRoutes => { |
| | | // // 根据roles权限生成可访问的路由表 |
| | | // accessRoutes.forEach(route => { |
| | | // if (!isHttp(route.path)) { |
| | | // router.addRoute(route) // 动态添加可访问路由表 |
| | | // } |
| | | // }) |
| | | // next({ ...to, replace: true }) // hack方法 确保addRoutes已完成 |
| | | // }) |
| | | // }).catch(err => { |
| | | // useUserStore().logOut().then(() => { |
| | | // ElMessage.error(err) |
| | | // next({ path: '/' }) |
| | | // }) |
| | | // }) |
| | | // } else { |
| | | if (to.path === '/homePage') { |
| | | next({ path: '/' }) |
| | | NProgress.done() |
| | | } else if (whiteList.indexOf(to.path) !== -1) { |
| | | next() |
| | | } else { |
| | | if (useUserStore().roles.length === 0) { |
| | | isRelogin.show = true |
| | | // 判断当前用户是否已拉取完user_info信息 |
| | | useUserStore().getInfo().then(() => { |
| | | isRelogin.show = false |
| | | usePermissionStore().generateRoutes().then(accessRoutes => { |
| | | // 根据roles权限生成可访问的路由表 |
| | | accessRoutes.forEach(route => { |
| | | if (!isHttp(route.path)) { |
| | | router.addRoute(route) // 动态添加可访问路由表 |
| | | } |
| | | }) |
| | | console.log(to.fullPath,"to.fullPath") |
| | | if (to.fullPath == '/index') { |
| | | // 当登录之后,直接通过ip地址和端口号访问时,跳转到第一个路由页面indexPage |
| | | let pathIndex = '' |
| | | //通过权限返回菜单去避免 如有首页权限 出现//index 情况 |
| | | if (accessRoutes[0].path == '/') { |
| | | pathIndex = accessRoutes[0].path + accessRoutes[0].children[0].path |
| | | } else{ |
| | | pathIndex = accessRoutes[0].path + '/' + accessRoutes[0].children[0].path |
| | | } |
| | | next({ path: pathIndex, replace: true }) // hack方法 确保addRoutes已完成 |
| | | } else { |
| | | next({ ...to, replace: true }) // hack方法 确保addRoutes已完成 |
| | | } |
| | | // next({ ...to, replace: true }) |
| | | // hack方法 确保addRoutes已完成 |
| | | }) |
| | | }).catch(err => { |
| | | useUserStore().logOut().then(() => { |
| | | ElMessage.error(err) |
| | | next({ path: '/' }) |
| | | }) |
| | | }) |
| | | } else { |
| | | next() |
| | | // } |
| | | // } |
| | | } |
| | | } |
| | | } else { |
| | | // 没有token |
| | | if (whiteList.indexOf(to.path) !== -1) { |