{"version":3,"file":"js/3692.chunk.js","mappings":"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","sources":["webpack:///./assets/common/src/ui/modal/ModalDialog.tsx","webpack:///./assets/common/src/utils/useBreakpoint.ts","webpack:///./assets/moncler/src/components/routerTransitions/AnimatedProvider.tsx","webpack:///./assets/moncler/src/components/routerTransitions/AnimatedRoute.tsx","webpack:///./assets/moncler/src/components/routerTransitions/useAnimatedImage.tsx","webpack:///./assets/moncler/src/components/product/ProductImage.tsx"],"sourcesContent":["import React, { Suspense } from 'react';\nimport { autoChooseComponent } from '@common/utils/brandDiffsUtils';\nconst StoneModalDialog = React.lazy(() => import('@stone/components/modal/ModalDialog'));\nconst MocnclerModalDialog = React.lazy(() => import('@moncler/components/modal/ModalDialog'));\nconst ModalDialog = (props) => {\n return (React.createElement(Suspense, { fallback: React.createElement(React.Fragment, null) }, autoChooseComponent({\n MO: React.createElement(MocnclerModalDialog, Object.assign({}, props)),\n ST: React.createElement(StoneModalDialog, Object.assign({}, props, { isLegacy: true })),\n })));\n};\nexport default ModalDialog;\n","import { useEffect, useState } from 'react';\nconst getInitialBreakpointValue = () => {\n var _a;\n // get initial breakpoint is called before the page is fully loaded and innerWith may be 0. windows.mqObj may not be set\n const mediaQueries = window.mqObj;\n const documentWidth = window.innerWidth || ((_a = window.visualViewport) === null || _a === void 0 ? void 0 : _a.width);\n if (documentWidth == 0 || !mediaQueries) {\n return;\n }\n const filtered = Object.keys(mediaQueries).filter((key) => mediaQueries[key] <= documentWidth);\n const initalBr = filtered.length ? mediaQueries[filtered[filtered.length - 1]] : mediaQueries['xs'];\n // console.info('[getInitialBreakpointValue]: ', documentWidth, initalBr);\n return initalBr;\n};\nconst mediaQueries = Object.assign({ ' {\n const [currentBreakpoint, setCurrentBreakpoint] = useState(getInitialBreakpointValue());\n const getCurrentBreakpoint = () => {\n var _a;\n const documentWidth = window.innerWidth || ((_a = window.visualViewport) === null || _a === void 0 ? void 0 : _a.width);\n if (documentWidth == 0) {\n return;\n }\n const filtered = Object.keys(mediaQueries).filter((key) => mediaQueries[key] <= documentWidth);\n return mediaQueries[filtered[filtered.length - 1]];\n };\n const handleResize = () => {\n const currentBr = getCurrentBreakpoint();\n if (currentBr && currentBr !== currentBreakpoint) {\n // console.info('%c[React - Breakpoint change] ', 'color: green;font-weight: bold;', currentBr);\n setCurrentBreakpoint(currentBr);\n }\n };\n // const debounceResize = () => {\n // handleResize();\n // };\n useEffect(() => {\n window.addEventListener('resize', handleResize);\n return () => {\n window.removeEventListener('resize', handleResize);\n };\n });\n return currentBreakpoint;\n};\nexport default useBreakpoint;\n","import { useAnimation } from 'framer-motion';\nimport React, { createContext, useContext, useRef } from 'react';\nimport { useLocation } from 'react-router-dom';\nimport { originXYZero, pushTransition } from './transitions';\nimport { ScrollTrigger } from 'gsap/ScrollTrigger';\nexport const AnimatedContext = createContext({});\nconst AnimatedProvider = (props) => {\n // State\n const location = useLocation();\n const firstRender = useRef(true);\n const bodyHeight = useRef(null);\n const store = {\n enter: null,\n exit: null,\n };\n const intermediaryImg = { el: useRef(null), animation: useAnimation() };\n const intermediaryWrapper = useRef(null);\n const playbackHooks = useRef({\n done: [],\n setup: [],\n animate: [],\n appMounted: [],\n });\n // Methods\n const subscribe = (key, cb) => {\n playbackHooks.current[key].push(cb);\n };\n const unsubscribe = (key, cb) => {\n playbackHooks.current[key] = [...playbackHooks.current[key].filter((entry) => entry !== cb)];\n };\n const setIntermediarySrc = async (exitSrc) => {\n const img = intermediaryImg.el.current;\n img.src = exitSrc;\n await img.decode();\n };\n const resetIntermediary = async () => {\n intermediaryWrapper.current.querySelector('.fade-backdrop').classList.remove('transitioning');\n intermediaryImg.el.current.classList.remove('shown');\n intermediaryImg.el.current.classList.remove('transitioning');\n intermediaryImg.el.current.src = '';\n };\n const resetStore = () => {\n store.exit = null;\n store.enter = null;\n };\n const skipAnimation = async (params) => {\n var _a;\n const { animate, done } = playbackHooks.current;\n const { enter, exit, transition, viewport } = params;\n const scrollY = (viewport === null || viewport === void 0 ? void 0 : viewport.scrollY) || 0;\n const header = document.getElementsByTagName('header')[0];\n const catalogContainer = document.getElementById('catalog');\n if ((transition === null || transition === void 0 ? void 0 : transition.direction) === 'out') {\n header === null || header === void 0 ? void 0 : header.classList.add('no-transition');\n }\n await Promise.all(animate.map(async (cb) => await cb(params)));\n enter.animation.set(Object.assign({ opacity: 1, pointerEvents: 'all', y: 0, x: 0, scale: 1 }, originXYZero));\n await Promise.all(done.map(async (cb) => await cb(params)));\n if ((_a = enter === null || enter === void 0 ? void 0 : enter.el) === null || _a === void 0 ? void 0 : _a.current) {\n enter.el.current.style.position = 'static';\n }\n catalogContainer.style.removeProperty('overflow');\n catalogContainer.style.removeProperty('height');\n header === null || header === void 0 ? void 0 : header.classList.remove('transitioning');\n document.documentElement.scrollTop = scrollY;\n exit.done();\n enter.done();\n resetStore();\n if (transition.direction === 'out') {\n header === null || header === void 0 ? void 0 : header.classList.remove('header--pdp');\n header === null || header === void 0 ? void 0 : header.classList.remove('no-transition');\n }\n };\n // SECTION - No Transition --------------------------------------------------------------------\n const noTransition = async (params) => {\n const { setup } = playbackHooks.current;\n const { enter, exit, transition } = params;\n const catalogContainer = document.getElementById('catalog');\n if (transition.direction === 'in') {\n bodyHeight.current = `${catalogContainer.offsetHeight}`;\n }\n else {\n catalogContainer.style.height = `${bodyHeight.current}px`;\n }\n const header = document.getElementsByTagName('header')[0];\n if (transition.direction === 'in') {\n header === null || header === void 0 ? void 0 : header.classList.add('header--pdp');\n }\n else {\n header === null || header === void 0 ? void 0 : header.classList.add('no-transition');\n header === null || header === void 0 ? void 0 : header.classList.remove('header--pdp');\n }\n enter.el.current.style.zIndex = '0';\n exit.el.current.style.zIndex = '1';\n exit.el.current.style.position = 'relative';\n enter.el.current.style.position = 'absolute';\n // Setup\n await Promise.all(setup.map(async (cb) => await cb(params)));\n skipAnimation(params);\n };\n // !SECTION End No transition\n // SECTION - Push --------------------------------------------------------------------\n const push = async (params) => {\n var _a, _b;\n const { animate, done } = playbackHooks.current;\n const { enter, exit, transition, viewport } = params;\n const catalogContainer = document.getElementById('catalog');\n if (transition.direction === 'in') {\n bodyHeight.current = `${catalogContainer.offsetHeight}`;\n }\n const header = document.getElementsByTagName('header')[0];\n if (window.innerWidth < window.mqObj['md'] && transition.direction === 'in') {\n header === null || header === void 0 ? void 0 : header.classList.add('header--pdp');\n header === null || header === void 0 ? void 0 : header.classList.add('transitioning');\n }\n else if (window.innerWidth > window.mqObj['md']) {\n header === null || header === void 0 ? void 0 : header.classList.remove('header--pdp');\n }\n const scale = (transition === null || transition === void 0 ? void 0 : transition.direction) === 'in' ? 0.7 : 1 / 0.7;\n const scrollY = (viewport === null || viewport === void 0 ? void 0 : viewport.scrollY) || 0;\n const exitScrollTop = window.scrollY;\n const winHeight = document.documentElement.clientHeight;\n const exitOriginY = winHeight / 2 + exitScrollTop;\n exit.el.current.style.zIndex = '2'; // Needed for PLP to be over PDP's accordions\n exit.el.current.style.position = 'fixed';\n exit.el.current.style.overflow = `hidden`;\n exit.el.current.style.scale = `1`;\n exit.el.current.style.opacity = `1`;\n const pushTransitionEase = pushTransition.transition.ease.join(',');\n exit.el.current.style.transition = `scale .75s cubic-bezier(${pushTransitionEase}), opacity .33s cubic-bezier(${pushTransitionEase})`;\n enter.el.current.style.transition = `opacity .5s cubic-bezier(${pushTransitionEase})`;\n enter.el.current.style.position = 'static';\n enter.el.current.style.zIndex = '0';\n enter.el.current.style.opacity = '0';\n enter.el.current.style.scale = '1';\n // Setup\n // await Promise.all(setup.map(async (cb: Function) => await cb(params)));\n //check if page is not ready\n if (!((_a = exit === null || exit === void 0 ? void 0 : exit.el) === null || _a === void 0 ? void 0 : _a.current) || !((_b = enter === null || enter === void 0 ? void 0 : enter.el) === null || _b === void 0 ? void 0 : _b.current)) {\n console.warn('ANIMATION SKIPPED FOR AJAX PROBLEM');\n skipAnimation(params);\n return;\n }\n await Promise.all(animate.map(async (cb) => await cb(params)));\n document.documentElement.scrollTop = scrollY;\n exit.el.current.style.top = `-${exitScrollTop}px`;\n exit.el.current.style.transformOrigin = `center ${exitOriginY}px`;\n // exit.animation.start\n exit.el.current.style.scale = `${1 / scale}`;\n exit.el.current.style.opacity = `0`;\n await new Promise((resolve) => {\n setTimeout(() => {\n resolve(1);\n }, 750);\n });\n exit.done();\n enter.el.current.style.opacity = '1';\n // Clean up\n await Promise.all(done.map(async (cb) => await cb(params)));\n if (transition.direction === 'in' && window.isMobile()) {\n enter.el.current.querySelector('.product-hero-gallery').classList.add('fix-flicker-ios');\n }\n enter.el.current.style.pointerEvents = 'all';\n enter.el.current.style.scale = '';\n enter.done();\n resetStore();\n if (transition.direction === 'out') {\n header === null || header === void 0 ? void 0 : header.classList.remove('header--pdp');\n }\n header === null || header === void 0 ? void 0 : header.classList.remove('transitioning');\n if (transition.direction === 'in' && window.isMobile()) {\n setTimeout(() => {\n enter.el.current.querySelector('.product-hero-gallery').classList.remove('fix-flicker-ios');\n }, 150);\n }\n };\n // !SECTION End Push\n const getCustomTime = () => {\n const cookiename = 'devtranstime';\n let name = cookiename + '=';\n let decodedCookie = decodeURIComponent(document.cookie);\n let ca = decodedCookie.split(';');\n for (let i = 0; i < ca.length; i++) {\n let c = ca[i];\n while (c.charAt(0) == ' ') {\n c = c.substring(1);\n }\n if (c.indexOf(name) == 0) {\n return parseInt(c.substring(name.length, c.length));\n }\n }\n return null;\n };\n const CUSTOM_TIME = getCustomTime();\n const TOTAL_TIME = CUSTOM_TIME || 1.2;\n const handleTime = (time) => {\n return (time / 12) * TOTAL_TIME;\n };\n // !SECTION End Zoomout\n // SECTION Zoom in --------------------------------------------------------------------\n const handleZoomIn = async (params) => {\n var _a, _b;\n const { setup, animate, done } = playbackHooks.current;\n const { enter, exit, transition } = params;\n const { state } = location;\n const header = document.getElementsByTagName('header')[0];\n const tickerBar = document.querySelector('.ticker-bar');\n const catalogContainer = document.getElementById('catalog');\n // const stickyTray = document.querySelector('.sticky-tray') as HTMLElement;\n const exitTile = document.querySelector(`[data-productuuid=\"${state.transition.productUuid}\"]`);\n if (transition.direction === 'in') {\n bodyHeight.current = `${catalogContainer.offsetHeight}`;\n }\n else {\n catalogContainer.style.height = `${bodyHeight.current}px`;\n }\n header.classList.add('header--pdp');\n header.classList.add('transitioning');\n // Setup\n enter.el.current.style.position = 'absolute';\n catalogContainer.style.overflow = 'hidden';\n // if (stickyTray) stickyTray.style.opacity = '0';\n await Promise.all(setup.map(async (cb) => await cb(params)));\n const availableEnterAnimatedImages = enter.animatedImages.filter((image) => image.productId);\n const enterImagesCount = availableEnterAnimatedImages.length;\n let enterImage;\n if (enterImagesCount === 1) {\n enterImage = availableEnterAnimatedImages[0];\n }\n else {\n enterImage = availableEnterAnimatedImages.find((i) => {\n return i.productId === state.transition.productId;\n });\n }\n const exitImage = exit.animatedImages.find((image) => {\n return image.productUuid === state.transition.productUuid;\n });\n //check if page is not ready\n if (!((_a = enterImage === null || enterImage === void 0 ? void 0 : enterImage.el) === null || _a === void 0 ? void 0 : _a.current) || !((_b = exitImage === null || exitImage === void 0 ? void 0 : exitImage.el) === null || _b === void 0 ? void 0 : _b.current)) {\n console.warn('ANIMATION SKIPPED FOR AJAX PROBLEM');\n skipAnimation(params);\n await resetIntermediary();\n return;\n }\n const exitingImageSrc = enterImage.el.current.dataset.qualityImg;\n try {\n await setIntermediarySrc(exitingImageSrc);\n }\n catch (error) {\n console.log('intermediaryImage Decoding error', error);\n skipAnimation(params);\n await resetIntermediary();\n return;\n }\n // ANCHOR zoomIN standard\n const exitRect = exitImage.el.current.getBoundingClientRect(); // Repaint\n const exitTileRect = exitTile.getBoundingClientRect(); // Repaint\n const enterRect = enterImage.el.current.getBoundingClientRect(); // Repaint\n const scale = exitRect.width / enterRect.width;\n const leftAnchored = exitTileRect.left <= 0;\n intermediaryImg.el.current.style.setProperty('transform-origin', leftAnchored ? '0 0' : '100% 0');\n let intermediaryX = 0;\n let intermediaryY = exitTileRect.top / scale;\n intermediaryImg.el.current.style.setProperty('--intermediaryT', `scale(${scale}) translate(${intermediaryX}px, ${intermediaryY}px)`);\n intermediaryImg.el.current.classList.add('shown');\n await new Promise((resolve) => {\n setTimeout(() => {\n resolve(1);\n }, 100);\n });\n // animazioni di setup\n enter.animation.set({\n pointerEvents: 'all',\n y: 0,\n zIndex: 10,\n });\n await Promise.all(animate.map(async (cb) => await cb(params)));\n // Actual Transitions\n // ANCHOR * INTERMEDIARY ๐ŸŒ† --------------------------------------------------------------------\n intermediaryY = tickerBar ? tickerBar.offsetHeight : 0;\n intermediaryImg.el.current.classList.add('transitioning');\n intermediaryWrapper.current.querySelector('.fade-backdrop').classList.add('transitioning');\n intermediaryImg.el.current.style.setProperty('--intermediaryT', `translate(-${intermediaryX}px, ${intermediaryY}px)`);\n const finalScale = (enterRect.height / exitRect.height) * scale;\n intermediaryX = ((enterRect.width * finalScale - window.innerWidth) / 2 / finalScale) * (leftAnchored ? -1 : 1);\n // Animating both scale and translate creates an unwanted \"curve\" in the tile's movement, better add scale in a second moment\n intermediaryImg.el.current.style.setProperty('--intermediaryT', `scale(${finalScale}) translate(${intermediaryX}px, ${intermediaryY}px)`);\n await new Promise((resolve) => {\n intermediaryImg.el.current.addEventListener('transitionend', () => {\n resolve(1);\n }, { once: true });\n });\n // ANCHOR * EXIT โŒ --------------------------------------------------------------------\n // Removed EXIT animation ( the exit will be covered - not needed )\n // @ts-ignore scrollBehavior should accepts 'instant' indeed\n window.scroll({ top: 0, left: 0, behavior: 'instant' });\n // ANCHOR * ENTER โœ… --------------------------------------------------------------------\n await enter.animation.start({\n opacity: 1,\n transition: {\n duration: handleTime(2),\n },\n });\n // ANCHOR * CLEAN UP โญ๏ธ -------------------------------------------------------------------\n resetIntermediary();\n enter.el.current.style.position = 'static';\n enter.el.current.style.scale = '';\n exit.el.current.style.position = 'static';\n header.classList.remove('transitioning');\n catalogContainer.style.removeProperty('overflow');\n catalogContainer.style.removeProperty('height');\n exit.done();\n enter.done();\n await Promise.all(done.map(async (cb) => await cb(params)));\n resetStore();\n };\n // !SECTION\n const submitEnter = async (enter) => {\n if (firstRender.current) {\n const { appMounted } = playbackHooks.current;\n await Promise.all(appMounted.map(async (cb) => {\n await cb();\n }));\n firstRender.current = false;\n }\n else {\n store.enter = enter;\n ready();\n }\n };\n const submitExit = (exit) => {\n store.exit = exit;\n ready();\n };\n // ANCHOR - Ready --------------------------------------------------------------------\n const ready = async () => {\n const { state } = location;\n const { exit, enter } = store;\n if (!exit || !enter)\n return;\n // OE-14793 - PLP click on color swatch not works the zoom()\n const animationObject = {\n exit,\n enter,\n viewport: state === null || state === void 0 ? void 0 : state.viewport,\n transition: state === null || state === void 0 ? void 0 : state.transition,\n };\n if (window.tileToPlpTransition !== 'none') {\n if (window.tileToPlpTransition === 'push') {\n await push(animationObject);\n }\n else if (window.tileToPlpTransition === 'scale') {\n if (state.transition.direction === 'in' && window.innerWidth < window.mqObj['md']) {\n await handleZoomIn(animationObject);\n }\n else {\n await push(animationObject);\n }\n }\n }\n else {\n await noTransition(animationObject);\n }\n if (state.transition.direction === 'out') {\n ScrollTrigger.disable();\n }\n else {\n ScrollTrigger.refresh();\n }\n // update global variable in order to force chat refresh\n //@ts-ignore\n if (window.chatObject)\n window.chatObject.value = new Date().getTime();\n };\n const context = {\n submitExit,\n submitEnter,\n subscribe,\n unsubscribe,\n };\n // Render\n return (React.createElement(AnimatedContext.Provider, { value: context },\n React.createElement(\"div\", { ref: intermediaryWrapper, className: \"intermediary-wrapper\" },\n React.createElement(\"img\", { ref: intermediaryImg.el, src: \"\", alt: \"\", className: \"intermediary-image\" }),\n React.createElement(\"div\", { className: \"fade-backdrop\" })),\n props.children));\n};\nexport const useAnimatedContext = () => {\n return useContext(AnimatedContext);\n};\nexport default AnimatedProvider;\n","import { __rest } from \"tslib\";\nimport { motion, useAnimation } from 'framer-motion';\nimport React, { createContext, useContext, useEffect, useRef, useState } from 'react';\nimport { Route, useLocation } from 'react-router-dom';\nimport { Transition } from 'react-transition-group';\nimport { useAnimatedContext } from './AnimatedProvider';\nexport const AnimatedRouteContext = createContext({\n // Cannot remove default values!\n registerAnimatedImage: () => { },\n unregisterAnimatedImage: () => { },\n});\nexport const useAnimatedRouteContext = () => useContext(AnimatedRouteContext);\n// Component\nconst AnimatedRoute = (props) => {\n const { path, exact, children } = props, rest = __rest(props, [\"path\", \"exact\", \"children\"]);\n const el = useRef();\n const endListener = useRef(() => { });\n const [animatedImages, setanimatedImages] = useState([]);\n const { subscribe, unsubscribe, submitEnter, submitExit } = useAnimatedContext();\n const { pathname } = useLocation();\n const animation = useAnimation();\n useEffect(() => {\n const onAppMounted = () => {\n animation.set({\n opacity: 1,\n pointerEvents: 'all',\n });\n };\n subscribe('appMounted', onAppMounted);\n return () => {\n unsubscribe('appMounted', onAppMounted);\n };\n }, []);\n const done = () => {\n endListener.current();\n };\n const handleEntering = () => {\n // console.info('%c [transition] handleEntering', 'color: green;');\n submitEnter({\n el,\n done,\n animation,\n animatedImages,\n });\n };\n const handleExit = () => {\n // console.info('%c [transition] handleExit', 'color: red;');\n submitExit({\n el,\n done,\n animation,\n animatedImages,\n });\n };\n const methods = {\n registerAnimatedImage(image) {\n // console.info('%c registerAnimatedImage transition', 'background-color: green;', image);\n setanimatedImages((state) => {\n if (typeof state != 'object') {\n return state;\n }\n if (!state.find((el) => el.productUuid == image.productUuid)) {\n // console.info('%c [transition] registerAnimatedImage - add: ', 'background-color: blue;', image, '\\n current state: ', state);\n state.push(image);\n }\n else if (!state.find((el) => el.productId == image.productId)) {\n // console.info('%c [transition] registerAnimatedImage - add: ', 'background-color: blue;', image, '\\n current state: ', state);\n state.push(image);\n }\n return state;\n });\n },\n unregisterAnimatedImage(productId, productUuid) {\n // console.info('%c unregisterAnimatedImage transition', 'background-color: red;', productId);\n setanimatedImages((state) => {\n if (typeof state != 'object') {\n return state;\n }\n // console.info('%c [transition] unregisterAnimatedImage - remove: ', 'background-color: purple;', productId, '\\n current state: ', state);\n return state.filter((image) => {\n return image.productUuid !== productUuid;\n });\n });\n },\n };\n const initialStyle = {\n opacity: 0,\n pointerEvents: 'none',\n width: '100%',\n top: 0,\n left: 0,\n zIndex: 1,\n backgroundColor: '#fff',\n };\n return (React.createElement(AnimatedRouteContext.Provider, { value: methods },\n React.createElement(Route, Object.assign({ exact: exact, path: path }, rest), (location) => {\n var _a;\n return (React.createElement(Transition, { appear: true, unmountOnExit: true, onEntering: handleEntering, onExit: handleExit, in: pathname === ((_a = location.match) === null || _a === void 0 ? void 0 : _a.url), \n //@ts-ignore\n addEndListener: (node, done) => {\n endListener.current = done;\n } },\n React.createElement(motion.div, { ref: el, animate: animation, initial: initialStyle },\n React.createElement(React.Fragment, null, children))));\n })));\n};\nexport default AnimatedRoute;\n","import { useEffect } from 'react';\nimport { useAnimatedRouteContext } from './AnimatedRoute';\nconst useAnimatedImage = (productId, el, productUuid) => {\n const { registerAnimatedImage, unregisterAnimatedImage } = useAnimatedRouteContext();\n useEffect(() => {\n if ((productId || productUuid) && el.current) {\n registerAnimatedImage({\n el,\n productId,\n productUuid,\n });\n }\n return () => {\n if (productId || productUuid) {\n unregisterAnimatedImage(productId, productUuid);\n }\n };\n }, [productId, productUuid]);\n};\nexport default useAnimatedImage;\n","import useAnimatedImage from '@moncler/components/routerTransitions/useAnimatedImage';\nimport imageutils, { LG, MD, SM, XS, XXS } from '@utils/imageutils';\nimport classNames from 'classnames';\nimport React, { useMemo, useRef } from 'react';\nimport useBreakpoint from '@utils/useBreakpoint';\nconst defaultSizes = [XXS, XS, SM, MD];\nconst ProductImage = (props) => {\n var _a;\n const el = useRef();\n const image = useMemo(() => {\n var _a, _b, _c, _d, _e, _f, _g, _h, _j;\n if (props.index != undefined) {\n let url = (_b = (_a = props.img) === null || _a === void 0 ? void 0 : _a.urls) === null || _b === void 0 ? void 0 : _b[props.index];\n if (props.genderImageSorted) {\n url = (_d = (_c = props.img) === null || _c === void 0 ? void 0 : _c[props.genderImageSorted]) === null || _d === void 0 ? void 0 : _d[props.index];\n }\n return url;\n }\n if (props.type) {\n let imageoldsuffix = '_' + props.type + '.';\n let imagenewsuffix = '_' + props.type + '1.';\n let img = (_f = (_e = props.img) === null || _e === void 0 ? void 0 : _e.urls) === null || _f === void 0 ? void 0 : _f.find((u) => u && (u.includes(imageoldsuffix) || u.includes(imagenewsuffix)));\n if (!img && props.type === 'X') {\n // fallback su F per vecchie immagini\n img = (_h = (_g = props.img) === null || _g === void 0 ? void 0 : _g.urls) === null || _h === void 0 ? void 0 : _h.find((u) => u && (u.includes('_F.') || u.includes('_F1.')));\n }\n if (img) {\n return img;\n }\n }\n return (_j = props.img) === null || _j === void 0 ? void 0 : _j.urls[0];\n }, [props.img, props.index, props.type]);\n // custom hook per animated image - funziona solo se tutti รจ tre i parametri sono valorizzati e mi trovo dentro AnimatedRoute\n if (((props === null || props === void 0 ? void 0 : props.index) == 0 || !(props === null || props === void 0 ? void 0 : props.index)) && el && props.animatedImage) {\n // useAnimatedImage(props.productId, el);\n useAnimatedImage(props.productId, el, props.productUuid);\n }\n const lowResImg = useMemo(() => { var _a; return imageutils.transform(image, XXS, (_a = props.img) === null || _a === void 0 ? void 0 : _a.alt); }, [image]);\n const currentBreakpoint = useBreakpoint();\n const hiResImage = useMemo(() => {\n var _a, _b;\n if (currentBreakpoint >= window.mqObj.md) {\n return imageutils.transform(image, LG, (_a = props.img) === null || _a === void 0 ? void 0 : _a.alt, null, 'avif');\n }\n else {\n return imageutils.transform(image, MD, (_b = props.img) === null || _b === void 0 ? void 0 : _b.alt, null, 'avif');\n }\n }, [currentBreakpoint, image]);\n const multipleSrc = useMemo(() => {\n let srcs = [];\n (props.sizes || defaultSizes).forEach((sz, i) => {\n var _a;\n srcs.push(`${imageutils.transform(image, sz, (_a = props.img) === null || _a === void 0 ? void 0 : _a.alt, props.imgQuality)} ${sz.width}w`);\n });\n return srcs.join(', ');\n }, [image]);\n const multipleSrcAvif = useMemo(() => {\n let srcs = [];\n (props.sizes || defaultSizes).forEach((sz, i) => {\n var _a;\n srcs.push(`${imageutils.transform(image, sz, (_a = props.img) === null || _a === void 0 ? void 0 : _a.alt, props.imgQuality, 'avif')} ${sz.width}w`);\n });\n return srcs.join(', ');\n }, [image]);\n const lazyPosterImg = useMemo(() => {\n return props.lazyLowRes ? lowResImg : '';\n }, [image]);\n const altText = useMemo(() => {\n var _a, _b;\n const index = (_a = props.seoIndex) !== null && _a !== void 0 ? _a : props.index;\n return `${props.alt || ((_b = props.img) === null || _b === void 0 ? void 0 : _b.alt)}${index >= 0 ? ` ${index + 1}` : ''}`;\n }, [image]);\n const imageElement = (React.createElement(\"picture\", { className: classNames({ lazyload: !props.lazyDisabled }, props.className) },\n React.createElement(\"source\", Object.assign({}, (!props.lazyDisabled && { ['data-srcset']: multipleSrcAvif }), { srcSet: props.lazyDisabled ? multipleSrcAvif : lazyPosterImg, type: 'image/avif' })),\n React.createElement(\"source\", Object.assign({}, (!props.lazyDisabled && { ['data-srcset']: multipleSrc }), { srcSet: props.lazyDisabled ? multipleSrc : lazyPosterImg, type: 'image/webp' })),\n React.createElement(\"img\", { ref: props.ref || el, alt: altText, src: props.lazyDisabled ? hiResImage : lowResImg, \"data-sizes\": \"auto\", \"data-idx\": props.index || 0, className: classNames({ lazyload: !props.lazyDisabled }, props.className), \"data-quality-img\": hiResImage, \n //width={\"100%\"}\n height: XXS.height, style: props.style, \"aria-hidden\": (props === null || props === void 0 ? void 0 : props.ariaHidden) != undefined ? props === null || props === void 0 ? void 0 : props.ariaHidden : !!props.alt || !!((_a = props.img) === null || _a === void 0 ? void 0 : _a.alt) })));\n if (props.onlyImage) {\n return imageElement;\n }\n if (!props.img) {\n return (React.createElement(\"div\", { className: \"product-image\", \"data-tiletype\": props.tiletype, \"data-type\": props.type },\n React.createElement(\"img\", { alt: \"\", src: \"\", \"data-idx\": props.index || 0, className: props.className, width: XXS.width, height: XXS.height, style: props.style })));\n }\n return (React.createElement(\"div\", { className: \"product-image\", \"data-tiletype\": props.tiletype, \"data-type\": props.type }, imageElement));\n};\nexport default ProductImage;\n"],"names":["StoneModalDialog","MocnclerModalDialog","props","Suspense","fallback","MO","Object","assign","ST","isLegacy","mediaQueries","window","mqObj","currentBreakpoint","setCurrentBreakpoint","useState","_a","documentWidth","innerWidth","visualViewport","width","filtered","keys","filter","key","length","getInitialBreakpointValue","handleResize","currentBr","getCurrentBreakpoint","useEffect","addEventListener","removeEventListener","createContext","AnimatedRouteContext","registerAnimatedImage","unregisterAnimatedImage","productId","el","productUuid","useContext","current","defaultSizes","XS","SM","MD","useRef","image","useMemo","_b","_c","_d","_e","_f","_g","_h","_j","undefined","index","url","img","urls","genderImageSorted","type","imageoldsuffix","imagenewsuffix","find","u","includes","animatedImage","lowResImg","imageutils","alt","useBreakpoint","hiResImage","md","LG","multipleSrc","srcs","sizes","forEach","sz","i","push","imgQuality","join","multipleSrcAvif","lazyPosterImg","lazyLowRes","altText","seoIndex","imageElement","className","lazyload","lazyDisabled","srcSet","ref","src","height","style","ariaHidden","onlyImage","tiletype"],"sourceRoot":""}