summaryrefslogtreecommitdiff
path: root/src/lib/home/components/CategoryDynamicMobile.jsx
diff options
context:
space:
mode:
authorit-fixcomart <it@fixcomart.co.id>2024-07-23 09:28:21 +0700
committerit-fixcomart <it@fixcomart.co.id>2024-07-23 09:28:21 +0700
commitbf5c3b1d48da54e0e44689412ad9de9c10cf9edb (patch)
treec60e3fb26f1d8e519dfc0f87fa702a995ec14627 /src/lib/home/components/CategoryDynamicMobile.jsx
parenta78251dc5cdfdd5438aad3ce7b7e342fceb7275e (diff)
<iman> update category management
Diffstat (limited to 'src/lib/home/components/CategoryDynamicMobile.jsx')
-rw-r--r--src/lib/home/components/CategoryDynamicMobile.jsx41
1 files changed, 20 insertions, 21 deletions
diff --git a/src/lib/home/components/CategoryDynamicMobile.jsx b/src/lib/home/components/CategoryDynamicMobile.jsx
index 317042b8..c1433a2d 100644
--- a/src/lib/home/components/CategoryDynamicMobile.jsx
+++ b/src/lib/home/components/CategoryDynamicMobile.jsx
@@ -1,5 +1,5 @@
import React, { useEffect, useState } from 'react';
-import { fetchProductManagementSolr } from '../hooks/useCategoryManagement';
+import useCategoryManagement from '../hooks/useCategoryManagement';
import NextImage from 'next/image';
import Link from "next/link";
import { createSlug } from '@/core/utils/slug';
@@ -7,51 +7,50 @@ import { Swiper, SwiperSlide } from 'swiper/react';
import 'swiper/css';
const CategoryDynamicMobile = () => {
- const [promoItems, setPromoItems] = useState([]);
+ const { categoryManagement } = useCategoryManagement()
const [selectedCategory, setSelectedCategory] = useState({});
useEffect(() => {
const loadPromo = async () => {
try {
- const items = await fetchProductManagementSolr();
- setPromoItems(items);
- if (items.length > 0) {
- const initialSelections = items.reduce((acc, category) => {
- if (category.category_id2.length > 0) {
- acc[category.id] = category.category_id2[0].id_level_2;
+ if (categoryManagement.data?.length > 0) {
+ const initialSelections = categoryManagement.data.reduce((acc, category) => {
+ if (category.categories.length > 0) {
+ acc[category.id] = category.categories[0].idLevel2;
}
return acc;
}, {});
setSelectedCategory(initialSelections);
}
} catch (loadError) {
- // console.error("Error loading promo items:", loadError)
+ // console.error("Error loading promo items:", loadError);
}
};
+
loadPromo();
- }, []);
+ }, [categoryManagement.data]);
- const handleCategoryLevel2Click = (categoryLevel1Id, categoryLevel2Id) => {
+ const handleCategoryLevel2Click = (categoryIdI, idLevel2) => {
setSelectedCategory(prev => ({
...prev,
- [categoryLevel1Id]: categoryLevel2Id
+ [categoryIdI]: idLevel2
}));
};
-
+
return (
<div className='p-4'>
- {promoItems && promoItems.map((category) => (
+ {categoryManagement.data && categoryManagement.data.map((category) => (
<div key={category.id}>
<div className='bagian-judul flex flex-row justify-between items-center gap-3 mb-4 mt-4'>
<div className='font-semibold sm:text-h-sm mr-2'>{category.name}</div>
- <Link href={createSlug('/shop/category/', category?.name, category?.category_id)} className="!text-red-500 font-semibold text-sm">Lihat Semua</Link>
+ <Link href={createSlug('/shop/category/', category?.name, category?.categoryIdI)} className="!text-red-500 font-semibold text-sm">Lihat Semua</Link>
</div>
<Swiper slidesPerView={2.3} spaceBetween={10}>
- {category.category_id2.map((index) => (
+ {category.categories.map((index) => (
<SwiperSlide key={index.id}>
<div
- onClick={() => handleCategoryLevel2Click(category.id, index?.id_level_2)}
- className={`border flex justify-start items-center max-w-48 max-h-16 rounded ${selectedCategory[category.id] === index?.id_level_2 ? 'bg-red-50 border-red-500 text-red-500' : 'border-gray-200 text-gray-900'}`}
+ onClick={() => handleCategoryLevel2Click(category.id, index?.idLevel2)}
+ className={`border flex justify-start items-center max-w-48 max-h-16 rounded ${selectedCategory[category.id] === index?.idLevel2 ? 'bg-red-50 border-red-500 text-red-500' : 'border-gray-200 text-gray-900'}`}
>
<div className='p-1 flex justify-start items-center'>
<div className='flex flex-row justify-center items-center'>
@@ -74,10 +73,10 @@ const CategoryDynamicMobile = () => {
</Swiper>
<div className='p-3 mt-2 border'>
<div className='grid grid-cols-2 gap-2 overflow-y-auto max-h-[240px]'>
- {category.category_id2.map((index) => (
- selectedCategory[category.id] === index?.id_level_2 && index.child_frontend_id_i.map((x) => (
+ {category.categories.map((index) => (
+ selectedCategory[category.id] === index?.idLevel2 && index.childFrontendIdI.map((x) => (
<div key={x.id}>
- <Link href={createSlug('/shop/category/', x?.name, x?.id_level_3)} className="flex flex-row gap-1 border rounded group hover:border-red-500">
+ <Link href={createSlug('/shop/category/', x?.name, x?.idLevel3)} className="flex flex-row gap-1 border rounded group hover:border-red-500">
<NextImage
src={x.image ? x.image : "/images/noimage.jpeg"}
alt={x.name}