refactor(SW-194): change naming
This commit is contained in:
@@ -36,8 +36,8 @@ export const accordionItemsSchema = z.array(
|
||||
export type Accordion = z.infer<typeof accordionSchema>
|
||||
|
||||
enum AccordionEnum {
|
||||
ContentPageBlocksAccordionBlockFaqGlobalFaq = "ContentPageBlocksAccordionBlockFaqGlobalFaq",
|
||||
ContentPageBlocksAccordionBlockFaqSpecificFaq = "ContentPageBlocksAccordionBlockFaqSpecificFaq",
|
||||
ContentPageBlocksAccordionBlockAccordionsGlobalAccordion = "ContentPageBlocksAccordionBlockAccordionsGlobalAccordion",
|
||||
ContentPageBlocksAccordionBlockAccordionsSpecificAccordion = "ContentPageBlocksAccordionBlockAccordionsSpecificAccordion",
|
||||
}
|
||||
|
||||
export const accordionSchema = z.object({
|
||||
@@ -48,15 +48,15 @@ export const accordionSchema = z.object({
|
||||
accordion: z
|
||||
.object({
|
||||
title: z.string().optional().default(""),
|
||||
faq: z.array(
|
||||
accordions: z.array(
|
||||
z.object({
|
||||
__typename: z.enum([
|
||||
AccordionEnum.ContentPageBlocksAccordionBlockFaqGlobalFaq,
|
||||
AccordionEnum.ContentPageBlocksAccordionBlockFaqSpecificFaq,
|
||||
AccordionEnum.ContentPageBlocksAccordionBlockAccordionsGlobalAccordion,
|
||||
AccordionEnum.ContentPageBlocksAccordionBlockAccordionsSpecificAccordion,
|
||||
]),
|
||||
global_faq: z
|
||||
global_accordion: z
|
||||
.object({
|
||||
global_faqConnection: z.object({
|
||||
global_accordionConnection: z.object({
|
||||
edges: z.array(
|
||||
z.object({
|
||||
node: z.object({
|
||||
@@ -67,7 +67,7 @@ export const accordionSchema = z.object({
|
||||
}),
|
||||
})
|
||||
.optional(),
|
||||
specific_faq: z
|
||||
specific_accordion: z
|
||||
.object({
|
||||
questions: accordionItemsSchema,
|
||||
})
|
||||
@@ -78,18 +78,18 @@ export const accordionSchema = z.object({
|
||||
.transform((data) => {
|
||||
return {
|
||||
...data,
|
||||
faq: data.faq.flatMap((faq) => {
|
||||
switch (faq.__typename) {
|
||||
case AccordionEnum.ContentPageBlocksAccordionBlockFaqGlobalFaq:
|
||||
accordions: data.accordions.flatMap((acc) => {
|
||||
switch (acc.__typename) {
|
||||
case AccordionEnum.ContentPageBlocksAccordionBlockAccordionsGlobalAccordion:
|
||||
return (
|
||||
faq.global_faq?.global_faqConnection.edges.flatMap(
|
||||
({ node: faqConnection }) => {
|
||||
return faqConnection.questions
|
||||
acc.global_accordion?.global_accordionConnection.edges.flatMap(
|
||||
({ node: accordionConnection }) => {
|
||||
return accordionConnection.questions
|
||||
}
|
||||
) || []
|
||||
)
|
||||
case AccordionEnum.ContentPageBlocksAccordionBlockFaqSpecificFaq:
|
||||
return faq.specific_faq?.questions || []
|
||||
case AccordionEnum.ContentPageBlocksAccordionBlockAccordionsSpecificAccordion:
|
||||
return acc.specific_accordion?.questions || []
|
||||
}
|
||||
}),
|
||||
}
|
||||
@@ -103,7 +103,7 @@ const actualRefs = z.discriminatedUnion("__typename", [
|
||||
pageLinks.loyaltyPageRefSchema,
|
||||
])
|
||||
|
||||
export const globalFaqConnectionRefs = z.object({
|
||||
export const globalAccordionConnectionRefs = z.object({
|
||||
edges: z.array(
|
||||
z.object({
|
||||
node: z.object({
|
||||
@@ -125,7 +125,7 @@ export const globalFaqConnectionRefs = z.object({
|
||||
),
|
||||
})
|
||||
|
||||
export const specificFaqConnectionRefs = z.object({
|
||||
export const specificAccordionConnectionRefs = z.object({
|
||||
questions: z.array(
|
||||
z.object({
|
||||
answer: z.object({
|
||||
@@ -144,29 +144,29 @@ export const specificFaqConnectionRefs = z.object({
|
||||
export const accordionRefsSchema = z.object({
|
||||
accordion: z
|
||||
.object({
|
||||
faq: z.array(
|
||||
accordions: z.array(
|
||||
z.object({
|
||||
__typename: z.enum([
|
||||
AccordionEnum.ContentPageBlocksAccordionBlockFaqGlobalFaq,
|
||||
AccordionEnum.ContentPageBlocksAccordionBlockFaqSpecificFaq,
|
||||
AccordionEnum.ContentPageBlocksAccordionBlockAccordionsGlobalAccordion,
|
||||
AccordionEnum.ContentPageBlocksAccordionBlockAccordionsSpecificAccordion,
|
||||
]),
|
||||
global_faq: z
|
||||
global_accordion: z
|
||||
.object({
|
||||
global_faqConnection: globalFaqConnectionRefs,
|
||||
global_accordionConnection: globalAccordionConnectionRefs,
|
||||
})
|
||||
.optional(),
|
||||
specific_faq: specificFaqConnectionRefs.optional(),
|
||||
specific_accordion: specificAccordionConnectionRefs.optional(),
|
||||
})
|
||||
),
|
||||
})
|
||||
.transform((data) => {
|
||||
return data.faq.flatMap((faq) => {
|
||||
switch (faq.__typename) {
|
||||
case AccordionEnum.ContentPageBlocksAccordionBlockFaqGlobalFaq:
|
||||
return data.accordions.flatMap((accordion) => {
|
||||
switch (accordion.__typename) {
|
||||
case AccordionEnum.ContentPageBlocksAccordionBlockAccordionsGlobalAccordion:
|
||||
return (
|
||||
faq.global_faq?.global_faqConnection.edges.flatMap(
|
||||
({ node: faqConnection }) => {
|
||||
return faqConnection.questions.flatMap((question) =>
|
||||
accordion.global_accordion?.global_accordionConnection.edges.flatMap(
|
||||
({ node: accordionConnection }) => {
|
||||
return accordionConnection.questions.flatMap((question) =>
|
||||
question.answer.embedded_itemsConnection.edges.flatMap(
|
||||
({ node }) => node.system
|
||||
)
|
||||
@@ -174,9 +174,9 @@ export const accordionRefsSchema = z.object({
|
||||
}
|
||||
) || []
|
||||
)
|
||||
case AccordionEnum.ContentPageBlocksAccordionBlockFaqSpecificFaq:
|
||||
case AccordionEnum.ContentPageBlocksAccordionBlockAccordionsSpecificAccordion:
|
||||
return (
|
||||
faq.specific_faq?.questions.flatMap((question) =>
|
||||
accordion.specific_accordion?.questions.flatMap((question) =>
|
||||
question.answer.embedded_itemsConnection.edges.flatMap(
|
||||
({ node }) => node.system
|
||||
)
|
||||
|
||||
@@ -2,8 +2,8 @@ import { z } from "zod"
|
||||
|
||||
import {
|
||||
accordionItemsSchema,
|
||||
globalFaqConnectionRefs,
|
||||
specificFaqConnectionRefs,
|
||||
globalAccordionConnectionRefs,
|
||||
specificAccordionConnectionRefs,
|
||||
} from "./accordion"
|
||||
|
||||
import { BlocksEnums } from "@/types/enums/blocks"
|
||||
@@ -41,7 +41,7 @@ export const hotelFaqSchema = z
|
||||
}) || []
|
||||
)
|
||||
array.push(data.specific_faq?.questions || [])
|
||||
return { ...data, faq: array.flat(2) }
|
||||
return { ...data, accordions: array.flat(2) }
|
||||
})
|
||||
|
||||
export const hotelFaqRefsSchema = z
|
||||
@@ -50,8 +50,8 @@ export const hotelFaqRefsSchema = z
|
||||
.literal(HotelPageEnum.ContentStack.blocks.Faq)
|
||||
.optional()
|
||||
.default(HotelPageEnum.ContentStack.blocks.Faq),
|
||||
global_faqConnection: globalFaqConnectionRefs.optional(),
|
||||
specific_faq: specificFaqConnectionRefs.optional(),
|
||||
global_faqConnection: globalAccordionConnectionRefs.optional(),
|
||||
specific_faq: specificAccordionConnectionRefs.optional(),
|
||||
})
|
||||
.transform((data) => {
|
||||
const array = []
|
||||
|
||||
Reference in New Issue
Block a user