fix: set redeem description nullable in order to handle the transition from string to RTE

This commit is contained in:
Christian Andolf
2025-04-11 09:16:13 +02:00
parent 543ea3e5a3
commit 80a738af7b
2 changed files with 42 additions and 32 deletions

View File

@@ -46,13 +46,13 @@ export default function Tier({
{reward.label} {reward.label}
</Title> </Title>
{reward.redeemLocation !== "Non-redeemable" ? ( {reward.redeemLocation !== "Non-redeemable" && (
<> <>
{redeemStep === "initial" && ( {redeemStep === "initial" && (
<Body textAlign="center">{reward.description}</Body> <Body textAlign="center">{reward.description}</Body>
)} )}
{redeemStep === "confirmation" && ( {redeemStep === "confirmation" && reward.redeem_description && (
<JsonToHtml <JsonToHtml
embeds={ embeds={
reward.redeem_description.embedded_itemsConnection.edges reward.redeem_description.embedded_itemsConnection.edges
@@ -67,7 +67,9 @@ export default function Tier({
<MembershipNumberBadge membershipNumber={membershipNumber} /> <MembershipNumberBadge membershipNumber={membershipNumber} />
)} )}
</> </>
) : ( )}
{reward.redeemLocation === "Non-redeemable" &&
reward.redeem_description && (
<JsonToHtml <JsonToHtml
embeds={reward.redeem_description.embedded_itemsConnection.edges} embeds={reward.redeem_description.embedded_itemsConnection.edges}
nodes={reward.redeem_description.json.children} nodes={reward.redeem_description.json.children}

View File

@@ -36,7 +36,8 @@ const validateCmsRewardsSchema = z
reward_id: z.string(), reward_id: z.string(),
grouped_label: z.string().optional(), grouped_label: z.string().optional(),
description: z.string().optional(), description: z.string().optional(),
redeem_description: z.object({ redeem_description: z
.object({
json: z.any(), // JSON json: z.any(), // JSON
embedded_itemsConnection: z.object({ embedded_itemsConnection: z.object({
edges: z.array( edges: z.array(
@@ -51,7 +52,10 @@ const validateCmsRewardsSchema = z
}) })
), ),
}), }),
}), })
// This is primarily added in order to handle a transition
// switching from string to RTE
.nullable(),
grouped_description: z.string().optional(), grouped_description: z.string().optional(),
value: z.string().optional(), value: z.string().optional(),
}) })
@@ -66,7 +70,8 @@ const rewardRefsSchema = z.object({
all_reward: z.object({ all_reward: z.object({
items: z.array( items: z.array(
z.object({ z.object({
redeem_description: z.object({ redeem_description: z
.object({
embedded_itemsConnection: z.object({ embedded_itemsConnection: z.object({
edges: z.array( edges: z.array(
z.object({ z.object({
@@ -74,7 +79,10 @@ const rewardRefsSchema = z.object({
}) })
), ),
}), }),
}), })
// This is primarily added in order to handle a transition
// switching from string to RTE
.nullable(),
system: systemSchema, system: systemSchema,
}) })
), ),