Files
web/apps/scandic-web/components/HotelReservation/MyStay/Ancillaries/GuaranteeCallback/index.tsx
Bianca Widstam 35c1724afb Merged in feat/SW-1997-tracking-gla-my-stay-ancillaries (pull request #1657)
Feat/SW-1997 tracking gla my stay ancillaries

* feat(SW-1996): tracking gla my stay

* feat(SW-1996): update gla tracking

* feat(SW-1996): fix comment

* feat(SW-1997): add tracking for gla my stay and ancillaries

* feat(SW-1997): rebase master

* feat(SW-1997): fix duplicate import

* feat(SW-1997): add hotelId and category for ancillaries, and add more tracking

* feat(SW-1997): remove commments and fix spelling mistake

* feat(SW-1997): if addAncillary failed, but guarantee is successful, default to card in booking


Approved-by: Niclas Edenvin
2025-04-01 09:38:36 +00:00

94 lines
2.3 KiB
TypeScript

"use client"
import { useRouter } from "next/navigation"
import { useEffect } from "react"
import { trpc } from "@/lib/trpc/client"
import LoadingSpinner from "@/components/LoadingSpinner"
import {
trackAncillaryFailed,
trackAncillarySuccess,
} from "@/utils/tracking/myStay"
import {
buildAncillaryPackages,
clearAncillarySessionData,
getAncillarySessionData,
} from "../utils"
import type { Lang } from "@/constants/languages"
export default function GuaranteeAncillaryHandler({
confirmationNumber,
returnUrl,
lang,
}: {
confirmationNumber: string
returnUrl: string
lang: Lang
}) {
const router = useRouter()
const addAncillary = trpc.booking.packages.useMutation()
useEffect(() => {
if (addAncillary.isPending || addAncillary.submittedAt) {
return
}
const sessionData = getAncillarySessionData()
if (!sessionData?.formData || !sessionData?.selectedAncillary) {
router.replace(`${returnUrl}&errorCode=AncillaryFailed`)
return
}
const { formData, selectedAncillary } = sessionData
const packages = buildAncillaryPackages(formData, selectedAncillary)
addAncillary.mutate(
{
confirmationNumber,
ancillaryComment: formData.optionalText,
ancillaryDeliveryTime: selectedAncillary.requiresDeliveryTime
? formData.deliveryTime
: undefined,
packages,
language: lang,
},
{
onSuccess: (data) => {
if (data) {
trackAncillarySuccess(
confirmationNumber,
packages,
formData.deliveryTime,
"room + ancillary",
selectedAncillary
)
clearAncillarySessionData()
router.replace(returnUrl)
} else {
trackAncillaryFailed(
packages,
formData.deliveryTime,
selectedAncillary
)
router.replace(`${returnUrl}&errorCode=AncillaryFailed`)
}
},
onError: () => {
trackAncillaryFailed(
packages,
formData.deliveryTime,
selectedAncillary
)
router.replace(`${returnUrl}&errorCode=AncillaryFailed`)
},
}
)
}, [confirmationNumber, returnUrl, addAncillary, lang, router])
return <LoadingSpinner />
}