first commit
Some checks failed
Build / run (push) Has been cancelled

This commit is contained in:
maher
2025-10-29 11:42:25 +01:00
commit 703f50a09d
4595 changed files with 385164 additions and 0 deletions

101
resources/client/app-routes.tsx Executable file
View File

@@ -0,0 +1,101 @@
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 (
<Fragment>
<ToastContainer />
<Routes>
<Route path="*" element={<EmailVerificationPage />} />
</Routes>
</Fragment>
);
}
return (
<Fragment>
<AppearanceListener />
<CookieNotice />
<ToastContainer />
<Routes>
<Route
path="/*"
element={
<AuthRoute requireLogin={false} permission="titles.view">
<React.Suspense fallback={<FullPageLoader screen />}>
<SiteRoutes />
</React.Suspense>
</AuthRoute>
}
/>
{!homepage?.type?.startsWith('channel') &&
(user == null || isAppearanceEditorActive) && (
<Route
path="/"
element={
<DynamicHomepage homepageResolver={() => <LandingPage />} />
}
/>
)}
<Route
path="/admin/*"
element={
<AuthRoute permission="admin.access">
<React.Suspense fallback={<FullPageLoader screen />}>
<AdminRoutes />
</React.Suspense>
</AuthRoute>
}
/>
{AuthRoutes}
{billing.enable && BillingRoutes}
{notifications.integrated && NotificationRoutes}
{api?.integrated && hasPermission('api.access') && (
<Route
path="api-docs"
element={
<React.Suspense fallback={<FullPageLoader screen />}>
<SwaggerApiDocs />
</React.Suspense>
}
/>
)}
<Route path="contact" element={<ContactUsPage />} />
<Route path="pages/:pageSlug" element={<CustomPageLayout />} />
<Route path="pages/:pageId/:pageSlug" element={<CustomPageLayout />} />
<Route path="*" element={<NotFoundPage />} />
</Routes>
<DialogStoreOutlet />
</Fragment>
);
}