MingruiZhang's picture
feat: project analysis (#27)
96ac62a unverified
raw history blame
No virus
3.33 kB
'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();
return (
<Image
src={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;