Merged in fix/rateCodes (pull request #1315)

fix: taking care of missing rateDefinitions

* fix: taking care of missing rateDefinitions


Approved-by: Linus Flood
This commit is contained in:
Simon.Emanuelsson
2025-02-12 08:52:08 +00:00
committed by Linus Flood
parent 8d6f4b82f3
commit 4a06162f79
5 changed files with 108 additions and 27 deletions

View File

@@ -109,6 +109,23 @@ function everyRateHasBreakfastIncluded(
return rateDefinition.breakfastIncluded
}
function getRate(rate: RateDefinition | undefined) {
if (!rate) {
return null
}
switch (rate.cancellationRule) {
case "CancellableBefore6PM":
return "flex"
case "Changeable":
return "change"
case "NotCancellable":
return "save"
default:
console.info(`Should never happen!`)
return null
}
}
/**
* This is used for custom sorting further down
* to guarantee correct order of rates
@@ -164,6 +181,32 @@ export const roomsAvailabilitySchema = z
"public"
)
)
room.products = room.products.map((product) => {
const publicRateDefinition = o.data.attributes.rateDefinitions.find(
(rate) =>
product.productType.public.rateCode
? rate.rateCode === product.productType.public.rateCode
: rate.rateCode === product.productType.public.oldRateCode
)
const publicRate = getRate(publicRateDefinition)
const memberRateDefinition = o.data.attributes.rateDefinitions.find(
(rate) =>
product.productType.member?.rateCode
? rate.rateCode === product.productType.member?.rateCode
: rate.rateCode === product.productType.member?.oldRateCode
)
const memberRate = getRate(memberRateDefinition)
if (publicRate) {
product.productType.public.rate = publicRate
}
if (memberRate && product.productType.member) {
product.productType.member.rate = memberRate
}
return product
})
}
// CancellationRule is the same for public and member per product