permission.js 1.92 KB
/*
 * @Description:
 * @Autor: renchao
 * @LastEditTime: 2023-05-11 16:19:21
 */
import Vue from 'vue'
import router from "./router";
import store from "./store";
import { getMenuInfo } from "@/api/user";
import NProgress from "nprogress"; // progress bar
import "nprogress/nprogress.css"; // progress bar style
import getPageTitle from "@/utils/get-page-title";
import getTheme from "@/utils/theme";
import Cookies from "js-cookie";
NProgress.configure({ showSpinner: false });
router.beforeEach(async (to, from, next) => {
  getTheme()
  NProgress.start();
  document.title = getPageTitle(to.meta.title);
  let hasAddDict = store.state.dict.addDict;
  let hasUser = store.state.user.hasUser;
  let hasAddRoute = store.state.permission.addRoutes;
  if (to.path == "/sb") {
    localStorage.removeItem("token");
    next();
  } else {
    let code = Vue.prototype.BASE_API.CODE
    //判断token是否存在
    const hasToken = localStorage.getItem("token");
    if (hasToken) {
      //请求用户信息
      if (!hasUser) {
        store.dispatch("user/getUserInfo");
        if (!hasAddDict) {
          await store.dispatch("dict/generateDic");
        }
      }
      if (hasAddRoute) {
        next();
      } else {
        //请求菜单
        const { result: getMenuData } = (await getMenuInfo(code)) || [];
        const accessRoutes = await store.dispatch(
          "permission/generateRoutes",
          getMenuData
        );
        router.addRoutes([
          ...accessRoutes,
          { path: "*", redirect: "/404", hidden: true },
        ]);
        const routeTo = Cookies.get("routerTo");
        if (routeTo && routeTo !== "/" && routeTo !== "/sb") {
          next({ ...to, replace: true });
        } else {
          next()
        }
      }
    } else {
      next('/sb')
    }
  }
  NProgress.done()
});
router.afterEach((to) => {
  // 解决刷新页面报404问题
  Cookies.set("routerTo", to.fullPath);
  NProgress.done();
})