fix: make image loading more robust
This commit is contained in:
		| @@ -2,6 +2,7 @@ | ||||
| import type { ImageMetadata } from "astro"; | ||||
| import { Picture as AstroImage } from "astro:assets"; | ||||
| import { generateThumbHash, getExifData } from "@helpers/image"; | ||||
| import sharp from "sharp"; | ||||
| interface Props { | ||||
|   src: ImageMetadata & { fsPath?: string }; | ||||
|   alt: string; | ||||
| @@ -16,12 +17,12 @@ interface Props { | ||||
| async function checkImage(src: string) { | ||||
|   try { | ||||
|     if (src.startsWith("/@fs") || src.startsWith("/_astro")) return true; | ||||
|     const res = await fetch(src); | ||||
|     if (res.ok) { | ||||
|     const res = await sharp(src).metadata(); | ||||
|     if (res.format) { | ||||
|       return true; | ||||
|       }else { | ||||
|     }else { | ||||
|       console.log("Failed to fetch: ", src); | ||||
|       } | ||||
|     } | ||||
|     return false; | ||||
|   } catch (err) { | ||||
|     console.log("Failed to fetch: ", src); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user