admin-vben5/packages/business/layouts/src/basic/content/content.vue

61 lines
1.7 KiB
Vue
Raw Normal View History

2024-05-19 21:20:42 +08:00
<script lang="ts" setup>
2024-06-08 19:49:06 +08:00
import type { RouteLocationNormalizedLoaded } from 'vue-router';
2024-06-01 23:15:29 +08:00
import { preferences, usePreferences } from '@vben-core/preferences';
import { storeToRefs, useTabsStore } from '@vben-core/stores';
2024-05-19 21:20:42 +08:00
import { IFrameRouterView } from '../../iframe';
defineOptions({ name: 'LayoutContent' });
2024-06-01 23:15:29 +08:00
const { keepAlive } = usePreferences();
2024-05-19 21:20:42 +08:00
const tabsStore = useTabsStore();
const { getCacheTabs, getExcludeTabs, renderRouteView } =
storeToRefs(tabsStore);
// 页面切换动画
function getTransitionName(route: RouteLocationNormalizedLoaded) {
// 如果偏好设置未设置,则不使用动画
2024-06-01 23:15:29 +08:00
const { tabbar, transition } = preferences;
const transitionName = transition.name;
if (!transitionName || !transition.enable) {
2024-05-19 21:20:42 +08:00
return;
}
// 标签页未启用或者未开启缓存,则使用全局配置动画
2024-06-01 23:15:29 +08:00
if (!tabbar.enable || !keepAlive) {
return transitionName;
2024-05-19 21:20:42 +08:00
}
// 如果页面已经加载过,则不使用动画
if (route.meta.loaded) {
return;
}
// 已经打开且已经加载过的页面不使用动画
const inTabs = getCacheTabs.value.includes(route.name as string);
2024-06-01 23:15:29 +08:00
return inTabs && route.meta.loaded ? undefined : transitionName;
2024-05-19 21:20:42 +08:00
}
</script>
<template>
<IFrameRouterView />
<RouterView v-slot="{ Component, route }">
<Transition :name="getTransitionName(route)" mode="out-in" appear>
<KeepAlive
v-if="keepAlive"
:include="getCacheTabs"
:exclude="getExcludeTabs"
>
<component
:is="Component"
v-if="renderRouteView"
v-show="!route.meta.iframeSrc"
2024-05-19 21:20:42 +08:00
:key="route.fullPath"
/>
</KeepAlive>
<component :is="Component" v-else :key="route.fullPath" />
</Transition>
</RouterView>
</template>