Spaces:
Sleeping
Sleeping
File size: 3,538 Bytes
8e3dbd3 bc0330e 8e3dbd3 3a22cf3 8e3dbd3 760e83d 8e3dbd3 bc0330e 8e3dbd3 3a22cf3 8e3dbd3 96ac62a 8e3dbd3 96ac62a 8e3dbd3 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
'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: width ? Number(width) / aspectRatio : img.naturalHeight,
});
});
return onLoad?.(e);
}}
{...props}
/>
);
});
Img.displayName = Image.displayName;
export default Img;
|