import React, { memo, useCallback } from "react";
import { Avatar, Chip } from "@heroui/react";
import { Star, Clock } from "lucide-react";
import { Product } from "@/types/ApiResponse";
import { useRouter } from "next/router";

type Props = {
  product: Product;
  onProductClick: (product: Product) => void;
  formatDeliveryTime: (time: number | null) => string;
  searchQuery: string;
  isActive?: boolean;
  onMouseEnter?: () => void;
  onClose: () => void;
};

const SearchProductCard: React.FC<Props> = ({
  product,
  onProductClick,
  formatDeliveryTime,
  searchQuery,
  isActive = false,
  onMouseEnter,
  onClose = () => {},
}) => {
  const handlePress = useCallback(() => {
    onProductClick(product);
  }, [product, onProductClick]);
  const router = useRouter();

  const highlightText = (text: string, query: string) => {
    if (!query) return text;
    const parts = text.split(new RegExp(`(${query})`, "gi"));
    return parts.map((part, i) =>
      part.toLowerCase() === query.toLowerCase() ? (
        <span key={i} className="font-semibold text-primary">
          {part}
        </span>
      ) : (
        part
      )
    );
  };

  return (
    <div
      onClick={handlePress}
      onMouseEnter={onMouseEnter}
      tabIndex={0}
      onKeyDown={(e) => {
        if (e.key === "Enter") handlePress();
      }}
      className={`flex items-center gap-3 px-4 py-3 hover:bg-default-100 cursor-pointer transition-colors border-b border-divider last:border-b-0 ${
        isActive ? "bg-default-100" : ""
      }`}
    >
      <Avatar
        src={product.main_image}
        alt={product.title}
        size="md"
        radius="sm"
        classNames={{ base: "w-12 h-12 shrink-0" }}
      />
      <div className="flex-1 min-w-0">
        <div className="font-medium text-sm mb-1">
          {highlightText(product.title, searchQuery)}
        </div>
        <div className="flex items-center gap-2 flex-wrap">
          {product.category_name && (
            <Chip
              size="sm"
              variant="flat"
              color="default"
              className="text-xs h-5"
              radius="sm"
              title={product.category_name}
              onClick={(e) => {
                e.preventDefault();
                e.stopPropagation();
                router.push(`/categories/${product.category}`);
                onClose();
              }}
            >
              {product.category_name}
            </Chip>
          )}
          {product.brand_name && (
            <Chip
              size="sm"
              variant="flat"
              color="primary"
              className="text-xs h-5"
              radius="sm"
              title={product.brand_name}
              onClick={(e) => {
                e.preventDefault();
                e.stopPropagation();
                router.push(`/brands/${product.brand}`);
                onClose();
              }}
            >
              {product.brand_name}
            </Chip>
          )}
        </div>
      </div>
      <div className="flex flex-col items-end gap-1 text-xs text-foreground/60">
        <div className="flex items-center gap-1">
          <Star className="w-3 h-3 text-yellow-500 fill-current" />
          <span>{product.ratings}</span>
          <span>({product.rating_count})</span>
        </div>
        <div className="flex items-center gap-1">
          <Clock className="w-3 h-3" />
          <span>{formatDeliveryTime(product.estimated_delivery_time)}</span>
        </div>
      </div>
    </div>
  );
};

const Memo = memo(SearchProductCard);
Memo.displayName = "SearchProductCard";

export default Memo;
