1Panel/frontend/src/App.vue

38 lines
950 B
Vue

<template>
<el-config-provider :locale="i18nLocale" :button="config" size="default">
<router-view v-if="isRouterAlive" />
</el-config-provider>
</template>
<script setup lang="ts">
import { reactive, computed, ref, nextTick, provide } from 'vue';
import { GlobalStore } from '@/store';
import zhCn from 'element-plus/es/locale/lang/zh-cn';
import en from 'element-plus/es/locale/lang/en';
import { useTheme } from '@/hooks/use-theme';
useTheme();
const globalStore = GlobalStore();
const config = reactive({
autoInsertSpace: false,
});
const i18nLocale = computed(() => {
if (globalStore.language === 'zh') return zhCn;
if (globalStore.language === 'en') return en;
return zhCn;
});
const isRouterAlive = ref(true);
const reload = () => {
isRouterAlive.value = false;
nextTick(() => {
isRouterAlive.value = true;
});
};
provide('reload', reload);
</script>
<style scoped lang="scss"></style>