import { AppInsightsBoundary } from '@logto/app-insights/react'; import { UserScope } from '@logto/core-kit'; import { LogtoProvider } from '@logto/react'; import { adminConsoleApplicationId, PredefinedScope } from '@logto/schemas'; import { conditionalArray, deduplicate } from '@silverhand/essentials'; import { useContext, useMemo } from 'react'; import { Helmet } from 'react-helmet'; import 'overlayscrollbars/overlayscrollbars.css'; import './scss/normalized.scss'; import './scss/overlayscrollbars.scss'; // eslint-disable-next-line import/no-unassigned-import import '@fontsource/roboto-mono'; import CloudApp from '@/cloud/App'; import { cloudApi, getManagementApi, meApi } from '@/consts/resources'; import { adminTenantEndpoint, mainTitle } from './consts'; import { isCloud } from './consts/env'; import ErrorBoundary from './containers/ErrorBoundary'; import TenantAppContainer from './containers/TenantAppContainer'; import AppConfirmModalProvider from './contexts/AppConfirmModalProvider'; import AppEndpointsProvider from './contexts/AppEndpointsProvider'; import { AppThemeProvider } from './contexts/AppThemeProvider'; import TenantsProvider, { TenantsContext } from './contexts/TenantsProvider'; import initI18n from './i18n/init'; void initI18n(); function Content() { const { tenants, currentTenantId } = useContext(TenantsContext); const resources = useMemo( () => deduplicate( conditionalArray( // Explicitly add `currentTenantId` and deduplicate since the user may directly // access a URL with Tenant ID, adding the ID from the URL here can possibly remove one // additional redirect. currentTenantId && getManagementApi(currentTenantId).indicator, ...tenants.map(({ id }) => getManagementApi(id).indicator), isCloud && cloudApi.indicator, meApi.indicator ) ), [currentTenantId, tenants] ); const scopes = useMemo( () => [ UserScope.Email, UserScope.Identities, UserScope.CustomData, PredefinedScope.All, ...conditionalArray( isCloud && cloudApi.scopes.CreateTenant, isCloud && cloudApi.scopes.ManageTenant, isCloud && cloudApi.scopes.ManageTenantSelf ), ], [] ); return ( {/** * If it's not Cloud (OSS), render the tenant app container directly since only default tenant is available; * if it's Cloud, render the tenant app container only when init is complete and a tenant ID is available (in a tenant context). */} {!isCloud || currentTenantId ? ( ) : ( )} ); } function App() { return ( ); } export default App;