{"version":3,"file":"static/js/188.c90262bb.chunk.js","mappings":"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","sources":["blocks/SlideshowBlock/index.tsx","components/Image.tsx","components/Video/index.tsx","../node_modules/@mui/material/styles/useTheme.js"],"sourcesContent":["import { Box } from \"@mui/material\"\nimport Image from \"components/Image\"\nimport Text from \"components/Text\"\nimport Video from \"components/Video\"\nimport React from \"react\"\n\nexport type SlideshowBlockProps = {\n heading?: string\n preamble?: string\n minimumHeight?: string\n overlay?: string\n heroLink?: string\n heroLinkText?: string\n textColor?: string\n isVerticallyCentered?: boolean\n video?: {\n url: string\n }\n image?: {\n url: string\n }\n}\n\nconst overlayOptions = {\n dark: 0.5,\n light: 0.2,\n none: 0,\n}\n\nconst SlideshowBlock = ({\n heading,\n image,\n preamble,\n overlay,\n video,\n isVerticallyCentered = true,\n minimumHeight = \"auto\",\n}: SlideshowBlockProps) => {\n const opacity = overlayOptions[overlay?.split(\"-\").pop() || \"none\"]\n const isBigScreen = minimumHeight === \"c-hero--large\"\n return (\n ({\n ...blocks?.SlideshowBlock,\n display: \"flex\",\n flexDirection: \"column\",\n })}\n className={minimumHeight}\n >\n {heading?.trim() && (\n \n {heading}\n \n )}\n {(image?.url || video) && (\n \n {video ? (\n \n ) : (\n \n )}\n {overlay && (\n \n )}\n \n )}\n {preamble && (\n ({\n ...blocks?.SlideshowBlock,\n maxWidth: \"600px\",\n mx: \"auto\",\n my: 1,\n px: 2,\n })}\n component=\"p\"\n // className={textColor} This is toggled of until marketing ask for the color-control back\n >\n {preamble}\n \n )}\n \n )\n}\nexport default SlideshowBlock\n","import { isSearchBot } from \"@ignite/utils/device\"\nimport Box, { BoxProps } from \"@mui/material/Box\"\nimport { Breakpoints, useTheme } from \"@mui/material/styles\"\nimport React, {\n CSSProperties,\n useCallback,\n useEffect,\n useRef,\n useState,\n} from \"react\"\n\nexport type ImageProps = Omit<\n JSX.IntrinsicElements[\"img\"],\n \"src\" | \"srcSet\" | \"width\" | \"height\"\n> & {\n alt?: string\n url?: JSX.IntrinsicElements[\"img\"][\"src\"]\n srcSet?: JSX.IntrinsicElements[\"img\"][\"srcSet\"] | null\n width?: BoxProps[\"width\"]\n height?: BoxProps[\"height\"]\n lazy?: boolean\n color?: string\n containerProps?: BoxProps\n objectFit?: CSSProperties[\"objectFit\"]\n objectPosition?: CSSProperties[\"objectPosition\"]\n title?: string\n aspectRatio?: CSSProperties[\"aspectRatio\"] | number\n forceHigherRes?: boolean\n}\n\nconst IMAGE_SIZE_BASIS = 128\nconst BLANK_PIXEL =\n \"data:image/gif;base64,R0lGODlhAQABAIAAAP///wAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==\"\n\nexport const nearestDimension = (width: ImageProps[\"width\"]) =>\n Math.max(\n IMAGE_SIZE_BASIS,\n Number(width) - (Number(width) % IMAGE_SIZE_BASIS) + IMAGE_SIZE_BASIS\n )\n\nconst generateSourceSetValues = (\n url: string,\n containerWidth: ImageProps[\"width\"],\n forceHigherRes: boolean\n) => {\n const width = nearestDimension(\n forceHigherRes ? Number(containerWidth) * 2 : containerWidth\n )\n const queryBinder = url.includes(\"?\") ? \"&\" : \"?\"\n\n return Array.from({ length: 3 }, (v, k) => k + 1).map(\n (v) => `${url}${queryBinder}w=${width * v}`\n )\n}\n\nconst getClosestMuiBreakpoint = (\n breakpoints: Breakpoints,\n dimensions: BoxProps[\"width\"] | BoxProps[\"height\"]\n) => {\n if (typeof dimensions === \"undefined\") {\n return \"xs\"\n }\n // Get highest matching breakpoints in image by viewport width or height\n const matchingBreakpoint = breakpoints.keys\n .slice()\n .reverse()\n .filter((breakpoint) => typeof dimensions[breakpoint] !== \"undefined\")\n .find((breakpoint) => window.innerWidth >= breakpoints.values[breakpoint])\n return matchingBreakpoint || \"xs\"\n}\n\nconst Image = ({\n alt = \"\",\n url,\n srcSet,\n lazy = true,\n color = \"transparent\",\n containerProps,\n objectFit = \"cover\",\n objectPosition = \"center\",\n title,\n width = \"100%\",\n height = \"auto\",\n aspectRatio,\n forceHigherRes = false,\n ...rest\n}: ImageProps) => {\n const [isLoaded, setIsLoaded] = useState(false)\n const [actualWidth, setActualWidth] = useState(width)\n const [actualHeight, setActualHeight] = useState(height)\n const theme = useTheme()\n\n const imageRef = useRef(null)\n\n const setImageSize = useCallback(() => {\n // Set correct image size if the image is lacking width, height or aspect ratio\n let actualWidth = width\n let actualHeight = height\n let surroundingElementRect\n\n const surroundingElement = imageRef.current?.parentElement?.parentElement\n\n if (typeof width === \"object\" && Object.keys(width).length > 0) {\n // Width is an object with breakpoints\n const closestBreakpoint = getClosestMuiBreakpoint(\n theme.breakpoints,\n width\n )\n actualWidth = width[closestBreakpoint] || width\n }\n\n if (typeof height === \"object\" && Object.keys(height).length > 0) {\n // Height is an object with breakpoints\n const closestBreakpoint = getClosestMuiBreakpoint(\n theme.breakpoints,\n height\n )\n actualHeight = height[closestBreakpoint] || height\n }\n\n if (\n (actualWidth.toString().endsWith(\"%\") ||\n actualWidth === \"auto\" ||\n actualHeight.toString().endsWith(\"%\") ||\n actualHeight === \"auto\") &&\n surroundingElement\n ) {\n surroundingElementRect = surroundingElement.getBoundingClientRect()\n }\n\n if (\n (actualWidth.toString().endsWith(\"%\") || actualWidth === \"auto\") &&\n surroundingElementRect\n ) {\n // If percentage width, get actual width from container\n actualWidth = Math.ceil(surroundingElementRect.width)\n }\n\n if (\n (actualHeight.toString().endsWith(\"%\") || actualHeight === \"auto\") &&\n surroundingElementRect\n ) {\n // If percentage height, get actual height from container\n actualHeight = Math.ceil(surroundingElementRect.height)\n }\n\n setActualWidth(actualWidth)\n setActualHeight(actualHeight)\n }, [width, height, theme.breakpoints])\n\n useEffect(() => {\n // Add loading event listener for opacity transition effect\n const ref = imageRef.current\n\n const onLoad = () => {\n setIsLoaded(true)\n\n if (ref) {\n ref.removeEventListener(\"load\", onLoad)\n }\n }\n\n if (ref) {\n ref.addEventListener(\"load\", onLoad)\n }\n\n return () => {\n setIsLoaded(false)\n\n if (ref) {\n ref.removeEventListener(\"load\", onLoad)\n }\n }\n }, [imageRef])\n\n useEffect(setImageSize, [setImageSize])\n\n let src\n\n if (typeof actualWidth !== \"number\") {\n src = BLANK_PIXEL\n } else if (!srcSet && srcSet !== null) {\n // srcSet isn't set, but if it's null we really don't want a srcset at all\n const srcSetValues =\n (url && generateSourceSetValues(url, actualWidth, forceHigherRes)) || []\n src = srcSetValues[0] ? srcSetValues[0] : \"\"\n srcSet = srcSetValues.map((set, index) => `${set} ${index + 1}x`).toString()\n } else {\n src = url\n }\n\n if (!src) {\n return null\n }\n\n // Remove not needed props from API\n delete rest[\"id\"]\n delete rest[\"type\"]\n delete rest[\"properties\"]\n\n return (\n ({\n ...(color !== \"transparent\" && { backgroundColor: color }),\n \"& > img\": {\n width: \"100%\",\n height: \"100%\",\n objectFit,\n objectPosition,\n opacity: isLoaded || !lazy || isSearchBot() ? 1 : 0,\n transition: `opacity ${transitions.duration.short}ms ${transitions.easing.easeInOut}`,\n ...(aspectRatio && { aspectRatio: aspectRatio.toString() }),\n },\n }),\n ...(containerProps?.sx && Array.isArray(containerProps.sx)\n ? containerProps.sx\n : [containerProps?.sx]),\n ]}\n >\n
\n \n )\n}\n\nexport default Image\n","import {\n getClosestLowBreakpoint,\n setAllLowerBreakpointsTrueandEmit,\n videoBreakpoints,\n} from \"@ignite/react/components/DataLayerPublisher\"\nimport { videoParameters } from \"@ignite/react/components/DataLayerPublisher/constants\"\nimport Box, { BoxProps } from \"@mui/material/Box\"\nimport ButtonBase from \"@mui/material/ButtonBase\"\nimport PlayIcon from \"components/Icons/PlayIcon\"\nimport useOnScreen from \"hooks/useOnScreen\"\nimport React, { ReactElement, useEffect, useRef, useState } from \"react\"\n\nimport { nearestDimension } from \"../Image\"\n\nexport type VideoProps = JSX.IntrinsicElements[\"video\"] & {\n url: string\n background?: boolean\n lazy?: boolean\n defer?: boolean\n videoWrapperProps?: BoxProps\n playButton?: ReactElement\n}\n\n/** Shows a self hosted video, ie. a MP4 file\n * @param url - The url of the video, ie. /videos/video.mp4\n * @param background - If true, the video will be shown as a background\n * @param lazy - If true, the video will only be loaded when it is in the viewport\n * @param defer - Not really sure, needs to be fixed\n * @param poster - The url of the poster image, ie. /images/poster.jpg\n * @param videoWrapperProps - Props on the wrapper element\n */\nconst Video = ({\n url,\n background,\n autoPlay = true,\n lazy = true,\n defer = false,\n poster,\n videoWrapperProps,\n playButton,\n ...rest\n}: VideoProps) => {\n // const { t } = useTranslation()\n const videoRef = useRef(null)\n\n const [playing, setPlaying] = useState(autoPlay)\n const [disableRipple, setDisableRipple] = useState(autoPlay)\n const [posterUrl, setPosterUrl] = useState()\n const [videoTracking, setVideoTracking] = useState({\n breakpoints: {\n 10: false,\n 25: false,\n 50: false,\n 75: false,\n 90: false,\n } as videoBreakpoints,\n videoStart: false,\n videoCompleted: false,\n videoDuration: \"0\",\n videoParams: videoParameters,\n })\n let isInViewport = useOnScreen(videoRef)\n isInViewport = lazy ? isInViewport : true\n\n useEffect(() => {\n if (videoRef?.current && isInViewport) {\n if (playing) {\n videoRef.current.play().catch(() => {\n /* Ignore error, can happen when video is not playable yet */\n })\n } else {\n videoRef.current.pause()\n }\n if (poster && !posterUrl) {\n const width = parseInt(window.getComputedStyle(videoRef.current).width!)\n setPosterUrl(`${poster}?w=${nearestDimension(width)}`)\n }\n }\n }, [isInViewport, playing, poster, posterUrl])\n\n useEffect(() => {\n if (playing) {\n const tm = setTimeout(() => setDisableRipple(true), 300)\n return () => {\n clearTimeout(tm)\n }\n }\n return\n }, [playing])\n\n const getVideoStats = (e: React.SyntheticEvent) => {\n const stats = {\n currentlyPlayedinWholeSeconds: Math.round(e.currentTarget.currentTime),\n duration: Math.round(e.currentTarget.duration),\n currentlyPlayed: Math.round(\n (e.currentTarget.currentTime / e.currentTarget.duration) * 100\n ),\n }\n return stats\n }\n\n const videoProgress = (e: React.SyntheticEvent) => {\n const { currentlyPlayed, currentlyPlayedinWholeSeconds, duration } =\n getVideoStats(e)\n const breakpoints = Object.keys(videoTracking.breakpoints).map((el) =>\n Number(el)\n )\n const closestBp = getClosestLowBreakpoint(breakpoints, currentlyPlayed)\n const currentBp = videoTracking.breakpoints[closestBp!] ?? null\n const src = videoRef.current?.currentSrc\n const filename = src!.substring(src!.lastIndexOf(\"/\") + 1)\n\n if (closestBp && currentBp === false) {\n const params = {\n ...videoTracking.videoParams,\n video_current_time: currentlyPlayedinWholeSeconds.toString(),\n video_percent: closestBp.toString(),\n visible: isInViewport.toString(),\n video_duration: duration,\n event_label: filename ?? \"not available\",\n video_title: filename ?? \"not available\",\n video_provider: \"website\",\n event_sub_category: \"website\",\n video_url: videoRef.current?.currentSrc,\n }\n const newBps = setAllLowerBreakpointsTrueandEmit(\n videoTracking.breakpoints,\n closestBp,\n params\n )\n setVideoTracking((oldState) => ({\n ...oldState,\n breakpoints: {\n ...oldState.breakpoints,\n ...newBps,\n },\n }))\n }\n }\n const videoProps: React.HTMLProps = (background && {\n autoPlay: true,\n muted: true,\n loop: true,\n onTimeUpdate: (e) => {\n videoProgress(e)\n },\n playsInline: true,\n preload: \"auto\",\n style: {\n objectFit: \"cover\",\n },\n }) || {\n controls: playing,\n onTimeUpdate: (e) => {\n videoProgress(e)\n },\n }\n\n const showPlayButton = !autoPlay && !playing\n\n const handleVideoClick = () => {\n if (showPlayButton) {\n setPlaying(true)\n }\n }\n\n const VideoWrapper = (\n video\": {\n position: \"absolute\",\n top: 0,\n left: 0,\n width: 1.0,\n height: 1.0,\n objectPosition: \"center\",\n borderRadius: \"18px\",\n overflow: \"hidden\",\n },\n },\n ...(videoWrapperProps?.sx && Array.isArray(videoWrapperProps.sx)\n ? videoWrapperProps.sx\n : [videoWrapperProps?.sx]),\n ]}\n >\n \n \n )\n\n if (showPlayButton) {\n return (\n \n {VideoWrapper}\n\n {playButton || (\n ({\n top: \"50%\",\n left: \"50%\",\n transform: \"translate(-50%, -50%)\",\n color: palette.common.white,\n })}\n >\n ({\n width: { xs: 42, md: 54 },\n height: { xs: 42, md: 54 },\n color: palette.common.white,\n opacity: 0.8,\n })}\n />\n \n )}\n \n )\n } else {\n return VideoWrapper\n }\n}\n\nexport default Video\n","'use client';\n\nimport * as React from 'react';\nimport { useTheme as useThemeSystem } from '@mui/system';\nimport defaultTheme from './defaultTheme';\nimport THEME_ID from './identifier';\nexport default function useTheme() {\n const theme = useThemeSystem(defaultTheme);\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useDebugValue(theme);\n }\n return theme[THEME_ID] || theme;\n}"],"names":["overlayOptions","dark","light","none","_ref","heading","image","preamble","overlay","video","_ref$isVerticallyCent","isVerticallyCentered","_ref$minimumHeight","minimumHeight","opacity","split","pop","isBigScreen","_jsxs","Box","sx","_ref2","blocks","_objectSpread","SlideshowBlock","display","flexDirection","className","children","trim","_jsx","Text","component","variant","bold","textAlign","textWrap","overflowWrap","hyphens","url","position","borderRadius","width","overflow","maxHeight","my","Video","background","videoWrapperProps","objectPosition","xs","sm","Image","alt","containerProps","minHeight","height","top","left","backgroundColor","_ref3","maxWidth","mx","px","nearestDimension","Math","max","Number","getClosestMuiBreakpoint","breakpoints","dimensions","keys","slice","reverse","filter","breakpoint","find","window","innerWidth","values","src","_ref$alt","srcSet","_ref$lazy","lazy","_ref$color","color","_ref$objectFit","objectFit","_ref$objectPosition","title","_ref$width","_ref$height","aspectRatio","_ref$forceHigherRes","forceHigherRes","rest","_objectWithoutProperties","_excluded","_useState","useState","_useState2","_slicedToArray","isLoaded","setIsLoaded","_useState3","_useState4","actualWidth","setActualWidth","_useState5","_useState6","actualHeight","setActualHeight","theme","useTheme","imageRef","useRef","setImageSize","useCallback","_imageRef$current","_imageRef$current$par","surroundingElementRect","surroundingElement","current","parentElement","Object","length","closestBreakpoint","toString","endsWith","getBoundingClientRect","ceil","useEffect","ref","onLoad","removeEventListener","addEventListener","srcSetValues","containerWidth","queryBinder","includes","Array","from","v","k","map","concat","generateSourceSetValues","set","index","transitions","isSearchBot","transition","duration","short","easing","easeInOut","_toConsumableArray","isArray","loading","draggable","_ref$autoPlay","autoPlay","_ref$defer","defer","poster","playButton","videoRef","playing","setPlaying","disableRipple","setDisableRipple","posterUrl","setPosterUrl","_useState7","videoStart","videoCompleted","videoDuration","videoParams","videoParameters","_useState8","videoTracking","setVideoTracking","isInViewport","useOnScreen","play","catch","pause","parseInt","getComputedStyle","tm","setTimeout","clearTimeout","videoProgress","e","_videoTracking$breakp","_videoRef$current","_getVideoStats","currentlyPlayedinWholeSeconds","round","currentTarget","currentTime","currentlyPlayed","getVideoStats","el","closestBp","getClosestLowBreakpoint","currentBp","currentSrc","filename","substring","lastIndexOf","_videoRef$current2","params","video_current_time","video_percent","visible","video_duration","event_label","video_title","video_provider","event_sub_category","video_url","newBps","setAllLowerBreakpointsTrueandEmit","oldState","videoProps","muted","loop","onTimeUpdate","playsInline","preload","style","controls","showPlayButton","VideoWrapper","paddingBottom","type","ButtonBase","onClick","alignItems","justifyContent","transform","palette","common","white","PlayIcon","md","useThemeSystem","defaultTheme","THEME_ID"],"sourceRoot":""}