2024-11-14 21:21:00 +07:00

66 lines
1.7 KiB
TypeScript

// @ts-nocheck
'use client';
import Image from 'next/image';
import React, { useState } from 'react';
import { cn } from '../../lib/utils';
export const Card = React.memo(
({
card,
index,
hovered,
setHovered,
}: {
card: any;
index: number;
hovered: number | null;
setHovered: React.Dispatch<React.SetStateAction<number | null>>;
}) => (
<div
onMouseEnter={() => setHovered(index)}
onMouseLeave={() => setHovered(null)}
className={cn(
'relative h-60 w-full overflow-hidden rounded-lg bg-gray-100 transition-all duration-300 ease-out md:h-96 dark:bg-neutral-900',
hovered !== null && hovered !== index && 'scale-[0.98] blur-sm',
)}
>
<Image src={card.src} alt={card.title} fill className='absolute inset-0 object-cover' />
<div
className={cn(
'absolute inset-0 flex items-end bg-black/50 px-4 py-8 transition-opacity duration-300',
hovered === index ? 'opacity-100' : 'opacity-0',
)}
>
<div className='bg-gradient-to-b from-neutral-50 to-neutral-200 bg-clip-text text-xl font-medium text-transparent md:text-2xl'>
{card.title}
</div>
</div>
</div>
),
);
Card.displayName = 'Card';
type Card = {
title: string;
src: string;
};
export function FocusCards({ cards }: { cards: Card[] }) {
const [hovered, setHovered] = useState<number | null>(null);
return (
<div className='mx-auto grid w-full max-w-5xl grid-cols-1 gap-10 md:grid-cols-3 md:px-8'>
{cards.map((card, index) => (
<Card
key={card.title}
card={card}
index={index}
hovered={hovered}
setHovered={setHovered}
/>
))}
</div>
);
}