diff --git a/src/components/Image/Image.jsx b/src/components/Image/Image.jsx index 4e62c5f65..c49faa9c6 100644 --- a/src/components/Image/Image.jsx +++ b/src/components/Image/Image.jsx @@ -38,90 +38,91 @@ const Image = ({ sizes = '100vw', ...imageProps }) => { - const { src, srcSet, width, height, aspectRatio } = getImageAttributes( - image, - { - itemUrl, - imageField, - maxSize, - useOriginal, - minSize, - }, - ); - const imageRef = useRef(); - const [actualSrcSet, setActualSrcSet] = useState( - critical && srcSet ? srcSet.join(', ') : null, - ); - // TODO: serve a qualcuno questo? - const imageHasLoaded = imageRef?.current?.complete; + if (image) { + const { src, srcSet, width, height, aspectRatio } = getImageAttributes( + image, + { + itemUrl, + imageField, + maxSize, + useOriginal, + minSize, + }, + ); + const imageRef = useRef(); + const [actualSrcSet, setActualSrcSet] = useState( + critical && srcSet ? srcSet.join(', ') : null, + ); + // TODO: serve a qualcuno questo? + const imageHasLoaded = imageRef?.current?.complete; - //picture classname - let pictureClassName = `volto-image${ - containerClassName ? ` ${containerClassName}` : '' - }`; - if (floated) { - pictureClassName = `${pictureClassName} floated ${floated}`; - } - if (size) { - pictureClassName = `${pictureClassName} ${size}`; - } + //picture classname + let pictureClassName = `volto-image${ + containerClassName ? ` ${containerClassName}` : '' + }`; + if (floated) { + pictureClassName = `${pictureClassName} floated ${floated}`; + } + if (size) { + pictureClassName = `${pictureClassName} ${size}`; + } - if (responsive) { - pictureClassName = `${pictureClassName} responsive`; - } + if (responsive) { + pictureClassName = `${pictureClassName} responsive`; + } - //intersection observer - useEffect(() => { - const applySrcSet = () => { - setActualSrcSet(srcSet.join(', ')); - }; + //intersection observer + useEffect(() => { + const applySrcSet = () => { + setActualSrcSet(srcSet.join(', ')); + }; - if (srcSet && !critical) { - if ('IntersectionObserver' in window) { - const observer = new IntersectionObserver( - (entries) => { - entries.forEach((entry) => { - if (entry.isIntersecting && !actualSrcSet) { - applySrcSet(); - if (imageRef.current instanceof Element) { - observer.unobserve(imageRef.current); + if (srcSet && !critical) { + if ('IntersectionObserver' in window) { + const observer = new IntersectionObserver( + (entries) => { + entries.forEach((entry) => { + if (entry.isIntersecting && !actualSrcSet) { + applySrcSet(); + if (imageRef.current instanceof Element) { + observer.unobserve(imageRef.current); + } } - } - }); - }, - { threshold: [0], rootMargin: '100px' }, - ); - observer.observe(imageRef.current); - } else { - applySrcSet(); + }); + }, + { threshold: [0], rootMargin: '100px' }, + ); + observer.observe(imageRef.current); + } else { + applySrcSet(); + } } - } - }, [imageHasLoaded, srcSet, actualSrcSet, critical]); + }, [imageHasLoaded, srcSet, actualSrcSet, critical]); - return ( - <> - - {actualSrcSet?.length > 0 && ( - - )} - {alt} - - {!critical && ( -