Merged in feature/select-rate-vertical-data-flow (pull request #2535)
Feature/select rate vertical data flow * add fix from SW-2666 * use translations for room packages * move types to it's own file * Merge branch 'master' of bitbucket.org:scandic-swap/web into feature/select-rate-vertical-data-flow * merge * feature/select-rate: double rate for campaing rates * revert NODE_ENV check in Cookiebot script * revert testing values * fix(SW-3171): fix all filter selected in price details * fix(SW-3166): multiroom anchoring when changing filter * fix(SW-3172): check hotelType, show correct breakfast message * Merge branch 'feature/select-rate-vertical-data-flow' of bitbucket.org:scandic-swap/web into feature/select-rate-vertical-data-flow * fix: show special needs icons for subsequent roomTypes SW-3167 * fix: Display strike through text when logged in SW-3168 * fix: Reinstate the scrollToView behaviour when selecting a rate SW-3169 * merge * . * PR fixes * fix: don't return notFound() * . * always include defaults for room packages * merge * merge * merge * Remove floating h1 for new select-rate Approved-by: Anton Gunnarsson
This commit is contained in:
41
apps/scandic-web/contexts/SelectRate/isRateSelected.ts
Normal file
41
apps/scandic-web/contexts/SelectRate/isRateSelected.ts
Normal file
@@ -0,0 +1,41 @@
|
||||
import type { RateEnum } from "@scandic-hotels/trpc/enums/rate"
|
||||
|
||||
import type { Rate } from "./types"
|
||||
|
||||
export function isRateSelected({
|
||||
selectedRateCode,
|
||||
selectedRoomTypeCode,
|
||||
rate,
|
||||
roomTypeCode,
|
||||
}: {
|
||||
selectedRateCode: RateEnum | string | undefined | null
|
||||
selectedRoomTypeCode: RateEnum | string | undefined | null
|
||||
rate: Rate
|
||||
roomTypeCode: string | null | undefined
|
||||
}) {
|
||||
if (!selectedRateCode || !selectedRoomTypeCode || !rate || !roomTypeCode) {
|
||||
return false
|
||||
}
|
||||
|
||||
let rateCodes: string[] = []
|
||||
if ("public" in rate && rate.public) {
|
||||
rateCodes = [...rateCodes, rate.public.rateCode?.toLowerCase()]
|
||||
}
|
||||
if ("member" in rate && rate.member) {
|
||||
rateCodes = [...rateCodes, rate.member.rateCode?.toLowerCase()]
|
||||
}
|
||||
if ("redemption" in rate && rate.redemption) {
|
||||
rateCodes = [...rateCodes, rate.redemption.rateCode?.toLowerCase()]
|
||||
}
|
||||
if ("voucher" in rate && rate.voucher) {
|
||||
rateCodes = [...rateCodes, rate.voucher.rateCode?.toLowerCase()]
|
||||
}
|
||||
if ("corporateCheque" in rate && rate.corporateCheque) {
|
||||
rateCodes = [...rateCodes, rate.corporateCheque.rateCode?.toLowerCase()]
|
||||
}
|
||||
|
||||
return (
|
||||
rateCodes.includes(selectedRateCode.toLowerCase()) &&
|
||||
selectedRoomTypeCode.toLowerCase() === roomTypeCode.toLowerCase()
|
||||
)
|
||||
}
|
||||
Reference in New Issue
Block a user