{"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":""}