'use client'; import React, { useEffect, useState } from 'react'; import Image from 'next/image'; import { cn } from '@/lib/utils'; import { toast } from 'react-hot-toast'; import { getVideoCover } from '@rajesh896/video-thumbnails-generator'; const placeholder = ''; // const Props = Omit, 'alt'>; const Img = React.forwardRef< React.ElementRef, React.ComponentPropsWithoutRef >(({ 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 [thumbnail, setThumbnail] = useState(''); const isVideo = typeof src === 'string' ? src.toLowerCase().endsWith('.mp4') : false; useEffect(() => { if (!isVideo) { return; } const generateThumbnail = async () => { try { const cover = await getVideoCover(src as string); setThumbnail(cover); } catch (e) { toast.error((e as Error).message); } }; generateThumbnail(); }, [isVideo, src]); return ( {alt { 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;