feat: #sw-694 using suspense when loading dynamic content and breadcrumbs
This commit is contained in:
@@ -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>
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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>
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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>
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user