progressGuard.ts 591 B

12345678910111213141516171819202122
  1. import type { Router } from 'vue-router';
  2. import { useTransitionSetting } from '/@/hooks/setting/useTransitionSetting';
  3. import nProgress from 'nprogress';
  4. import { unref } from 'vue';
  5. export function createProgressGuard(router: Router) {
  6. const { getOpenNProgress } = useTransitionSetting();
  7. router.beforeEach(async (to) => {
  8. if (to.meta.loaded) return true;
  9. unref(getOpenNProgress) && nProgress.start();
  10. return true;
  11. });
  12. router.afterEach(async () => {
  13. // if (to.meta.loaded) return true;
  14. unref(getOpenNProgress) && nProgress.done();
  15. return true;
  16. });
  17. }