UNPKG

@chakra-ui/image

Version:

React component for progressive image loading

73 lines (71 loc) 1.85 kB
'use client' // src/use-image.ts import { useSafeLayoutEffect } from "@chakra-ui/react-use-safe-layout-effect"; import { useCallback, useEffect, useRef, useState } from "react"; function useImage(props) { const { loading, src, srcSet, onLoad, onError, crossOrigin, sizes, ignoreFallback } = props; const [status, setStatus] = useState("pending"); useEffect(() => { setStatus(src ? "loading" : "pending"); }, [src]); const imageRef = useRef(); const load = useCallback(() => { if (!src) return; flush(); const img = new Image(); img.src = src; if (crossOrigin) img.crossOrigin = crossOrigin; if (srcSet) img.srcset = srcSet; if (sizes) img.sizes = sizes; if (loading) img.loading = loading; img.onload = (event) => { flush(); setStatus("loaded"); onLoad == null ? void 0 : onLoad(event); }; img.onerror = (error) => { flush(); setStatus("failed"); onError == null ? void 0 : onError(error); }; imageRef.current = img; }, [src, crossOrigin, srcSet, sizes, onLoad, onError, loading]); const flush = () => { if (imageRef.current) { imageRef.current.onload = null; imageRef.current.onerror = null; imageRef.current = null; } }; useSafeLayoutEffect(() => { if (ignoreFallback) return void 0; if (status === "loading") { load(); } return () => { flush(); }; }, [status, load, ignoreFallback]); return ignoreFallback ? "loaded" : status; } var shouldShowFallbackImage = (status, fallbackStrategy) => status !== "loaded" && fallbackStrategy === "beforeLoadOrError" || status === "failed" && fallbackStrategy === "onError"; export { useImage, shouldShowFallbackImage }; //# sourceMappingURL=chunk-SPIKMR6I.mjs.map