123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- <template>
- <el-config-provider :locale="currentLocale">
- <router-view />
- <ReDialog />
- </el-config-provider>
- </template>
- <script lang="ts">
- import { defineComponent } from "vue";
- import { checkVersion } from "version-rocket";
- import { ElConfigProvider } from "element-plus";
- import en from "element-plus/dist/locale/en.mjs";
- import { ReDialog } from "@/components/ReDialog";
- import zhCn from "element-plus/dist/locale/zh-cn.mjs";
- export default defineComponent({
- name: "app",
- components: {
- [ElConfigProvider.name]: ElConfigProvider,
- ReDialog
- },
- computed: {
- currentLocale() {
- return this.$storage.locale?.locale === "zh" ? zhCn : en;
- }
- },
- beforeCreate() {
- const { version, name: title } = __APP_INFO__.pkg;
- const { VITE_PUBLIC_PATH, MODE } = import.meta.env;
- // https://github.com/guMcrey/version-rocket/blob/main/README.zh-CN.md#api
- if (MODE === "production") {
- // 版本实时更新检测,只作用于线上环境
- checkVersion(
- // config
- {
- // 5分钟检测一次版本
- pollingTime: 300000,
- localPackageVersion: version,
- originVersionFileUrl: `${location.origin}${VITE_PUBLIC_PATH}version.json`
- },
- // options
- {
- title,
- description: "检测到新版本",
- buttonText: "立即更新"
- }
- );
- }
- }
- });
- </script>
|