Merged in feat/SW-3494-noOfNightsStayed (pull request #2832)
feat(SW-3494): removed properties that we dont need in the tracking * feat(SW-3494): removed properties that we dont need in the tracking * Fixed waiting on user response before tracking * Refactor and cleanup * Cleanup Approved-by: Joakim Jäderberg
This commit is contained in:
@@ -2,9 +2,6 @@
|
|||||||
|
|
||||||
import { usePathname } from "next/navigation"
|
import { usePathname } from "next/navigation"
|
||||||
|
|
||||||
import { trpc } from "@scandic-hotels/trpc/client"
|
|
||||||
|
|
||||||
import useLang from "./hooks/useLang"
|
|
||||||
import { useTrackHardNavigation } from "./useTrackHardNavigation"
|
import { useTrackHardNavigation } from "./useTrackHardNavigation"
|
||||||
import { useTrackSoftNavigation } from "./useTrackSoftNavigation"
|
import { useTrackSoftNavigation } from "./useTrackSoftNavigation"
|
||||||
|
|
||||||
@@ -13,7 +10,6 @@ import type {
|
|||||||
TrackingSDKHotelInfo,
|
TrackingSDKHotelInfo,
|
||||||
TrackingSDKPageData,
|
TrackingSDKPageData,
|
||||||
TrackingSDKPaymentInfo,
|
TrackingSDKPaymentInfo,
|
||||||
TrackingSDKUserData,
|
|
||||||
} from "./types"
|
} from "./types"
|
||||||
|
|
||||||
export function TrackingSDK({
|
export function TrackingSDK({
|
||||||
@@ -28,31 +24,20 @@ export function TrackingSDK({
|
|||||||
ancillaries?: TrackingSDKAncillaries
|
ancillaries?: TrackingSDKAncillaries
|
||||||
}) {
|
}) {
|
||||||
const pathName = usePathname()
|
const pathName = usePathname()
|
||||||
const lang = useLang()
|
|
||||||
|
|
||||||
const { data, isError } = trpc.user.userTrackingInfo.useQuery({
|
|
||||||
lang,
|
|
||||||
})
|
|
||||||
|
|
||||||
const userData: TrackingSDKUserData =
|
|
||||||
!data || isError
|
|
||||||
? ({ loginStatus: "Error" } as const)
|
|
||||||
: { ...data, memberType: "scandic-friends" }
|
|
||||||
|
|
||||||
useTrackHardNavigation({
|
useTrackHardNavigation({
|
||||||
pageData,
|
pageData,
|
||||||
hotelInfo,
|
hotelInfo,
|
||||||
paymentInfo,
|
paymentInfo,
|
||||||
ancillaries,
|
ancillaries,
|
||||||
userData,
|
|
||||||
pathName,
|
pathName,
|
||||||
})
|
})
|
||||||
|
|
||||||
useTrackSoftNavigation({
|
useTrackSoftNavigation({
|
||||||
pageData,
|
pageData,
|
||||||
hotelInfo,
|
hotelInfo,
|
||||||
paymentInfo,
|
paymentInfo,
|
||||||
ancillaries,
|
ancillaries,
|
||||||
userData,
|
|
||||||
pathName,
|
pathName,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
@@ -38,8 +38,6 @@ type LoggedInScandicUserData = TrackingSDKUserDataBase & {
|
|||||||
memberId?: string
|
memberId?: string
|
||||||
membershipNumber?: string
|
membershipNumber?: string
|
||||||
memberLevel?: MembershipLevel
|
memberLevel?: MembershipLevel
|
||||||
noOfNightsStayed?: number
|
|
||||||
totalPointsAvailableToSpend?: number
|
|
||||||
loginAction?: "login success"
|
loginAction?: "login success"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ import { logger } from "@scandic-hotels/common/logger"
|
|||||||
import { promiseWithTimeout } from "@scandic-hotels/common/utils/promiseWithTimeout"
|
import { promiseWithTimeout } from "@scandic-hotels/common/utils/promiseWithTimeout"
|
||||||
|
|
||||||
import { createSDKPageObject, trackPageView } from "./pageview"
|
import { createSDKPageObject, trackPageView } from "./pageview"
|
||||||
|
import { useTrackingUserData } from "./useTrackingUserData"
|
||||||
|
|
||||||
import type {
|
import type {
|
||||||
TrackingSDKAncillaries,
|
TrackingSDKAncillaries,
|
||||||
@@ -21,7 +22,6 @@ type TrackingSDKProps = {
|
|||||||
hotelInfo?: TrackingSDKHotelInfo
|
hotelInfo?: TrackingSDKHotelInfo
|
||||||
paymentInfo?: TrackingSDKPaymentInfo
|
paymentInfo?: TrackingSDKPaymentInfo
|
||||||
ancillaries?: TrackingSDKAncillaries
|
ancillaries?: TrackingSDKAncillaries
|
||||||
userData: TrackingSDKUserData | undefined
|
|
||||||
pathName: string
|
pathName: string
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -31,12 +31,16 @@ export const useTrackHardNavigation = ({
|
|||||||
hotelInfo,
|
hotelInfo,
|
||||||
paymentInfo,
|
paymentInfo,
|
||||||
ancillaries,
|
ancillaries,
|
||||||
userData,
|
|
||||||
pathName,
|
pathName,
|
||||||
}: TrackingSDKProps) => {
|
}: TrackingSDKProps) => {
|
||||||
const sessionId = useSessionId()
|
const sessionId = useSessionId()
|
||||||
|
const { userData, isPending } = useTrackingUserData()
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
|
if (isPending) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
if (!userData) {
|
if (!userData) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,13 +7,13 @@ import useRouterTransitionStore from "@scandic-hotels/common/stores/router-trans
|
|||||||
import useTrackingStore from "@scandic-hotels/common/stores/tracking"
|
import useTrackingStore from "@scandic-hotels/common/stores/tracking"
|
||||||
|
|
||||||
import { createSDKPageObject, trackPageView } from "./pageview"
|
import { createSDKPageObject, trackPageView } from "./pageview"
|
||||||
|
import { useTrackingUserData } from "./useTrackingUserData"
|
||||||
|
|
||||||
import type {
|
import type {
|
||||||
TrackingSDKAncillaries,
|
TrackingSDKAncillaries,
|
||||||
TrackingSDKHotelInfo,
|
TrackingSDKHotelInfo,
|
||||||
TrackingSDKPageData,
|
TrackingSDKPageData,
|
||||||
TrackingSDKPaymentInfo,
|
TrackingSDKPaymentInfo,
|
||||||
TrackingSDKUserData,
|
|
||||||
} from "./types"
|
} from "./types"
|
||||||
|
|
||||||
type TrackingSDKProps = {
|
type TrackingSDKProps = {
|
||||||
@@ -21,7 +21,6 @@ type TrackingSDKProps = {
|
|||||||
hotelInfo?: TrackingSDKHotelInfo
|
hotelInfo?: TrackingSDKHotelInfo
|
||||||
paymentInfo?: TrackingSDKPaymentInfo
|
paymentInfo?: TrackingSDKPaymentInfo
|
||||||
ancillaries?: TrackingSDKAncillaries
|
ancillaries?: TrackingSDKAncillaries
|
||||||
userData: TrackingSDKUserData | undefined
|
|
||||||
pathName: string
|
pathName: string
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -38,7 +37,6 @@ export const useTrackSoftNavigation = ({
|
|||||||
hotelInfo,
|
hotelInfo,
|
||||||
paymentInfo,
|
paymentInfo,
|
||||||
ancillaries,
|
ancillaries,
|
||||||
userData,
|
|
||||||
pathName,
|
pathName,
|
||||||
}: TrackingSDKProps) => {
|
}: TrackingSDKProps) => {
|
||||||
const [status, setStatus] = useState<TransitionStatus>(
|
const [status, setStatus] = useState<TransitionStatus>(
|
||||||
@@ -50,8 +48,13 @@ export const useTrackSoftNavigation = ({
|
|||||||
const { isTransitioning, stopRouterTransition } = useRouterTransitionStore()
|
const { isTransitioning, stopRouterTransition } = useRouterTransitionStore()
|
||||||
|
|
||||||
const previousPathname = useRef<string | null>(null)
|
const previousPathname = useRef<string | null>(null)
|
||||||
|
const { userData, isPending } = useTrackingUserData()
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
|
if (isPending) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
if (!userData) {
|
if (!userData) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|||||||
17
packages/tracking/lib/useTrackingUserData.ts
Normal file
17
packages/tracking/lib/useTrackingUserData.ts
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
"use client"
|
||||||
|
|
||||||
|
import { trpc } from "@scandic-hotels/trpc/client"
|
||||||
|
|
||||||
|
import type { TrackingSDKUserData } from "./types"
|
||||||
|
|
||||||
|
export const useTrackingUserData = () => {
|
||||||
|
const { data, isError, isPending } = trpc.user.userTrackingInfo.useQuery()
|
||||||
|
|
||||||
|
const userData: TrackingSDKUserData | undefined = !isPending
|
||||||
|
? isError || !data
|
||||||
|
? ({ loginStatus: "Error" } as const)
|
||||||
|
: { ...data, memberType: "scandic-friends" }
|
||||||
|
: undefined
|
||||||
|
|
||||||
|
return { userData, isPending, isError }
|
||||||
|
}
|
||||||
@@ -35,8 +35,6 @@ export type TrackingUserData =
|
|||||||
memberId?: string
|
memberId?: string
|
||||||
membershipNumber?: string
|
membershipNumber?: string
|
||||||
memberLevel?: MembershipLevel
|
memberLevel?: MembershipLevel
|
||||||
noOfNightsStayed?: number
|
|
||||||
totalPointsAvailableToSpend?: number
|
|
||||||
loginAction?: "login success"
|
loginAction?: "login success"
|
||||||
}
|
}
|
||||||
| {
|
| {
|
||||||
|
|||||||
@@ -1,92 +1,68 @@
|
|||||||
import { z } from "zod"
|
|
||||||
|
|
||||||
import { Lang } from "@scandic-hotels/common/constants/language"
|
|
||||||
import { createCounter } from "@scandic-hotels/common/telemetry"
|
import { createCounter } from "@scandic-hotels/common/telemetry"
|
||||||
|
|
||||||
import { safeProtectedProcedure } from "../../../procedures"
|
import { safeProtectedProcedure } from "../../../procedures"
|
||||||
import { isValidSession } from "../../../utils/session"
|
import { isValidSession } from "../../../utils/session"
|
||||||
import { getFriendsMembership } from "../helpers"
|
import { getFriendsMembership } from "../helpers"
|
||||||
import { getPreviousStays, getVerifiedUser } from "../utils"
|
import { getVerifiedUser } from "../utils"
|
||||||
|
|
||||||
import type { LoginType } from "@scandic-hotels/common/constants/loginType"
|
import type { LoginType } from "@scandic-hotels/common/constants/loginType"
|
||||||
|
|
||||||
import type { TrackingUserData } from "../../types"
|
import type { TrackingUserData } from "../../types"
|
||||||
|
|
||||||
export const userTrackingInput = z.object({
|
export const userTrackingInfo = safeProtectedProcedure.query(async function ({
|
||||||
lang: z.nativeEnum(Lang).optional(),
|
ctx,
|
||||||
})
|
}) {
|
||||||
export const userTrackingInfo = safeProtectedProcedure
|
const userTrackingInfoCounter = createCounter("user", "userTrackingInfo")
|
||||||
.input(userTrackingInput)
|
const metricsUserTrackingInfo = userTrackingInfoCounter.init()
|
||||||
.query(async function ({ ctx, input }) {
|
|
||||||
const { lang } = input
|
|
||||||
const language = lang || ctx.lang
|
|
||||||
|
|
||||||
const userTrackingInfoCounter = createCounter("user", "userTrackingInfo")
|
metricsUserTrackingInfo.start()
|
||||||
const metricsUserTrackingInfo = userTrackingInfoCounter.init()
|
|
||||||
|
|
||||||
metricsUserTrackingInfo.start()
|
const notLoggedInUserTrackingData: TrackingUserData = {
|
||||||
|
loginStatus: "Non-logged in",
|
||||||
|
}
|
||||||
|
|
||||||
const notLoggedInUserTrackingData: TrackingUserData = {
|
if (!isValidSession(ctx.session)) {
|
||||||
loginStatus: "Non-logged in",
|
metricsUserTrackingInfo.success({
|
||||||
}
|
reason: "invalid session",
|
||||||
|
data: notLoggedInUserTrackingData,
|
||||||
|
})
|
||||||
|
return notLoggedInUserTrackingData
|
||||||
|
}
|
||||||
|
|
||||||
if (!isValidSession(ctx.session)) {
|
try {
|
||||||
|
const verifiedUserData = await getVerifiedUser({ session: ctx.session })
|
||||||
|
|
||||||
|
if (
|
||||||
|
!verifiedUserData ||
|
||||||
|
"error" in verifiedUserData ||
|
||||||
|
!verifiedUserData.data.loyalty
|
||||||
|
) {
|
||||||
metricsUserTrackingInfo.success({
|
metricsUserTrackingInfo.success({
|
||||||
reason: "invalid session",
|
reason: "invalid user data",
|
||||||
data: notLoggedInUserTrackingData,
|
data: notLoggedInUserTrackingData,
|
||||||
})
|
})
|
||||||
return notLoggedInUserTrackingData
|
return notLoggedInUserTrackingData
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
const membership = getFriendsMembership(verifiedUserData.data.loyalty)
|
||||||
const verifiedUserData = await getVerifiedUser({ session: ctx.session })
|
|
||||||
|
|
||||||
if (
|
const loggedInUserTrackingData: TrackingUserData = {
|
||||||
!verifiedUserData ||
|
loginStatus: "logged in",
|
||||||
"error" in verifiedUserData ||
|
loginType: ctx.session.token.loginType as LoginType,
|
||||||
!verifiedUserData.data.loyalty
|
memberId: verifiedUserData.data.profileId,
|
||||||
) {
|
membershipNumber: membership?.membershipNumber,
|
||||||
metricsUserTrackingInfo.success({
|
memberLevel: membership?.membershipLevel,
|
||||||
reason: "invalid user data",
|
loginAction: "login success",
|
||||||
data: notLoggedInUserTrackingData,
|
|
||||||
})
|
|
||||||
return notLoggedInUserTrackingData
|
|
||||||
}
|
|
||||||
|
|
||||||
const previousStaysData = await getPreviousStays(
|
|
||||||
ctx.session.token.access_token,
|
|
||||||
1,
|
|
||||||
language
|
|
||||||
)
|
|
||||||
if (!previousStaysData) {
|
|
||||||
metricsUserTrackingInfo.success({
|
|
||||||
reason: "no previous stays data",
|
|
||||||
data: notLoggedInUserTrackingData,
|
|
||||||
})
|
|
||||||
return notLoggedInUserTrackingData
|
|
||||||
}
|
|
||||||
|
|
||||||
const membership = getFriendsMembership(verifiedUserData.data.loyalty)
|
|
||||||
|
|
||||||
const loggedInUserTrackingData: TrackingUserData = {
|
|
||||||
loginStatus: "logged in",
|
|
||||||
loginType: ctx.session.token.loginType as LoginType,
|
|
||||||
memberId: verifiedUserData.data.profileId,
|
|
||||||
membershipNumber: membership?.membershipNumber,
|
|
||||||
memberLevel: membership?.membershipLevel,
|
|
||||||
noOfNightsStayed: previousStaysData.links?.totalCount ?? 0,
|
|
||||||
totalPointsAvailableToSpend: membership?.currentPoints,
|
|
||||||
loginAction: "login success",
|
|
||||||
}
|
|
||||||
|
|
||||||
metricsUserTrackingInfo.success({
|
|
||||||
reason: "valid logged in",
|
|
||||||
data: loggedInUserTrackingData,
|
|
||||||
})
|
|
||||||
|
|
||||||
return loggedInUserTrackingData
|
|
||||||
} catch (error) {
|
|
||||||
metricsUserTrackingInfo.fail(error)
|
|
||||||
return notLoggedInUserTrackingData
|
|
||||||
}
|
}
|
||||||
})
|
|
||||||
|
metricsUserTrackingInfo.success({
|
||||||
|
reason: "valid logged in",
|
||||||
|
data: loggedInUserTrackingData,
|
||||||
|
})
|
||||||
|
|
||||||
|
return loggedInUserTrackingData
|
||||||
|
} catch (error) {
|
||||||
|
metricsUserTrackingInfo.fail(error)
|
||||||
|
return notLoggedInUserTrackingData
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user