|  | @@ -4,12 +4,12 @@ import { emitter } from "@/utils/mitt";
 | 
											
												
													
														|  |  import { RouteConfigs } from "../../types";
 |  |  import { RouteConfigs } from "../../types";
 | 
											
												
													
														|  |  import { useTags } from "../../hooks/useTag";
 |  |  import { useTags } from "../../hooks/useTag";
 | 
											
												
													
														|  |  import { routerArrays } from "@/layout/types";
 |  |  import { routerArrays } from "@/layout/types";
 | 
											
												
													
														|  | -import { isEqual, isAllEmpty } from "@pureadmin/utils";
 |  | 
 | 
											
												
													
														|  |  import { handleAliveRoute, getTopMenu } from "@/router/utils";
 |  |  import { handleAliveRoute, getTopMenu } from "@/router/utils";
 | 
											
												
													
														|  |  import { useSettingStoreHook } from "@/store/modules/settings";
 |  |  import { useSettingStoreHook } from "@/store/modules/settings";
 | 
											
												
													
														|  | 
 |  | +import { useResizeObserver, useFullscreen } from "@vueuse/core";
 | 
											
												
													
														|  | 
 |  | +import { isEqual, isAllEmpty, debounce } from "@pureadmin/utils";
 | 
											
												
													
														|  |  import { useMultiTagsStoreHook } from "@/store/modules/multiTags";
 |  |  import { useMultiTagsStoreHook } from "@/store/modules/multiTags";
 | 
											
												
													
														|  |  import { ref, watch, unref, toRaw, nextTick, onBeforeUnmount } from "vue";
 |  |  import { ref, watch, unref, toRaw, nextTick, onBeforeUnmount } from "vue";
 | 
											
												
													
														|  | -import { useResizeObserver, useDebounceFn, useFullscreen } from "@vueuse/core";
 |  | 
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  import ExitFullscreen from "@iconify-icons/ri/fullscreen-exit-fill";
 |  |  import ExitFullscreen from "@iconify-icons/ri/fullscreen-exit-fill";
 | 
											
												
													
														|  |  import Fullscreen from "@iconify-icons/ri/fullscreen-fill";
 |  |  import Fullscreen from "@iconify-icons/ri/fullscreen-fill";
 | 
											
										
											
												
													
														|  | @@ -54,20 +54,22 @@ const topPath = getTopMenu()?.path;
 | 
											
												
													
														|  |  const { VITE_HIDE_HOME } = import.meta.env;
 |  |  const { VITE_HIDE_HOME } = import.meta.env;
 | 
											
												
													
														|  |  const { isFullscreen, toggle } = useFullscreen();
 |  |  const { isFullscreen, toggle } = useFullscreen();
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -const dynamicTagView = () => {
 |  | 
 | 
											
												
													
														|  | 
 |  | +const dynamicTagView = async () => {
 | 
											
												
													
														|  | 
 |  | +  await nextTick();
 | 
											
												
													
														|  |    const index = multiTags.value.findIndex(item => {
 |  |    const index = multiTags.value.findIndex(item => {
 | 
											
												
													
														|  | -    if (item.query) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +    if (!isAllEmpty(route.query)) {
 | 
											
												
													
														|  |        return isEqual(route.query, item.query);
 |  |        return isEqual(route.query, item.query);
 | 
											
												
													
														|  | -    } else if (item.params) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +    } else if (!isAllEmpty(route.params)) {
 | 
											
												
													
														|  |        return isEqual(route.params, item.params);
 |  |        return isEqual(route.params, item.params);
 | 
											
												
													
														|  |      } else {
 |  |      } else {
 | 
											
												
													
														|  | -      return item.path === route.path;
 |  | 
 | 
											
												
													
														|  | 
 |  | +      return route.path === item.path;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |    });
 |  |    });
 | 
											
												
													
														|  |    moveToView(index);
 |  |    moveToView(index);
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  const moveToView = async (index: number): Promise<void> => {
 |  |  const moveToView = async (index: number): Promise<void> => {
 | 
											
												
													
														|  | 
 |  | +  await nextTick();
 | 
											
												
													
														|  |    const tabNavPadding = 10;
 |  |    const tabNavPadding = 10;
 | 
											
												
													
														|  |    if (!instance.refs["dynamic" + index]) return;
 |  |    if (!instance.refs["dynamic" + index]) return;
 | 
											
												
													
														|  |    const tabItemEl = instance.refs["dynamic" + index][0];
 |  |    const tabItemEl = instance.refs["dynamic" + index][0];
 | 
											
										
											
												
													
														|  | @@ -78,9 +80,6 @@ const moveToView = async (index: number): Promise<void> => {
 | 
											
												
													
														|  |      ? scrollbarDom.value?.offsetWidth
 |  |      ? scrollbarDom.value?.offsetWidth
 | 
											
												
													
														|  |      : 0;
 |  |      : 0;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  // 获取视图更新后dom
 |  | 
 | 
											
												
													
														|  | -  await nextTick();
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |    // 已有标签页总长度(包含溢出部分)
 |  |    // 已有标签页总长度(包含溢出部分)
 | 
											
												
													
														|  |    const tabDomWidth = tabDom.value ? tabDom.value?.offsetWidth : 0;
 |  |    const tabDomWidth = tabDom.value ? tabDom.value?.offsetWidth : 0;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -135,31 +134,29 @@ const handleScroll = (offset: number): void => {
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -function dynamicRouteTag(value: string, parentPath: string): void {
 |  | 
 | 
											
												
													
														|  | 
 |  | +function dynamicRouteTag(value: string): void {
 | 
											
												
													
														|  |    const hasValue = multiTags.value.some(item => {
 |  |    const hasValue = multiTags.value.some(item => {
 | 
											
												
													
														|  |      return item.path === value;
 |  |      return item.path === value;
 | 
											
												
													
														|  |    });
 |  |    });
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  function concatPath(arr: object[], value: string, parentPath: string) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  function concatPath(arr: object[], value: string) {
 | 
											
												
													
														|  |      if (!hasValue) {
 |  |      if (!hasValue) {
 | 
											
												
													
														|  |        arr.forEach((arrItem: any) => {
 |  |        arr.forEach((arrItem: any) => {
 | 
											
												
													
														|  | -        const pathConcat = parentPath + arrItem.path;
 |  | 
 | 
											
												
													
														|  | -        if (arrItem.path === value || pathConcat === value) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +        if (arrItem.path === value || arrItem.path === value) {
 | 
											
												
													
														|  |            useMultiTagsStoreHook().handleTags("push", {
 |  |            useMultiTagsStoreHook().handleTags("push", {
 | 
											
												
													
														|  |              path: value,
 |  |              path: value,
 | 
											
												
													
														|  | -            parentPath: `/${parentPath.split("/")[1]}`,
 |  | 
 | 
											
												
													
														|  |              meta: arrItem.meta,
 |  |              meta: arrItem.meta,
 | 
											
												
													
														|  |              name: arrItem.name
 |  |              name: arrItem.name
 | 
											
												
													
														|  |            });
 |  |            });
 | 
											
												
													
														|  |          } else {
 |  |          } else {
 | 
											
												
													
														|  |            if (arrItem.children && arrItem.children.length > 0) {
 |  |            if (arrItem.children && arrItem.children.length > 0) {
 | 
											
												
													
														|  | -            concatPath(arrItem.children, value, parentPath);
 |  | 
 | 
											
												
													
														|  | 
 |  | +            concatPath(arrItem.children, value);
 | 
											
												
													
														|  |            }
 |  |            }
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |        });
 |  |        });
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  | -  concatPath(router.options.routes as any, value, parentPath);
 |  | 
 | 
											
												
													
														|  | 
 |  | +  concatPath(router.options.routes as any, value);
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  /** 刷新路由 */
 |  |  /** 刷新路由 */
 | 
											
										
											
												
													
														|  | @@ -465,7 +462,7 @@ function tagOnClick(item) {
 | 
											
												
													
														|  |    // showMenuModel(item?.path, item?.query);
 |  |    // showMenuModel(item?.path, item?.query);
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -watch([route], () => {
 |  | 
 | 
											
												
													
														|  | 
 |  | +watch(route, () => {
 | 
											
												
													
														|  |    activeIndex.value = -1;
 |  |    activeIndex.value = -1;
 | 
											
												
													
														|  |    dynamicTagView();
 |  |    dynamicTagView();
 | 
											
												
													
														|  |  });
 |  |  });
 | 
											
										
											
												
													
														|  | @@ -493,8 +490,8 @@ onMounted(() => {
 | 
											
												
													
														|  |    });
 |  |    });
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    //  接收侧边栏切换传递过来的参数
 |  |    //  接收侧边栏切换传递过来的参数
 | 
											
												
													
														|  | -  emitter.on("changLayoutRoute", ({ indexPath, parentPath }) => {
 |  | 
 | 
											
												
													
														|  | -    dynamicRouteTag(indexPath, parentPath);
 |  | 
 | 
											
												
													
														|  | 
 |  | +  emitter.on("changLayoutRoute", indexPath => {
 | 
											
												
													
														|  | 
 |  | +    dynamicRouteTag(indexPath);
 | 
											
												
													
														|  |      setTimeout(() => {
 |  |      setTimeout(() => {
 | 
											
												
													
														|  |        showMenuModel(indexPath);
 |  |        showMenuModel(indexPath);
 | 
											
												
													
														|  |      });
 |  |      });
 | 
											
										
											
												
													
														|  | @@ -502,9 +499,7 @@ onMounted(() => {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    useResizeObserver(
 |  |    useResizeObserver(
 | 
											
												
													
														|  |      scrollbarDom,
 |  |      scrollbarDom,
 | 
											
												
													
														|  | -    useDebounceFn(() => {
 |  | 
 | 
											
												
													
														|  | -      dynamicTagView();
 |  | 
 | 
											
												
													
														|  | -    }, 200)
 |  | 
 | 
											
												
													
														|  | 
 |  | +    debounce(() => dynamicTagView())
 | 
											
												
													
														|  |    );
 |  |    );
 | 
											
												
													
														|  |  });
 |  |  });
 | 
											
												
													
														|  |  
 |  |  
 |