Files
ops2/frontend/ops_vue_js/src/main.js
T
2026-06-11 13:32:21 +08:00

47 lines
1.3 KiB
JavaScript

import { createApp } from 'vue'
import { createI18n } from 'vue-i18n'
import { createPinia } from 'pinia'
import App from './App.vue'
import router from './router'
import './assets/main.css'
// Initialize theme and locale from localStorage
const savedTheme = localStorage.getItem('theme') // 改用 'theme' key
const savedLocale = localStorage.getItem('locale')
const prefersDark = window.matchMedia('(prefers-color-scheme: dark)').matches
if (savedTheme === 'dark' || (!savedTheme && prefersDark)) {
document.documentElement.classList.add('dark')
} else {
document.documentElement.classList.remove('dark')
}
import en from './i18n/en.json'
import zhCN from './i18n/zh-CN.json'
const i18n = createI18n({
legacy: false,
locale: savedLocale || 'en', // 使用已保存的语言或默认英文
fallbackLocale: 'en',
messages: {
en,
'zh-CN': zhCN,
},
})
const pinia = createPinia()
const app = createApp(App)
app.use(pinia)
app.use(router)
app.use(i18n)
// 在 mount 前恢复登录状态,确保所有子组件 onMounted 时 isLoggedIn 已正确初始化
// 避免 AiChatView 等组件因时序问题先以"未登录"状态渲染再跃迁
import { useUserStore } from '@/stores/user'
const userStore = useUserStore()
userStore.restoreSession()
app.mount('#app')