Spaces:
Sleeping
Sleeping
'use client'; | |
import React from 'react'; | |
import Image from 'next/image'; | |
import { cn } from '@/lib/utils'; | |
const placeholder = | |
''; | |
// const Props = Omit<React.ComponentPropsWithoutRef<typeof Image>, 'alt'>; | |
const Img = React.forwardRef< | |
React.ElementRef<typeof Image>, | |
React.ComponentPropsWithoutRef<typeof Image> | |
>(({ src, alt, onLoad, width, height, className, ...props }, ref) => { | |
const [dimensions, setDimensions] = React.useState({ | |
width: width ?? 200, | |
height: height ?? 200, | |
}); | |
// const [isLoading, setIsLoading] = React.useState(true); | |
const [_, startTransition] = React.useTransition(); | |
const isVideo = | |
typeof src === 'string' ? src.toLowerCase().endsWith('.mp4') : false; | |
return ( | |
<Image | |
src={ | |
isVideo | |
? (src as string).replace('.mp4', '.png').replace('.MP4', '.png') | |
: src | |
} | |
placeholder={placeholder} | |
width={dimensions.width} | |
height={dimensions.height} | |
alt={alt ?? 'image'} | |
ref={ref} | |
className={cn('rounded-md', className)} | |
onLoad={e => { | |
const img = e.target as HTMLImageElement; | |
const aspectRatio = img.naturalWidth / img.naturalHeight; | |
startTransition(() => { | |
setDimensions({ | |
width: width ?? img.naturalWidth, | |
height: | |
height ?? width ? Number(width) / aspectRatio : img.naturalHeight, | |
}); | |
}); | |
return onLoad?.(e); | |
}} | |
{...props} | |
/> | |
); | |
}); | |
Img.displayName = Image.displayName; | |
export default Img; | |