{"version":3,"file":"6652-bc2bdcd560fa66858a03.js","mappings":"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","sources":["webpack://nikon-client/./components/atoms/CloseButton/CloseButton.tsx","webpack://nikon-client/./components/atoms/Image/Image.tsx","webpack://nikon-client/./components/atoms/Modal/Modal.tsx","webpack://nikon-client/./components/atoms/Portal/Portal.tsx","webpack://nikon-client/./components/atoms/Video/Video.tsx","webpack://nikon-client/./config/video.config.ts","webpack://nikon-client/./models/enums/VideoProviderEnum.ts","webpack://nikon-client/./components/molecules/ExternalVideo/ExternalVideo.tsx","webpack://nikon-client/./components/molecules/VideoModal/VideoModal.tsx","webpack://nikon-client/./models/enums/BreakpointEnum.ts","webpack://nikon-client/./models/enums/IconSizeEnum.ts","webpack://nikon-client/./state-management/AriaLabelsStore.ts","webpack://nikon-client/./utility/helpers/bodyScrollLock.ts","webpack://nikon-client/./utility/helpers/gtm.ts","webpack://nikon-client/./utility/hooks/useAriaLabels.ts","webpack://nikon-client/./utility/hooks/useBreakpoint.ts"],"sourcesContent":["import IconSizeEnum from '@models/enums/IconSizeEnum';\nimport useAriaLabels from '@utils/hooks/useAriaLabels';\nimport classNames from 'classnames';\nimport { MouseEventHandler } from 'react';\n\ninterface Props {\n readonly ariaLabel?: string;\n readonly className?: string;\n readonly color?: 'black' | 'white' | 'red';\n readonly onClick: MouseEventHandler;\n readonly size?: IconSizeEnum | string;\n readonly dataTestId?: string;\n}\n\nconst CloseButton = ({\n ariaLabel,\n className,\n color = 'black',\n onClick,\n size = IconSizeEnum.lg,\n dataTestId,\n}: Props) => {\n const { closeModalAriaLabel } = useAriaLabels();\n\n const closeColours = {\n black: 'before:bg-black-100 after:bg-black-100',\n white: 'before:bg-white after:bg-white',\n red: 'before:bg-red-100 after:bg-red-100',\n };\n\n return (\n \n );\n};\n\nexport default CloseButton;\n","import BreakpointEnum from '@models/enums/BreakpointEnum';\nimport { IImage } from '@models/IImage';\nimport useBreakpoint from '@utils/hooks/useBreakpoint';\nimport classNames from 'classnames';\nimport { PropsWithChildren, RefObject, useState } from 'react';\n\ninterface Props {\n readonly classes?: string;\n readonly dataTestId?: string;\n readonly epiEdit?: string;\n readonly image?: IImage;\n readonly imageClasses?: string;\n readonly imageRef?:\n | RefObject\n | ((node: HTMLElement | null) => void);\n readonly lazyLoad?: boolean;\n readonly progressiveLoad?: boolean;\n readonly sizes?: string;\n}\n\nconst Image = ({\n children,\n classes,\n dataTestId,\n epiEdit,\n image,\n imageClasses,\n imageRef,\n lazyLoad = true,\n progressiveLoad = true,\n sizes = '',\n}: PropsWithChildren) => {\n const mobileSource = image?.mobile;\n const tabletSource = image?.tablet;\n const desktopSource = image?.desktop;\n const largeDesktopSource = image?.largeDesktop;\n const breakpoint = useBreakpoint() as BreakpointEnum;\n const [isLoaded, setIsLoaded] = useState(false);\n\n if (!desktopSource?.url) return null;\n\n const currentSrc = {\n [BreakpointEnum.Small]: mobileSource,\n [BreakpointEnum.Medium]: tabletSource,\n [BreakpointEnum.Large]: desktopSource,\n [BreakpointEnum.XLarge]: largeDesktopSource,\n };\n\n return (\n \n \n setIsLoaded(true)}\n sizes={sizes}\n src={\n isLoaded && progressiveLoad\n ? currentSrc[breakpoint]?.url\n : mobileSource?.url\n }\n height={currentSrc[breakpoint]?.height}\n width={currentSrc[breakpoint]?.width}\n srcSet={`${mobileSource?.originalUrl} 376w, ${tabletSource?.originalUrl} 768w, ${desktopSource?.originalUrl} 1024w, ${largeDesktopSource?.originalUrl} 1440w`}\n {...(dataTestId && { 'data-testid': dataTestId })}\n />\n {isLoaded && children}\n \n );\n};\n\nexport default Image;\n","import CloseButton from '@atoms/CloseButton/CloseButton';\nimport Portal from '@atoms/Portal/Portal';\nimport IconSizeEnum from '@models/enums/IconSizeEnum';\nimport bodyScrollLock from '@utils/helpers/bodyScrollLock';\nimport classNames from 'classnames';\nimport FocusTrap from 'focus-trap-react';\nimport { motion } from 'framer-motion';\nimport { PropsWithChildren, useCallback, useEffect, useRef } from 'react';\n\ninterface Props {\n readonly onCloseCallback?: () => void;\n readonly contentClasses?: string;\n readonly crossMarginsClassName?: string;\n readonly crossClasses?: string;\n readonly crossColor?: 'black' | 'white';\n readonly isOpen: boolean;\n readonly modalClasses?: string;\n readonly setIsOpen?: (param: boolean) => void;\n readonly showCloseButton?: boolean;\n readonly transparent?: boolean;\n readonly isCloseButtonFixed?: boolean;\n readonly closeButtonIconSize?: IconSizeEnum | string;\n readonly shouldCloseOnClickOutsideContent?: boolean;\n readonly shouldLockBody?: boolean;\n}\n\nconst Modal = ({\n onCloseCallback,\n children,\n contentClasses,\n crossColor = 'white',\n crossMarginsClassName = 'mr-8 mt-8',\n crossClasses,\n isOpen,\n modalClasses,\n setIsOpen,\n showCloseButton = true,\n transparent = false,\n isCloseButtonFixed = true,\n closeButtonIconSize = IconSizeEnum.md,\n shouldCloseOnClickOutsideContent = false,\n shouldLockBody = true,\n}: PropsWithChildren) => {\n const contentRef = useRef(null);\n\n useEffect(() => {\n if (isOpen && shouldLockBody) {\n bodyScrollLock(true);\n }\n\n return () => {\n if (shouldLockBody) bodyScrollLock(false);\n };\n }, [isOpen, shouldLockBody]);\n\n const close = useCallback(() => {\n setIsOpen?.(false);\n onCloseCallback?.();\n }, [onCloseCallback, setIsOpen]);\n\n useEffect(() => {\n const keyboardClose = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape' && isOpen === true) {\n setIsOpen?.(false);\n }\n };\n window.addEventListener('keydown', keyboardClose);\n\n return () => {\n window.removeEventListener('keydown', keyboardClose);\n };\n }, [isOpen, setIsOpen]);\n\n useEffect(() => {\n const handleClickOutsideContent = (ev: Event) => {\n if (\n isOpen &&\n shouldCloseOnClickOutsideContent &&\n !contentRef.current?.contains(ev.target as HTMLElement)\n ) {\n close();\n }\n };\n\n window.addEventListener('click', handleClickOutsideContent, true);\n\n return () => {\n window.removeEventListener('click', handleClickOutsideContent, true);\n };\n }, [close, isOpen, shouldCloseOnClickOutsideContent]);\n\n if (!isOpen) {\n return null;\n }\n\n return (\n \n \n \n \n
\n \n \n {showCloseButton && (\n <>\n {/* A hidden button that steals the inital focus of the modal preventing the close icon from animating on modal open */}\n {/* eslint-disable-next-line jsx-a11y/control-has-associated-label */}\n
\n \n \n \n \n \n
\n );\n};\n\nexport default Modal;\n","import { PropsWithChildren, useEffect, useMemo } from 'react';\nimport { createPortal } from 'react-dom';\n\ninterface Props {\n readonly mountId: string;\n}\n\nconst Portal = ({ mountId, children }: PropsWithChildren) => {\n const containerElement = useMemo(() => document.createElement('div'), []);\n\n useEffect(() => {\n document.getElementById(mountId)?.appendChild(containerElement);\n\n return () => {\n document.getElementById(mountId)?.removeChild(containerElement);\n };\n }, [mountId, containerElement]);\n\n return createPortal(children, containerElement);\n};\n\nexport default Portal;\n","import loadable from '@loadable/component';\nimport { AspectRatioType } from '@models/IAspectRatio';\nimport { IVideoAttributes } from '@models/IVideoAttributes';\nimport { IVideoSubtitles } from '@models/IVideoSubtitles';\nimport updateDataLayer from '@utils/helpers/gtm';\nimport classNames from 'classnames';\nimport { motion, MotionValue } from 'framer-motion';\nimport {\n ChangeEvent,\n ForwardedRef,\n forwardRef,\n useEffect,\n useState,\n} from 'react';\nimport { Config } from 'react-player';\n\nconst ReactPlayer = loadable(\n () => import(/* webpackChunkName: \"react-player\" */ 'react-player')\n);\n\ninterface Props {\n readonly classes?: string;\n readonly config?: Config;\n readonly controls?: boolean;\n readonly epiEdit?: string;\n readonly isPlaying?: boolean;\n readonly subtitles?: IVideoSubtitles[];\n readonly title?: string;\n readonly url?: string;\n readonly videoAttributes?: IVideoAttributes;\n readonly videoRatio?: AspectRatioType;\n readonly videoSource?: string;\n readonly videoWrapperOpacityProgress?: MotionValue;\n readonly onEndedVideo?: () => void;\n readonly onVideoReady?: () => void;\n readonly onVideoStart?: () => void;\n readonly onVolumeChange?: (videoElement: HTMLVideoElement) => void;\n readonly setIsPlaying?: (playing: boolean) => void;\n}\n\nconst Video = forwardRef(\n (\n {\n classes,\n config,\n controls = true,\n epiEdit,\n isPlaying,\n title,\n subtitles,\n videoAttributes,\n videoRatio = 'aspect-video',\n videoSource,\n videoWrapperOpacityProgress,\n onEndedVideo,\n onVideoReady,\n onVideoStart,\n onVolumeChange,\n setIsPlaying,\n }: Props,\n ref\n ) => {\n const [prevProgress, setPrevProgress] = useState(0);\n const [isBrowser, setIsBrowser] = useState(false);\n\n useEffect(() => {\n setIsBrowser(typeof window !== 'undefined');\n }, []);\n\n useEffect(() => {\n setPrevProgress(0);\n }, [title]);\n\n const handleProgressUpdate = (progress: string) => {\n updateDataLayer({\n event: 'videoInteraction',\n video_interaction: 'video_progress',\n video_progress: progress,\n video_title: title,\n });\n };\n\n const handleVideoAction = (action: string) => {\n updateDataLayer({\n event: 'videoInteraction',\n video_interaction:\n action === 'START' ? 'video_start' : 'video_complete',\n video_progress: action === 'START' ? 'video_start' : 'video_complete',\n video_title: title,\n });\n };\n\n const updateVideoProgressData = (progress: number) => {\n if (prevProgress < 0.25 && progress > 0.25) {\n handleProgressUpdate('25%');\n }\n if (prevProgress < 0.5 && progress > 0.5) {\n handleProgressUpdate('50%');\n }\n if (prevProgress < 0.75 && progress > 0.75) {\n handleProgressUpdate('75%');\n }\n if (prevProgress > 0.9 && progress < 0.1) {\n handleVideoAction('COMPLETE');\n }\n setPrevProgress(progress);\n };\n\n if (!videoSource) return null;\n\n return (\n }\n className={classNames(classes, videoRatio, 'w-full')}\n data-epi-property-name={epiEdit}\n data-testid={isPlaying ? 'video-playing' : 'video-paused'}\n style={{\n opacity: videoWrapperOpacityProgress ?? 1,\n }}\n >\n {isBrowser && (\n updateVideoProgressData(played)}\n onStart={() => {\n onVideoStart?.();\n handleVideoAction('START');\n }}\n onEnded={() => {\n onEndedVideo?.();\n handleVideoAction('COMPLETE');\n }}\n onPause={() => setIsPlaying?.(false)}\n onPlay={() => setIsPlaying?.(true)}\n onReady={onVideoReady}\n config={{\n ...config,\n file: {\n tracks: subtitles || [],\n },\n }}\n onVolumeChange={(event: ChangeEvent) => {\n onVolumeChange?.(event.target);\n }}\n {...videoAttributes}\n />\n )}\n \n );\n }\n);\n\nexport default Video;\n","export const autoPlayYoutubePlayerAttributes = {\n playsinline: true,\n muted: true,\n playing: true,\n};\n\nexport const autoPlayYoutubePlayerConfig = {\n youtube: {\n playerVars: {\n autoplay: 1,\n mute: 1,\n enablejsapi: 1,\n showinfo: 0,\n },\n },\n};\n\nexport const standardYoutubePlayerAttributes = {\n playsinline: true,\n muted: true,\n playing: false,\n};\n\nexport const standardYoutubePlayerConfig = {\n youtube: {\n playerVars: {\n autoplay: 0,\n mute: 0,\n enablejsapi: 1,\n showinfo: 0,\n },\n },\n};\n\nexport const autoPlayVimeoPlayerAttributes = {\n playsinline: true,\n muted: true,\n playing: true,\n};\n\nexport const autoPlayVimeoPlayerConfig = {\n vimeo: {\n playerOptions: {\n autoplay: true,\n muted: true,\n },\n },\n};\n\nexport const standardVimeoPlayerAttributes = {\n playsinline: true,\n muted: false,\n playing: false,\n loop: true,\n};\n\nexport const standardViemoPlayerConfig = {\n vimeo: {\n playerOptions: {\n autoplay: false,\n muted: false,\n },\n },\n};\n","enum VideoProviderEnum {\n Youtube = 'youtube',\n Vimeo = 'vimeo',\n}\n\nexport default VideoProviderEnum;\n","import Video from '@atoms/Video/Video';\nimport {\n autoPlayVimeoPlayerAttributes,\n autoPlayVimeoPlayerConfig,\n autoPlayYoutubePlayerAttributes,\n autoPlayYoutubePlayerConfig,\n standardViemoPlayerConfig,\n standardVimeoPlayerAttributes,\n standardYoutubePlayerAttributes,\n standardYoutubePlayerConfig,\n} from '@config/video.config';\nimport VideoProviderEnum from '@models/enums/VideoProviderEnum';\nimport IExternalVideo from '@models/IExternalVideo';\nimport { IVideoAttributes } from '@models/IVideoAttributes';\nimport classNames from 'classnames';\nimport { forwardRef, PropsWithChildren } from 'react';\n\ninterface Props extends IExternalVideo {\n readonly autoPlay: boolean;\n readonly onEndedVideo?: () => void;\n readonly onVideoReady?: () => void;\n readonly onVideoStart?: () => void;\n readonly classes?: string;\n readonly customVideoAttributes?: IVideoAttributes;\n readonly isInvisible?: boolean;\n readonly dataTestId?: string;\n}\n\nconst ExternalVideo = forwardRef(\n (\n {\n videoProvider = VideoProviderEnum.Youtube,\n videoId,\n autoPlay,\n onEndedVideo,\n onVideoReady,\n onVideoStart,\n classes,\n children,\n title,\n customVideoAttributes,\n isInvisible = false,\n dataTestId = 'External-Video',\n }: PropsWithChildren,\n ref\n ) => {\n const options = {\n youtube: {\n autoPlay: {\n videoAttributes: autoPlayYoutubePlayerAttributes,\n videoConfig: autoPlayYoutubePlayerConfig,\n },\n standard: {\n videoAttributes: standardYoutubePlayerAttributes,\n videoConfig: standardYoutubePlayerConfig,\n },\n },\n vimeo: {\n autoPlay: {\n videoAttributes: autoPlayVimeoPlayerAttributes,\n videoConfig: autoPlayVimeoPlayerConfig,\n },\n standard: {\n videoAttributes: standardVimeoPlayerAttributes,\n videoConfig: standardViemoPlayerConfig,\n },\n },\n };\n\n return (\n \n \n {children}\n \n );\n }\n);\n\nexport default ExternalVideo;\n","import Modal from '@atoms/Modal/Modal';\nimport Video from '@atoms/Video/Video';\nimport VideoProviderEnum from '@models/enums/VideoProviderEnum';\nimport ExternalVideo from '@molecules/ExternalVideo/ExternalVideo';\nimport { useState } from 'react';\n\ninterface Props {\n readonly dataTestId?: string;\n readonly videoTitle?: string;\n readonly videoProvider?: VideoProviderEnum;\n readonly videoId?: string;\n readonly videoUrl?: string;\n readonly isOpen: boolean;\n readonly onOpenChange: (isOpen: boolean) => void;\n readonly onCloseCallback?: () => void;\n readonly shouldCloseOnClickOutsideContent?: boolean;\n readonly transparent?: boolean;\n}\n\nconst VideoModal = ({\n videoTitle,\n videoProvider,\n videoId,\n isOpen,\n onOpenChange,\n onCloseCallback,\n shouldCloseOnClickOutsideContent = true,\n transparent = true,\n videoUrl,\n dataTestId,\n}: Props) => {\n const [isPlaying, setIsPlaying] = useState(true);\n\n return (\n \n {videoId && videoProvider && (\n \n )}\n\n {videoUrl && (\n \n )}\n \n );\n};\n\nexport default VideoModal;\n","const enum BreakpointEnum {\n Small = 'sm',\n Medium = 'md',\n Large = 'lg',\n XLarge = 'xl',\n}\n\nexport default BreakpointEnum;\n","const enum IconSizeEnum {\n xs = '.5rem',\n sm = '.75rem',\n md = '1rem',\n lg = '1.5rem',\n xl = '1.75rem',\n}\n\nexport default IconSizeEnum;\n","import { IAriaLabels } from '@models/IAriaLabels';\nimport create from 'zustand';\n\ninterface IAriaLabelsState {\n ariaLabels: IAriaLabels;\n setAriaLabels: (ariaLabels: IAriaLabels) => void;\n}\n\nexport const initialAriaLabels: IAriaLabels = {\n backToFirstLevelNavigationAriaLabel: 'Back to first level of navigation',\n breadcrumbAriaLabel: 'Breadcrumb navigation',\n breadcrumbFooterAriaLabel: 'Breadcrumb footer navigation',\n clearFiltersAriaLabel: 'Clear filters',\n closeMenuAriaLabel: 'Close menu',\n closeAddressListAriaLabel: 'Close address list',\n closeMobileNavigationAriaLabel: 'Close navigation',\n closeModalAriaLabel: 'Close Modal',\n closeSignUpFormAriaLabel: 'Close signup form',\n closeSiteNotificationAriaLabel: 'Close site notification',\n copyToClipboardAriaLabel: 'Copy to clipboard',\n editOrDeleteAriaLabel: 'Edit or delete',\n mainNavigationAriaLabel: 'Main navigation',\n moreInformationAriaLabel: 'More information',\n nextAriaLabel: 'Go to next slide',\n openAddressListAriaLabel: 'Open address list',\n openImageInFullScreenAriaLabel: 'Open image in full screen',\n openMenuAriaLabel: 'Open menu',\n overlayToCloseDesktopNavigationAriaLabel: 'Close overlay',\n pauseVideoAriaLabel: 'Pause video',\n playVideoAriaLabel: 'Play video',\n previousAriaLabel: 'Go to previous slide',\n searchAriaLabel: 'Search',\n shareToFacebookAriaLabel: 'Share to Facebook',\n shareToWhatsappAriaLabel: 'Share to Whatsapp',\n shareToXAriaLabel: 'Share to X',\n siteNotificationsAriaLabel: 'Site notifications banner',\n uspStripAriaLabel: 'Unique Selling Point Strip',\n zoomInAriaLabel: 'Zoom in',\n zoomOutAriaLabel: 'Zoom out',\n};\n\nconst useAriaLabelsStore = create((set) => ({\n ariaLabels: initialAriaLabels,\n setAriaLabels: (ariaLabels: IAriaLabels) => set({ ariaLabels }),\n}));\n\nexport default useAriaLabelsStore;\n","const bodyScrollLock = (isScrollLocked: boolean) => {\n const documentElementScroll =\n document.documentElement.style.getPropertyValue('--scroll-y');\n const cacheLocator = documentElementScroll || `${window.scrollY}px`;\n\n if (!documentElementScroll) {\n window.addEventListener('scroll', () => {\n document.documentElement.style.setProperty(\n '--scroll-y',\n `${window.scrollY}px`\n );\n });\n }\n\n if (isScrollLocked) {\n const scrollY = cacheLocator;\n const { body } = document;\n body.style.position = 'fixed';\n body.style.top = `-${scrollY}`;\n } else {\n const { body } = document;\n body.style.position = '';\n const scrollY = body.style.top || cacheLocator;\n body.style.top = '';\n window.scrollTo(0, Math.abs(parseInt(scrollY || '0', 10)));\n }\n};\n\nexport default bodyScrollLock;\n","const updateDataLayer = (eventPayload: Record) => {\n if (typeof window !== 'undefined') {\n window.dataLayer = window.dataLayer || [];\n window.dataLayer.push(eventPayload);\n }\n};\n\nexport default updateDataLayer;\n","import { IAriaLabels } from '@models/IAriaLabels';\nimport useAriaLabelsStore, { initialAriaLabels } from '@state/AriaLabelsStore';\nimport { useEffect, useState } from 'react';\n\nconst useAriaLabels = () => {\n const [ariaLabels, setAriaLabels] = useState(initialAriaLabels);\n const ariaLabelsFromStore = useAriaLabelsStore((state) => state.ariaLabels);\n\n useEffect(() => {\n setAriaLabels(ariaLabelsFromStore);\n }, [ariaLabelsFromStore]);\n\n return ariaLabels;\n};\n\nexport default useAriaLabels;\n","import BreakpointEnum from '@models/enums/BreakpointEnum';\nimport { useCallback, useEffect, useState } from 'react';\n\nconst getCurrentBreakpoint = () => {\n const breakpoints = { tablet: 768, desktop: 1024, lgDesktop: 1440 };\n const width = window.innerWidth;\n\n if (width < breakpoints.tablet) {\n return BreakpointEnum.Small;\n }\n if (width >= breakpoints.tablet && width < breakpoints.desktop) {\n return BreakpointEnum.Medium;\n }\n if (width >= breakpoints.desktop && width < breakpoints.lgDesktop) {\n return BreakpointEnum.Large;\n }\n return BreakpointEnum.XLarge;\n};\n\nconst useBreakpoint = () => {\n const [screen, setScreen] = useState();\n\n const resizeHandler = useCallback(\n () => setScreen(getCurrentBreakpoint()),\n []\n );\n\n useEffect(() => {\n window.addEventListener('resize', resizeHandler);\n setScreen(getCurrentBreakpoint());\n\n return () => {\n window.removeEventListener('resize', resizeHandler);\n };\n }, [resizeHandler]);\n\n return screen;\n};\n\nexport default useBreakpoint;\n"],"names":["_ref","ariaLabel","className","color","onClick","size","IconSizeEnum","lg","dataTestId","closeModalAriaLabel","useAriaLabels","React","createElement","type","classNames","black","white","red","style","width","height","children","classes","epiEdit","image","imageClasses","imageRef","lazyLoad","progressiveLoad","sizes","mobileSource","mobile","tabletSource","tablet","desktopSource","desktop","largeDesktopSource","largeDesktop","breakpoint","useBreakpoint","isLoaded","setIsLoaded","useState","url","currentSrc","BreakpointEnum","Small","Medium","Large","XLarge","srcSet","_extends","ref","alt","altText","length","draggable","loading","onLoad","src","originalUrl","onCloseCallback","contentClasses","crossColor","crossMarginsClassName","crossClasses","isOpen","modalClasses","setIsOpen","showCloseButton","transparent","isCloseButtonFixed","closeButtonIconSize","md","shouldCloseOnClickOutsideContent","shouldLockBody","contentRef","useRef","useEffect","bodyScrollLock","close","useCallback","keyboardClose","ev","key","window","addEventListener","removeEventListener","handleClickOutsideContent","current","contains","target","Portal","mountId","FocusTrap","focusTrapOptions","preventScroll","escapeDeactivates","motion","div","animate","opacity","exit","initial","transition","duration","ease","Fragment","CloseButton","containerElement","useMemo","document","getElementById","appendChild","removeChild","createPortal","ReactPlayer","loadable","forwardRef","config","controls","isPlaying","title","subtitles","videoAttributes","videoRatio","videoSource","videoWrapperOpacityProgress","onEndedVideo","onVideoReady","onVideoStart","onVolumeChange","setIsPlaying","prevProgress","setPrevProgress","isBrowser","setIsBrowser","handleProgressUpdate","progress","updateDataLayer","event","video_interaction","video_progress","video_title","handleVideoAction","action","playing","onProgress","_ref2","played","onStart","onEnded","onPause","onPlay","onReady","file","tracks","autoPlayYoutubePlayerAttributes","playsinline","muted","autoPlayYoutubePlayerConfig","youtube","playerVars","autoplay","mute","enablejsapi","showinfo","standardYoutubePlayerAttributes","standardYoutubePlayerConfig","autoPlayVimeoPlayerAttributes","autoPlayVimeoPlayerConfig","vimeo","playerOptions","standardVimeoPlayerAttributes","loop","standardViemoPlayerConfig","VideoProviderEnum","videoProvider","Youtube","videoId","autoPlay","customVideoAttributes","isInvisible","options","videoConfig","standard","invisible","Video","videoTitle","onOpenChange","videoUrl","Modal","ExternalVideo","initialAriaLabels","backToFirstLevelNavigationAriaLabel","breadcrumbAriaLabel","breadcrumbFooterAriaLabel","clearFiltersAriaLabel","closeMenuAriaLabel","closeAddressListAriaLabel","closeMobileNavigationAriaLabel","closeSignUpFormAriaLabel","closeSiteNotificationAriaLabel","copyToClipboardAriaLabel","editOrDeleteAriaLabel","mainNavigationAriaLabel","moreInformationAriaLabel","nextAriaLabel","openAddressListAriaLabel","openImageInFullScreenAriaLabel","openMenuAriaLabel","overlayToCloseDesktopNavigationAriaLabel","pauseVideoAriaLabel","playVideoAriaLabel","previousAriaLabel","searchAriaLabel","shareToFacebookAriaLabel","shareToWhatsappAriaLabel","shareToXAriaLabel","siteNotificationsAriaLabel","uspStripAriaLabel","zoomInAriaLabel","zoomOutAriaLabel","create","set","ariaLabels","setAriaLabels","isScrollLocked","documentElementScroll","documentElement","getPropertyValue","cacheLocator","scrollY","setProperty","body","position","top","scrollTo","Math","abs","parseInt","eventPayload","dataLayer","push","ariaLabelsFromStore","useAriaLabelsStore","state","getCurrentBreakpoint","breakpoints","innerWidth","screen","setScreen","resizeHandler"],"sourceRoot":""}