'use client'; import React, { useState, useEffect } from 'react'; import ProductCard from './product-card'; import { getProducts } from '@/hooks/use-shopify-products'; import { Button } from '@/components/ui/button'; import { Spinner } from '@/components/ui/spinner'; interface ProductImage { url: string; altText?: string; } interface ProductPrice { amount: string; currencyCode: string; } interface ProductVariant { id: string; title: string; price: ProductPrice; availableForSale: boolean; } interface Product { id: string; title: string; description?: string; handle: string; images: { edges: Array<{ node: ProductImage; }>; }; priceRange: { minVariantPrice: ProductPrice; }; compareAtPriceRange?: { minVariantPrice: ProductPrice; }; variants: { edges: Array<{ node: ProductVariant; }>; }; } interface ProductsProps { title?: string; limit?: number; showLoadMore?: boolean; } const Products: React.FC = ({ title = "Our Products", limit = 12, showLoadMore = true }) => { const [products, setProducts] = useState([]); const [loading, setLoading] = useState(true); const [error, setError] = useState(null); const [loadingMore, setLoadingMore] = useState(false); const [hasMoreProducts, setHasMoreProducts] = useState(true); const fetchProducts = async (currentProducts: Product[] = [], loadMore = false) => { try { if (loadMore) { setLoadingMore(true); } else { setLoading(true); setError(null); } const newProducts = await getProducts({ first: limit, sortKey: 'CREATED_AT', reverse: true }); if (loadMore) { // Filter out products that already exist const existingIds = new Set(currentProducts.map(p => p.id)); const uniqueNewProducts = newProducts.filter(p => !existingIds.has(p.id)); if (uniqueNewProducts.length === 0) { setHasMoreProducts(false); } else { setProducts(prev => [...prev, ...uniqueNewProducts]); } } else { setProducts(newProducts); setHasMoreProducts(newProducts.length === limit); } } catch (err) { console.error('Error fetching products:', err); setError(err instanceof Error ? err.message : 'Failed to load products'); } finally { setLoading(false); setLoadingMore(false); } }; useEffect(() => { fetchProducts(); }, [limit]); const handleAddToCart = async (product: Product) => { // Here you would typically integrate with cart functionality console.log('Adding to cart:', product); }; const handleLoadMore = () => { if (!loadingMore && hasMoreProducts) { fetchProducts(products, true); } }; if (loading) { return (

{title}

{/* Loading Skeleton */}
{Array.from({ length: 8 }).map((_, index) => (
))}
); } if (error) { return (

{title}

Failed to Load Products

{error}

); } if (products.length === 0) { return (

{title}

No Products Found

Check back later or configure your Shopify store connection.

); } return (

{title}

{/* Products Grid */}
{products.map((product) => ( ))}
{/* Load More Button */} {showLoadMore && hasMoreProducts && (
)}
); }; export default Products;