'use client' import type { StaticImageData } from 'next/image' import { cn } from '@/utilities/ui' import NextImage from 'next/image' import React from 'react' import type { Props as MediaProps } from '../types' import { cssVariables } from '@/cssVariables' import { getClientSideURL } from '@/utilities/getURL' const { breakpoints } = cssVariables // A base64 encoded image to use as a placeholder while the image is loading const placeholderBlur = '' export const ImageMedia: React.FC = (props) => { const { alt: altFromProps, fill, pictureClassName, imgClassName, priority, resource, size: sizeFromProps, src: srcFromProps, loading: loadingFromProps, } = props let width: number | undefined let height: number | undefined let alt = altFromProps let src: StaticImageData | string = srcFromProps || '' if (!src && resource && typeof resource === 'object') { const { alt: altFromResource, height: fullHeight, url, width: fullWidth } = resource width = fullWidth! height = fullHeight! alt = altFromResource || '' const cacheTag = resource.updatedAt src = `${getClientSideURL()}${url}?${cacheTag}` } const loading = loadingFromProps || (!priority ? 'lazy' : undefined) // NOTE: this is used by the browser to determine which image to download at different screen sizes const sizes = sizeFromProps ? sizeFromProps : Object.entries(breakpoints) .map(([, value]) => `(max-width: ${value}px) ${value * 2}w`) .join(', ') return ( ) }