'use client';

import clsx from 'clsx';
import { Menu } from 'lib/shopify/types';
import Link from 'next/link';
import { usePathname } from 'next/navigation';
import { useEffect, useState } from 'react';

const FooterMenuItem = ({ item }: { item: Menu }) => {
  const pathname = usePathname();
  const [active, setActive] = useState(pathname === item.path);

  useEffect(() => {
    setActive(pathname === item.path);
  }, [pathname, item.path]);

  return (
    <li>
      <Link
        href={item.path}
        className={clsx(
          'block py-2 text-lg underline-offset-4 hover:underline md:inline-block md:text-sm',
          {
            'text-black dark:text-neutral-300': active
          }
        )}
      >
        {item.title}
      </Link>
    </li>
  );
};

function FooterMenu({ menu }: { menu: Menu[] }) {
  if (!menu.length) return null;

  return (
    <ul>
      {menu.map((item: Menu) => {
        return <FooterMenuItem key={item.title} item={item} />;
      })}
    </ul>
  );
}

export default function FooterMenuGrid({ menu }: { menu: Menu[] }) {
  if (!menu.length) return null;

  return (
    <nav className="ml-2 flex lg:ml-auto">
      <div className="grid w-full grid-cols-2 gap-0 md:grid-cols-3 lg:gap-4">
        {menu.map((item) => (
          <div key={item.title}>
            <span className="text-primary">{item.title}</span>
            <FooterMenu menu={item.items} />
          </div>
        ))}
      </div>
    </nav>
  );
}