summaryrefslogtreecommitdiff
path: root/src-migrate/modules/side-banner/index.tsx
diff options
context:
space:
mode:
authorit-fixcomart <it@fixcomart.co.id>2024-06-26 11:19:27 +0700
committerit-fixcomart <it@fixcomart.co.id>2024-06-26 11:19:27 +0700
commiteead8eec2e37a2edf3c431664cacdcc502a64364 (patch)
tree129633fc6aac6aea9250251ca566f7cc7a5cf89d /src-migrate/modules/side-banner/index.tsx
parent98109d3da0a88dfa1a513be68a0debe2e626d331 (diff)
bug fix side & footer banner
Diffstat (limited to 'src-migrate/modules/side-banner/index.tsx')
-rw-r--r--src-migrate/modules/side-banner/index.tsx29
1 files changed, 15 insertions, 14 deletions
diff --git a/src-migrate/modules/side-banner/index.tsx b/src-migrate/modules/side-banner/index.tsx
index be52c554..6214edfb 100644
--- a/src-migrate/modules/side-banner/index.tsx
+++ b/src-migrate/modules/side-banner/index.tsx
@@ -1,29 +1,30 @@
-import Link from "next/link"
-import { useQuery } from "react-query"
-import Image from "~/components/ui/image"
-import { getBanner } from "~/services/banner"
+import React, { useMemo } from "react";
+import Link from "next/link";
+import { useQuery } from "react-query";
+import Image from "~/components/ui/image";
+import { getBanner } from "~/services/banner";
+import { getRandomInt } from '@/utils/getRandomInt';
const SideBanner = () => {
const fetchSideBanner = useQuery({
queryKey: 'sideBanner',
queryFn: () => getBanner({ type: 'side-banner-search' })
- })
-
- const banner = fetchSideBanner?.data?.[0] || false
+ });
+ // ubah dari static menjadid dynamic dengan menggunakan random index
+ const length = useMemo(() => fetchSideBanner.data?.length, [fetchSideBanner.data]);
+ const randomIndex = useMemo(() => getRandomInt(length), [length]);
+ const banner = fetchSideBanner?.data?.[randomIndex] || false;
return banner && (
<>
- {banner.url && (
+ {banner.url ? (
<Link href={banner.url}>
<Image src={banner.image} alt={banner.name} width={315} height={450} className='object-cover object-center rounded-lg' />
</Link>
- )}
-
- {!banner.url && (
+ ) : (
<Image src={banner.image} alt={banner.name} width={315} height={450} className='object-cover object-center rounded-lg' />
)}
</>
- )
+ );
}
-
-export default SideBanner \ No newline at end of file
+export default SideBanner;