wuyiqunLu
feat: generate thumbnail and save on video upload (#43)
bc0330e unverified
raw
history blame
3.54 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();
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;