Prechádzať zdrojové kódy

feat: add refresh route

xiaoxian521 4 rokov pred
rodič
commit
f9ff87c708

+ 40 - 37
src/layout/components/tag/tagsHook.ts

@@ -1,85 +1,88 @@
-import { reactive, toRefs, nextTick } from "vue"
-import { storageLocal } from "/@/utils/storage"
-import { useRouter } from "vue-router"
+import { reactive, toRefs, nextTick } from "vue";
+import { storageLocal } from "/@/utils/storage";
+import { useRouter } from "vue-router";
 
 interface InterDynamic {
-  dRoutes: object[],
-  [propName: string]: any
+  dRoutes: object[];
+  [propName: string]: any;
 }
 
 // 默认显示首页tag
 let dynamic: InterDynamic = reactive({
   dRoutes: [
     {
-      path: "/welcome", meta: {
+      path: "/welcome",
+      meta: {
         title: "home",
-        icon: 'el-icon-s-home',
+        icon: "el-icon-s-home",
         showLink: true,
         savedPosition: false,
-      }
-    }]
-})
+      },
+    },
+  ],
+});
 
 export function useDynamicRoutesHook() {
-  const router = useRouter()
+  const router = useRouter();
   /**
    * @param value string 当前menu对应的路由path
    * @param parentPath string 当前路由中父级路由
    */
   const dynamicRouteTags = (value: string, parentPath: string): void => {
     const hasValue = dynamic.dRoutes.some((item: any) => {
-      return item.path === value
-    })
+      return item.path === value;
+    });
 
     function concatPath(arr: object[], value: string, parentPath: string) {
       if (!hasValue) {
         arr.forEach((arrItem: any) => {
-          let pathConcat = parentPath + '/' + arrItem.path
+          let pathConcat = parentPath + "/" + arrItem.path;
           if (arrItem.path === value || pathConcat === value) {
-            dynamic.dRoutes.push({ path: value, meta: arrItem.meta })
+            dynamic.dRoutes.push({ path: value, meta: arrItem.meta });
             // console.log(dynamic.dRoutes)
           } else {
             if (arrItem.children && arrItem.children.length > 0) {
-              concatPath(arrItem.children, value, parentPath)
+              concatPath(arrItem.children, value, parentPath);
             }
           }
-        })
+        });
       }
     }
-    concatPath(router.options.routes, value, parentPath)
+    concatPath(router.options.routes, value, parentPath);
 
-    if (storageLocal.getItem("routesInStorage") && storageLocal.getItem("routesInStorage").length > 2) {
-      let lens = storageLocal.getItem("routesInStorage").length
-      let itemss = storageLocal.getItem("routesInStorage")[lens - 1]
-      dynamic.dRoutes.push({ path: itemss.path, meta: itemss.meta })
-    }
+    // if (storageLocal.getItem("routesInStorage") && storageLocal.getItem("routesInStorage").length > 2) {
+    //   let lens = storageLocal.getItem("routesInStorage").length
+    //   let itemss = storageLocal.getItem("routesInStorage")[lens - 1]
+    //   dynamic.dRoutes.push({ path: itemss.path, meta: itemss.meta })
+    // }
 
-    storageLocal.setItem("routesInStorage", dynamic.dRoutes)
-  }
+    // storageLocal.setItem("routesInStorage", dynamic.dRoutes)
+  };
   /**
    * @param value any 当前删除tag路由
    * @param current objct 当前激活路由对象
    */
   const deleteDynamicTag = async (obj: any, current: object): Promise<any> => {
     let valueIndex: number = dynamic.dRoutes.findIndex((item: any) => {
-      return item.path === obj.path
-    })
+      return item.path === obj.path;
+    });
     // 从当前匹配到的路径中删除
-    await dynamic.dRoutes.splice(valueIndex, 1)
-    storageLocal.setItem("routesInStorage", dynamic.dRoutes)
-    if (current === obj.path) { // 如果删除当前激活tag就自动切换到最后一个tag
-      let newRoute: any = dynamic.dRoutes.slice(-1)
+    await dynamic.dRoutes.splice(valueIndex, 1);
+    // storageLocal.setItem("routesInStorage", dynamic.dRoutes)
+    if (current === obj.path) {
+      // 如果删除当前激活tag就自动切换到最后一个tag
+      let newRoute: any = dynamic.dRoutes.slice(-1);
       nextTick(() => {
         router.push({
-          path: newRoute[0].path
-        })
-      })
+          path: newRoute[0].path,
+        });
+      });
     }
