File size: 1,343 Bytes
bbb1195 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 | import { createBrowserRouter, RouterProvider } from 'react-router-dom';
import Layout from './components/layout/Layout';
import Dashboard from './pages/Dashboard';
import Accounts from './pages/Accounts';
import Settings from './pages/Settings';
import ApiProxy from './pages/ApiProxy';
import ThemeManager from './components/common/ThemeManager';
import { useEffect } from 'react';
import { useConfigStore } from './stores/useConfigStore';
import { useTranslation } from 'react-i18next';
const router = createBrowserRouter([
{
path: '/',
element: <Layout />,
children: [
{
index: true,
element: <Dashboard />,
},
{
path: 'accounts',
element: <Accounts />,
},
{
path: 'api-proxy',
element: <ApiProxy />,
},
{
path: 'settings',
element: <Settings />,
},
],
},
]);
function App() {
const { config, loadConfig } = useConfigStore();
const { i18n } = useTranslation();
useEffect(() => {
loadConfig();
}, [loadConfig]);
// Sync language from config
useEffect(() => {
if (config?.language) {
i18n.changeLanguage(config.language);
}
}, [config?.language, i18n]);
return (
<>
<ThemeManager />
<RouterProvider router={router} />
</>
);
}
export default App;
|