0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2024-12-23 20:33:16 -05:00
logto/packages/console/src/App.tsx

76 lines
2.7 KiB
TypeScript
Raw Normal View History

2022-03-11 06:04:27 -05:00
import { LogtoProvider } from '@logto/react';
import React, { useEffect } from 'react';
import { BrowserRouter, Navigate, Route, Routes, useLocation, useNavigate } from 'react-router-dom';
import { SWRConfig } from 'swr';
2022-02-27 21:35:14 -05:00
import './scss/normalized.scss';
import AppContent from './components/AppContent';
2022-03-11 06:04:27 -05:00
import { getPath, sections } from './components/AppContent/components/Sidebar';
import Callback from './components/Callback';
import Toast from './components/Toast';
2022-02-28 09:18:01 -05:00
import initI18n from './i18n/init';
import ApiResourceDetails from './pages/ApiResourceDetails';
import ApiResources from './pages/ApiResources';
import ApplicationDetails from './pages/ApplicationDetails';
import Applications from './pages/Applications';
import ConnectorDetails from './pages/ConnectorDetails';
2022-03-07 22:10:46 -05:00
import Connectors from './pages/Connectors';
2022-03-14 04:13:24 -05:00
import Users from './pages/Users';
import { fetcher } from './swr';
2022-02-28 09:18:01 -05:00
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 (
2022-03-11 06:04:27 -05:00
<LogtoProvider logtoConfig={{ endpoint: 'https://logto.dev', clientId: 'foo' }}>
<SWRConfig value={{ fetcher }}>
<Toast />
<Routes>
<Route path="callback" element={<Callback />} />
<Route element={<AppContent theme="light" />}>
<Route path="applications">
<Route index element={<Applications />} />
<Route path=":id">
<Route index element={<Navigate to="settings" />} />
<Route path="settings" element={<ApplicationDetails />} />
<Route path="advanced-settings" element={<ApplicationDetails />} />
</Route>
2022-03-11 06:04:27 -05:00
</Route>
<Route path="api-resources">
<Route index element={<ApiResources />} />
<Route path=":id" element={<ApiResourceDetails />} />
</Route>
<Route path="connectors">
<Route index element={<Connectors />} />
<Route path="social" element={<Connectors />} />
<Route path=":connectorId" element={<ConnectorDetails />} />
</Route>
<Route path="users">
<Route index element={<Users />} />
</Route>
</Route>
</Routes>
</SWRConfig>
</LogtoProvider>
2022-02-27 21:35:14 -05:00
);
};
const App = () => (
<BrowserRouter basename={isBasenameNeeded ? '/console' : ''}>
<Main />
</BrowserRouter>
);
export default App;