-  }
+  };
 
   return {
     ...toRefs(dynamic),
     dynamicRouteTags,
-    deleteDynamicTag
-  }
+    deleteDynamicTag,
+  };
 }

+ 14 - 2
src/layout/index.vue

@@ -16,7 +16,7 @@
           <!-- 右侧功能按钮 -->
           <ul class="right-func">
             <li>
-              <i class="el-icon-refresh-right"></i>
+              <i class="el-icon-refresh-right" @click="onFresh"></i>
             </li>
             <li>
               <i class="el-icon-arrow-down"></i>
@@ -58,6 +58,7 @@ import { useEventListener, useFullscreen } from "@vueuse/core";
 import { toggleClass } from "/@/utils/operate";
 let hiddenMainContainer = "hidden-main-container";
 import options from "/@/settings";
+import { useRouter, useRoute } from "vue-router";
 
 interface setInter {
   sidebar: any;
@@ -78,6 +79,9 @@ export default {
   setup() {
     const store = useStore();
 
+    const router = useRouter();
+    const route = useRoute();
+
     const WIDTH = ref(992);
 
     let containerHiddenSideBar = ref(options.hiddenSideBar);
@@ -149,6 +153,13 @@ export default {
       }
     }
 
+    function onFresh() {
+      const { path, fullPath } = unref(route);
+      router.replace({
+        path: "/redirect" + fullPath
+      });
+    }
+
     onMounted(() => {
       const isMobile = $_isMobile();
       if (isMobile) {
@@ -170,7 +181,8 @@ export default {
       ...toRefs(set),
       handleClickOutside,
       containerHiddenSideBar,
-      onFullScreen
+      onFullScreen,
+      onFresh
     };
   }
 };

+ 212 - 155
src/router/index.ts

@@ -1,118 +1,153 @@
-import { createRouter, createWebHistory, createWebHashHistory, RouteRecordRaw } from "vue-router"
+import {
+  createRouter,
+  createWebHistory,
+  createWebHashHistory,
+  RouteRecordRaw,
+} from "vue-router";
 
-import Layout from '../layout/index.vue'
+import Layout from "../layout/index.vue";
 
-import { storageSession } from "../utils/storage"
+import { storageSession } from "../utils/storage";
 
 const routes: Array<RouteRecordRaw> = [
   {
-    path: '/',
-    name: 'home',
+    path: "/",
+    name: "home",
     component: Layout,
     redirect: "/welcome",
-    children: [{
-      path: '/welcome',
-      name: 'welcome',
-      component: () => import(/* webpackChunkName: "home" */ '../views/welcome.vue'),
-      meta: {
-        title: 'home',
-        showLink: true,
-        savedPosition: false
-      }
-    }],
+    children: [
+      {
+        path: "/welcome",
+        name: "welcome",
+        component: () =>
+          import(/* webpackChunkName: "home" */ "../views/welcome.vue"),
+        meta: {
+          title: "home",
+          showLink: true,
+          savedPosition: false,
+        },
+      },
+    ],
     meta: {
-      icon: 'el-icon-s-home',
+      icon: "el-icon-s-home",
       showLink: true,
       savedPosition: false,
-    }
+    },
   },
   {
-    path: '/components',
-    name: 'components',
+    path: "/components",
+    name: "components",
     component: Layout,
-    redirect: '/components/split-pane',
+    redirect: "/components/split-pane",
     children: [
       {
-        path: '/components/video',
-        component: () => import(/* webpackChunkName: "components" */ '../views/components/video/index.vue'),
+        path: "/components/video",
+        component: () =>
+          import(
+            /* webpackChunkName: "components" */ "../views/components/video/index.vue"
+          ),
         meta: {
-          title: 'video',
+          title: "video",
           showLink: false,
-          savedPosition: true
-        }
+          savedPosition: true,
+        },
       },
       {
-        path: '/components/map',
-        component: () => import(/* webpackChunkName: "components" */ '../views/components/map/index.vue'),
+        path: "/components/map",
+        component: () =>
+          import(
+            /* webpackChunkName: "components" */ "../views/components/map/index.vue"
+          ),
         meta: {
-          title: 'map',
+          title: "map",
           showLink: false,
-          savedPosition: true
-        }
+          savedPosition: true,
+        },
       },
       {
-        path: '/components/draggable',
-        component: () => import(/* webpackChunkName: "components" */ '../views/components/draggable/index.vue'),
+        path: "/components/draggable",
+        component: () =>
+          import(
+            /* webpackChunkName: "components" */ "../views/components/draggable/index.vue"
+          ),
         meta: {
-          title: 'draggable',
+          title: "draggable",
           showLink: false,
-          savedPosition: true
-        }
+          savedPosition: true,
+        },
       },
       {
-        path: '/components/split-pane',
-        component: () => import(/* webpackChunkName: "components" */ '../views/components/split-pane/index.vue'),
+        path: "/components/split-pane",
+        component: () =>
+          import(
+            /* webpackChunkName: "components" */ "../views/components/split-pane/index.vue"
+          ),
         meta: {
-          title: 'split-pane',
+          title: "split-pane",
           showLink: false,
-          savedPosition: true
-        }
+          savedPosition: true,
+        },
       },
       {
-        path: '/components/button',
-        component: () => import(/* webpackChunkName: "components" */ '../views/components/button/index.vue'),
+        path: "/components/button",
+        component: () =>
+          import(
+            /* webpackChunkName: "components" */ "../views/components/button/index.vue"
+          ),
         meta: {
-          title: 'button',
+          title: "button",
           showLink: false,
-          savedPosition: true
-        }
+          savedPosition: true,
+        },
       },
       {
-        path: '/components/cropping',
-        component: () => import(/* webpackChunkName: "components" */ '../views/components/cropping/index.vue'),
+        path: "/components/cropping",
+        component: () =>
+          import(
+            /* webpackChunkName: "components" */ "../views/components/cropping/index.vue"
+          ),
         meta: {
-          title: 'cropping',
+          title: "cropping",
           showLink: false,
-          savedPosition: true
-        }
+          savedPosition: true,
+        },
       },
       {
-        path: '/components/countTo',
-        component: () => import(/* webpackChunkName: "components" */ '../views/components/count-to/index.vue'),
+        path: "/components/countTo",
+        component: () =>
+          import(
+            /* webpackChunkName: "components" */ "../views/components/count-to/index.vue"
+          ),
         meta: {
-          title: 'countTo',
+          title: "countTo",
           showLink: false,
-          savedPosition: true
-        }
+          savedPosition: true,
+        },
       },
       {
-        path: '/components/selector',
-        component: () => import(/* webpackChunkName: "components" */ '../views/components/selector/index.vue'),
+        path: "/components/selector",
+        component: () =>
+          import(
+            /* webpackChunkName: "components" */ "../views/components/selector/index.vue"
+          ),
         meta: {
-          title: 'selector',
+          title: "selector",
           showLink: false,
-          savedPosition: true
-        }
+          savedPosition: true,
+        },
       },
       {
-        path: '/components/seamlessScroll',
-        component: () => import(/* webpackChunkName: "components" */ '../views/components/seamless-scroll/index.vue'),
+        path: "/components/seamlessScroll",
+        component: () =>
+          import(
+            /* webpackChunkName: "components" */ "../views/components/seamless-scroll/index.vue"
+          ),
         meta: {
-          title: 'seamless',
+          title: "seamless",
           showLink: false,
-          savedPosition: true
-        }
-      }
+          savedPosition: true,
+        },
+      },
       // {
       //   path: '/components/flowChart',
       //   component: () => import(/* webpackChunkName: "components" */ '../views/components/flow-chart/index.vue'),
