summaryrefslogtreecommitdiff
path: root/src-migrate/components/ui/image.tsx
diff options
context:
space:
mode:
authortrisusilo48 <tri.susilo@altama.co.id>2024-07-10 15:58:51 +0700
committertrisusilo48 <tri.susilo@altama.co.id>2024-07-10 15:58:51 +0700
commit2e3c726bc8217f3960cfecec44b81303b03de72b (patch)
tree1b85ced7f61f3e4c3f1f27b577b37aa161615065 /src-migrate/components/ui/image.tsx
parent2b3bd9c0a454dbad69ce29cee877bfb1fca5dfa6 (diff)
parenta99bf6480eea556e53b85e6db45f3b8c2361e693 (diff)
Merge branch 'release' into development
# Conflicts: # src/pages/shop/product/variant/[slug].jsx
Diffstat (limited to 'src-migrate/components/ui/image.tsx')
-rw-r--r--src-migrate/components/ui/image.tsx34
1 files changed, 34 insertions, 0 deletions
diff --git a/src-migrate/components/ui/image.tsx b/src-migrate/components/ui/image.tsx
new file mode 100644
index 00000000..de0ad1da
--- /dev/null
+++ b/src-migrate/components/ui/image.tsx
@@ -0,0 +1,34 @@
+import NextImage, { ImageProps as NextImageProps } from 'next/image';
+import { useState } from 'react';
+
+import clsxm from '~/libs/clsxm';
+
+type ImageProps = {
+ rounded?: string;
+} & NextImageProps;
+
+const Image = (props: ImageProps) => {
+ const { alt, src, className, rounded, ...rest } = props;
+ const [isLoading, setLoading] = useState(true);
+
+ return (
+ <NextImage
+ className={clsxm(
+ 'duration-500 ease-in-out',
+ isLoading
+ ? 'scale-[1.02] blur-xl grayscale'
+ : 'scale-100 blur-0 grayscale-0',
+ rounded,
+ className
+ )}
+ src={src}
+ alt={alt}
+ loading='lazy'
+ quality={100}
+ onLoadingComplete={() => setLoading(false)}
+ unoptimized
+ {...rest}
+ />
+ );
+};
+export default Image; \ No newline at end of file