feat(BOOK-53): Added component for SEO filters and support filter switching

Approved-by: Chuma Mcphoy (We Ahead)
This commit is contained in:
Erik Tiekstra
2025-09-19 08:26:41 +00:00
parent 0e30a2d218
commit 7c92a8fc9a
30 changed files with 339 additions and 111 deletions

View File

@@ -11,6 +11,10 @@ import {
accordionSchema,
} from "../schemas/blocks/accordion"
import { contentRefsSchema, contentSchema } from "../schemas/blocks/content"
import {
destinationFiltersRefsSchema,
destinationFiltersSchema,
} from "../schemas/destinationFilters"
import { mapLocationSchema } from "../schemas/mapLocation"
import {
linkRefsUnionSchema,
@@ -159,6 +163,7 @@ export const destinationCityPageSchema = z.object({
})
.nullish(),
blocks: discriminatedUnionArray(blocksSchema.options).nullable(),
seo_filters: destinationFiltersSchema,
system: systemSchema.merge(
z.object({
created_at: z.string(),
@@ -258,6 +263,7 @@ export const destinationCityPageRefsSchema = z.object({
})
.nullish(),
blocks: discriminatedUnionArray(blocksRefsSchema.options).nullable(),
seo_filters: destinationFiltersRefsSchema,
system: systemSchema,
}),
})

View File

@@ -11,6 +11,10 @@ import {
accordionSchema,
} from "../schemas/blocks/accordion"
import { contentRefsSchema, contentSchema } from "../schemas/blocks/content"
import {
destinationFiltersRefsSchema,
destinationFiltersSchema,
} from "../schemas/destinationFilters"
import { mapLocationSchema } from "../schemas/mapLocation"
import {
linkRefsUnionSchema,
@@ -88,6 +92,7 @@ export const destinationCountryPageSchema = z.object({
})
.nullish(),
blocks: discriminatedUnionArray(blocksSchema.options).nullable(),
seo_filters: destinationFiltersSchema,
system: systemSchema.merge(
z.object({
created_at: z.string(),
@@ -160,6 +165,7 @@ export const destinationCountryPageRefsSchema = z.object({
}),
}),
blocks: discriminatedUnionArray(blocksRefsSchema.options).nullable(),
seo_filters: destinationFiltersRefsSchema,
system: systemSchema,
}),
})

View File

@@ -0,0 +1,55 @@
import { z } from "zod"
import { isDefined } from "@scandic-hotels/common/utils/isDefined"
import { hotelFilterSchema } from "./hotelFilter"
import { systemSchema } from "./system"
export const destinationFiltersSchema = z
.array(
z.object({
filterConnection: z.object({
edges: z.array(
z.object({
node: hotelFilterSchema,
})
),
}),
})
)
.nullish()
.transform((data) => {
const filters = data
?.map(({ filterConnection }) => filterConnection.edges[0]?.node)
.filter(isDefined)
if (!data || !filters?.length) {
return null
}
const facilityFilters = filters.filter((f) => f.filterType === "facility")
const surroundingsFilters = filters.filter(
(f) => f.filterType === "surroundings"
)
return {
facilityFilters,
surroundingsFilters,
}
})
export const destinationFiltersRefsSchema = z
.array(
z.object({
filterConnection: z.object({
edges: z.array(
z.object({
node: z.object({
system: systemSchema,
}),
})
),
}),
})
)
.nullish()

View File

@@ -0,0 +1,18 @@
import { z } from "zod"
import { FacilityEnum } from "@scandic-hotels/common/constants/facilities"
export const hotelFilterSchema = z
.object({
title: z.string(),
facility_id: z.nativeEnum(FacilityEnum).catch(FacilityEnum.UNKNOWN),
category: z.string(),
slug: z.string(),
})
.transform((data) => ({
id: data.facility_id,
name: data.title,
filterType: data.category,
slug: data.slug,
sortOrder: 0,
}))