feat: #sw-694 using suspense when loading dynamic content and breadcrumbs

This commit is contained in:
Linus Flood
2024-10-25 10:59:34 +02:00
parent 6ce6bbd60b
commit 1a921940e8
5 changed files with 79 additions and 52 deletions

View File

@@ -1,3 +1,5 @@
import { Suspense } from "react"
import Breadcrumbs from "@/components/Breadcrumbs" import Breadcrumbs from "@/components/Breadcrumbs"
import { setLang } from "@/i18n/serverContext" import { setLang } from "@/i18n/serverContext"
@@ -6,5 +8,9 @@ import { LangParams, PageArgs } from "@/types/params"
export default function AllBreadcrumbs({ params }: PageArgs<LangParams>) { export default function AllBreadcrumbs({ params }: PageArgs<LangParams>) {
setLang(params.lang) setLang(params.lang)
return <Breadcrumbs /> return (
<Suspense>
<Breadcrumbs />
</Suspense>
)
} }

View File

@@ -1,3 +1,5 @@
import { Suspense } from "react"
import Breadcrumbs from "@/components/Breadcrumbs" import Breadcrumbs from "@/components/Breadcrumbs"
import { setLang } from "@/i18n/serverContext" import { setLang } from "@/i18n/serverContext"
@@ -6,5 +8,9 @@ import { LangParams, PageArgs } from "@/types/params"
export default function PageBreadcrumbs({ params }: PageArgs<LangParams>) { export default function PageBreadcrumbs({ params }: PageArgs<LangParams>) {
setLang(params.lang) setLang(params.lang)
return <Breadcrumbs /> return (
<Suspense>
<Breadcrumbs />
</Suspense>
)
} }

View File

