import Link from "next/link"; import React from "react"; import { useFavorites } from "@/contexts/FavoritesContext"; interface CatalogProductCardProps { image: string; discount: string; price: string; oldPrice: string; title: string; brand: string; articleNumber?: string; brandName?: string; artId?: string; productId?: string; offerKey?: string; currency?: string; priceElement?: React.ReactNode; // Элемент для отображения цены (например, скелетон) onAddToCart?: (e: React.MouseEvent) => void | Promise; } const CatalogProductCard: React.FC = ({ image, discount, price, oldPrice, title, brand, articleNumber, brandName, artId, productId, offerKey, currency = 'RUB', priceElement, onAddToCart, }) => { const { addToFavorites, removeFromFavorites, isFavorite, favorites } = useFavorites(); // Обрабатываем пустое изображение - используем SVG-заглушку вместо мокап-фотки const displayImage = image || ''; // Создаем ссылку на card с параметрами товара const cardUrl = articleNumber && brandName ? `/card?article=${encodeURIComponent(articleNumber)}&brand=${encodeURIComponent(brandName)}${artId ? `&artId=${artId}` : ''}` : '/card'; // Fallback на card если нет данных // Проверяем, есть ли товар в избранном const isItemFavorite = isFavorite(productId, offerKey, articleNumber, brandName || brand); // Обработчик клика по сердечку const handleFavoriteClick = (e: React.MouseEvent) => { e.preventDefault(); e.stopPropagation(); // Извлекаем цену как число const numericPrice = parseFloat(price.replace(/[^\d.,]/g, '').replace(',', '.')) || 0; if (isItemFavorite) { // Находим товар в избранном по правильному ID const favoriteItem = favorites.find((fav: any) => { // Проверяем по разным комбинациям идентификаторов if (productId && fav.productId === productId) return true; if (offerKey && fav.offerKey === offerKey) return true; if (fav.article === articleNumber && fav.brand === (brandName || brand)) return true; return false; }); if (favoriteItem) { removeFromFavorites(favoriteItem.id); } } else { // Добавляем в избранное addToFavorites({ productId, offerKey, name: title, brand: brandName || brand, article: articleNumber || '', price: numericPrice, currency, image }); } }; // Обработчик клика по кнопке "Купить" const handleBuyClick = (e: React.MouseEvent) => { if (onAddToCart) { onAddToCart(e); } else { // Fallback - переходим на страницу товара window.location.href = cardUrl; } }; return (
{/* Делаем картинку и контент кликабельными для перехода на card */}
{discount}
{priceElement ? (
{priceElement}
) : (
{price}
)}
{oldPrice}
{title}
{brand}
{/* Обновляем кнопку купить */}
Купить
); }; export default CatalogProductCard;