content.vue 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. <script lang="ts" setup>
  2. import type { RouteLocationNormalizedLoaded } from 'vue-router';
  3. import { preferences, usePreferences } from '@vben-core/preferences';
  4. import { Spinner } from '@vben-core/shadcn-ui';
  5. import { storeToRefs, useCoreTabbarStore } from '@vben-core/stores';
  6. import { IFrameRouterView } from '../../iframe';
  7. import { useContentSpinner } from './use-content-spinner';
  8. defineOptions({ name: 'LayoutContent' });
  9. const tabbarStore = useCoreTabbarStore();
  10. const { keepAlive } = usePreferences();
  11. const { spinning } = useContentSpinner();
  12. const { getCachedTabs, getExcludeCachedTabs, renderRouteView } =
  13. storeToRefs(tabbarStore);
  14. // 页面切换动画
  15. function getTransitionName(route: RouteLocationNormalizedLoaded) {
  16. // 如果偏好设置未设置,则不使用动画
  17. const { tabbar, transition } = preferences;
  18. const transitionName = transition.name;
  19. if (!transitionName || !transition.enable) {
  20. return;
  21. }
  22. // 标签页未启用或者未开启缓存,则使用全局配置动画
  23. if (!tabbar.enable || !keepAlive) {
  24. return transitionName;
  25. }
  26. // 如果页面已经加载过,则不使用动画
  27. // if (route.meta.loaded) {
  28. // return;
  29. // }
  30. // 已经打开且已经加载过的页面不使用动画
  31. const inTabs = getCachedTabs.value.includes(route.name as string);
  32. return inTabs && route.meta.loaded ? undefined : transitionName;
  33. }
  34. </script>
  35. <template>
  36. <div class="relative h-full">
  37. <Spinner
  38. v-if="preferences.transition.loading"
  39. :spinning="spinning"
  40. class="h-[var(--vben-content-client-height)]"
  41. />
  42. <IFrameRouterView />
  43. <RouterView v-slot="{ Component, route }">
  44. <Transition :name="getTransitionName(route)" appear mode="out-in">
  45. <KeepAlive
  46. v-if="keepAlive"
  47. :exclude="getExcludeCachedTabs"
  48. :include="getCachedTabs"
  49. >
  50. <component
  51. :is="Component"
  52. v-if="renderRouteView"
  53. v-show="!route.meta.iframeSrc"
  54. :key="route.fullPath"
  55. />
  56. </KeepAlive>
  57. <component
  58. :is="Component"
  59. v-else-if="renderRouteView"
  60. :key="route.fullPath"
  61. />
  62. </Transition>
  63. </RouterView>
  64. </div>
  65. </template>