Files
nexus-terminal/packages/frontend/src/main.ts
T
2025-05-13 14:15:29 +08:00

97 lines
4.1 KiB
TypeScript

import { createApp } from 'vue';
import { createPinia } from 'pinia'; // 引入 Pinia
import piniaPluginPersistedstate from 'pinia-plugin-persistedstate'; // 引入持久化插件
import App from './App.vue';
import router from './router'; // 引入我们创建的 router
import i18n from './i18n'; // 引入 i18n 实例
import { useAuthStore } from './stores/auth.store'; // 引入 Auth Store
import { useSettingsStore } from './stores/settings.store'; // 引入 Settings Store
import { useAppearanceStore } from './stores/appearance.store'; // 引入 Appearance Store
import './style.css';
// 导入 Font Awesome CSS
import '@fortawesome/fontawesome-free/css/all.min.css';
// 导入 splitpanes CSS
import 'splitpanes/dist/splitpanes.css';
const pinia = createPinia(); // 创建 Pinia 实例
pinia.use(piniaPluginPersistedstate); // 使用持久化插件
const app = createApp(App);
app.use(pinia); // 使用配置好的 Pinia 实例
// 注意:在状态初始化完成前,暂时不 use(router)
app.use(i18n); // 使用 i18n
// --- 应用初始化逻辑 ---
// 使用 async IIFE 来允许顶层 await
(async () => {
const authStore = useAuthStore(pinia); // 实例化 Auth Store
// **提前实例化 AppearanceStore 以确保 immediate watcher 运行**
const appearanceStore = useAppearanceStore(pinia);
try {
console.log("[main.ts] 开始检查设置和认证状态...");
// 1. 同时检查设置和认证状态,并等待它们完成
// 确保 checkAuthStatus 可以在 needsSetup=true 时也能安全运行并返回正确状态
await Promise.all([
authStore.checkSetupStatus(),
authStore.checkAuthStatus()
]);
console.log(`[main.ts] 状态检查完成: needsSetup=${authStore.needsSetup}, isAuthenticated=${authStore.isAuthenticated}`);
// 2. 如果不需要设置且用户已认证,则加载用户特定数据
if (!authStore.needsSetup && authStore.isAuthenticated) {
console.log("[main.ts] 用户已认证且无需设置,加载设置和外观数据...");
const settingsStore = useSettingsStore(pinia);
try {
await Promise.all([
settingsStore.loadInitialSettings(),
appearanceStore.loadInitialAppearanceData() // 调用已实例化的 store 的 action
]);
console.log("[main.ts] 用户设置和外观数据加载完成。");
} catch (error) {
console.error("[main.ts] 加载用户设置或外观数据失败:", error);
// 加载失败也继续,可能使用默认值或显示错误
}
} else if (authStore.needsSetup) {
console.log("[main.ts] 需要初始设置,将由路由守卫处理重定向。");
// 不再手动 router.push('/setup')
} else {
console.log("[main.ts] 用户未认证或无需设置。");
// appearanceStore 已实例化,其 immediate watcher 会应用默认主题
}
// 3. 状态和数据准备就绪后,再启用路由并挂载应用
console.log("[main.ts] 状态准备就绪,启用路由并挂载应用...");
app.use(router); // 在这里启用路由,确保守卫能获取到最新状态
await router.isReady(); // 等待路由初始化完成 (特别是异步路由加载)
app.mount('#app');
console.log("[main.ts] 应用已挂载。");
} catch (error) {
// 捕获初始化过程中的意外错误
console.error("[main.ts] 应用初始化过程中发生严重错误:", error);
// 即使发生严重错误,也尝试启用路由并挂载应用,可能显示错误页面或回退状态
app.use(router); // 确保路由被添加
try {
await router.isReady();
} catch (routerError) {
console.error("[main.ts] 路由初始化失败:", routerError);
}
app.mount('#app');
}
// --- PWA Service Worker Registration ---
if ('serviceWorker' in navigator) {
window.addEventListener('load', () => {
navigator.serviceWorker.register('/sw.js').then(registration => {
console.log('SW registered: ', registration);
}).catch(registrationError => {
console.log('SW registration failed: ', registrationError);
});
});
}
})();