{"version":3,"file":"static/chunks/3942-3008a12c6779c942.js","mappings":"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","sources":["webpack://_N_E/../../../src/client/legacy/image.tsx","webpack://_N_E/../../node_modules/.pnpm/next@15.1.6_@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"],"sourcesContent":["'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","module.exports = require('../dist/client/legacy/image')\n"],"names":["Image","normalizeSrc","src","slice","supportsFloat","ReactDOM","preload","configEnv","process","loadedImageURLs","Set","emptyDataURL","loaders","Map","defaultLoader","config","width","q","quality","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","customLoader","isStaticRequire","undefined","default","generateImgAttrs","unoptimized","layout","sizes","loader","srcSet","getWidths","deviceSizes","allSizes","viewportWidthRe","percentSizes","match","exec","push","parseInt","length","smallestRatio","min","widths","filter","s","kind","map","w","find","p","last","i","getInt","x","defaultImageLoader","loaderProps","loaderKey","load","VALID_LOADERS","handleLoading","img","placeholder","onLoadingCompleteRef","setBlurComplete","decode","Promise","resolve","catch","then","parentNode","add","current","naturalWidth","naturalHeight","ImageElement","heightInt","widthInt","qualityInt","className","isLazy","loading","srcString","setIntersection","onLoad","noscriptSizes","isVisible","rest","imgAttributes","imgStyle","blurStyle","onError","decoding","data-nimg","style","ref","useCallback","complete","event","currentTarget","noscript","sizerSvgUrl","priority","height","objectFit","onLoadingComplete","all","lazyRoot","lazyBoundary","objectPosition","blurDataURL","configContext","useContext","ImageConfigContext","useMemo","c","imageConfigDefault","imageSizes","sort","a","b","customImageLoader","obj","opts","staticSrc","isStaticImageData","staticImageData","JSON","stringify","startsWith","has","useState","blurComplete","useIntersection","rootRef","rootMargin","disabled","isIntersected","resetIntersected","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":[1]}