fix(BOOK-599): Filtering on correct values for hotel pages now and added comments

Approved-by: Matilda Landström
This commit is contained in:
Erik Tiekstra
2025-12-05 06:31:17 +00:00
parent 2b9bc8c3ce
commit a9c1a91134
2 changed files with 24 additions and 36 deletions

View File

@@ -149,6 +149,13 @@ export default async function HotelPage({
const isThemed = hotelTheme !== DEFAULT_THEME
const galleryImages = mapApiImagesToGalleryImages(images ?? [])
const filteredAlerts = specialAlerts.filter(({ endDate, name }) => {
// Hotel alerts should only be shown if they:
// - Have no end date or Have an end date in the future (including today)
// - Are not of type 'HotelChildrenInBooking'
const shouldShowNow = !endDate || dt().isSameOrBefore(dt(endDate), "day")
return name !== AlertName.HotelChildrenInBooking && shouldShowNow
})
return (
<div className={styles.pageContainer}>
@@ -194,21 +201,9 @@ export default async function HotelPage({
<AmenitiesList detailedFacilities={detailedFacilities} />
</div>
{specialAlerts.length ? (
{filteredAlerts.length ? (
<div className={styles.alertsContainer}>
{specialAlerts
.filter((alert) => {
const now = dt().utc().format("YYYY-MM-DD")
const shouldShowNow =
alert.startDate && alert.endDate
? alert.startDate <= now && alert.endDate >= now
: true
return (
alert.name !== AlertName.HotelChildrenInBooking &&
shouldShowNow
)
})
.map((alert) => (
{filteredAlerts.map((alert) => (
<Alert
key={alert.id}
type={alert.type}

View File

@@ -1,7 +1,6 @@
import { z } from "zod"
import { AlertTypeEnum } from "@scandic-hotels/common/constants/alert"
import { dt } from "@scandic-hotels/common/dt"
import { nullableStringValidator } from "@scandic-hotels/common/utils/zod/stringValidator"
const specialAlertSchema = z.object({
@@ -16,19 +15,13 @@ const specialAlertSchema = z.object({
export const specialAlertsSchema = z
.array(specialAlertSchema)
.nullish()
.transform((arr) => (arr ? arr.filter(Boolean) : []))
.transform((data) => {
const now = dt().utc().format("YYYY-MM-DD")
const filteredAlerts = data.filter((alert) => {
const hasText = alert.description || alert.title
const hasDates = alert.startDate && alert.endDate
if (!hasDates) {
return hasText
}
const isAlertExpired = alert.endDate < now
return !isAlertExpired && hasText
})
return filteredAlerts.map((alert, idx) => ({
// Filter out alerts with no title and no description since they won't have any visible content
// We're filtering on dates on the hotel page itself
.transform((arr) =>
arr ? arr.filter((alert) => alert?.description || alert?.title) : []
)
.transform((alerts) =>
alerts.map((alert, idx) => ({
heading: alert.title || null,
id: `alert-${alert.type}-${idx}`,
name: alert.type,
@@ -38,4 +31,4 @@ export const specialAlertsSchema = z
endDate: alert.endDate,
startDate: alert.startDate,
}))
})
)