@@ -124,146 +159,165 @@ const routes: Array<RouteRecordRaw> = [
       // }
     ],
     meta: {
-      icon: 'el-icon-menu',
-      title: 'components',
+      icon: "el-icon-menu",
+      title: "components",
       showLink: true,
-      savedPosition: true
-    }
+      savedPosition: true,
+    },
   },
   {
-    path: '/flowChart',
-    name: 'flowChart',
+    path: "/flowChart",
+    name: "flowChart",
     component: Layout,
-    redirect: '/flowChart/index',
+    redirect: "/flowChart/index",
     children: [
       {
-        path: '/flowChart/index',
-        component: () => import(/* webpackChunkName: "user" */ '../views/flow-chart/index.vue'),
+        path: "/flowChart/index",
+        component: () =>
+          import(
+            /* webpackChunkName: "user" */ "../views/flow-chart/index.vue"
+          ),
         meta: {
-          title: 'flowChart',
+          title: "flowChart",
           showLink: false,
-          savedPosition: true
-        }
+          savedPosition: true,
+        },
       },
     ],
     meta: {
-      icon: 'el-icon-set-up',
-      title: 'flowChart',
+      icon: "el-icon-set-up",
+      title: "flowChart",
       showLink: true,
-      savedPosition: true
-    }
+      savedPosition: true,
+    },
   },
   {
-    path: '/editor',
-    name: 'editor',
+    path: "/editor",
+    name: "editor",
     component: Layout,
-    redirect: '/editor/index',
+    redirect: "/editor/index",
     children: [
       {
-        path: '/editor/index',
-        component: () => import(/* webpackChunkName: "user" */ '../views/editor/index.vue'),
+        path: "/editor/index",
+        component: () =>
+          import(/* webpackChunkName: "user" */ "../views/editor/index.vue"),
         meta: {
           // icon: 'el-icon-edit-outline',
-          title: 'editor',
+          title: "editor",
           showLink: false,
-          savedPosition: true
-        }
+          savedPosition: true,
+        },
       },
     ],
     meta: {
-      icon: 'el-icon-edit-outline',
-      title: 'editor',
+      icon: "el-icon-edit-outline",
+      title: "editor",
       showLink: true,
-      savedPosition: true
-    }
+      savedPosition: true,
+    },
   },
   {
-    path: '/user',
-    name: 'user',
+    path: "/user",
+    name: "user",
     component: Layout,
-    redirect: '/user/base',
+    redirect: "/user/base",
     children: [
       {
-        path: '/user/base',
-        component: () => import(/* webpackChunkName: "user" */ '../views/user.vue'),
+        path: "/user/base",
+        component: () =>
+          import(/* webpackChunkName: "user" */ "../views/user.vue"),
         meta: {
           // icon: 'el-icon-user',
-          title: 'baseinfo',
+          title: "baseinfo",
           showLink: false,
-          savedPosition: true
-        }
+          savedPosition: true,
+        },
       },
     ],
     meta: {
-      icon: 'el-icon-user',
-      title: 'usermanagement',
+      icon: "el-icon-user",
+      title: "usermanagement",
       showLink: true,
-      savedPosition: true
-    }
+      savedPosition: true,
+    },
   },
   {
-    path: '/error',
-    name: 'error',
+    path: "/error",
+    name: "error",
     component: Layout,
-    redirect: '/error/401',
+    redirect: "/error/401",
     children: [
       {
-        path: '/error/401',
-        component: () => import(/* webpackChunkName: "error" */ '../views/error/401.vue'),
+        path: "/error/401",
+        component: () =>
+          import(/* webpackChunkName: "error" */ "../views/error/401.vue"),
         meta: {
-          title: '401',
+          title: "401",
           showLink: false,
-          savedPosition: true
-        }
+          savedPosition: true,
+        },
       },
       {
-        path: '/error/404',
-        component: () => import(/* webpackChunkName: "error" */ '../views/error/404.vue'),
+        path: "/error/404",
+        component: () =>
+          import(/* webpackChunkName: "error" */ "../views/error/404.vue"),
         meta: {
-          title: '404',
+          title: "404",
           showLink: false,
-          savedPosition: true
-        }
+          savedPosition: true,
+        },
       },
     ],
     meta: {
-      icon: 'el-icon-position',
-      title: 'error',
+      icon: "el-icon-position",
+      title: "error",
       showLink: true,
-      savedPosition: true
-    }
+      savedPosition: true,
+    },
   },
   {
-    path: '/login',
-    name: 'login',
-    component: () => import(/* webpackChunkName: "login" */ '../views/login.vue'),
+    path: "/login",
+    name: "login",
+    component: () =>
+      import(/* webpackChunkName: "login" */ "../views/login.vue"),
     meta: {
-      title: '登陆',
-      showLink: false
-    }
+      title: "登陆",
+      showLink: false,
+    },
   },
   {
-    path: '/register',
-    name: 'register',
-    component: () => import(/* webpackChunkName: "register" */ '../views/register.vue'),
+    path: "/register",
+    name: "register",
+    component: () =>
+      import(/* webpackChunkName: "register" */ "../views/register.vue"),
     meta: {
-      title: '注册',
-      showLink: false
-    }
+      title: "注册",
+      showLink: false,
+    },
   },
   {
     // 找不到路由重定向到404页面
-    path: '/:pathMatch(.*)',
+    path: "/:pathMatch(.*)",
     component: Layout,
     redirect: "/error/404",
     meta: {
-      icon: 'el-icon-s-home',
-      title: '首页',
+      icon: "el-icon-s-home",
+      title: "首页",
       showLink: false,
       savedPosition: false,
-    }
+    },
   },
