mirror of
https://github.com/1Panel-dev/1Panel.git
synced 2024-11-24 11:09:16 +08:00
38 lines
950 B
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>
|