0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-01-13 21:30:30 -05:00
logto/packages/console/src/App.tsx

44 lines
1.1 KiB
TypeScript
Raw Normal View History

import React, { useEffect } from 'react';
import { BrowserRouter, useLocation, useNavigate } from 'react-router-dom';
2022-02-27 21:35:14 -05:00
import './scss/normalized.scss';
import * as styles from './App.module.scss';
import AppContent from './components/AppContent';
2022-02-27 21:35:14 -05:00
import Content from './components/Content';
import Sidebar, { getPath, sections } from './components/Sidebar';
2022-02-27 21:35:14 -05:00
import Topbar from './components/Topbar';
2022-02-28 09:18:01 -05:00
import initI18n from './i18n/init';
const isBasenameNeeded = process.env.NODE_ENV !== 'development' || process.env.PORT === '5002';
2022-02-28 09:18:01 -05:00
void initI18n();
const Main = () => {
const location = useLocation();
const navigate = useNavigate();
useEffect(() => {
if (location.pathname === '/') {
navigate(getPath(sections[0]?.items[0]?.title ?? ''));
}
}, [location.pathname, navigate]);
2022-02-27 21:35:14 -05:00
return (
<AppContent theme="light">
2022-02-27 21:35:14 -05:00
<Topbar />
<div className={styles.content}>
<Sidebar />
<Content />
</div>
</AppContent>
2022-02-27 21:35:14 -05:00
);
};
const App = () => (
<BrowserRouter basename={isBasenameNeeded ? '/console' : ''}>
<Main />
</BrowserRouter>
);
export default App;