feat(SW-2116): RefId instead of confirmationNumber

This commit is contained in:
Arvid Norlin
2025-04-25 13:44:49 +02:00
committed by Michael Zetterberg
parent 7eeb0bbcac
commit 74d37dad93
61 changed files with 1032 additions and 843 deletions

View File

@@ -13,7 +13,6 @@ import {
getProfileSafely,
getSavedPaymentCardsSafely,
} from "@/lib/trpc/memoizedRequests"
import { decrypt } from "@/server/routers/utils/encryption"
import AdditionalInfoForm from "@/components/HotelReservation/FindMyBooking/AdditionalInfoForm"
import accessBooking, {
@@ -32,6 +31,7 @@ import Image from "@/components/Image"
import { getIntl } from "@/i18n"
import { setLang } from "@/i18n/serverContext"
import MyStayProvider from "@/providers/MyStay"
import { parseRefId } from "@/utils/refId"
import { getCurrentWebUrl } from "@/utils/url"
import styles from "./page.module.css"
@@ -44,29 +44,26 @@ export default async function MyStay({
searchParams,
}: PageArgs<LangParams, { RefId?: string }>) {
setLang(params.lang)
const refId = searchParams.RefId
if (!refId) {
notFound()
}
const value = decrypt(refId)
if (!value) {
return notFound()
}
const [confirmationNumber, lastName] = value.split(",")
const bookingConfirmation = await getBookingConfirmation(confirmationNumber)
const bookingConfirmation = await getBookingConfirmation(refId, params.lang)
if (!bookingConfirmation) {
return notFound()
}
const { additionalData, booking, hotel, roomCategories } = bookingConfirmation
const { booking, hotelData } = bookingConfirmation
const { hotel } = hotelData
const user = await getProfileSafely()
const bv = cookies().get("bv")?.value
const intl = await getIntl()
const { lastName } = parseRefId(refId)
const access = accessBooking(booking.guest, lastName, user, bv)
if (access === ACCESS_GRANTED) {
@@ -74,9 +71,7 @@ export default async function MyStay({
const fromDate = dt(booking.checkInDate).format("YYYY-MM-DD")
const toDate = dt(booking.checkOutDate).format("YYYY-MM-DD")
const linkedReservationsPromise = getLinkedReservations({
rooms: booking.linkedReservations,
})
const linkedReservationsPromise = getLinkedReservations(refId, params.lang)
const packagesInput = {
adults: booking.adults,
@@ -98,9 +93,9 @@ export default async function MyStay({
(pkg) => pkg.code === BreakfastPackageEnum.REGULAR_BREAKFAST
)
const breakfastIncluded = booking.rateDefinition.breakfastIncluded
const alreadyHasABreakfastSelection =
const shouldFetchBreakfastPackages =
!hasBreakfastPackage && !breakfastIncluded
if (alreadyHasABreakfastSelection) {
if (shouldFetchBreakfastPackages) {
void getPackages(packagesInput)
}
void getSavedPaymentCardsSafely(savedPaymentCardsInput)
@@ -112,7 +107,7 @@ export default async function MyStay({
})
let breakfastPackages = null
if (alreadyHasABreakfastSelection) {
if (shouldFetchBreakfastPackages) {
breakfastPackages = await getPackages(packagesInput)
}
const savedCreditCards = await getSavedPaymentCardsSafely(
@@ -121,7 +116,7 @@ export default async function MyStay({
const imageSrc =
hotel.hotelContent.images.imageSizes.large ??
additionalData.gallery?.heroImages[0]?.imageSizes.large ??
hotelData.additionalData.gallery?.heroImages[0]?.imageSizes.large ??
hotel.galleryImages[0]?.imageSizes.large
const baseUrl = env.PUBLIC_URL || "https://www.scandichotels.com"
@@ -138,7 +133,7 @@ export default async function MyStay({
lang={params.lang}
linkedReservationsPromise={linkedReservationsPromise}
refId={refId}
roomCategories={roomCategories}
roomCategories={hotelData.roomCategories}
savedCreditCards={savedCreditCards}
>
<main className={styles.main}>
@@ -197,10 +192,7 @@ export default async function MyStay({
return (
<main className={styles.main}>
<div className={styles.form}>
<AdditionalInfoForm
confirmationNumber={confirmationNumber}
lastName={lastName}
/>
<AdditionalInfoForm refId={refId} lastName={lastName} />
</div>
</main>
)