{"version":3,"file":"static/chunks/9172-add6f138680c324b.js","mappings":"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","sources":["webpack://_N_E/../../node_modules/.pnpm/next@15.2.3_@babel+core@7.26.0_babel-plugin-macros@3.1.0_react-dom@18.3.1_react@18.3.1__react@18.3.1_sass@1.85.1/node_modules/next/legacy/image.js","webpack://_N_E/../../../src/client/legacy/image.tsx"],"sourcesContent":["module.exports = require('../dist/client/legacy/image')\n","'use client'\n\nimport React, {\n useRef,\n useEffect,\n useCallback,\n useContext,\n useMemo,\n useState,\n type JSX,\n} from 'react'\nimport * as ReactDOM from 'react-dom'\nimport Head from '../../shared/lib/head'\nimport {\n imageConfigDefault,\n VALID_LOADERS,\n} from '../../shared/lib/image-config'\nimport type {\n ImageConfigComplete,\n LoaderValue,\n} from '../../shared/lib/image-config'\nimport { useIntersection } from '../use-intersection'\nimport { ImageConfigContext } from '../../shared/lib/image-config-context.shared-runtime'\nimport { warnOnce } from '../../shared/lib/utils/warn-once'\nimport { normalizePathTrailingSlash } from '../normalize-trailing-slash'\n\nfunction normalizeSrc(src: string): string {\n return src[0] === '/' ? src.slice(1) : src\n}\n\nconst supportsFloat = typeof ReactDOM.preload === 'function'\nconst DEFAULT_Q = 75\nconst configEnv = process.env.__NEXT_IMAGE_OPTS as any as ImageConfigComplete\nconst loadedImageURLs = new Set<string>()\nconst allImgs = new Map<\n string,\n { src: string; priority: boolean; placeholder: string }\n>()\nlet perfObserver: PerformanceObserver | undefined\nconst emptyDataURL =\n ''\n\nif (typeof window === 'undefined') {\n ;(globalThis as any).__NEXT_IMAGE_IMPORTED = true\n}\n\nconst VALID_LOADING_VALUES = ['lazy', 'eager', undefined] as const\ntype LoadingValue = (typeof VALID_LOADING_VALUES)[number]\ntype ImageConfig = ImageConfigComplete & { allSizes: number[] }\nexport type ImageLoader = (resolverProps: ImageLoaderProps) => string\n\nexport type ImageLoaderProps = {\n src: string\n width: number\n quality?: number\n}\n\n// Do not export - this is an internal type only\n// because `next.config.js` is only meant for the\n// built-in loaders, not for a custom loader() prop.\ntype ImageLoaderWithConfig = (\n resolverProps: ImageLoaderPropsWithConfig\n) => string\ntype ImageLoaderPropsWithConfig = ImageLoaderProps & {\n config: Readonly<ImageConfig>\n}\n\nfunction imgixLoader({\n config,\n src,\n width,\n quality,\n}: ImageLoaderPropsWithConfig): string {\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\n // auto params can be combined with comma separation, or reiteration\n params.set('auto', params.getAll('auto').join(',') || 'format')\n params.set('fit', params.get('fit') || 'max')\n params.set('w', params.get('w') || width.toString())\n\n if (quality) {\n params.set('q', quality.toString())\n }\n\n return url.href\n}\n\nfunction akamaiLoader({\n config,\n src,\n width,\n}: ImageLoaderPropsWithConfig): string {\n return `${config.path}${normalizeSrc(src)}?imwidth=${width}`\n}\n\nfunction cloudinaryLoader({\n config,\n src,\n width,\n quality,\n}: ImageLoaderPropsWithConfig): string {\n // Demo: https://res.cloudinary.com/demo/image/upload/w_300,c_limit,q_auto/turtles.jpg\n const params = ['f_auto', 'c_limit', 'w_' + width, 'q_' + (quality || 'auto')]\n const paramsString = params.join(',') + '/'\n return `${config.path}${paramsString}${normalizeSrc(src)}`\n}\n\nfunction customLoader({ src }: ImageLoaderProps): string {\n throw new Error(\n `Image with src \"${src}\" is missing \"loader\" prop.` +\n `\\nRead more: https://nextjs.org/docs/messages/next-image-missing-loader`\n )\n}\n\nfunction defaultLoader({\n config,\n src,\n width,\n quality,\n}: ImageLoaderPropsWithConfig): string {\n if (process.env.NODE_ENV !== 'production') {\n const missingValues = []\n\n // these should always be provided but make sure they are\n if (!src) missingValues.push('src')\n if (!width) missingValues.push('width')\n\n if (missingValues.length > 0) {\n throw new Error(\n `Next Image Optimization requires ${missingValues.join(\n ', '\n )} to be provided. Make sure you pass them as props to the \\`next/image\\` component. Received: ${JSON.stringify(\n { src, width, quality }\n )}`\n )\n }\n\n if (src.startsWith('//')) {\n throw new Error(\n `Failed to parse src \"${src}\" on \\`next/image\\`, protocol-relative URL (//) must be changed to an absolute URL (http:// or https://)`\n )\n }\n\n if (src.startsWith('/') && config.localPatterns) {\n if (\n process.env.NODE_ENV !== 'test' &&\n // micromatch isn't compatible with edge runtime\n process.env.NEXT_RUNTIME !== 'edge'\n ) {\n // We use dynamic require because this should only error in development\n const {\n hasLocalMatch,\n } = require('../../shared/lib/match-local-pattern')\n if (!hasLocalMatch(config.localPatterns, src)) {\n throw new Error(\n `Invalid src prop (${src}) on \\`next/image\\` does not match \\`images.localPatterns\\` configured in your \\`next.config.js\\`\\n` +\n `See more info: https://nextjs.org/docs/messages/next-image-unconfigured-localpatterns`\n )\n }\n }\n }\n\n if (!src.startsWith('/') && (config.domains || config.remotePatterns)) {\n let parsedSrc: URL\n try {\n parsedSrc = new URL(src)\n } catch (err) {\n console.error(err)\n throw new Error(\n `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 }\n\n if (\n process.env.NODE_ENV !== 'test' &&\n // micromatch isn't compatible with edge runtime\n process.env.NEXT_RUNTIME !== 'edge'\n ) {\n // We use dynamic require because this should only error in development\n const {\n hasRemoteMatch,\n } = require('../../shared/lib/match-remote-pattern')\n if (!hasRemoteMatch(config.domains, config.remotePatterns, parsedSrc)) {\n throw new Error(\n `Invalid src prop (${src}) on \\`next/image\\`, hostname \"${parsedSrc.hostname}\" is not configured under images in your \\`next.config.js\\`\\n` +\n `See more info: https://nextjs.org/docs/messages/next-image-unconfigured-host`\n )\n }\n }\n }\n\n if (quality && config.qualities && !config.qualities.includes(quality)) {\n throw new Error(\n `Invalid quality prop (${quality}) on \\`next/image\\` does not match \\`images.qualities\\` configured in your \\`next.config.js\\`\\n` +\n `See more info: https://nextjs.org/docs/messages/next-image-unconfigured-qualities`\n )\n }\n }\n\n const q =\n quality ||\n config.qualities?.reduce((prev, cur) =>\n Math.abs(cur - DEFAULT_Q) < Math.abs(prev - DEFAULT_Q) ? cur : prev\n ) ||\n DEFAULT_Q\n\n if (!config.dangerouslyAllowSVG && src.split('?', 1)[0].endsWith('.svg')) {\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\n return `${normalizePathTrailingSlash(config.path)}?url=${encodeURIComponent(\n src\n )}&w=${width}&q=${q}`\n}\n\nconst loaders = new Map<\n LoaderValue,\n (props: ImageLoaderPropsWithConfig) => string\n>([\n ['default', defaultLoader],\n ['imgix', imgixLoader],\n ['cloudinary', cloudinaryLoader],\n ['akamai', akamaiLoader],\n ['custom', customLoader],\n])\n\nconst VALID_LAYOUT_VALUES = [\n 'fill',\n 'fixed',\n 'intrinsic',\n 'responsive',\n undefined,\n] as const\ntype LayoutValue = (typeof VALID_LAYOUT_VALUES)[number]\n\ntype PlaceholderValue = 'blur' | 'empty'\n\ntype OnLoadingComplete = (result: {\n naturalWidth: number\n naturalHeight: number\n}) => void\n\ntype ImgElementStyle = NonNullable<JSX.IntrinsicElements['img']['style']>\n\ntype ImgElementWithDataProp = HTMLImageElement & {\n 'data-loaded-src': string | undefined\n}\n\nexport interface StaticImageData {\n src: string\n height: number\n width: number\n blurDataURL?: string\n}\n\ninterface StaticRequire {\n default: StaticImageData\n}\n\ntype StaticImport = StaticRequire | StaticImageData\n\ntype SafeNumber = number | `${number}`\n\nfunction isStaticRequire(\n src: StaticRequire | StaticImageData\n): src is StaticRequire {\n return (src as StaticRequire).default !== undefined\n}\n\nfunction isStaticImageData(\n src: StaticRequire | StaticImageData\n): src is StaticImageData {\n return (src as StaticImageData).src !== undefined\n}\n\nfunction isStaticImport(src: string | StaticImport): src is StaticImport {\n return (\n typeof src === 'object' &&\n (isStaticRequire(src as StaticImport) ||\n isStaticImageData(src as StaticImport))\n )\n}\n\nexport type ImageProps = Omit<\n JSX.IntrinsicElements['img'],\n 'src' | 'srcSet' | 'ref' | 'width' | 'height' | 'loading'\n> & {\n src: string | StaticImport\n width?: SafeNumber\n height?: SafeNumber\n layout?: LayoutValue\n loader?: ImageLoader\n quality?: SafeNumber\n priority?: boolean\n loading?: LoadingValue\n lazyRoot?: React.RefObject<HTMLElement | null> | null\n lazyBoundary?: string\n placeholder?: PlaceholderValue\n blurDataURL?: string\n unoptimized?: boolean\n objectFit?: ImgElementStyle['objectFit']\n objectPosition?: ImgElementStyle['objectPosition']\n onLoadingComplete?: OnLoadingComplete\n}\n\ntype ImageElementProps = Omit<ImageProps, 'src' | 'loader'> & {\n srcString: string\n imgAttributes: GenImgAttrsResult\n heightInt: number | undefined\n widthInt: number | undefined\n qualityInt: number | undefined\n layout: LayoutValue\n imgStyle: ImgElementStyle\n blurStyle: ImgElementStyle\n isLazy: boolean\n loading: LoadingValue\n config: ImageConfig\n unoptimized: boolean\n loader: ImageLoaderWithConfig\n placeholder: PlaceholderValue\n onLoadingCompleteRef: React.MutableRefObject<OnLoadingComplete | undefined>\n setBlurComplete: (b: boolean) => void\n setIntersection: (img: HTMLImageElement | null) => void\n isVisible: boolean\n noscriptSizes: string | undefined\n}\n\nfunction getWidths(\n { deviceSizes, allSizes }: ImageConfig,\n width: number | undefined,\n layout: LayoutValue,\n sizes: string | undefined\n): { widths: number[]; kind: 'w' | 'x' } {\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 { widths: allSizes, kind: 'w' }\n }\n if (\n typeof width !== 'number' ||\n layout === 'fill' ||\n layout === 'responsive'\n ) {\n return { widths: deviceSizes, kind: 'w' }\n }\n\n const widths = [\n ...new Set(\n // > 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 [width, width * 2 /*, width * 3*/].map(\n (w) => allSizes.find((p) => p >= w) || allSizes[allSizes.length - 1]\n )\n ),\n ]\n return { widths, kind: 'x' }\n}\n\ntype GenImgAttrsData = {\n config: ImageConfig\n src: string\n unoptimized: boolean\n layout: LayoutValue\n loader: ImageLoaderWithConfig\n width?: number\n quality?: number\n sizes?: string\n}\n\ntype GenImgAttrsResult = {\n src: string\n srcSet: string | undefined\n sizes: string | undefined\n}\n\nfunction generateImgAttrs({\n config,\n src,\n unoptimized,\n layout,\n width,\n quality,\n sizes,\n loader,\n}: GenImgAttrsData): GenImgAttrsResult {\n if (unoptimized) {\n return { src, srcSet: undefined, sizes: undefined }\n }\n\n const { widths, kind } = getWidths(config, width, layout, sizes)\n const last = widths.length - 1\n\n return {\n sizes: !sizes && kind === 'w' ? '100vw' : sizes,\n srcSet: widths\n .map(\n (w, i) =>\n `${loader({ config, src, quality, width: w })} ${\n kind === 'w' ? w : i + 1\n }${kind}`\n )\n .join(', '),\n\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({ config, src, quality, width: widths[last] }),\n }\n}\n\nfunction getInt(x: unknown): number | undefined {\n if (typeof x === 'number') {\n return x\n }\n if (typeof x === 'string') {\n return parseInt(x, 10)\n }\n return undefined\n}\n\nfunction defaultImageLoader(loaderProps: ImageLoaderPropsWithConfig) {\n const loaderKey = loaderProps.config?.loader || 'default'\n const load = loaders.get(loaderKey)\n if (load) {\n return load(loaderProps)\n }\n throw new Error(\n `Unknown \"loader\" found in \"next.config.js\". Expected: ${VALID_LOADERS.join(\n ', '\n )}. Received: ${loaderKey}`\n )\n}\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(\n img: ImgElementWithDataProp,\n src: string,\n layout: LayoutValue,\n placeholder: PlaceholderValue,\n onLoadingCompleteRef: React.MutableRefObject<OnLoadingComplete | undefined>,\n setBlurComplete: (b: boolean) => void\n) {\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?.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({ naturalWidth, naturalHeight })\n }\n if (process.env.NODE_ENV !== 'production') {\n if (img.parentElement?.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 warnOnce(\n `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 )\n } else if (\n layout === 'fill' &&\n parent.position !== 'relative' &&\n parent.position !== 'fixed' &&\n parent.position !== 'absolute'\n ) {\n warnOnce(\n `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 })\n}\n\nconst ImageElement = ({\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 ...rest\n}: ImageElementProps) => {\n loading = isLazy ? 'lazy' : loading\n return (\n <>\n <img\n {...rest}\n {...imgAttributes}\n decoding=\"async\"\n data-nimg={layout}\n className={className}\n style={{ ...imgStyle, ...blurStyle }}\n ref={useCallback(\n (img: ImgElementWithDataProp) => {\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?.complete) {\n handleLoading(\n img,\n srcString,\n layout,\n placeholder,\n onLoadingCompleteRef,\n setBlurComplete\n )\n }\n },\n [\n setIntersection,\n srcString,\n layout,\n placeholder,\n onLoadingCompleteRef,\n setBlurComplete,\n ]\n )}\n onLoad={(event) => {\n const img = event.currentTarget as ImgElementWithDataProp\n handleLoading(\n img,\n srcString,\n layout,\n placeholder,\n onLoadingCompleteRef,\n setBlurComplete\n )\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 />\n {(isLazy || placeholder === 'blur') && (\n <noscript>\n <img\n {...rest}\n // @ts-ignore - TODO: upgrade to `@types/react@17`\n loading={loading}\n decoding=\"async\"\n data-nimg={layout}\n style={imgStyle}\n className={className}\n // It's intended to keep `loading` before `src` because React updates\n // props in order which causes Safari/Firefox to not lazy load properly.\n // See https://github.com/facebook/react/issues/25883\n {...generateImgAttrs({\n config,\n src: srcString,\n unoptimized,\n layout,\n width: widthInt,\n quality: qualityInt,\n sizes: noscriptSizes,\n loader,\n })}\n />\n </noscript>\n )}\n </>\n )\n}\n\nexport default function Image({\n src,\n sizes,\n unoptimized = false,\n priority = false,\n loading,\n lazyRoot = null,\n lazyBoundary,\n className,\n quality,\n width,\n height,\n style,\n objectFit,\n objectPosition,\n onLoadingComplete,\n placeholder = 'empty',\n blurDataURL,\n ...all\n}: ImageProps) {\n const configContext = useContext(ImageConfigContext)\n const config: ImageConfig = useMemo(() => {\n const c = configEnv || configContext || imageConfigDefault\n const allSizes = [...c.deviceSizes, ...c.imageSizes].sort((a, b) => a - b)\n const deviceSizes = c.deviceSizes.sort((a, b) => a - b)\n const qualities = c.qualities?.sort((a, b) => a - b)\n return { ...c, allSizes, deviceSizes, qualities }\n }, [configContext])\n\n let rest: Partial<ImageProps> = all\n let layout: NonNullable<LayoutValue> = 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\n // Remove property so it's not spread on <img>:\n delete rest.layout\n }\n\n let loader: ImageLoaderWithConfig = defaultImageLoader\n if ('loader' in rest) {\n if (rest.loader) {\n const customImageLoader = rest.loader\n loader = (obj) => {\n const { config: _, ...opts } = obj\n // The config object is internal only so we must\n // not pass it to the user-defined loader()\n return customImageLoader(opts)\n }\n }\n // Remove property so it's not spread on <img>\n delete rest.loader\n }\n\n let staticSrc = ''\n if (isStaticImport(src)) {\n const staticImageData = isStaticRequire(src) ? src.default : src\n\n if (!staticImageData.src) {\n throw new Error(\n `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(\n staticImageData\n )}`\n )\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(\n `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(\n staticImageData\n )}`\n )\n }\n }\n }\n src = typeof src === 'string' ? src : staticSrc\n\n let isLazy =\n !priority && (loading === 'lazy' || typeof loading === 'undefined')\n if (src.startsWith('data:') || src.startsWith('blob:')) {\n // https://developer.mozilla.org/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 (config.unoptimized) {\n unoptimized = true\n }\n\n const [blurComplete, setBlurComplete] = useState(false)\n const [setIntersection, isIntersected, resetIntersected] =\n useIntersection<HTMLImageElement>({\n rootRef: lazyRoot,\n rootMargin: lazyBoundary || '200px',\n disabled: !isLazy,\n })\n const isVisible = !isLazy || isIntersected\n\n const wrapperStyle: JSX.IntrinsicElements['span']['style'] = {\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: JSX.IntrinsicElements['span']['style'] = {\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: string | undefined\n const layoutStyle: ImgElementStyle = {\n position: 'absolute',\n top: 0,\n left: 0,\n bottom: 0,\n right: 0,\n\n boxSizing: 'border-box',\n padding: 0,\n border: 'none',\n margin: 'auto',\n\n display: 'block',\n width: 0,\n height: 0,\n minWidth: '100%',\n maxWidth: '100%',\n minHeight: '100%',\n maxHeight: '100%',\n\n objectFit,\n objectPosition,\n }\n\n let widthInt = getInt(width)\n let heightInt = getInt(height)\n const qualityInt = getInt(quality)\n\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 throw new Error(\n `Image with src \"${src}\" has invalid \"layout\" property. Provided \"${layout}\" should be one of ${VALID_LAYOUT_VALUES.map(\n String\n ).join(',')}.`\n )\n }\n\n if (\n (typeof widthInt !== 'undefined' && isNaN(widthInt)) ||\n (typeof heightInt !== 'undefined' && isNaN(heightInt))\n ) {\n throw new Error(\n `Image with src \"${src}\" has invalid \"width\" or \"height\" property. These should be numeric values.`\n )\n }\n if (layout === 'fill' && (width || height)) {\n warnOnce(\n `Image with src \"${src}\" and \"layout='fill'\" has unused properties assigned. Please remove \"width\" and \"height\".`\n )\n }\n if (!VALID_LOADING_VALUES.includes(loading)) {\n throw new Error(\n `Image with src \"${src}\" has invalid \"loading\" property. Provided \"${loading}\" should be one of ${VALID_LOADING_VALUES.map(\n String\n ).join(',')}.`\n )\n }\n if (priority && loading === 'lazy') {\n throw new Error(\n `Image with src \"${src}\" has both \"priority\" and \"loading='lazy'\" properties. Only one should be used.`\n )\n }\n if (sizes && layout !== 'fill' && layout !== 'responsive') {\n warnOnce(\n `Image with src \"${src}\" has \"sizes\" property but it will be ignored. Only use \"sizes\" with \"layout='fill'\" or \"layout='responsive'\"`\n )\n }\n if (placeholder === 'blur') {\n if (layout !== 'fill' && (widthInt || 0) * (heightInt || 0) < 1600) {\n warnOnce(\n `Image with src \"${src}\" is smaller than 40x40. Consider removing the \"placeholder='blur'\" property to improve performance.`\n )\n }\n if (!blurDataURL) {\n const VALID_BLUR_EXT = ['jpeg', 'png', 'webp', 'avif'] // should match next-image-loader\n\n throw new Error(\n `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 ','\n )} (animated images not supported)\n - Remove the \"placeholder\" property, effectively no blur effect\n Read more: https://nextjs.org/docs/messages/placeholder-blur-data-url`\n )\n }\n }\n if ('ref' in rest) {\n warnOnce(\n `Image with src \"${src}\" is using unsupported \"ref\" property. Consider using the \"onLoadingComplete\" property instead.`\n )\n }\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: URL | undefined\n try {\n url = new URL(urlStr)\n } catch (err) {}\n if (urlStr === src || (url && url.pathname === src && !url.search)) {\n warnOnce(\n `Image with src \"${src}\" has a \"loader\" property that does not implement width. Please implement it or use the \"unoptimized\" property instead.` +\n `\\nRead more: https://nextjs.org/docs/messages/next-image-missing-loader-width`\n )\n }\n }\n\n if (style) {\n let overwrittenStyles = Object.keys(style).filter(\n (key) => key in layoutStyle\n )\n if (overwrittenStyles.length) {\n warnOnce(\n `Image with src ${src} is assigned the following styles, which are overwritten by automatically-generated styles: ${overwrittenStyles.join(\n ', '\n )}`\n )\n }\n }\n\n if (\n typeof window !== 'undefined' &&\n !perfObserver &&\n window.PerformanceObserver\n ) {\n perfObserver = new PerformanceObserver((entryList) => {\n for (const entry of entryList.getEntries()) {\n // @ts-ignore - missing \"LargestContentfulPaint\" class with \"element\" prop\n const imgSrc = entry?.element?.src || ''\n const lcpImage = allImgs.get(imgSrc)\n if (\n lcpImage &&\n !lcpImage.priority &&\n lcpImage.placeholder !== 'blur' &&\n !lcpImage.src.startsWith('data:') &&\n !lcpImage.src.startsWith('blob:')\n ) {\n // https://web.dev/lcp/#measure-lcp-in-javascript\n warnOnce(\n `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.` +\n `\\nRead more: https://nextjs.org/docs/api-reference/next/legacy/image#priority`\n )\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 =\n placeholder === 'blur' && !blurComplete\n ? {\n backgroundSize: objectFit || 'cover',\n backgroundPosition: objectPosition || '0% 0%',\n filter: 'blur(20px)',\n backgroundImage: `url(\"${blurDataURL}\")`,\n }\n : {}\n if (layout === 'fill') {\n // <Image src=\"i.png\" layout=\"fill\" />\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 (\n typeof widthInt !== 'undefined' &&\n typeof heightInt !== 'undefined'\n ) {\n // <Image src=\"i.png\" width=\"100\" height=\"100\" />\n const quotient = heightInt / widthInt\n const paddingTop = isNaN(quotient) ? '100%' : `${quotient * 100}%`\n if (layout === 'responsive') {\n // <Image src=\"i.png\" width=\"100\" height=\"100\" layout=\"responsive\" />\n wrapperStyle.display = 'block'\n wrapperStyle.position = 'relative'\n hasSizer = true\n sizerStyle.paddingTop = paddingTop\n } else if (layout === 'intrinsic') {\n // <Image src=\"i.png\" width=\"100\" height=\"100\" layout=\"intrinsic\" />\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 // <Image src=\"i.png\" width=\"100\" height=\"100\" layout=\"fixed\" />\n wrapperStyle.display = 'inline-block'\n wrapperStyle.position = 'relative'\n wrapperStyle.width = widthInt\n wrapperStyle.height = heightInt\n }\n } else {\n // <Image src=\"i.png\" />\n if (process.env.NODE_ENV !== 'production') {\n throw new Error(\n `Image with src \"${src}\" must use \"width\" and \"height\" properties or \"layout='fill'\" property.`\n )\n }\n }\n\n let imgAttributes: GenImgAttrsResult = {\n src: emptyDataURL,\n srcSet: undefined,\n sizes: undefined,\n }\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\n let srcString: string = src\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof window !== 'undefined') {\n let fullUrl: URL\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, { src, priority, placeholder })\n }\n }\n\n const linkProps:\n | React.DetailedHTMLProps<\n React.LinkHTMLAttributes<HTMLLinkElement>,\n HTMLLinkElement\n >\n | undefined = supportsFloat\n ? undefined\n : {\n imageSrcSet: imgAttributes.srcSet,\n imageSizes: imgAttributes.sizes,\n crossOrigin: rest.crossOrigin,\n referrerPolicy: rest.referrerPolicy,\n }\n\n const useLayoutEffect =\n typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect\n const onLoadingCompleteRef = useRef(onLoadingComplete)\n\n const previousImageSrc = useRef<string | StaticImport>(src)\n useEffect(() => {\n onLoadingCompleteRef.current = onLoadingComplete\n }, [onLoadingComplete])\n\n useLayoutEffect(() => {\n if (previousImageSrc.current !== src) {\n resetIntersected()\n previousImageSrc.current = src\n }\n }, [resetIntersected, src])\n\n const imgElementArgs = {\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 }\n return (\n <>\n <span style={wrapperStyle}>\n {hasSizer ? (\n <span style={sizerStyle}>\n {sizerSvgUrl ? (\n <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 />\n ) : null}\n </span>\n ) : null}\n <ImageElement {...imgElementArgs} />\n </span>\n {!supportsFloat && priority ? (\n // 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 <Head>\n <link\n key={\n '__nimg-' +\n imgAttributes.src +\n imgAttributes.srcSet +\n imgAttributes.sizes\n }\n rel=\"preload\"\n as=\"image\"\n href={imgAttributes.srcSet ? undefined : imgAttributes.src}\n {...linkProps}\n />\n </Head>\n ) : null}\n </>\n )\n}\n"],"names":["Image","normalizeSrc","src","slice","supportsFloat","ReactDOM","preload","configEnv","process","loadedImageURLs","Set","emptyDataURL","loaders","Map","defaultLoader","config","width","quality","q","qualities","reduce","prev","cur","Math","abs","DEFAULT_Q","dangerouslyAllowSVG","split","endsWith","normalizePathTrailingSlash","path","encodeURIComponent","imgixLoader","url","URL","params","searchParams","set","getAll","join","get","toString","href","cloudinaryLoader","paramsString","akamaiLoader","customLoader","isStaticRequire","undefined","default","generateImgAttrs","unoptimized","layout","sizes","loader","srcSet","widths","kind","getWidths","deviceSizes","allSizes","viewportWidthRe","percentSizes","match","exec","push","parseInt","length","smallestRatio","min","filter","s","map","find","p","w","i","last","getInt","x","defaultImageLoader","loaderProps","loaderKey","load","VALID_LOADERS","handleLoading","img","placeholder","onLoadingCompleteRef","setBlurComplete","decode","Promise","resolve","catch","then","parentNode","add","current","naturalWidth","naturalHeight","ImageElement","imgAttributes","heightInt","widthInt","qualityInt","className","imgStyle","blurStyle","isLazy","loading","srcString","setIntersection","onLoad","onError","isVisible","noscriptSizes","rest","decoding","data-nimg","style","ref","useCallback","complete","event","currentTarget","noscript","sizerSvgUrl","priority","lazyRoot","lazyBoundary","height","objectFit","objectPosition","onLoadingComplete","blurDataURL","all","configContext","useContext","ImageConfigContext","useMemo","c","imageConfigDefault","imageSizes","sort","a","b","customImageLoader","_","opts","obj","staticSrc","isStaticImport","isStaticImageData","staticImageData","JSON","stringify","startsWith","has","blurComplete","useState","isIntersected","resetIntersected","useIntersection","rootRef","rootMargin","disabled","wrapperStyle","boxSizing","display","overflow","background","opacity","border","margin","padding","sizerStyle","hasSizer","Object","assign","position","layoutStyle","top","left","bottom","right","minWidth","maxWidth","minHeight","maxHeight","backgroundSize","backgroundPosition","backgroundImage","quotient","paddingTop","isNaN","linkProps","imageSrcSet","crossOrigin","referrerPolicy","useLayoutEffect","React","useRef","previousImageSrc","useEffect","imgElementArgs","span","alt","aria-hidden","Head","link","rel","as"],"sourceRoot":"","ignoreList":[0]}