fix: tracking fixes SW-1353 and SW-2497 * fix: tracking fixes * fix: remove console log and rename variable Approved-by: Michael Zetterberg Approved-by: Arvid Norlin
102 lines
2.8 KiB
TypeScript
102 lines
2.8 KiB
TypeScript
"use client"
|
|
|
|
import { create } from "zustand"
|
|
|
|
import { convertSearchParamsToObj, searchParamsToRecord } from "@/utils/url"
|
|
|
|
import { checkIsSameBooking } from "./enter-details/helpers"
|
|
|
|
import type { ReadonlyURLSearchParams } from "next/navigation"
|
|
|
|
import type { SelectRateSearchParams } from "@/types/components/hotelReservation/selectRate/selectRate"
|
|
|
|
interface TrackingStoreState {
|
|
initialStartTime: number
|
|
setInitialPageLoadTime: (time: number) => void
|
|
getPageLoadTime: () => number
|
|
currentParams: ReadonlyURLSearchParams | null
|
|
previousParams: ReadonlyURLSearchParams | null
|
|
currentPath: string | null
|
|
previousPath: string | null
|
|
currentLang: string | null
|
|
previousLang: string | null
|
|
updateRouteInfo: (
|
|
path: string,
|
|
lang: string,
|
|
params: ReadonlyURLSearchParams
|
|
) => void
|
|
hasPathOrLangChanged: () => boolean
|
|
hasBookingFlowParamsChanged: () => boolean
|
|
}
|
|
|
|
const useTrackingStore = create<TrackingStoreState>((set, get) => ({
|
|
initialStartTime: Date.now(),
|
|
setInitialPageLoadTime: (time) => set({ initialStartTime: time }),
|
|
getPageLoadTime: () => {
|
|
const { initialStartTime } = get()
|
|
return (Date.now() - initialStartTime) / 1000
|
|
},
|
|
currentParams: null,
|
|
previousParams: null,
|
|
currentPath: null,
|
|
previousPath: null,
|
|
currentLang: null,
|
|
previousLang: null,
|
|
updateRouteInfo: (path, lang, params) =>
|
|
set((state) => {
|
|
if (!path || !lang) return state
|
|
|
|
if (!state.currentPath || !state.currentLang) {
|
|
return {
|
|
currentParams: params,
|
|
currentPath: path,
|
|
currentLang: lang,
|
|
previousParams: null,
|
|
previousPath: null,
|
|
previousLang: null,
|
|
}
|
|
}
|
|
|
|
return {
|
|
previousParams: state.currentParams,
|
|
previousPath: state.currentPath,
|
|
previousLang: state.currentLang,
|
|
currentParams: params,
|
|
currentPath: path,
|
|
currentLang: lang,
|
|
}
|
|
}),
|
|
hasPathOrLangChanged: () => {
|
|
const { currentPath, previousPath, currentLang, previousLang } = get()
|
|
|
|
if (!previousPath || !previousLang) return false
|
|
|
|
return currentPath !== previousPath || currentLang !== previousLang
|
|
},
|
|
hasBookingFlowParamsChanged: () => {
|
|
const { currentPath, currentParams, previousParams } = get()
|
|
|
|
if (!previousParams || !currentParams) return false
|
|
|
|
if (!currentPath?.match(/^\/(da|de|en|fi|no|sv)\/(hotelreservation)/))
|
|
return false
|
|
|
|
const previousParamsObject =
|
|
convertSearchParamsToObj<SelectRateSearchParams>(
|
|
searchParamsToRecord(previousParams)
|
|
)
|
|
const currentParamsObject =
|
|
convertSearchParamsToObj<SelectRateSearchParams>(
|
|
searchParamsToRecord(currentParams)
|
|
)
|
|
|
|
const isSameBooking = checkIsSameBooking(
|
|
previousParamsObject,
|
|
currentParamsObject
|
|
)
|
|
return !isSameBooking
|
|
},
|
|
}))
|
|
|
|
export default useTrackingStore
|