101 lines
3.2 KiB
TypeScript
101 lines
3.2 KiB
TypeScript
'use client';
|
|
|
|
import React from 'react';
|
|
import { useCollections } from '@/hooks/use-shopify-collections';
|
|
import CollectionCard from './collection-card';
|
|
|
|
const Collections: React.FC = () => {
|
|
const { collections, loading, error, refetch } = useCollections(20);
|
|
|
|
if (loading) {
|
|
return (
|
|
<div className="py-16">
|
|
<div className="container mx-auto px-4">
|
|
<h2 className="text-4xl font-medium tracking-tight text-center mb-12 text-gray-900 font-heading">
|
|
Our Collections
|
|
</h2>
|
|
|
|
{/* Loading Skeleton */}
|
|
<div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-8">
|
|
{Array.from({ length: 6 }).map((_, index) => (
|
|
<div key={index} className="animate-pulse">
|
|
<div className="aspect-video bg-gray-200"></div>
|
|
<div className="mt-3 h-4 w-1/3 bg-gray-200 rounded"></div>
|
|
</div>
|
|
))}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
if (error) {
|
|
return (
|
|
<div className="py-16">
|
|
<div className="container mx-auto px-4 text-center">
|
|
<h2 className="text-4xl font-medium tracking-tight mb-8 text-gray-900 font-heading">
|
|
Our Collections
|
|
</h2>
|
|
|
|
<div className="bg-red-50 border border-red-200 rounded-md p-8 max-w-md mx-auto">
|
|
<i className="ri-error-warning-line text-4xl text-red-500 mb-4"></i>
|
|
<h3 className="text-lg font-medium text-red-800 mb-2">
|
|
Failed to Load Collections
|
|
</h3>
|
|
<p className="text-red-600 mb-4">
|
|
{error}
|
|
</p>
|
|
<button
|
|
onClick={() => refetch()}
|
|
className="bg-red-600 text-white px-6 py-2 rounded-md hover:bg-red-700 transition-colors"
|
|
>
|
|
Try Again
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
if (collections.length === 0) {
|
|
return (
|
|
<div className="py-16">
|
|
<div className="container mx-auto px-4 text-center">
|
|
<h2 className="text-4xl font-medium tracking-tight mb-8 text-gray-900 font-heading">
|
|
Our Collections
|
|
</h2>
|
|
|
|
<div className="bg-gray-50 border border-gray-200 rounded-md p-8 max-w-md mx-auto">
|
|
<i className="ri-folder-line text-4xl text-gray-400 mb-4"></i>
|
|
<h3 className="text-lg font-medium text-gray-600 mb-2">
|
|
No Collections Found
|
|
</h3>
|
|
<p className="text-gray-500">
|
|
Check back later or configure your Shopify store connection.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<div className="py-16">
|
|
<div className="container mx-auto px-4">
|
|
<h2 className="text-4xl font-medium tracking-tight text-center mb-12 text-gray-900 font-heading">
|
|
Our Collections
|
|
</h2>
|
|
|
|
{/* Collections Grid */}
|
|
<div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-8">
|
|
{collections.map((collection) => (
|
|
<CollectionCard key={collection.id} collection={collection} />
|
|
))}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default Collections;
|