fixed favorites api
This commit is contained in:
@@ -5,8 +5,12 @@ import InfiniteScroll from "react-infinite-scroll-component";
|
||||
import HeroCarousel from "./Carousel";
|
||||
import CategoryGrid from "./CategoryGrid";
|
||||
import CollectionSection from "./ProductGrid";
|
||||
import { useCategories, useCarousels, useCollections } from "@/lib/hooks";
|
||||
|
||||
import {
|
||||
useCategories,
|
||||
useCarousels,
|
||||
useCollections,
|
||||
useFavorites,
|
||||
} from "@/lib/hooks";
|
||||
|
||||
export default function HomePage() {
|
||||
const locale = useLocale();
|
||||
@@ -19,15 +23,18 @@ export default function HomePage() {
|
||||
isLoading: categoriesLoading,
|
||||
isError: categoriesError,
|
||||
} = useCategories();
|
||||
|
||||
|
||||
const { data: carousels, isLoading: carouselsLoading } = useCarousels();
|
||||
|
||||
|
||||
const {
|
||||
data: collections,
|
||||
isLoading: collectionsLoading,
|
||||
isError: collectionsError,
|
||||
} = useCollections();
|
||||
|
||||
// CRITICAL: Prefetch favorites on mount to avoid loading states
|
||||
const { isLoading: favoritesLoading } = useFavorites();
|
||||
|
||||
useEffect(() => setMounted(true), []);
|
||||
|
||||
const loadMore = () => {
|
||||
@@ -48,8 +55,12 @@ export default function HomePage() {
|
||||
const visibleCollections = collections?.slice(0, visibleCount) || [];
|
||||
const hasMore = collections ? visibleCount < collections.length : false;
|
||||
|
||||
// Show loading indicator while favorites are being fetched
|
||||
const showFavoritesLoading =
|
||||
favoritesLoading && !categoriesLoading && !collectionsLoading;
|
||||
|
||||
return (
|
||||
<div className="px-2 md:px-4 lg:px-4 pt-4 pb-12 space-y-8 max-w-[1504px] mx-auto">
|
||||
<div className="px-2 md:px-4 lg:px-6 pt-4 pb-12 space-y-8 max-w-[1504px] mx-auto">
|
||||
{!carouselsLoading && carouselItems.length > 0 && (
|
||||
<HeroCarousel items={carouselItems} />
|
||||
)}
|
||||
@@ -62,6 +73,13 @@ export default function HomePage() {
|
||||
title={t("categories")}
|
||||
/>
|
||||
|
||||
{showFavoritesLoading && (
|
||||
<div className="text-center py-4">
|
||||
<div className="inline-block h-6 w-6 animate-spin rounded-full border-2 border-solid border-blue-600 border-r-transparent"></div>
|
||||
<p className="text-gray-500 text-sm mt-2">Loading favorites...</p>
|
||||
</div>
|
||||
)}
|
||||
|
||||
{collectionsError ? (
|
||||
<section className="bg-white rounded-2xl shadow-sm p-6">
|
||||
<p className="text-red-600">
|
||||
@@ -115,4 +133,4 @@ export default function HomePage() {
|
||||
)}
|
||||
</div>
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user