{"version":3,"file":"static/chunks/675-02198d6424ed7cd8.js","mappings":"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","sources":["webpack://_N_E/./node_modules/@swc/helpers/lib/_define_property.js","webpack://_N_E/./node_modules/next/dist/client/image.js","webpack://_N_E/./node_modules/next/dist/client/use-intersection.js","webpack://_N_E/./node_modules/next/image.js"],"sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = _defineProperty;\nfunction _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = Image;\nvar _react = _interopRequireWildcard(require(\"react\"));\nvar _head = _interopRequireDefault(require(\"../shared/lib/head\"));\nvar _imageConfig = require(\"../shared/lib/image-config\");\nvar _useIntersection = require(\"./use-intersection\");\nvar _imageConfigContext = require(\"../shared/lib/image-config-context\");\nvar _utils = require(\"../shared/lib/utils\");\nvar _normalizeTrailingSlash = require(\"./normalize-trailing-slash\");\nfunction Image(_param) {\n var { src , sizes , unoptimized =false , priority =false , loading , lazyRoot =null , lazyBoundary , className , quality , width , height , style , objectFit , objectPosition , onLoadingComplete , placeholder ='empty' , blurDataURL } = _param, all = _objectWithoutPropertiesLoose(_param, [\n \"src\",\n \"sizes\",\n \"unoptimized\",\n \"priority\",\n \"loading\",\n \"lazyRoot\",\n \"lazyBoundary\",\n \"className\",\n \"quality\",\n \"width\",\n \"height\",\n \"style\",\n \"objectFit\",\n \"objectPosition\",\n \"onLoadingComplete\",\n \"placeholder\",\n \"blurDataURL\"\n ]);\n const configContext = (0, _react).useContext(_imageConfigContext.ImageConfigContext);\n const config = (0, _react).useMemo(()=>{\n const c = configEnv || configContext || _imageConfig.imageConfigDefault;\n const allSizes = [\n ...c.deviceSizes,\n ...c.imageSizes\n ].sort((a, b)=>a - b);\n const deviceSizes = c.deviceSizes.sort((a, b)=>a - b);\n return _extends({}, c, {\n allSizes,\n deviceSizes\n });\n }, [\n configContext\n ]);\n let rest = all;\n let layout = sizes ? 'responsive' : 'intrinsic';\n if ('layout' in rest) {\n // Override default layout if the user specified one:\n if (rest.layout) layout = rest.layout;\n // Remove property so it's not spread on
:\n delete rest.layout;\n }\n let loader = defaultImageLoader;\n if ('loader' in rest) {\n if (rest.loader) {\n const customImageLoader = rest.loader;\n var _tmp;\n _tmp = (obj)=>{\n const { config: _ } = obj, opts = _objectWithoutPropertiesLoose(obj, [\n \"config\"\n ]);\n // The config object is internal only so we must\n // not pass it to the user-defined loader()\n return customImageLoader(opts);\n }, loader = _tmp, _tmp;\n }\n // Remove property so it's not spread on
\n delete rest.loader;\n }\n let staticSrc = '';\n if (isStaticImport(src)) {\n const staticImageData = isStaticRequire(src) ? src.default : src;\n if (!staticImageData.src) {\n throw new Error(`An object should only be passed to the image component src parameter if it comes from a static image import. It must include src. Received ${JSON.stringify(staticImageData)}`);\n }\n blurDataURL = blurDataURL || staticImageData.blurDataURL;\n staticSrc = staticImageData.src;\n if (!layout || layout !== 'fill') {\n height = height || staticImageData.height;\n width = width || staticImageData.width;\n if (!staticImageData.height || !staticImageData.width) {\n throw new Error(`An object should only be passed to the image component src parameter if it comes from a static image import. It must include height and width. Received ${JSON.stringify(staticImageData)}`);\n }\n }\n }\n src = typeof src === 'string' ? src : staticSrc;\n let isLazy = !priority && (loading === 'lazy' || typeof loading === 'undefined');\n if (src.startsWith('data:') || src.startsWith('blob:')) {\n // https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs\n unoptimized = true;\n isLazy = false;\n }\n if (typeof window !== 'undefined' && loadedImageURLs.has(src)) {\n isLazy = false;\n }\n if (experimentalUnoptimized) {\n unoptimized = true;\n }\n const [blurComplete, setBlurComplete] = (0, _react).useState(false);\n const [setIntersection, isIntersected, resetIntersected] = (0, _useIntersection).useIntersection({\n rootRef: lazyRoot,\n rootMargin: lazyBoundary || '200px',\n disabled: !isLazy\n });\n const isVisible = !isLazy || isIntersected;\n const wrapperStyle = {\n boxSizing: 'border-box',\n display: 'block',\n overflow: 'hidden',\n width: 'initial',\n height: 'initial',\n background: 'none',\n opacity: 1,\n border: 0,\n margin: 0,\n padding: 0\n };\n const sizerStyle = {\n boxSizing: 'border-box',\n display: 'block',\n width: 'initial',\n height: 'initial',\n background: 'none',\n opacity: 1,\n border: 0,\n margin: 0,\n padding: 0\n };\n let hasSizer = false;\n let sizerSvgUrl;\n const layoutStyle = {\n position: 'absolute',\n top: 0,\n left: 0,\n bottom: 0,\n right: 0,\n boxSizing: 'border-box',\n padding: 0,\n border: 'none',\n margin: 'auto',\n display: 'block',\n width: 0,\n height: 0,\n minWidth: '100%',\n maxWidth: '100%',\n minHeight: '100%',\n maxHeight: '100%',\n objectFit,\n objectPosition\n };\n let widthInt = getInt(width);\n let heightInt = getInt(height);\n const qualityInt = getInt(quality);\n if (process.env.NODE_ENV !== 'production') {\n if (!src) {\n // React doesn't show the stack trace and there's\n // no `src` to help identify which image, so we\n // instead console.error(ref) during mount.\n widthInt = widthInt || 1;\n heightInt = heightInt || 1;\n unoptimized = true;\n } else {\n if (!VALID_LAYOUT_VALUES.includes(layout)) {\n if (layout === 'raw') {\n throw new Error(`The layout=\"raw\" experiment has been moved to a new module. Please import \\`next/future/image\\` instead.`);\n }\n throw new Error(`Image with src \"${src}\" has invalid \"layout\" property. Provided \"${layout}\" should be one of ${VALID_LAYOUT_VALUES.map(String).join(',')}.`);\n }\n if (typeof widthInt !== 'undefined' && isNaN(widthInt) || typeof heightInt !== 'undefined' && isNaN(heightInt)) {\n throw new Error(`Image with src \"${src}\" has invalid \"width\" or \"height\" property. These should be numeric values.`);\n }\n if (layout === 'fill' && (width || height)) {\n (0, _utils).warnOnce(`Image with src \"${src}\" and \"layout='fill'\" has unused properties assigned. Please remove \"width\" and \"height\".`);\n }\n if (!VALID_LOADING_VALUES.includes(loading)) {\n throw new Error(`Image with src \"${src}\" has invalid \"loading\" property. Provided \"${loading}\" should be one of ${VALID_LOADING_VALUES.map(String).join(',')}.`);\n }\n if (priority && loading === 'lazy') {\n throw new Error(`Image with src \"${src}\" has both \"priority\" and \"loading='lazy'\" properties. Only one should be used.`);\n }\n if (sizes && layout !== 'fill' && layout !== 'responsive') {\n (0, _utils).warnOnce(`Image with src \"${src}\" has \"sizes\" property but it will be ignored. Only use \"sizes\" with \"layout='fill'\" or \"layout='responsive'\"`);\n }\n if (placeholder === 'blur') {\n if (layout !== 'fill' && (widthInt || 0) * (heightInt || 0) < 1600) {\n (0, _utils).warnOnce(`Image with src \"${src}\" is smaller than 40x40. Consider removing the \"placeholder='blur'\" property to improve performance.`);\n }\n if (!blurDataURL) {\n const VALID_BLUR_EXT = [\n 'jpeg',\n 'png',\n 'webp',\n 'avif'\n ] // should match next-image-loader\n ;\n throw new Error(`Image with src \"${src}\" has \"placeholder='blur'\" property but is missing the \"blurDataURL\" property.\n Possible solutions:\n - Add a \"blurDataURL\" property, the contents should be a small Data URL to represent the image\n - Change the \"src\" property to a static import with one of the supported file types: ${VALID_BLUR_EXT.join(',')}\n - Remove the \"placeholder\" property, effectively no blur effect\n Read more: https://nextjs.org/docs/messages/placeholder-blur-data-url`);\n }\n }\n if ('ref' in rest) {\n (0, _utils).warnOnce(`Image with src \"${src}\" is using unsupported \"ref\" property. Consider using the \"onLoadingComplete\" property instead.`);\n }\n if (!unoptimized && loader !== defaultImageLoader) {\n const urlStr = loader({\n config,\n src,\n width: widthInt || 400,\n quality: qualityInt || 75\n });\n let url;\n try {\n url = new URL(urlStr);\n } catch (err) {}\n if (urlStr === src || url && url.pathname === src && !url.search) {\n (0, _utils).warnOnce(`Image with src \"${src}\" has a \"loader\" property that does not implement width. Please implement it or use the \"unoptimized\" property instead.` + `\\nRead more: https://nextjs.org/docs/messages/next-image-missing-loader-width`);\n }\n }\n if (style) {\n let overwrittenStyles = Object.keys(style).filter((key)=>key in layoutStyle);\n if (overwrittenStyles.length) {\n (0, _utils).warnOnce(`Image with src ${src} is assigned the following styles, which are overwritten by automatically-generated styles: ${overwrittenStyles.join(', ')}`);\n }\n }\n if (typeof window !== 'undefined' && !perfObserver && window.PerformanceObserver) {\n perfObserver = new PerformanceObserver((entryList)=>{\n for (const entry of entryList.getEntries()){\n var ref;\n // @ts-ignore - missing \"LargestContentfulPaint\" class with \"element\" prop\n const imgSrc = (entry == null ? void 0 : (ref = entry.element) == null ? void 0 : ref.src) || '';\n const lcpImage = allImgs.get(imgSrc);\n if (lcpImage && !lcpImage.priority && lcpImage.placeholder !== 'blur' && !lcpImage.src.startsWith('data:') && !lcpImage.src.startsWith('blob:')) {\n // https://web.dev/lcp/#measure-lcp-in-javascript\n (0, _utils).warnOnce(`Image with src \"${lcpImage.src}\" was detected as the Largest Contentful Paint (LCP). Please add the \"priority\" property if this image is above the fold.` + `\\nRead more: https://nextjs.org/docs/api-reference/next/image#priority`);\n }\n }\n });\n try {\n perfObserver.observe({\n type: 'largest-contentful-paint',\n buffered: true\n });\n } catch (err) {\n // Log error but don't crash the app\n console.error(err);\n }\n }\n }\n }\n const imgStyle = Object.assign({}, style, layoutStyle);\n const blurStyle = placeholder === 'blur' && !blurComplete ? {\n backgroundSize: objectFit || 'cover',\n backgroundPosition: objectPosition || '0% 0%',\n filter: 'blur(20px)',\n backgroundImage: `url(\"${blurDataURL}\")`\n } : {};\n if (layout === 'fill') {\n // \n wrapperStyle.display = 'block';\n wrapperStyle.position = 'absolute';\n wrapperStyle.top = 0;\n wrapperStyle.left = 0;\n wrapperStyle.bottom = 0;\n wrapperStyle.right = 0;\n } else if (typeof widthInt !== 'undefined' && typeof heightInt !== 'undefined') {\n // \n const quotient = heightInt / widthInt;\n const paddingTop = isNaN(quotient) ? '100%' : `${quotient * 100}%`;\n if (layout === 'responsive') {\n // \n wrapperStyle.display = 'block';\n wrapperStyle.position = 'relative';\n hasSizer = true;\n sizerStyle.paddingTop = paddingTop;\n } else if (layout === 'intrinsic') {\n // \n wrapperStyle.display = 'inline-block';\n wrapperStyle.position = 'relative';\n wrapperStyle.maxWidth = '100%';\n hasSizer = true;\n sizerStyle.maxWidth = '100%';\n sizerSvgUrl = `data:image/svg+xml,%3csvg%20xmlns=%27http://www.w3.org/2000/svg%27%20version=%271.1%27%20width=%27${widthInt}%27%20height=%27${heightInt}%27/%3e`;\n } else if (layout === 'fixed') {\n // \n wrapperStyle.display = 'inline-block';\n wrapperStyle.position = 'relative';\n wrapperStyle.width = widthInt;\n wrapperStyle.height = heightInt;\n }\n } else {\n // \n if (process.env.NODE_ENV !== 'production') {\n throw new Error(`Image with src \"${src}\" must use \"width\" and \"height\" properties or \"layout='fill'\" property.`);\n }\n }\n let imgAttributes = {\n src: emptyDataURL,\n srcSet: undefined,\n sizes: undefined\n };\n if (isVisible) {\n imgAttributes = generateImgAttrs({\n config,\n src,\n unoptimized,\n layout,\n width: widthInt,\n quality: qualityInt,\n sizes,\n loader\n });\n }\n let srcString = src;\n if (process.env.NODE_ENV !== 'production') {\n if (typeof window !== 'undefined') {\n let fullUrl;\n try {\n fullUrl = new URL(imgAttributes.src);\n } catch (e) {\n fullUrl = new URL(imgAttributes.src, window.location.href);\n }\n allImgs.set(fullUrl.href, {\n src,\n priority,\n placeholder\n });\n }\n }\n let imageSrcSetPropName = 'imagesrcset';\n let imageSizesPropName = 'imagesizes';\n if (process.env.__NEXT_REACT_ROOT) {\n imageSrcSetPropName = 'imageSrcSet';\n imageSizesPropName = 'imageSizes';\n }\n const linkProps = {\n // Note: imagesrcset and imagesizes are not in the link element type with react 17.\n [imageSrcSetPropName]: imgAttributes.srcSet,\n [imageSizesPropName]: imgAttributes.sizes\n };\n const useLayoutEffect = typeof window === 'undefined' ? _react.default.useEffect : _react.default.useLayoutEffect;\n const onLoadingCompleteRef = (0, _react).useRef(onLoadingComplete);\n const previousImageSrc = (0, _react).useRef(src);\n (0, _react).useEffect(()=>{\n onLoadingCompleteRef.current = onLoadingComplete;\n }, [\n onLoadingComplete\n ]);\n useLayoutEffect(()=>{\n if (previousImageSrc.current !== src) {\n resetIntersected();\n previousImageSrc.current = src;\n }\n }, [\n resetIntersected,\n src\n ]);\n const imgElementArgs = _extends({\n isLazy,\n imgAttributes,\n heightInt,\n widthInt,\n qualityInt,\n layout,\n className,\n imgStyle,\n blurStyle,\n loading,\n config,\n unoptimized,\n placeholder,\n loader,\n srcString,\n onLoadingCompleteRef,\n setBlurComplete,\n setIntersection,\n isVisible,\n noscriptSizes: sizes\n }, rest);\n return /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement(\"span\", {\n style: wrapperStyle\n }, hasSizer ? /*#__PURE__*/ _react.default.createElement(\"span\", {\n style: sizerStyle\n }, sizerSvgUrl ? /*#__PURE__*/ _react.default.createElement(\"img\", {\n style: {\n display: 'block',\n maxWidth: '100%',\n width: 'initial',\n height: 'initial',\n background: 'none',\n opacity: 1,\n border: 0,\n margin: 0,\n padding: 0\n },\n alt: \"\",\n \"aria-hidden\": true,\n src: sizerSvgUrl\n }) : null) : null, /*#__PURE__*/ _react.default.createElement(ImageElement, Object.assign({}, imgElementArgs))), priority ? // Note how we omit the `href` attribute, as it would only be relevant\n // for browsers that do not support `imagesrcset`, and in those cases\n // it would likely cause the incorrect image to be preloaded.\n //\n // https://html.spec.whatwg.org/multipage/semantics.html#attr-link-imagesrcset\n /*#__PURE__*/ _react.default.createElement(_head.default, null, /*#__PURE__*/ _react.default.createElement(\"link\", Object.assign({\n key: '__nimg-' + imgAttributes.src + imgAttributes.srcSet + imgAttributes.sizes,\n rel: \"preload\",\n as: \"image\",\n href: imgAttributes.srcSet ? undefined : imgAttributes.src\n }, linkProps))) : null);\n}\nfunction _extends() {\n _extends = Object.assign || function(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i];\n for(var key in source){\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}\nfunction _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n default: obj\n };\n}\nfunction _getRequireWildcardCache() {\n if (typeof WeakMap !== \"function\") return null;\n var cache = new WeakMap();\n _getRequireWildcardCache = function() {\n return cache;\n };\n return cache;\n}\nfunction _interopRequireWildcard(obj) {\n if (obj && obj.__esModule) {\n return obj;\n }\n if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") {\n return {\n default: obj\n };\n }\n var cache = _getRequireWildcardCache();\n if (cache && cache.has(obj)) {\n return cache.get(obj);\n }\n var newObj = {};\n var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;\n for(var key in obj){\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;\n if (desc && (desc.get || desc.set)) {\n Object.defineProperty(newObj, key, desc);\n } else {\n newObj[key] = obj[key];\n }\n }\n }\n newObj.default = obj;\n if (cache) {\n cache.set(obj, newObj);\n }\n return newObj;\n}\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for(i = 0; i < sourceKeys.length; i++){\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\nconst { experimentalRemotePatterns =[] , experimentalUnoptimized } = process.env.__NEXT_IMAGE_OPTS || {};\nconst configEnv = process.env.__NEXT_IMAGE_OPTS;\nconst loadedImageURLs = new Set();\nconst allImgs = new Map();\nlet perfObserver;\nconst emptyDataURL = '';\nif (typeof window === 'undefined') {\n global.__NEXT_IMAGE_IMPORTED = true;\n}\nconst VALID_LOADING_VALUES = [\n 'lazy',\n 'eager',\n undefined\n];\nconst loaders = new Map([\n [\n 'default',\n defaultLoader\n ],\n [\n 'imgix',\n imgixLoader\n ],\n [\n 'cloudinary',\n cloudinaryLoader\n ],\n [\n 'akamai',\n akamaiLoader\n ],\n [\n 'custom',\n customLoader\n ], \n]);\nconst VALID_LAYOUT_VALUES = [\n 'fill',\n 'fixed',\n 'intrinsic',\n 'responsive',\n undefined, \n];\nfunction isStaticRequire(src) {\n return src.default !== undefined;\n}\nfunction isStaticImageData(src) {\n return src.src !== undefined;\n}\nfunction isStaticImport(src) {\n return typeof src === 'object' && (isStaticRequire(src) || isStaticImageData(src));\n}\nfunction getWidths({ deviceSizes , allSizes }, width, layout, sizes) {\n if (sizes && (layout === 'fill' || layout === 'responsive')) {\n // Find all the \"vw\" percent sizes used in the sizes prop\n const viewportWidthRe = /(^|\\s)(1?\\d?\\d)vw/g;\n const percentSizes = [];\n for(let match; match = viewportWidthRe.exec(sizes); match){\n percentSizes.push(parseInt(match[2]));\n }\n if (percentSizes.length) {\n const smallestRatio = Math.min(...percentSizes) * 0.01;\n return {\n widths: allSizes.filter((s)=>s >= deviceSizes[0] * smallestRatio),\n kind: 'w'\n };\n }\n return {\n widths: allSizes,\n kind: 'w'\n };\n }\n if (typeof width !== 'number' || layout === 'fill' || layout === 'responsive') {\n return {\n widths: deviceSizes,\n kind: 'w'\n };\n }\n const widths = [\n ...new Set(// > This means that most OLED screens that say they are 3x resolution,\n // > are actually 3x in the green color, but only 1.5x in the red and\n // > blue colors. Showing a 3x resolution image in the app vs a 2x\n // > resolution image will be visually the same, though the 3x image\n // > takes significantly more data. Even true 3x resolution screens are\n // > wasteful as the human eye cannot see that level of detail without\n // > something like a magnifying glass.\n // https://blog.twitter.com/engineering/en_us/topics/infrastructure/2019/capping-image-fidelity-on-ultra-high-resolution-devices.html\n [\n width,\n width * 2 /*, width * 3*/ \n ].map((w)=>allSizes.find((p)=>p >= w) || allSizes[allSizes.length - 1])), \n ];\n return {\n widths,\n kind: 'x'\n };\n}\nfunction generateImgAttrs({ config , src , unoptimized , layout , width , quality , sizes , loader }) {\n if (unoptimized) {\n return {\n src,\n srcSet: undefined,\n sizes: undefined\n };\n }\n const { widths , kind } = getWidths(config, width, layout, sizes);\n const last = widths.length - 1;\n return {\n sizes: !sizes && kind === 'w' ? '100vw' : sizes,\n srcSet: widths.map((w, i)=>`${loader({\n config,\n src,\n quality,\n width: w\n })} ${kind === 'w' ? w : i + 1}${kind}`).join(', '),\n // It's intended to keep `src` the last attribute because React updates\n // attributes in order. If we keep `src` the first one, Safari will\n // immediately start to fetch `src`, before `sizes` and `srcSet` are even\n // updated by React. That causes multiple unnecessary requests if `srcSet`\n // and `sizes` are defined.\n // This bug cannot be reproduced in Chrome or Firefox.\n src: loader({\n config,\n src,\n quality,\n width: widths[last]\n })\n };\n}\nfunction getInt(x) {\n if (typeof x === 'number') {\n return x;\n }\n if (typeof x === 'string') {\n return parseInt(x, 10);\n }\n return undefined;\n}\nfunction defaultImageLoader(loaderProps) {\n var ref;\n const loaderKey = ((ref = loaderProps.config) == null ? void 0 : ref.loader) || 'default';\n const load = loaders.get(loaderKey);\n if (load) {\n return load(loaderProps);\n }\n throw new Error(`Unknown \"loader\" found in \"next.config.js\". Expected: ${_imageConfig.VALID_LOADERS.join(', ')}. Received: ${loaderKey}`);\n}\n// See https://stackoverflow.com/q/39777833/266535 for why we use this ref\n// handler instead of the img's onLoad attribute.\nfunction handleLoading(img, src, layout, placeholder, onLoadingCompleteRef, setBlurComplete) {\n if (!img || img.src === emptyDataURL || img['data-loaded-src'] === src) {\n return;\n }\n img['data-loaded-src'] = src;\n const p = 'decode' in img ? img.decode() : Promise.resolve();\n p.catch(()=>{}).then(()=>{\n if (!img.parentNode) {\n // Exit early in case of race condition:\n // - onload() is called\n // - decode() is called but incomplete\n // - unmount is called\n // - decode() completes\n return;\n }\n loadedImageURLs.add(src);\n if (placeholder === 'blur') {\n setBlurComplete(true);\n }\n if (onLoadingCompleteRef == null ? void 0 : onLoadingCompleteRef.current) {\n const { naturalWidth , naturalHeight } = img;\n // Pass back read-only primitive values but not the\n // underlying DOM element because it could be misused.\n onLoadingCompleteRef.current({\n naturalWidth,\n naturalHeight\n });\n }\n if (process.env.NODE_ENV !== 'production') {\n var ref;\n if ((ref = img.parentElement) == null ? void 0 : ref.parentElement) {\n const parent = getComputedStyle(img.parentElement.parentElement);\n if (!parent.position) {\n // The parent has not been rendered to the dom yet and therefore it has no position. Skip the warnings for such cases.\n } else if (layout === 'responsive' && parent.display === 'flex') {\n (0, _utils).warnOnce(`Image with src \"${src}\" may not render properly as a child of a flex container. Consider wrapping the image with a div to configure the width.`);\n } else if (layout === 'fill' && parent.position !== 'relative' && parent.position !== 'fixed' && parent.position !== 'absolute') {\n (0, _utils).warnOnce(`Image with src \"${src}\" may not render properly with a parent using position:\"${parent.position}\". Consider changing the parent style to position:\"relative\" with a width and height.`);\n }\n }\n }\n });\n}\nconst ImageElement = (_param)=>{\n var { imgAttributes , heightInt , widthInt , qualityInt , layout , className , imgStyle , blurStyle , isLazy , placeholder , loading , srcString , config , unoptimized , loader , onLoadingCompleteRef , setBlurComplete , setIntersection , onLoad , onError , isVisible , noscriptSizes } = _param, rest = _objectWithoutPropertiesLoose(_param, [\n \"imgAttributes\",\n \"heightInt\",\n \"widthInt\",\n \"qualityInt\",\n \"layout\",\n \"className\",\n \"imgStyle\",\n \"blurStyle\",\n \"isLazy\",\n \"placeholder\",\n \"loading\",\n \"srcString\",\n \"config\",\n \"unoptimized\",\n \"loader\",\n \"onLoadingCompleteRef\",\n \"setBlurComplete\",\n \"setIntersection\",\n \"onLoad\",\n \"onError\",\n \"isVisible\",\n \"noscriptSizes\"\n ]);\n loading = isLazy ? 'lazy' : loading;\n return /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement(\"img\", Object.assign({}, rest, imgAttributes, {\n decoding: \"async\",\n \"data-nimg\": layout,\n className: className,\n style: _extends({}, imgStyle, blurStyle),\n ref: (0, _react).useCallback((img)=>{\n if (process.env.NODE_ENV !== 'production') {\n if (img && !srcString) {\n console.error(`Image is missing required \"src\" property:`, img);\n }\n }\n setIntersection(img);\n if (img == null ? void 0 : img.complete) {\n handleLoading(img, srcString, layout, placeholder, onLoadingCompleteRef, setBlurComplete);\n }\n }, [\n setIntersection,\n srcString,\n layout,\n placeholder,\n onLoadingCompleteRef,\n setBlurComplete, \n ]),\n onLoad: (event)=>{\n const img = event.currentTarget;\n handleLoading(img, srcString, layout, placeholder, onLoadingCompleteRef, setBlurComplete);\n if (onLoad) {\n onLoad(event);\n }\n },\n onError: (event)=>{\n if (placeholder === 'blur') {\n // If the real image fails to load, this will still remove the placeholder.\n setBlurComplete(true);\n }\n if (onError) {\n onError(event);\n }\n }\n })), (isLazy || placeholder === 'blur') && /*#__PURE__*/ _react.default.createElement(\"noscript\", null, /*#__PURE__*/ _react.default.createElement(\"img\", Object.assign({}, rest, generateImgAttrs({\n config,\n src: srcString,\n unoptimized,\n layout,\n width: widthInt,\n quality: qualityInt,\n sizes: noscriptSizes,\n loader\n }), {\n decoding: \"async\",\n \"data-nimg\": layout,\n style: imgStyle,\n className: className,\n // @ts-ignore - TODO: upgrade to `@types/react@17`\n loading: loading\n }))));\n};\nfunction normalizeSrc(src) {\n return src[0] === '/' ? src.slice(1) : src;\n}\nfunction imgixLoader({ config , src , width , quality }) {\n // Demo: https://static.imgix.net/daisy.png?auto=format&fit=max&w=300\n const url = new URL(`${config.path}${normalizeSrc(src)}`);\n const params = url.searchParams;\n params.set('auto', params.get('auto') || 'format');\n params.set('fit', params.get('fit') || 'max');\n params.set('w', params.get('w') || width.toString());\n if (quality) {\n params.set('q', quality.toString());\n }\n return url.href;\n}\nfunction akamaiLoader({ config , src , width }) {\n return `${config.path}${normalizeSrc(src)}?imwidth=${width}`;\n}\nfunction cloudinaryLoader({ config , src , width , quality }) {\n // Demo: https://res.cloudinary.com/demo/image/upload/w_300,c_limit,q_auto/turtles.jpg\n const params = [\n 'f_auto',\n 'c_limit',\n 'w_' + width,\n 'q_' + (quality || 'auto')\n ];\n const paramsString = params.join(',') + '/';\n return `${config.path}${paramsString}${normalizeSrc(src)}`;\n}\nfunction customLoader({ src }) {\n throw new Error(`Image with src \"${src}\" is missing \"loader\" prop.` + `\\nRead more: https://nextjs.org/docs/messages/next-image-missing-loader`);\n}\nfunction defaultLoader({ config , src , width , quality }) {\n if (process.env.NODE_ENV !== 'production') {\n const missingValues = [];\n // these should always be provided but make sure they are\n if (!src) missingValues.push('src');\n if (!width) missingValues.push('width');\n if (missingValues.length > 0) {\n throw new Error(`Next Image Optimization requires ${missingValues.join(', ')} to be provided. Make sure you pass them as props to the \\`next/image\\` component. Received: ${JSON.stringify({\n src,\n width,\n quality\n })}`);\n }\n if (src.startsWith('//')) {\n throw new Error(`Failed to parse src \"${src}\" on \\`next/image\\`, protocol-relative URL (//) must be changed to an absolute URL (http:// or https://)`);\n }\n if (!src.startsWith('/') && (config.domains || experimentalRemotePatterns)) {\n let parsedSrc;\n try {\n parsedSrc = new URL(src);\n } catch (err) {\n console.error(err);\n throw new Error(`Failed to parse src \"${src}\" on \\`next/image\\`, if using relative image it must start with a leading slash \"/\" or be an absolute URL (http:// or https://)`);\n }\n if (process.env.NODE_ENV !== 'test') {\n // We use dynamic require because this should only error in development\n const { hasMatch } = require('../shared/lib/match-remote-pattern');\n if (!hasMatch(config.domains, experimentalRemotePatterns, parsedSrc)) {\n throw new Error(`Invalid src prop (${src}) on \\`next/image\\`, hostname \"${parsedSrc.hostname}\" is not configured under images in your \\`next.config.js\\`\\n` + `See more info: https://nextjs.org/docs/messages/next-image-unconfigured-host`);\n }\n }\n }\n }\n if (src.endsWith('.svg') && !config.dangerouslyAllowSVG) {\n // Special case to make svg serve as-is to avoid proxying\n // through the built-in Image Optimization API.\n return src;\n }\n return `${(0, _normalizeTrailingSlash).normalizePathTrailingSlash(config.path)}?url=${encodeURIComponent(src)}&w=${width}&q=${quality || 75}`;\n}\n\nif ((typeof exports.default === 'function' || (typeof exports.default === 'object' && exports.default !== null)) && typeof exports.default.__esModule === 'undefined') {\n Object.defineProperty(exports.default, '__esModule', { value: true });\n Object.assign(exports.default, exports);\n module.exports = exports.default;\n}\n\n//# sourceMappingURL=image.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.useIntersection = useIntersection;\nvar _react = require(\"react\");\nvar _requestIdleCallback = require(\"./request-idle-callback\");\nconst hasIntersectionObserver = typeof IntersectionObserver === 'function';\nfunction useIntersection({ rootRef , rootMargin , disabled }) {\n const isDisabled = disabled || !hasIntersectionObserver;\n const unobserve = (0, _react).useRef();\n const [visible, setVisible] = (0, _react).useState(false);\n const [element, setElement] = (0, _react).useState(null);\n (0, _react).useEffect(()=>{\n if (hasIntersectionObserver) {\n if (unobserve.current) {\n unobserve.current();\n unobserve.current = undefined;\n }\n if (isDisabled || visible) return;\n if (element && element.tagName) {\n unobserve.current = observe(element, (isVisible)=>isVisible && setVisible(isVisible), {\n root: rootRef == null ? void 0 : rootRef.current,\n rootMargin\n });\n }\n return ()=>{\n unobserve.current == null ? void 0 : unobserve.current();\n unobserve.current = undefined;\n };\n } else {\n if (!visible) {\n const idleCallback = (0, _requestIdleCallback).requestIdleCallback(()=>setVisible(true));\n return ()=>(0, _requestIdleCallback).cancelIdleCallback(idleCallback);\n }\n }\n }, [\n element,\n isDisabled,\n rootMargin,\n rootRef,\n visible\n ]);\n const resetVisible = (0, _react).useCallback(()=>{\n setVisible(false);\n }, []);\n return [\n setElement,\n visible,\n resetVisible\n ];\n}\nfunction observe(element, callback, options) {\n const { id , observer , elements } = createObserver(options);\n elements.set(element, callback);\n observer.observe(element);\n return function unobserve() {\n elements.delete(element);\n observer.unobserve(element);\n // Destroy observer when there's nothing left to watch:\n if (elements.size === 0) {\n observer.disconnect();\n observers.delete(id);\n const index = idList.findIndex((obj)=>obj.root === id.root && obj.margin === id.margin);\n if (index > -1) {\n idList.splice(index, 1);\n }\n }\n };\n}\nconst observers = new Map();\nconst idList = [];\nfunction createObserver(options) {\n const id = {\n root: options.root || null,\n margin: options.rootMargin || ''\n };\n const existing = idList.find((obj)=>obj.root === id.root && obj.margin === id.margin);\n let instance;\n if (existing) {\n instance = observers.get(existing);\n if (instance) {\n return instance;\n }\n }\n const elements = new Map();\n const observer = new IntersectionObserver((entries)=>{\n entries.forEach((entry)=>{\n const callback = elements.get(entry.target);\n const isVisible = entry.isIntersecting || entry.intersectionRatio > 0;\n if (callback && isVisible) {\n callback(isVisible);\n }\n });\n }, options);\n instance = {\n id,\n observer,\n elements\n };\n idList.push(id);\n observers.set(id, instance);\n return instance;\n}\n\nif ((typeof exports.default === 'function' || (typeof exports.default === 'object' && exports.default !== null)) && typeof exports.default.__esModule === 'undefined') {\n Object.defineProperty(exports.default, '__esModule', { value: true });\n Object.assign(exports.default, exports);\n module.exports = exports.default;\n}\n\n//# sourceMappingURL=use-intersection.js.map","module.exports = require('./dist/client/image')\n"],"names":["exports","obj","key","value","Object","defineProperty","enumerable","configurable","writable","_param","src","sizes","unoptimized","priority","loading","lazyRoot","lazyBoundary","className","quality","width","height","style","objectFit","objectPosition","onLoadingComplete","placeholder","blurDataURL","all","_objectWithoutPropertiesLoose","configContext","_react","useContext","_imageConfigContext","ImageConfigContext","config","useMemo","c","configEnv","_imageConfig","imageConfigDefault","allSizes","deviceSizes","imageSizes","sort","a","b","_extends","rest","layout","loader","defaultImageLoader","customImageLoader","opts","staticSrc","isStaticRequire","undefined","isStaticImageData","isStaticImport","staticImageData","default","Error","JSON","stringify","isLazy","startsWith","loadedImageURLs","has","experimentalUnoptimized","sizerSvgUrl","useState","blurComplete","setBlurComplete","_useIntersection","useIntersection","rootRef","rootMargin","disabled","setIntersection","isIntersected","resetIntersected","isVisible","wrapperStyle","boxSizing","display","overflow","background","opacity","border","margin","padding","sizerStyle","hasSizer","layoutStyle","position","top","left","bottom","right","minWidth","maxWidth","minHeight","maxHeight","widthInt","getInt","heightInt","qualityInt","process","imgStyle","assign","blurStyle","backgroundSize","backgroundPosition","filter","backgroundImage","quotient","paddingTop","isNaN","imgAttributes","emptyDataURL","srcSet","generateImgAttrs","srcString","imageSrcSetPropName","imageSizesPropName","linkProps","useLayoutEffect","onLoadingCompleteRef","useRef","previousImageSrc","useEffect","current","imgElementArgs","noscriptSizes","createElement","Fragment","alt","ImageElement","_head","rel","as","href","__esModule","cache","_getRequireWildcardCache","get","newObj","hasPropertyDescriptor","getOwnPropertyDescriptor","prototype","hasOwnProperty","call","desc","set","_interopRequireWildcard","require","_normalizeTrailingSlash","target","i","arguments","length","source","apply","this","WeakMap","excluded","sourceKeys","keys","indexOf","Set","Map","loaders","endsWith","dangerouslyAllowSVG","encodeURIComponent","normalizePathTrailingSlash","path","url","URL","normalizeSrc","params","searchParams","toString","paramsString","join","getWidths","match","viewportWidthRe","percentSizes","exec","push","parseInt","Math","smallestRatio","min","widths","s","kind","map","w","find","p","last","x","loaderProps","ref","loaderKey","load","VALID_LOADERS","handleLoading","img","decode","Promise","resolve","catch","then","parentNode","add","naturalWidth","naturalHeight","onLoad","onError","decoding","useCallback","complete","event","currentTarget","slice","module","isDisabled","hasIntersectionObserver","unobserve","visible","setVisible","element","setElement","tagName","callback","options","createObserver","instance","id","root","existing","idList","observers","elements","observer","IntersectionObserver","entries","forEach","entry","isIntersecting","intersectionRatio","observe","delete","size","disconnect","index","findIndex","splice","idleCallback","_requestIdleCallback","requestIdleCallback","cancelIdleCallback","resetVisible"],"sourceRoot":""}