{"version":3,"file":"js/5341.chunk.js","mappings":"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","sources":["webpack:///./assets/common/src/components/common/Metatags.tsx","webpack:///./assets/moncler/src/components/listing/ListingPagination.tsx","webpack:///./assets/moncler/src/components/listing/PlpPage.tsx"],"sourcesContent":["import React from 'react';\nimport { Helmet } from 'react-helmet';\nconst Metatags = (props) => {\n var _a, _b, _c;\n return (React.createElement(Helmet, null,\n props.pageMetaTags &&\n ((_a = Object.keys(props === null || props === void 0 ? void 0 : props.pageMetaTags)) === null || _a === void 0 ? void 0 : _a.map((key) => {\n if (key == 'title') {\n return React.createElement(\"title\", { key: key }, props === null || props === void 0 ? void 0 : props.pageMetaTags[key]);\n }\n if (key.startsWith('og:')) {\n return React.createElement(\"meta\", { key: key, property: key, content: props === null || props === void 0 ? void 0 : props.pageMetaTags[key] });\n }\n return React.createElement(\"meta\", { key: key, name: key, content: props === null || props === void 0 ? void 0 : props.pageMetaTags[key] });\n })), (_c = (_b = props.meta) === null || _b === void 0 ? void 0 : _b.hreflangs) === null || _c === void 0 ? void 0 :\n _c.map((key) => {\n return React.createElement(\"link\", { key: key, rel: \"alternate\", hrefLang: key.substring(0, key.indexOf(' ')), href: key.substring(key.indexOf(' ') + 1) });\n }),\n props.additionalMeta || []));\n};\nexport default Metatags;\n","import React, { useCallback, useEffect, useState } from 'react';\nimport { createPortal } from 'react-dom';\nimport { useSelector } from 'react-redux';\nimport Metatags from '@components/common/Metatags';\nconst PAGESSIZES = {\n base: 12,\n tier1: 25,\n tier2: 16,\n};\nconst ListingPagination = (props) => {\n const { progress, count, pageMetaTags, category, pageSize } = useSelector((state) => state.search);\n const originalSize = pageSize;\n const progressSize = pageSize;\n const [pagination, setPagination] = useState([]);\n const getAdditionalMeta = useCallback(() => {\n let list = [];\n if (category && (category === null || category === void 0 ? void 0 : category.url) && pagination.length < 1) {\n list.push(React.createElement(\"link\", { key: \"canonical\", href: `${location.origin + (category === null || category === void 0 ? void 0 : category.url)}` }));\n }\n else {\n let currentIndex = pagination.findIndex((page) => page.current);\n if (currentIndex) {\n let currentPage = pagination[currentIndex];\n list.push(React.createElement(\"link\", { key: \"canonical\", href: currentPage === null || currentPage === void 0 ? void 0 : currentPage.url }));\n let nextPage = pagination[currentIndex + 1];\n let prevPage = pagination[currentIndex - 1];\n if (!!prevPage) {\n list.push(React.createElement(\"link\", { key: \"prev\", rel: \"prev\", href: prevPage === null || prevPage === void 0 ? void 0 : prevPage.url }));\n }\n if (!!nextPage) {\n list.push(React.createElement(\"link\", { key: \"next\", rel: \"next\", href: nextPage === null || nextPage === void 0 ? void 0 : nextPage.url }));\n }\n }\n }\n return list;\n }, [pagination]);\n useEffect(() => {\n let paging = [];\n if (!category || count > originalSize) {\n let pageIndex = 0;\n for (let x = 0; x <= count; x = x + originalSize) {\n paging[pageIndex] = {\n displayName: pageIndex + 1,\n url: `${location.origin + category.url}` + ((pageIndex != 0 && `?start=${x}`) || ''),\n current: x === progress - progressSize,\n };\n pageIndex++;\n }\n }\n setPagination(paging);\n }, [count, progress, category]);\n return (React.createElement(React.Fragment, null,\n React.createElement(Metatags, { pageMetaTags: pageMetaTags, meta: category.meta, additionalMeta: getAdditionalMeta() }),\n pagination.length > 1 && (React.createElement(React.Fragment, null, createPortal(React.createElement(\"div\", { className: \"pagination\" }, pagination.map((page, i) => (React.createElement(React.Fragment, { key: i }, page.current ? React.createElement(\"span\", { className: \"current-page\" }, page.displayName) : React.createElement(\"a\", { href: page.url }, page.displayName))))), document.querySelector('#no-script-pagination'))))));\n};\nexport default ListingPagination;\n","import Metatags from '@components/common/Metatags';\nimport FeaturedProducts from '@moncler/components/listing/FeaturedProductsCarousel';\nimport HeroBannerSlim from '@moncler/components/listing/HeroBannerSlim';\nimport ListingResults from '@moncler/components/listing/ListingResults';\nimport ProductFilters from '@moncler/components/listing/ProductFilters';\nimport ListingPagination from '@moncler/components/listing/ListingPagination';\nimport { useAnimatedContext } from '@moncler/components/routerTransitions/AnimatedProvider';\nimport { ListingActionTypes } from '@state/features/common.types';\nimport analytics from '@utils/analytics';\nimport classNames from 'classnames';\nimport React, { useEffect, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { useDispatch, useSelector } from 'react-redux';\nimport customEventBus from '@common/scripts/libs/eventBus';\nconst PlpPage = (props) => {\n const { search: { results, category, pageMetaTags, resultsType, landingAnimation, firstLoad, heroBannerSlim, featuredProductsCarousel, plpintro }, product: { current: productReferrer }, redirect: { error, redirectOnError }, } = useSelector((state) => state);\n useTranslation(); // force immediate loading of translations\n const dispatch = useDispatch();\n const listingContainer = useRef();\n useEffect(() => {\n if (error && redirectOnError) {\n window.location.href = redirectOnError;\n }\n }, [redirectOnError]);\n useEffect(() => {\n // al back da PDP\n if (productReferrer) {\n let subCategory = category ? category.id : productReferrer.categoryId;\n window.datalayerdata = Object.assign(Object.assign({}, window.datalayerdata), { pageCategory: 'plp', subCategory: subCategory, pageDesign: 'special' });\n analytics.sendGeneralVariables();\n analytics.productDetailPageBack(results, false);\n document.documentElement.classList.remove('no-overflow-ios');\n customEventBus.emit('PLP:loaded', {});\n }\n }, []);\n const { subscribe, unsubscribe } = useAnimatedContext();\n const sleep = async (ms) => {\n return new Promise((resolve) => setTimeout(resolve, ms));\n };\n const setupFunction = async () => {\n // document.querySelector('header')?.style.removeProperty('transform');\n // const refine = document.querySelector('.refine') as HTMLElement;\n // if (refine && window.scrollY > 0) {\n // refine.style.opacity = '0';\n // }\n await sleep(150);\n };\n const getScrollThreshold = (header, refineContainer) => {\n var _a, _b;\n let isMobile = window.innerWidth < window.mqObj['md'];\n return ((header && header.offsetHeight) +\n (isMobile\n ? (((_a = document.querySelector('.breadcrumb.listing')) === null || _a === void 0 ? void 0 : _a.offsetHeight) || 0) +\n (((_b = document.querySelector('.intro-plp__text-tags-wrapper')) === null || _b === void 0 ? void 0 : _b.offsetHeight) || 0) +\n parseInt(window.getComputedStyle(refineContainer).paddingTop) -\n parseInt(window.getComputedStyle(refineContainer).paddingBottom) -\n 1\n : refineContainer.offsetHeight));\n };\n useEffect(() => {\n subscribe('setup', setupFunction);\n return () => {\n unsubscribe('setup', setupFunction);\n };\n }, []);\n // initial product fetch\n useEffect(() => {\n if (!resultsType) {\n dispatch({\n type: ListingActionTypes.FETCH_LISTING,\n payload: {\n cgid: props.cgid,\n slug: location.pathname,\n resultsType: 'INIT',\n start: props.start,\n isShelf: false,\n },\n });\n }\n }, []);\n // sticky behavior\n useEffect(() => {\n let lastScrollTop = 0;\n let cachedScrollTop = 0;\n const offsetScroll = 32;\n let scrollThreshold = 0;\n let header = document.querySelector('header');\n let firstRefine;\n let firstTime = true;\n const onScroll = () => {\n if (firstTime) {\n firstTime = false;\n return;\n }\n let refineContainer = firstRefine.firstElementChild;\n scrollThreshold = getScrollThreshold(header, refineContainer);\n const translateAmount = scrollThreshold;\n if (document.querySelector('.hero-banner-slim')) {\n scrollThreshold += document.querySelector('.hero-banner-slim').offsetHeight;\n }\n let st = window.pageYOffset || document.documentElement.scrollTop;\n let isBeforeThreshold = st < scrollThreshold;\n let isAfterThreshold = !isBeforeThreshold;\n let isScrollingDown = st > lastScrollTop;\n let scrollDelta = Math.abs(st - cachedScrollTop);\n let scrollingForceIsEnough = scrollDelta >= offsetScroll;\n lastScrollTop = Math.max(0, st);\n if (isBeforeThreshold) {\n refineContainer.classList.remove('sticky');\n }\n if (!scrollingForceIsEnough) {\n return;\n }\n if (!document.body.classList.contains('overlay-open') && isScrollingDown && isAfterThreshold && scrollingForceIsEnough) {\n // downscroll code\n if (header)\n header.style.transform = `translateY(-${translateAmount}px)`;\n firstRefine.style.transform = `translateY(-${(header === null || header === void 0 ? void 0 : header.offsetHeight) || 0}px)`;\n refineContainer.classList.add('sticky');\n }\n else if (scrollingForceIsEnough) {\n // upscroll code\n header === null || header === void 0 ? void 0 : header.style.removeProperty('transform');\n firstRefine.style.removeProperty('transform');\n }\n cachedScrollTop = lastScrollTop;\n };\n let interval = setInterval(() => {\n // console.info('interval ripetuto ', loop, ' volte');\n firstRefine = document.querySelector('.listing-container .refine');\n if (firstRefine) {\n clearInterval(interval);\n // console.info('init onscroll x gestione sticky');\n window.addEventListener('scroll', onScroll);\n }\n // loop++;\n }, 500);\n return () => {\n header === null || header === void 0 ? void 0 : header.style.removeProperty('transform');\n firstRefine === null || firstRefine === void 0 ? void 0 : firstRefine.style.removeProperty('transform');\n window.removeEventListener('scroll', onScroll);\n };\n }, []);\n // start animations effect\n useEffect(() => {\n if (category && firstLoad) {\n // console.info('ho caricato il listing!');\n dispatch({ type: ListingActionTypes.TOGGLE_LANDING_ANIMATION, payload: true });\n }\n }, [category]);\n // const previusH = useRef(1);\n if (!category) {\n return React.createElement(\"div\", { className: \"tmploader\", dangerouslySetInnerHTML: { __html: props.placeholder } });\n }\n return (React.createElement(React.Fragment, null,\n React.createElement(Metatags, { pageMetaTags: pageMetaTags, meta: category.meta }),\n React.createElement(\"noscript\", { id: \"no-script-pagination\" }),\n React.createElement(\"div\", { ref: listingContainer, className: classNames('listing-container', landingAnimation && 'loading') },\n heroBannerSlim && React.createElement(HeroBannerSlim, { heroBannerSlim: heroBannerSlim }),\n React.createElement(ProductFilters, { plpintro: plpintro, willStick: true }),\n featuredProductsCarousel && React.createElement(FeaturedProducts, { featuredProductsCarousel: featuredProductsCarousel }),\n React.createElement(ListingResults, { cgid: props.cgid }),\n React.createElement(ListingPagination, Object.assign({}, props)))));\n};\nexport default PlpPage;\n"],"names":["props","_a","_b","_c","pageMetaTags","Object","keys","map","key","startsWith","property","content","name","meta","hreflangs","rel","hrefLang","substring","indexOf","href","additionalMeta","progress","count","category","pageSize","state","search","originalSize","progressSize","pagination","setPagination","useState","getAdditionalMeta","useCallback","list","url","length","push","location","origin","currentIndex","findIndex","page","current","currentPage","nextPage","prevPage","useEffect","paging","pageIndex","x","displayName","Metatags","createPortal","className","i","document","querySelector","results","resultsType","landingAnimation","firstLoad","heroBannerSlim","featuredProductsCarousel","plpintro","product","productReferrer","redirect","error","redirectOnError","useTranslation","dispatch","listingContainer","useRef","window","subCategory","id","categoryId","datalayerdata","assign","pageCategory","pageDesign","analytics","documentElement","classList","remove","subscribe","unsubscribe","setupFunction","async","ms","Promise","resolve","setTimeout","sleep","type","payload","cgid","slug","pathname","start","isShelf","lastScrollTop","cachedScrollTop","firstRefine","scrollThreshold","header","firstTime","onScroll","refineContainer","firstElementChild","isMobile","innerWidth","mqObj","offsetHeight","parseInt","getComputedStyle","paddingTop","paddingBottom","getScrollThreshold","translateAmount","st","pageYOffset","scrollTop","isBeforeThreshold","isAfterThreshold","isScrollingDown","scrollingForceIsEnough","Math","abs","max","body","contains","style","transform","add","removeProperty","interval","setInterval","clearInterval","addEventListener","removeEventListener","ref","HeroBannerSlim","ProductFilters","willStick","ListingResults","dangerouslySetInnerHTML","__html","placeholder"],"sourceRoot":""}