2022-03-11 06:04:27 -05:00
|
|
|
import { LogtoProvider } from '@logto/react';
|
2022-04-29 08:01:28 -05:00
|
|
|
import { AppearanceMode, Setting } from '@logto/schemas';
|
2022-03-03 02:02:30 -05:00
|
|
|
import React, { useEffect } from 'react';
|
2022-03-14 23:42:42 -05:00
|
|
|
import { BrowserRouter, Navigate, Route, Routes, useLocation, useNavigate } from 'react-router-dom';
|
2022-04-29 08:01:28 -05:00
|
|
|
import useSWR, { SWRConfig } from 'swr';
|
2022-02-27 21:35:14 -05:00
|
|
|
import './scss/normalized.scss';
|
2022-03-04 04:26:34 -05:00
|
|
|
|
2022-04-29 08:01:28 -05:00
|
|
|
import * as styles from './App.module.scss';
|
2022-03-03 02:15:33 -05:00
|
|
|
import AppContent from './components/AppContent';
|
2022-03-11 06:04:27 -05:00
|
|
|
import { getPath, sections } from './components/AppContent/components/Sidebar';
|
2022-03-09 23:52:56 -05:00
|
|
|
import Toast from './components/Toast';
|
2022-04-29 08:01:28 -05:00
|
|
|
import { themeStorageKey, logtoApiResource } from './consts';
|
|
|
|
import { RequestError } from './hooks/use-api';
|
2022-03-16 02:34:03 -05:00
|
|
|
import useSwrFetcher from './hooks/use-swr-fetcher';
|
2022-02-28 09:18:01 -05:00
|
|
|
import initI18n from './i18n/init';
|
2022-03-09 04:56:50 -05:00
|
|
|
import ApiResourceDetails from './pages/ApiResourceDetails';
|
2022-03-03 04:44:25 -05:00
|
|
|
import ApiResources from './pages/ApiResources';
|
2022-03-08 01:53:49 -05:00
|
|
|
import ApplicationDetails from './pages/ApplicationDetails';
|
2022-03-03 23:47:02 -05:00
|
|
|
import Applications from './pages/Applications';
|
2022-03-15 00:22:07 -05:00
|
|
|
import Callback from './pages/Callback';
|
2022-03-09 02:54:46 -05:00
|
|
|
import ConnectorDetails from './pages/ConnectorDetails';
|
2022-03-07 22:10:46 -05:00
|
|
|
import Connectors from './pages/Connectors';
|
2022-03-16 02:49:30 -05:00
|
|
|
import NotFound from './pages/NotFound';
|
2022-04-23 22:46:35 -05:00
|
|
|
import Settings from './pages/Settings';
|
2022-04-12 02:30:43 -05:00
|
|
|
import SignInExperience from './pages/SignInExperience';
|
2022-03-14 23:54:15 -05:00
|
|
|
import UserDetails from './pages/UserDetails';
|
2022-03-14 04:13:24 -05:00
|
|
|
import Users from './pages/Users';
|
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-04-29 08:01:28 -05:00
|
|
|
const defaultTheme = localStorage.getItem(themeStorageKey) ?? AppearanceMode.SyncWithSystem;
|
2022-02-16 02:04:34 -05:00
|
|
|
|
2022-03-03 02:02:30 -05:00
|
|
|
const Main = () => {
|
|
|
|
const location = useLocation();
|
|
|
|
const navigate = useNavigate();
|
2022-03-16 02:34:03 -05:00
|
|
|
const fetcher = useSwrFetcher();
|
2022-04-29 08:01:28 -05:00
|
|
|
const { data } = useSWR<Setting, RequestError>('/api/settings');
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
const theme = data?.adminConsole.appearanceMode ?? defaultTheme;
|
|
|
|
const isFollowSystem = theme === AppearanceMode.SyncWithSystem;
|
|
|
|
const className = styles[theme] ?? '';
|
|
|
|
|
|
|
|
if (!isFollowSystem) {
|
|
|
|
document.body.classList.add(className);
|
|
|
|
}
|
|
|
|
|
|
|
|
return () => {
|
|
|
|
if (!isFollowSystem) {
|
|
|
|
document.body.classList.remove(className);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}, [data?.adminConsole.appearanceMode]);
|
2022-03-03 02:02:30 -05:00
|
|
|
|
2022-04-29 20:36:51 -05:00
|
|
|
useEffect(() => {
|
|
|
|
(async () => {
|
|
|
|
void initI18n(data?.adminConsole.language);
|
|
|
|
})();
|
|
|
|
}, [data?.adminConsole.language]);
|
|
|
|
|
2022-03-03 02:02:30 -05:00
|
|
|
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-16 02:34:03 -05:00
|
|
|
<SWRConfig value={{ fetcher }}>
|
|
|
|
<Toast />
|
|
|
|
<Routes>
|
|
|
|
<Route path="callback" element={<Callback />} />
|
2022-04-29 08:01:28 -05:00
|
|
|
<Route element={<AppContent />}>
|
2022-03-16 02:49:30 -05:00
|
|
|
<Route path="*" element={<NotFound />} />
|
2022-03-16 02:34:03 -05:00
|
|
|
<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 />} />
|
2022-03-11 06:04:27 -05:00
|
|
|
</Route>
|
|
|
|
</Route>
|
2022-03-16 02:34:03 -05:00
|
|
|
<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 path=":id" element={<UserDetails />} />
|
|
|
|
</Route>
|
2022-04-12 02:30:43 -05:00
|
|
|
<Route path="sign-in-experience">
|
|
|
|
<Route index element={<Navigate to="experience" />} />
|
|
|
|
<Route path=":tab" element={<SignInExperience />} />
|
|
|
|
</Route>
|
2022-04-23 22:46:35 -05:00
|
|
|
<Route path="settings" element={<Settings />} />
|
2022-03-16 02:34:03 -05:00
|
|
|
</Route>
|
|
|
|
</Routes>
|
|
|
|
</SWRConfig>
|
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-16 02:34:03 -05:00
|
|
|
<LogtoProvider
|
|
|
|
config={{ endpoint: window.location.origin, clientId: 'foo', resources: [logtoApiResource] }}
|
|
|
|
>
|
|
|
|
<Main />
|
|
|
|
</LogtoProvider>
|
2022-03-03 02:02:30 -05:00
|
|
|
</BrowserRouter>
|
|
|
|
);
|
|
|
|
|
|
|
|
export default App;
|