Files
web/components/PagesComponent/Home/PopularCategories.jsx
Husanjonazamov 64af77101f classify web
2026-02-24 12:52:49 +05:00

124 lines
3.8 KiB
JavaScript

"use client";
import { useEffect, useState } from "react";
import { RiArrowLeftLine, RiArrowRightLine } from "react-icons/ri";
import {
Carousel,
CarouselContent,
CarouselItem,
} from "@/components/ui/carousel";
import PopularCategoriesSkeleton from "./PopularCategoriesSkeleton.jsx";
import PopularCategoryCard from "@/components/PagesComponent/Home/PopularCategoryCard";
import { useSelector } from "react-redux";
import { t } from "@/utils";
import { getIsRtl } from "@/redux/reducer/languageSlice.js";
import { Loader2 } from "lucide-react";
import useGetCategories from "@/components/Layout/useGetCategories.jsx";
const PopularCategories = () => {
const {
cateData,
getCategories,
isCatLoading,
isCatLoadMore,
catLastPage,
catCurrentPage,
} = useGetCategories();
const isRTL = useSelector(getIsRtl);
const [api, setApi] = useState();
const [current, setCurrent] = useState(0);
const isNextDisabled =
isCatLoadMore ||
((!api || !api.canScrollNext()) && catCurrentPage >= catLastPage);
useEffect(() => {
if (!api) {
return;
}
setCurrent(api.selectedScrollSnap());
api.on("select", () => {
setCurrent(api.selectedScrollSnap());
});
}, [api, cateData.length]);
const handleNext = async () => {
if (api && api.canScrollNext()) {
api.scrollTo(current + 1);
} else if (catCurrentPage < catLastPage) {
await getCategories(catCurrentPage + 1);
setTimeout(() => {
api.scrollTo(current + 1);
}, 200);
}
};
return isCatLoading && !cateData.length ? (
<PopularCategoriesSkeleton />
) : (
cateData && cateData.length > 0 && (
<section className="container mt-12">
<div className="space-between">
<h5 className="text-xl sm:text-2xl font-medium">
{t("popularCategories")}
</h5>
<div className="flex items-center justify-center gap-2 sm:gap-4">
<button
onClick={() => api && api.scrollTo(current - 1)}
className={`bg-primary p-1 sm:p-2 rounded-full ${
!api?.canScrollPrev() ? "opacity-65 cursor-default" : ""
}`}
disabled={!api?.canScrollPrev()}
>
<RiArrowLeftLine
size={24}
color="white"
className={isRTL ? "rotate-180" : ""}
/>
</button>
<button
onClick={handleNext}
className={`bg-primary p-1 sm:p-2 rounded-full ${
isNextDisabled ? "opacity-65 cursor-default" : ""
}`}
disabled={isNextDisabled}
>
{isCatLoadMore ? (
<Loader2 size={24} className="animate-spin" />
) : (
<RiArrowRightLine
size={24}
color="white"
className={isRTL ? "rotate-180" : ""}
/>
)}
</button>
</div>
</div>
<Carousel
key={isRTL ? "rtl" : "ltr"}
className="w-full mt-6"
setApi={setApi}
opts={{
align: "start",
containScroll: "trim",
direction: isRTL ? "rtl" : "ltr",
}}
>
<CarouselContent className="-ml-3 md:-ml-[30px]">
{cateData.map((item) => (
<CarouselItem
key={item?.id}
className="basis-1/3 sm:basis-1/4 md:basis-1/5 lg:basis-[16.66%] xl:basis-[12.5%] 2xl:basis-[11.11%] md:pl-[30px]"
>
<PopularCategoryCard item={item} />
</CarouselItem>
))}
</CarouselContent>
</Carousel>
</section>
)
);
};
export default PopularCategories;