import {useSettings} from '@common/core/settings/use-settings'; import {useAppearanceEditorMode} from '@common/admin/appearance/commands/use-appearance-editor-mode'; import {useAuth} from '@common/auth/use-auth'; import {Route, Routes} from 'react-router-dom'; import {ToastContainer} from '@common/ui/toast/toast-container'; import {EmailVerificationPage} from '@common/auth/ui/email-verification-page/email-verification-page'; import {AppearanceListener} from '@common/admin/appearance/commands/appearance-listener'; import {CookieNotice} from '@common/ui/cookie-notice/cookie-notice'; import {AuthRoute} from '@common/auth/guards/auth-route'; import React, {Fragment} from 'react'; import {FullPageLoader} from '@common/ui/progress/full-page-loader'; import {DynamicHomepage} from '@common/ui/dynamic-homepage'; import {LandingPage} from '@app/landing-page/landing-page'; import {AuthRoutes} from '@common/auth/auth-routes'; import {BillingRoutes} from '@common/billing/billing-routes'; import {NotificationRoutes} from '@common/notifications/notification-routes'; import {ContactUsPage} from '@common/contact/contact-us-page'; import {CustomPageLayout} from '@common/custom-page/custom-page-layout'; import {NotFoundPage} from '@common/ui/not-found-page/not-found-page'; import {DialogStoreOutlet} from '@common/ui/overlays/store/dialog-store-outlet'; const AdminRoutes = React.lazy(() => import('@common/admin/admin-routes')); const SwaggerApiDocs = React.lazy( () => import('@common/swagger/swagger-api-docs-page') ); const SiteRoutes = React.lazy(() => import('@app/site-routes')); export function AppRoutes() { const {homepage, billing, notifications, require_email_confirmation, api} = useSettings(); const {isAppearanceEditorActive} = useAppearanceEditorMode(); const {user, hasPermission} = useAuth(); if (user != null && require_email_confirmation && !user.email_verified_at) { return ( } /> ); } return ( }> } /> {!homepage?.type?.startsWith('channel') && (user == null || isAppearanceEditorActive) && ( } /> } /> )} }> } /> {AuthRoutes} {billing.enable && BillingRoutes} {notifications.integrated && NotificationRoutes} {api?.integrated && hasPermission('api.access') && ( }> } /> )} } /> } /> } /> } /> ); }