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;