|  | @@ -1,4 +1,5 @@
 | 
											
												
													
														|  |  import type { FunctionalComponent } from 'vue';
 |  |  import type { FunctionalComponent } from 'vue';
 | 
											
												
													
														|  | 
 |  | +import type { DefaultContext } from './transition';
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  import { computed, defineComponent, unref, Transition, KeepAlive } from 'vue';
 |  |  import { computed, defineComponent, unref, Transition, KeepAlive } from 'vue';
 | 
											
												
													
														|  |  import { RouterView, RouteLocation } from 'vue-router';
 |  |  import { RouterView, RouteLocation } from 'vue-router';
 | 
											
										
											
												
													
														|  | @@ -10,6 +11,7 @@ import { useRootSetting } from '/@/hooks/setting/useRootSetting';
 | 
											
												
													
														|  |  import { useTransitionSetting } from '/@/hooks/setting/useTransitionSetting';
 |  |  import { useTransitionSetting } from '/@/hooks/setting/useTransitionSetting';
 | 
											
												
													
														|  |  import { useCache } from './useCache';
 |  |  import { useCache } from './useCache';
 | 
											
												
													
														|  |  import { useMultipleTabSetting } from '/@/hooks/setting/useMultipleTabSetting';
 |  |  import { useMultipleTabSetting } from '/@/hooks/setting/useMultipleTabSetting';
 | 
											
												
													
														|  | 
 |  | +import { getTransitionName } from './transition';
 | 
											
												
													
														|  |  // import { createAsyncComponent } from '/@/utils/factory/createAsyncComponent';
 |  |  // import { createAsyncComponent } from '/@/utils/factory/createAsyncComponent';
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  interface DefaultContext {
 |  |  interface DefaultContext {
 | 
											
										
											
												
													
														|  | @@ -32,17 +34,20 @@ export default defineComponent({
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      return () => {
 |  |      return () => {
 | 
											
												
													
														|  |        return (
 |  |        return (
 | 
											
												
													
														|  | -        <div>
 |  | 
 | 
											
												
													
														|  | 
 |  | +        <>
 | 
											
												
													
														|  |            <RouterView>
 |  |            <RouterView>
 | 
											
												
													
														|  |              {{
 |  |              {{
 | 
											
												
													
														|  |                default: ({ Component, route }: DefaultContext) => {
 |  |                default: ({ Component, route }: DefaultContext) => {
 | 
											
												
													
														|  |                  // No longer show animations that are already in the tab
 |  |                  // No longer show animations that are already in the tab
 | 
											
												
													
														|  |                  const cacheTabs = unref(getCaches);
 |  |                  const cacheTabs = unref(getCaches);
 | 
											
												
													
														|  | -                const isInCache = cacheTabs.includes(route.name as string);
 |  | 
 | 
											
												
													
														|  | -                const name =
 |  | 
 | 
											
												
													
														|  | -                  isInCache && route.meta.loaded && unref(getEnableTransition)
 |  | 
 | 
											
												
													
														|  | -                    ? 'fade-slide'
 |  | 
 | 
											
												
													
														|  | -                    : null;
 |  | 
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +                const name = getTransitionName({
 | 
											
												
													
														|  | 
 |  | +                  route,
 | 
											
												
													
														|  | 
 |  | +                  openCache: unref(openCache),
 | 
											
												
													
														|  | 
 |  | +                  enableTransition: unref(getEnableTransition),
 | 
											
												
													
														|  | 
 |  | +                  cacheTabs,
 | 
											
												
													
														|  | 
 |  | +                  def: unref(getBasicTransition),
 | 
											
												
													
														|  | 
 |  | +                });
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |                  // When the child element is the parentView, adding the key will cause the component to be executed multiple times. When it is not parentView, you need to add a key, because it needs to be compatible with the same route carrying different parameters
 |  |                  // When the child element is the parentView, adding the key will cause the component to be executed multiple times. When it is not parentView, you need to add a key, because it needs to be compatible with the same route carrying different parameters
 | 
											
												
													
														|  |                  const isParentView = Component?.type.parentView;
 |  |                  const isParentView = Component?.type.parentView;
 | 
											
										
											
												
													
														|  | @@ -60,11 +65,7 @@ export default defineComponent({
 | 
											
												
													
														|  |                    return PageContent;
 |  |                    return PageContent;
 | 
											
												
													
														|  |                  }
 |  |                  }
 | 
											
												
													
														|  |                  return (
 |  |                  return (
 | 
											
												
													
														|  | -                  <Transition
 |  | 
 | 
											
												
													
														|  | -                    name={name || route.meta.transitionName || unref(getBasicTransition)}
 |  | 
 | 
											
												
													
														|  | -                    mode="out-in"
 |  | 
 | 
											
												
													
														|  | -                    appear={true}
 |  | 
 | 
											
												
													
														|  | -                  >
 |  | 
 | 
											
												
													
														|  | 
 |  | +                  <Transition name={name} mode="out-in" appear={true}>
 | 
											
												
													
														|  |                      {() => PageContent}
 |  |                      {() => PageContent}
 | 
											
												
													
														|  |                    </Transition>
 |  |                    </Transition>
 | 
											
												
													
														|  |                  );
 |  |                  );
 | 
											
										
											
												
													
														|  | @@ -72,7 +73,7 @@ export default defineComponent({
 | 
											
												
													
														|  |              }}
 |  |              }}
 | 
											
												
													
														|  |            </RouterView>
 |  |            </RouterView>
 | 
											
												
													
														|  |            {unref(getCanEmbedIFramePage) && <FrameLayout />}
 |  |            {unref(getCanEmbedIFramePage) && <FrameLayout />}
 | 
											
												
													
														|  | -        </div>
 |  | 
 | 
											
												
													
														|  | 
 |  | +        </>
 | 
											
												
													
														|  |        );
 |  |        );
 | 
											
												
													
														|  |      };
 |  |      };
 | 
											
												
													
														|  |    },
 |  |    },
 |