MeterSphere/frontend/src/App.vue

114 lines
4.2 KiB
Vue
Raw Normal View History

2023-05-24 11:08:08 +08:00
<template>
<a-config-provider :locale="locale">
<router-view />
<!-- <global-setting /> -->
2023-05-24 11:08:08 +08:00
</a-config-provider>
</template>
<script lang="ts" setup>
import { computed, onBeforeMount, onMounted } from 'vue';
import { useRoute, useRouter } from 'vue-router';
import { useEventListener, useWindowSize } from '@vueuse/core';
2024-01-24 21:53:12 +08:00
import { getProjectInfo } from '@/api/modules/project-management/basicInfo';
import { saveBaseUrl } from '@/api/modules/setting/config';
import { GetPlatformIconUrl } from '@/api/requrls/setting/config';
// import GlobalSetting from '@/components/pure/global-setting/index.vue';
2023-05-24 11:08:08 +08:00
import useLocale from '@/locale/useLocale';
2024-01-29 12:08:30 +08:00
import { NO_PROJECT_ROUTE_NAME, WHITE_LIST } from '@/router/constants';
import { useUserStore } from '@/store';
import useAppStore from '@/store/modules/app';
import useLicenseStore from '@/store/modules/setting/license';
import { getLocalStorage, setLocalStorage } from '@/utils/local-storage';
import { setFavicon, watchStyle, watchTheme } from '@/utils/theme';
import { getPublicKeyRequest } from './api/modules/user';
import { WorkbenchRouteEnum } from './enums/routeEnum';
import enUS from '@arco-design/web-vue/es/locale/lang/en-us';
import zhCN from '@arco-design/web-vue/es/locale/lang/zh-cn';
const appStore = useAppStore();
const userStore = useUserStore();
const licenseStore = useLicenseStore();
const router = useRouter();
const route = useRoute();
2023-05-24 11:08:08 +08:00
const { currentLocale } = useLocale();
const locale = computed(() => {
switch (currentLocale.value) {
case 'zh-CN':
return zhCN;
case 'en-US':
return enUS;
default:
return zhCN;
}
});
// 初始化平台风格和主题色
watchStyle(appStore.pageConfig.style, appStore.pageConfig);
watchTheme(appStore.pageConfig.theme, appStore.pageConfig);
setFavicon(GetPlatformIconUrl);
onBeforeMount(async () => {
try {
appStore.initSystemVersion(); // 初始化系统版本
licenseStore.getValidateLicense(); // 初始化校验license
if (licenseStore.hasLicense()) {
appStore.initPageConfig(); // 初始化页面配置
}
// 项目初始化时需要获取基础设置信息,看当前站点 url是否为系统内置默认地址如果是需要替换为当前项目部署的 url 地址
const isInitUrl = getLocalStorage('isInitUrl'); // 是否已经初始化过 url
if (isInitUrl === 'true') return;
await saveBaseUrl(window.location.origin);
setLocalStorage('isInitUrl', 'true'); // 设置已经初始化过 url避免重复初始化
} catch (error) {
// eslint-disable-next-line no-console
console.log(error);
}
});
const checkIsLogin = async () => {
const isLogin = await userStore.isLogin();
const isLoginPage = route.name === 'login';
2024-01-29 12:08:30 +08:00
if (isLogin && appStore.currentProjectId && appStore.currentProjectId !== 'no_such_project') {
// 当前为登陆状态,且已经选择了项目,初始化当前项目配置
2024-01-24 21:53:12 +08:00
try {
const res = await getProjectInfo(appStore.currentProjectId);
if (res.deleted || !res.enable) {
// 如果项目被删除或者被禁用,跳转到无项目页面
2024-01-29 12:08:30 +08:00
router.push(NO_PROJECT_ROUTE_NAME);
2024-01-24 21:53:12 +08:00
return;
}
appStore.setCurrentMenuConfig(res.moduleIds);
} catch (err) {
appStore.setCurrentMenuConfig([]);
// eslint-disable-next-line no-console
console.log(err);
}
}
if (isLoginPage && isLogin) {
// 当前页面为登录页面,且已经登录,跳转到首页
router.push(WorkbenchRouteEnum.WORKBENCH);
}
};
// 获取公钥
const getPublicKey = async () => {
const publicKey = await getPublicKeyRequest();
setLocalStorage('salt', publicKey);
};
onMounted(async () => {
await getPublicKey();
if (WHITE_LIST.find((el) => el.path === window.location.hash.split('#')[1]) === undefined) {
await checkIsLogin();
}
2023-09-13 18:54:24 +08:00
const { height } = useWindowSize();
appStore.innerHeight = height.value;
});
/** 屏幕大小改变时重新赋值innerHeight */
useEventListener(window, 'resize', () => {
const { height } = useWindowSize();
appStore.innerHeight = height.value;
});
2023-05-24 11:08:08 +08:00
</script>