-]
+  {
+    path: "/redirect",
+    component: Layout,
+    children: [
+      {
+        path: "/redirect/:path(.*)",
+        component: () => import("../views/redirect.vue"),
+      },
+    ],
+  },
+];
 
 const router = createRouter({
   history: createWebHashHistory(),
@@ -271,30 +325,33 @@ const router = createRouter({
   scrollBehavior(to, from, savedPosition) {
     return new Promise((resolve, reject) => {
       if (savedPosition) {
-        return savedPosition
+        return savedPosition;
       } else {
         if (from.meta.saveSrollTop) {
-          const top: number = document.documentElement.scrollTop || document.body.scrollTop
-          resolve({ left: 0, top })
+          const top: number =
+            document.documentElement.scrollTop || document.body.scrollTop;
+          resolve({ left: 0, top });
         }
       }
-    })
-  }
-})
+    });
+  },
+});
 
-import NProgress from "../utils/progress"
+import NProgress from "../utils/progress";
 
-const whiteList = ["/login", "/register"]
+const whiteList = ["/login", "/register"];
 
 router.beforeEach((to, _from, next) => {
-  NProgress.start()
+  NProgress.start();
   // @ts-ignore
-  document.title = to.meta.title // 动态title
-  whiteList.indexOf(to.path) !== -1 || storageSession.getItem("info") ? next() : next("/login") // 全部重定向到登录页
-})
+  document.title = to.meta.title; // 动态title
+  whiteList.indexOf(to.path) !== -1 || storageSession.getItem("info")
+    ? next()
+    : next("/login"); // 全部重定向到登录页
+});
 
 router.afterEach(() => {
-  NProgress.done()
-})
+  NProgress.done();
+});
 
