Skip to content

Commit

Permalink
CW-performance
Browse files Browse the repository at this point in the history
Added React.lazy to routes
  • Loading branch information
pvm-code committed Oct 3, 2024
1 parent 81087f6 commit 0608a19
Show file tree
Hide file tree
Showing 15 changed files with 322 additions and 277 deletions.
5 changes: 3 additions & 2 deletions public/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -46,9 +46,10 @@
}

.loader-wrapper {
position: relative;
position: absolute;
left: 50%;
transform: translateX(-50%);
top: 50%;
transform: translate(-50%, -50%);
height: 75px;
width: 75px;
background-image: url(/icons/loader-pink.svg);
Expand Down
2 changes: 1 addition & 1 deletion src/pages/App/router/Router.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { ROUTES } from "./configuration";
const Router: FC = () => (
<Switch>
{ROUTES.map((layoutConfiguration, index) => (
<Layout key={index} {...layoutConfiguration} />
<Layout key={index} {...layoutConfiguration} />
))}
<Redirect />
</Switch>
Expand Down
9 changes: 5 additions & 4 deletions src/pages/App/router/components/Layout/Layout.tsx
Original file line number Diff line number Diff line change
@@ -1,19 +1,20 @@
import React, { FC } from "react";
import React, { FC, Suspense } from "react";
import { Route, Switch } from "react-router-dom";
import { LayoutConfigurationWithRouteProps } from "../../types";
import { LayoutRoute } from "../LayoutRoute";
import { SuspenseLoader } from "@/shared/ui-kit";

const Layout: FC<LayoutConfigurationWithRouteProps> = (props) => {
const { component: LayoutComponent, routes, ...restProps } = props;

return (
<LayoutRoute routeConfigurations={routes} {...restProps}>
<LayoutComponent>
<Suspense fallback={SuspenseLoader}>
<Switch>
{routes.map((route) => (
<Route key={route.path} {...route} />
))}
{routes.map((route) => <Route key={route.path} {...route} />)}
</Switch>
</Suspense>
</LayoutComponent>
</LayoutRoute>
);
Expand Down
31 changes: 17 additions & 14 deletions src/pages/App/router/components/LayoutRoute/LayoutRoute.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import React, { FC, useMemo } from "react";
import React, { FC, Suspense, useMemo } from "react";
import { useSelector } from "react-redux";
import { Route, RouteProps } from "react-router-dom";
import { Route as RouteConfiguration } from "@/pages/App/router/types";
Expand All @@ -9,6 +9,7 @@ import {
import { matchRoute } from "@/shared/utils";
import { LayoutRouteContext, LayoutRouteContextValue } from "./context";
import { renderRouteContent } from "./helpers";
import { SuspenseLoader } from "@/shared/ui-kit";

interface PrivateRouteProps extends RouteProps {
routeConfigurations: RouteConfiguration[];
Expand Down Expand Up @@ -36,19 +37,21 @@ const LayoutRoute: FC<PrivateRouteProps> = (props) => {

return (
<LayoutRouteContext.Provider value={contextValue}>
<Route
{...restProps}
render={(routeProps) =>
renderRouteContent({
...routeProps,
component,
children,
configuration: routeConfiguration,
userRoles: userRoles || [],
authenticated,
})
}
/>
<Suspense fallback={SuspenseLoader}>
<Route
{...restProps}
render={(routeProps) =>
renderRouteContent({
...routeProps,
component,
children,
configuration: routeConfiguration,
userRoles: userRoles || [],
authenticated,
})
}
/>
</Suspense>
</LayoutRouteContext.Provider>
);
};
Expand Down
133 changes: 66 additions & 67 deletions src/pages/App/router/configuration/commonSidenavLayout.tsx
Original file line number Diff line number Diff line change
@@ -1,76 +1,75 @@
import { BillingPage_v04 } from "@/pages/billing";
import { ALL_COMMON_PAGE_TABS, CommonPage_v04 } from "@/pages/common";
import {
CommonCreationPage,
ProjectCreationPage_v04,
} from "@/pages/commonCreation";
import { CommonEditingPage_v04 } from "@/pages/commonEditing";
import { CommonFeedPage_v04 } from "@/pages/commonFeed";
import { InboxPage_v04 } from "@/pages/inbox";
import { ProfilePage_v04 } from "@/pages/profile";
import { SettingsPage_v04 } from "@/pages/settings";
import React, { lazy } from "react";
import { ROUTE_PATHS } from "@/shared/constants";
import { CommonSidenavLayout } from "@/shared/layouts";
import { LayoutConfiguration, RouteType } from "../types";
import { ALL_COMMON_PAGE_TABS } from "@/pages/common";

const InboxPage_v04 = lazy(() => import("@/pages/inbox").then(module => ({ default: module.InboxPage_v04 })));
const CommonCreationPage = lazy(() => import("@/pages/commonCreation").then(module => ({ default: module.CommonCreationPage })));
const CommonFeedPage_v04 = lazy(() => import("@/pages/commonFeed").then(module => ({ default: module.CommonFeedPage_v04 })));
const ProjectCreationPage_v04 = lazy(() => import("@/pages/commonCreation").then(module => ({ default: module.ProjectCreationPage_v04 })));
const CommonEditingPage_v04 = lazy(() => import("@/pages/commonEditing").then(module => ({ default: module.CommonEditingPage_v04 })));
const ProfilePage_v04 = lazy(() => import("@/pages/profile").then(module => ({ default: module.ProfilePage_v04 })));
const BillingPage_v04 = lazy(() => import("@/pages/billing").then(module => ({ default: module.BillingPage_v04 })));
const SettingsPage_v04 = lazy(() => import("@/pages/settings").then(module => ({ default: module.SettingsPage_v04 })));
const CommonPage_v04 = lazy(() => import("@/pages/common").then(module => ({ default: module.CommonPage_v04 })));

export interface CommonSidenavLayoutRouteOptions {
sidenav?: boolean;
}

const getCommonPageConfiguration =
(): LayoutConfiguration<CommonSidenavLayoutRouteOptions>["routes"] =>
ALL_COMMON_PAGE_TABS.map((tab) => ({
path: `${ROUTE_PATHS.V04_COMMON}/${tab}` as ROUTE_PATHS,
exact: true,
component: CommonPage_v04,
}));
const getCommonPageConfiguration = (): LayoutConfiguration["routes"] =>
ALL_COMMON_PAGE_TABS.map((tab) => ({
path: `${ROUTE_PATHS.V04_COMMON}/${tab}` as ROUTE_PATHS,
exact: true,
component: CommonPage_v04,
}));

export const COMMON_SIDENAV_LAYOUT_CONFIGURATION: LayoutConfiguration<CommonSidenavLayoutRouteOptions> =
{
component: CommonSidenavLayout,
routes: [
{
path: ROUTE_PATHS.V04_INBOX,
exact: true,
component: InboxPage_v04,
type: RouteType.Private,
unauthenticatedRedirectPath: ROUTE_PATHS.HOME,
},
{
path: ROUTE_PATHS.V04_COMMON_CREATION,
exact: true,
component: CommonCreationPage,
},
{
path: ROUTE_PATHS.V04_COMMON,
exact: true,
component: CommonFeedPage_v04,
},
...getCommonPageConfiguration(),
{
path: ROUTE_PATHS.V04_PROJECT_CREATION,
exact: true,
component: ProjectCreationPage_v04,
},
{
path: ROUTE_PATHS.V04_COMMON_EDITING,
exact: true,
component: CommonEditingPage_v04,
},
{
path: ROUTE_PATHS.V04_PROFILE,
exact: true,
component: ProfilePage_v04,
},
{
path: ROUTE_PATHS.V04_BILLING,
exact: true,
component: BillingPage_v04,
},
{
path: ROUTE_PATHS.V04_SETTINGS,
exact: true,
component: SettingsPage_v04,
},
],
};
export const COMMON_SIDENAV_LAYOUT_CONFIGURATION: LayoutConfiguration = {
component: CommonSidenavLayout,
routes: [
{
path: ROUTE_PATHS.V04_INBOX,
exact: true,
component: InboxPage_v04,
type: RouteType.Private,
unauthenticatedRedirectPath: ROUTE_PATHS.HOME,
},
{
path: ROUTE_PATHS.V04_COMMON_CREATION,
exact: true,
component: CommonCreationPage,
},
{
path: ROUTE_PATHS.V04_COMMON,
exact: true,
component: CommonFeedPage_v04,
},
...getCommonPageConfiguration(),
{
path: ROUTE_PATHS.V04_PROJECT_CREATION,
exact: true,
component: ProjectCreationPage_v04,
},
{
path: ROUTE_PATHS.V04_COMMON_EDITING,
exact: true,
component: CommonEditingPage_v04,
},
{
path: ROUTE_PATHS.V04_PROFILE,
exact: true,
component: ProfilePage_v04,
},
{
path: ROUTE_PATHS.V04_BILLING,
exact: true,
component: BillingPage_v04,
},
{
path: ROUTE_PATHS.V04_SETTINGS,
exact: true,
component: SettingsPage_v04,
},
],
};
7 changes: 5 additions & 2 deletions src/pages/App/router/configuration/emptyLayout.tsx
Original file line number Diff line number Diff line change
@@ -1,9 +1,12 @@
import { PrivacyPolicy } from "@/pages/PrivacyPolicy";
import { EmptyPage } from "@/pages/empty";
import React, { lazy } from "react";
import { ROUTE_PATHS } from "@/shared/constants";
import { EmptyLayout } from "@/shared/layouts";
import { LayoutConfiguration } from "../types";

// Wrapping non-default exports for lazy loading
const EmptyPage = lazy(() => import("@/pages/empty").then(module => ({ default: module.EmptyPage })));
const PrivacyPolicy = lazy(() => import("@/pages/PrivacyPolicy").then(module => ({ default: module.PrivacyPolicy })));

export const EMPTY_LAYOUT_CONFIGURATION: LayoutConfiguration = {
component: EmptyLayout,
routes: [
Expand Down
Loading

0 comments on commit 0608a19

Please sign in to comment.