mirror of
https://github.com/router-for-me/Cli-Proxy-API-Management-Center.git
synced 2026-02-02 19:00:49 +08:00
49 lines
1.4 KiB
TypeScript
49 lines
1.4 KiB
TypeScript
import { useEffect } from 'react';
|
|
import { HashRouter, Route, Routes } from 'react-router-dom';
|
|
import { LoginPage } from '@/pages/LoginPage';
|
|
import { NotificationContainer } from '@/components/common/NotificationContainer';
|
|
import { ConfirmationModal } from '@/components/common/ConfirmationModal';
|
|
import { MainLayout } from '@/components/layout/MainLayout';
|
|
import { ProtectedRoute } from '@/router/ProtectedRoute';
|
|
import { useLanguageStore, useThemeStore } from '@/stores';
|
|
|
|
function App() {
|
|
const initializeTheme = useThemeStore((state) => state.initializeTheme);
|
|
const language = useLanguageStore((state) => state.language);
|
|
const setLanguage = useLanguageStore((state) => state.setLanguage);
|
|
|
|
useEffect(() => {
|
|
const cleanupTheme = initializeTheme();
|
|
return cleanupTheme;
|
|
}, [initializeTheme]);
|
|
|
|
useEffect(() => {
|
|
setLanguage(language);
|
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
}, []); // 仅用于首屏同步 i18n 语言
|
|
|
|
useEffect(() => {
|
|
document.documentElement.lang = language;
|
|
}, [language]);
|
|
|
|
return (
|
|
<HashRouter>
|
|
<NotificationContainer />
|
|
<ConfirmationModal />
|
|
<Routes>
|
|
<Route path="/login" element={<LoginPage />} />
|
|
<Route
|
|
path="/*"
|
|
element={
|
|
<ProtectedRoute>
|
|
<MainLayout />
|
|
</ProtectedRoute>
|
|
}
|
|
/>
|
|
</Routes>
|
|
</HashRouter>
|
|
);
|
|
}
|
|
|
|
export default App;
|