-export default router
+export default router;

+ 6 - 8
src/utils/algorithm/index.ts

@@ -1,10 +1,9 @@
 interface ProxyAlgorithm {
-  increaseIndexes<T>(val: Array<T>): Array<T>
+  increaseIndexes<T>(val: Array<T>): Array<T>;
 }
 
 class algorithmProxy implements ProxyAlgorithm {
-
-  constructor() { }
+  constructor() {}
 
   // 数组每一项添加索引字段
   public increaseIndexes<T>(val: Array<T>): Array<T> {
@@ -13,12 +12,11 @@ class algorithmProxy implements ProxyAlgorithm {
         return {
           // @ts-ignore
           ...val[v],
-          key: v
-        }
+          key: v,
+        };
       })
-      .filter(v => v.meta.showLink)
+      .filter((v) => v.meta && v.meta.showLink);
   }
-
 }
 
-export const algorithm = new algorithmProxy()
+export const algorithm = new algorithmProxy();

+ 26 - 0
src/views/redirect.vue

@@ -0,0 +1,26 @@
+<template>
+  <div></div>
+</template>
+<script lang="ts">
+import { defineComponent, unref } from "vue";
+import { useRouter } from "vue-router";
+
+export default defineComponent({
+  name: "Redirect",
+  setup() {
+    const { currentRoute, replace } = useRouter();
+
+    const { params, query } = unref(currentRoute);
+    const { path } = params;
+
+    const _path = Array.isArray(path) ? path.join("/") : path;
+
+    replace({
+      path: "/" + _path,
+      query
+    });
+
+    return {};
+  }
+});
+</script>