2022-03-03 02:02:30 -05:00
|
|
|
import React, { useEffect } from 'react';
|
2022-03-03 04:44:25 -05:00
|
|
|
import { BrowserRouter, Route, Routes, useLocation, useNavigate } from 'react-router-dom';
|
2022-02-16 02:04:34 -05:00
|
|
|
|
2022-02-27 21:35:14 -05:00
|
|
|
import './scss/normalized.scss';
|
2022-02-16 02:04:34 -05:00
|
|
|
import * as styles from './App.module.scss';
|
2022-03-03 02:15:33 -05:00
|
|
|
import AppContent from './components/AppContent';
|
2022-02-27 21:35:14 -05:00
|
|
|
import Content from './components/Content';
|
2022-03-03 02:02:30 -05:00
|
|
|
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';
|
2022-03-03 04:44:25 -05:00
|
|
|
import ApiResources from './pages/ApiResources';
|
2022-02-28 09:18:01 -05:00
|
|
|
|
2022-03-03 02:44:42 -05:00
|
|
|
const isBasenameNeeded = process.env.NODE_ENV !== 'development' || process.env.PORT === '5002';
|
|
|
|
|
2022-02-28 09:18:01 -05:00
|
|
|
void initI18n();
|
2022-02-16 02:04:34 -05:00
|
|
|
|
2022-03-03 02:02:30 -05:00
|
|
|
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 (
|
2022-03-03 02:15:33 -05:00
|
|
|
<AppContent theme="light">
|
2022-02-27 21:35:14 -05:00
|
|
|
<Topbar />
|
|
|
|
<div className={styles.content}>
|
|
|
|
<Sidebar />
|
2022-03-03 04:44:25 -05:00
|
|
|
<Content>
|
|
|
|
<Routes>
|
|
|
|
<Route path="api-resources" element={<ApiResources />} />
|
|
|
|
</Routes>
|
|
|
|
</Content>
|
2022-02-27 21:35:14 -05:00
|
|
|
</div>
|
2022-03-03 02:15:33 -05:00
|
|
|
</AppContent>
|
2022-02-27 21:35:14 -05:00
|
|
|
);
|
2022-02-16 02:04:34 -05:00
|
|
|
};
|
2022-03-03 02:02:30 -05:00
|
|
|
|
|
|
|
const App = () => (
|
2022-03-03 02:44:42 -05:00
|
|
|
<BrowserRouter basename={isBasenameNeeded ? '/console' : ''}>
|
2022-03-03 02:02:30 -05:00
|
|
|
<Main />
|
|
|
|
</BrowserRouter>
|
|
|
|
);
|
|
|
|
|
|
|
|
export default App;
|