{"version":3,"file":"static/chunks/5675-93ff7f9cdb23cb9c.js","mappings":"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","sources":["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 = 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 ='200px' , className , quality , width , height , style , objectFit , objectPosition , onLoadingComplete , placeholder ='empty' , blurDataURL } = _param, all = _objectWithoutProperties(_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 );\n const deviceSizes = c.deviceSizes.sort((a, b)=>a - b\n );\n return _objectSpread({}, 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 = _objectWithoutProperties(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 const widthInt = getInt(width);\n const heightInt = getInt(height);\n const qualityInt = getInt(quality);\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 const [blurComplete, setBlurComplete] = (0, _react).useState(false);\n const [setIntersection, isIntersected, resetIntersected] = (0, _useIntersection).useIntersection({\n rootRef: lazyRoot,\n rootMargin: lazyBoundary,\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 if (process.env.NODE_ENV !== 'production' && layout !== 'raw' && style) {}\n if (process.env.NODE_ENV !== 'production') {\n if (!src) {\n throw new Error(`Image is missing required \"src\" property. Make sure you pass \"src\" in props to the \\`next/image\\` component. Received: ${JSON.stringify({\n width,\n height,\n quality\n })}`);\n }\n if (!VALID_LAYOUT_VALUES.includes(layout)) {\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 (layout === 'raw' && !experimentalLayoutRaw) {\n throw new Error(`The \"raw\" layout is currently experimental and may be subject to breaking changes. To use layout=\"raw\", include \\`experimental: { images: { layoutRaw: true } }\\` in your next.config.js file.`);\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 (layout === 'raw' && (objectFit || objectPosition)) {\n throw new Error(`Image with src \"${src}\" has \"layout='raw'\" and 'objectFit' or 'objectPosition'. For raw images, these and other styles should be specified using the 'style' attribute.`);\n }\n if (sizes && layout !== 'fill' && layout !== 'responsive' && layout !== 'raw') {\n (0, _utils).warnOnce(`Image with src \"${src}\" has \"sizes\" property but it will be ignored. Only use \"sizes\" with \"layout='fill'\", \"layout='responsive'\", or \"layout='raw'`);\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 && layout !== 'raw') {\n let overwrittenStyles = Object.keys(style).filter((key)=>key in layoutStyle\n );\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 ref1;\n // @ts-ignore - missing \"LargestContentfulPaint\" class with \"element\" prop\n const imgSrc = (entry === null || entry === void 0 ? void 0 : (ref1 = entry.element) === null || ref1 === void 0 ? void 0 : ref1.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 const imgStyle = Object.assign({}, style, layout === 'raw' ? {} : layoutStyle);\n const blurStyle = placeholder === 'blur' && !blurComplete ? {\n filter: 'blur(20px)',\n backgroundSize: objectFit || 'cover',\n backgroundImage: `url(\"${blurDataURL}\")`,\n backgroundPosition: objectPosition || '0% 0%'\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 = _objectSpread({\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 }, rest);\n return(/*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, layout === 'raw' ? /*#__PURE__*/ _react.default.createElement(ImageElement, Object.assign({}, imgElementArgs)) : /*#__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 _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}\nfunction _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n default: obj\n };\n}\nfunction _interopRequireWildcard(obj) {\n if (obj && obj.__esModule) {\n return obj;\n } else {\n var newObj = {};\n if (obj != null) {\n for(var key in obj){\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {};\n if (desc.get || desc.set) {\n Object.defineProperty(newObj, key, desc);\n } else {\n newObj[key] = obj[key];\n }\n }\n }\n }\n newObj.default = obj;\n return newObj;\n }\n}\nfunction _objectSpread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _defineProperty(target, key, source[key]);\n });\n }\n return target;\n}\nfunction _objectWithoutProperties(source, excluded) {\n if (source == null) return {};\n var target = _objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for(i = 0; i < sourceSymbolKeys.length; i++){\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\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}\nvar ref;\nconst experimentalLayoutRaw = (ref = process.env.__NEXT_IMAGE_OPTS) === null || ref === void 0 ? void 0 : ref.experimentalLayoutRaw;\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 'raw',\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' || layout === 'raw')) {\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 ),\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\n ) || allSizes[allSizes.length - 1]\n )), \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}`\n ).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 ref2;\n const loaderKey = ((ref2 = loaderProps.config) === null || ref2 === void 0 ? void 0 : ref2.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 || onLoadingCompleteRef === void 0 ? 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 ref3;\n if (layout === 'raw') {\n const heightModified = img.height.toString() !== img.getAttribute('height');\n const widthModified = img.width.toString() !== img.getAttribute('width');\n if (heightModified && !widthModified || !heightModified && widthModified) {\n (0, _utils).warnOnce(`Image with src \"${src}\" has either width or height modified, but not the other. If you use CSS to change the size of your image, also include the styles 'width: \"auto\"' or 'height: \"auto\"' to maintain the aspect ratio.`);\n }\n }\n if ((ref3 = img.parentElement) === null || ref3 === void 0 ? void 0 : ref3.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 } = _param, rest = _objectWithoutProperties(_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 ]);\n return(/*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement(\"img\", Object.assign({}, rest, imgAttributes, layout === 'raw' ? {\n height: heightInt,\n width: widthInt\n } : {}, {\n decoding: \"async\",\n \"data-nimg\": layout,\n className: className,\n style: _objectSpread({}, imgStyle, blurStyle),\n ref: (0, _react).useCallback((img)=>{\n setIntersection(img);\n if (img === null || img === void 0 ? 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: imgAttributes.sizes,\n loader\n }), layout === 'raw' ? {\n height: heightInt,\n width: widthInt\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 || 'lazy'\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) {\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' && !config.domains.includes(parsedSrc.hostname)) {\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 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)) {\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 !== 'undefined';\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 [root, setRoot] = (0, _react).useState(rootRef ? rootRef.current : null);\n const setRef = (0, _react).useCallback((el)=>{\n if (unobserve.current) {\n unobserve.current();\n unobserve.current = undefined;\n }\n if (isDisabled || visible) return;\n if (el && el.tagName) {\n unobserve.current = observe(el, (isVisible)=>isVisible && setVisible(isVisible)\n , {\n root,\n rootMargin\n });\n }\n }, [\n isDisabled,\n root,\n rootMargin,\n visible\n ]);\n const resetVisible = (0, _react).useCallback(()=>{\n setVisible(false);\n }, []);\n (0, _react).useEffect(()=>{\n if (!hasIntersectionObserver) {\n if (!visible) {\n const idleCallback = (0, _requestIdleCallback).requestIdleCallback(()=>setVisible(true)\n );\n return ()=>(0, _requestIdleCallback).cancelIdleCallback(idleCallback)\n ;\n }\n }\n }, [\n visible\n ]);\n (0, _react).useEffect(()=>{\n if (rootRef) setRoot(rootRef.current);\n }, [\n rootRef\n ]);\n return [\n setRef,\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 let index = idList.findIndex((obj)=>obj.root === id.root && obj.margin === id.margin\n );\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 let existing = idList.find((obj)=>obj.root === id.root && obj.margin === id.margin\n );\n let instance;\n if (existing) {\n instance = observers.get(existing);\n } else {\n instance = observers.get(id);\n idList.push(id);\n }\n if (instance) {\n return instance;\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 observers.set(id, instance = {\n id,\n observer,\n elements\n });\n return instance;\n}\n\nif (typeof exports.default === 'function' || (typeof exports.default === 'object' && exports.default !== null)) {\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":["Object","defineProperty","exports","value","_param","src","sizes","unoptimized","priority","loading","lazyRoot","lazyBoundary","className","quality","width","height","style","objectFit","objectPosition","onLoadingComplete","placeholder","blurDataURL","all","_objectWithoutProperties","configContext","_react","useContext","_imageConfigContext","ImageConfigContext","config","useMemo","c","configEnv","_imageConfig","imageConfigDefault","allSizes","deviceSizes","imageSizes","sort","a","b","_objectSpread","rest","layout","loader","defaultImageLoader","customImageLoader","obj","opts","staticSrc","isStaticRequire","undefined","isStaticImageData","isStaticImport","staticImageData","default","Error","JSON","stringify","widthInt","getInt","heightInt","qualityInt","isLazy","startsWith","loadedImageURLs","has","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","process","imgStyle","assign","blurStyle","filter","backgroundSize","backgroundImage","backgroundPosition","quotient","paddingTop","isNaN","imgAttributes","emptyDataURL","srcSet","generateImgAttrs","srcString","linkProps","useLayoutEffect","onLoadingCompleteRef","useRef","previousImageSrc","useEffect","current","imgElementArgs","createElement","Fragment","ImageElement","alt","_head","key","rel","as","href","ref","__esModule","newObj","prototype","hasOwnProperty","call","desc","getOwnPropertyDescriptor","get","set","_interopRequireWildcard","require","_normalizeTrailingSlash","_defineProperty","enumerable","configurable","writable","target","source","arguments","i","ownKeys","keys","getOwnPropertySymbols","concat","sym","forEach","length","excluded","sourceKeys","indexOf","_objectWithoutPropertiesLoose","sourceSymbolKeys","propertyIsEnumerable","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","ref2","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","root","setRoot","setRef","el","tagName","element","callback","options","createObserver","instance","id","existing","idList","observers","elements","observer","IntersectionObserver","entries","entry","isIntersecting","intersectionRatio","observe","delete","size","disconnect","index","findIndex","splice","resetVisible","idleCallback","_requestIdleCallback","requestIdleCallback","cancelIdleCallback"],"sourceRoot":""}