0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2024-12-30 20:33:54 -05:00
logto/packages/console/src/App.tsx
Gao Sun 71e5da6216
feat(console): app details header (#327)
* feat(console): init app details

* feat(console): loading app details from api

* fix(console): back to app i18n

* refactor(console): add img placeholder alt
2022-03-08 14:53:49 +08:00

62 lines
2 KiB
TypeScript

import React, { useEffect } from 'react';
import { BrowserRouter, Route, Routes, useLocation, useNavigate } from 'react-router-dom';
import { SWRConfig } from 'swr';
import './scss/normalized.scss';
import * as styles from './App.module.scss';
import AppContent from './components/AppContent';
import Content from './components/Content';
import Sidebar, { getPath, sections } from './components/Sidebar';
import Topbar from './components/Topbar';
import initI18n from './i18n/init';
import ApiResources from './pages/ApiResources';
import ApplicationDetails from './pages/ApplicationDetails';
import Applications from './pages/Applications';
import Connectors from './pages/Connectors';
import Connector from './pages/Connectors/Connector';
import { fetcher } from './swr';
const isBasenameNeeded = process.env.NODE_ENV !== 'development' || process.env.PORT === '5002';
void initI18n();
const Main = () => {
const location = useLocation();
const navigate = useNavigate();
useEffect(() => {
if (location.pathname === '/') {
navigate(getPath(sections[0]?.items[0]?.title ?? ''));
}
}, [location.pathname, navigate]);
return (
<SWRConfig value={{ fetcher }}>
<AppContent theme="light">
<Topbar />
<div className={styles.content}>
<Sidebar />
<Content>
<Routes>
<Route path="api-resources" element={<ApiResources />} />
<Route path="connectors" element={<Connectors />} />
<Route path="connectors/:connectorId" element={<Connector />} />
<Route path="applications">
<Route index element={<Applications />} />
<Route path=":id" element={<ApplicationDetails />} />
</Route>
</Routes>
</Content>
</div>
</AppContent>
</SWRConfig>
);
};
const App = () => (
<BrowserRouter basename={isBasenameNeeded ? '/console' : ''}>
<Main />
</BrowserRouter>
);
export default App;