App.vue 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <template>
  2. <a-config-provider
  3. :locale="zhCN"
  4. :theme="{
  5. token: {
  6. colorPrimary: '#bd4b36',
  7. },
  8. }"
  9. :componentSize="'large'"
  10. >
  11. <NavBar v-if="!isInMiniProgram" />
  12. <main>
  13. <RouterView v-slot="{ Component }">
  14. <KeepAlive>
  15. <component :is="Component" v-if="route.meta.keepAlive" />
  16. </KeepAlive>
  17. <component :is="Component" v-if="!route.meta.keepAlive" />
  18. </RouterView>
  19. </main>
  20. <FooterSmall v-if="!isInMiniProgram" />
  21. </a-config-provider>
  22. </template>
  23. <script setup lang="ts">
  24. import { onMounted, watch } from 'vue';
  25. import { RouterView, useRoute } from 'vue-router'
  26. import { useAuthStore } from './stores/auth';
  27. import { useRedirectLoginPage } from './common/LoginPageRedirect';
  28. import { useAppConfiguration } from './api/system/useAppConfiguration';
  29. import NavBar from './components/NavBar.vue';
  30. import zhCN from "ant-design-vue/es/locale/zh_CN";
  31. import FooterSmall from './components/FooterSmall.vue';
  32. import { isInMiniProgram } from './composeables/MiniProgramIng.ts';
  33. const authStore = useAuthStore();
  34. const { checkAndRedirectLoginPage } = useRedirectLoginPage();
  35. const { loadAppConfiguration } = useAppConfiguration();
  36. onMounted(async () => {
  37. await authStore.loadLoginState();
  38. checkAndRedirectLoginPage();
  39. await loadAppConfiguration();
  40. });
  41. const route = useRoute();
  42. watch(route, () => {
  43. window.scrollTo({
  44. top: 0,
  45. behavior: 'instant'
  46. });
  47. checkAndRedirectLoginPage();
  48. });
  49. </script>
  50. <style>
  51. @import "./assets/scss/main.scss";
  52. @import "vue3-carousel/carousel.css";
  53. @import "@vuemap/vue-amap/dist/style.css";
  54. @import "@imengyu/vue-scroll-rect/lib/vue-scroll-rect.css";
  55. </style>