Files
web/apps/scandic-web/components/BookingFlowProviders.tsx
Joakim Jäderberg 17df3ee71a Merged in feature/SW-3516-pass-eurobonus-number-on-booking (pull request #2902)
* feat(SW-3516): Include partnerLoyaltyNumber on bookings

- Added user context to BookingFlowProviders for user state management.
- Updated booking input and output schemas to accommodate new user data.
- Refactored booking mutation logic to include user-related information.
- Improved type definitions for better TypeScript support across booking components.


Approved-by: Anton Gunnarsson
2025-10-08 10:48:42 +00:00

51 lines
1.3 KiB
TypeScript

"use client"
import { BookingFlowContextProvider } from "@scandic-hotels/booking-flow/BookingFlowContextProvider"
import { trpc } from "@scandic-hotels/trpc/client"
import { useIsUserLoggedIn } from "@/hooks/useIsUserLoggedIn"
import type { ComponentProps, ReactNode } from "react"
export function BookingFlowProviders({ children }: { children: ReactNode }) {
const isLoggedIn = useIsUserLoggedIn()
const user = useBookingFlowUser()
return (
<BookingFlowContextProvider data={{ isLoggedIn, user }}>
{children}
</BookingFlowContextProvider>
)
}
type BookingFlowContextData = ComponentProps<
typeof BookingFlowContextProvider
>["data"]
type BookingFlowUser = BookingFlowContextData["user"]
function useBookingFlowUser(): BookingFlowUser {
const isLoggedIn = useIsUserLoggedIn()
const { data, isError, isLoading } = trpc.user.getSafely.useQuery(undefined, {
enabled: isLoggedIn,
})
if (isLoading) {
return { state: "loading", data: undefined }
}
if (isError || !data) {
return { state: "error", data: undefined }
}
return {
state: "loaded",
data: {
type: "scandic",
partnerLoyaltyNumber: null,
membershipNumber: data.membershipNumber,
firstName: data.firstName || null,
lastName: data.lastName || null,
email: data.email,
},
}
}