@@ -16,7 +16,7 @@ import {
export { generateMetadata } from "@/utils/generateMetadata" export { generateMetadata } from "@/utils/generateMetadata"
export default async function ContentTypePage({ export default function ContentTypePage({
params, params,
}: PageArgs<LangParams & ContentTypeParams & UIDParams, {}>) { }: PageArgs<LangParams & ContentTypeParams & UIDParams, {}>) {
setLang(params.lang) setLang(params.lang)

View File

@@ -9,8 +9,11 @@ export default async function OverviewTable({
dynamic_content, dynamic_content,
firstItem, firstItem,
}: OverviewTableProps) { }: OverviewTableProps) {
const levels = await serverClient().contentstack.rewards.all() const [levels, membershipLevel] = await Promise.all([
const membershipLevel = await serverClient().user.safeMembershipLevel() serverClient().contentstack.rewards.all(),
serverClient().user.safeMembershipLevel(),
])
return ( return (
<SectionWrapper dynamic_content={dynamic_content} firstItem={firstItem}> <SectionWrapper dynamic_content={dynamic_content} firstItem={firstItem}>
<OverviewTableClient <OverviewTableClient

View File

@@ -1,3 +1,5 @@
import { Suspense } from "react"
import { env } from "@/env/server" import { env } from "@/env/server"
import HowItWorks from "@/components/Blocks/DynamicContent/HowItWorks" import HowItWorks from "@/components/Blocks/DynamicContent/HowItWorks"
@@ -14,58 +16,68 @@ import SignUpVerification from "@/components/Blocks/DynamicContent/SignUpVerific
import PreviousStays from "@/components/Blocks/DynamicContent/Stays/Previous" import PreviousStays from "@/components/Blocks/DynamicContent/Stays/Previous"
import SoonestStays from "@/components/Blocks/DynamicContent/Stays/Soonest" import SoonestStays from "@/components/Blocks/DynamicContent/Stays/Soonest"
import UpcomingStays from "@/components/Blocks/DynamicContent/Stays/Upcoming" import UpcomingStays from "@/components/Blocks/DynamicContent/Stays/Upcoming"
import LoadingSpinner from "@/components/LoadingSpinner"
import type { DynamicContentProps } from "@/types/components/blocks/dynamicContent" import type { DynamicContentProps } from "@/types/components/blocks/dynamicContent"
import { DynamicContentEnum } from "@/types/enums/dynamicContent" import { DynamicContentEnum } from "@/types/enums/dynamicContent"
export default async function DynamicContent({ export default function DynamicContent({
dynamic_content, dynamic_content,
firstItem, firstItem,
}: DynamicContentProps) { }: DynamicContentProps) {
switch (dynamic_content.component) { return (
case DynamicContentEnum.Blocks.components.current_benefits: <Suspense fallback={<LoadingSpinner />}>
return <CurrentRewardsBlock {...dynamic_content} /> {(() => {
case DynamicContentEnum.Blocks.components.earn_and_burn: switch (dynamic_content.component) {
return <EarnAndBurn {...dynamic_content} /> case DynamicContentEnum.Blocks.components.current_benefits:
case DynamicContentEnum.Blocks.components.expiring_points: return <CurrentRewardsBlock {...dynamic_content} />
return env.HIDE_FOR_NEXT_RELEASE ? null : ( case DynamicContentEnum.Blocks.components.earn_and_burn:
<ExpiringPoints {...dynamic_content} /> return <EarnAndBurn {...dynamic_content} />
) case DynamicContentEnum.Blocks.components.expiring_points:
case DynamicContentEnum.Blocks.components.how_it_works: return env.HIDE_FOR_NEXT_RELEASE ? null : (
return ( <ExpiringPoints {...dynamic_content} />
<HowItWorks dynamic_content={dynamic_content} firstItem={firstItem} /> )
) case DynamicContentEnum.Blocks.components.how_it_works:
case DynamicContentEnum.Blocks.components.loyalty_levels: return (
return ( <HowItWorks
<LoyaltyLevels dynamic_content={dynamic_content}
dynamic_content={dynamic_content} firstItem={firstItem}
firstItem={firstItem} />
/> )
) case DynamicContentEnum.Blocks.components.loyalty_levels:
case DynamicContentEnum.Blocks.components.membership_overview: return (
return <Overview {...dynamic_content} /> <LoyaltyLevels
case DynamicContentEnum.Blocks.components.next_benefits: dynamic_content={dynamic_content}
return <NextLevelRewardsBlock {...dynamic_content} /> firstItem={firstItem}
case DynamicContentEnum.Blocks.components.overview_table: />
return ( )
<OverviewTable case DynamicContentEnum.Blocks.components.membership_overview:
dynamic_content={dynamic_content} return <Overview {...dynamic_content} />
firstItem={firstItem} case DynamicContentEnum.Blocks.components.next_benefits:
/> return <NextLevelRewardsBlock {...dynamic_content} />
) case DynamicContentEnum.Blocks.components.overview_table:
case DynamicContentEnum.Blocks.components.points_overview: return (
return <PointsOverview {...dynamic_content} /> <OverviewTable
case DynamicContentEnum.Blocks.components.previous_stays: dynamic_content={dynamic_content}
return <PreviousStays {...dynamic_content} /> firstItem={firstItem}
case DynamicContentEnum.Blocks.components.sign_up_form: />
return <SignupFormWrapper dynamic_content={dynamic_content} /> )
case DynamicContentEnum.Blocks.components.sign_up_verification: case DynamicContentEnum.Blocks.components.points_overview:
return <SignUpVerification dynamic_content={dynamic_content} /> return <PointsOverview {...dynamic_content} />
case DynamicContentEnum.Blocks.components.soonest_stays: case DynamicContentEnum.Blocks.components.previous_stays:
return <SoonestStays {...dynamic_content} /> return <PreviousStays {...dynamic_content} />
case DynamicContentEnum.Blocks.components.upcoming_stays: case DynamicContentEnum.Blocks.components.sign_up_form:
return <UpcomingStays {...dynamic_content} /> return <SignupFormWrapper dynamic_content={dynamic_content} />
default: case DynamicContentEnum.Blocks.components.sign_up_verification:
return null return <SignUpVerification dynamic_content={dynamic_content} />
} case DynamicContentEnum.Blocks.components.soonest_stays:
return <SoonestStays {...dynamic_content} />
case DynamicContentEnum.Blocks.components.upcoming_stays:
return <UpcomingStays {...dynamic_content} />
default:
return null
}
})()}
</Suspense>
)
} }