import { Menu, Transition } from "@headlessui/react"; import { Fragment, useState } from "react"; import { ChevronRightIcon, ChevronLeftIcon } from "@heroicons/react/20/solid"; import { ChevronDownIcon } from "@heroicons/react/24/outline"; type MultiLevelDropdownProps = { label: string; options: { id: string; label: string; value: any; selected?: boolean; children?: { id: string; label: string | JSX.Element; value: any; selected?: boolean; }[]; }[]; onSelect: (value: any) => void; direction?: "left" | "right"; }; export const MultiLevelDropdown: React.FC = ({ label, options, onSelect, direction = "right", }) => { const [openChildFor, setOpenChildFor] = useState(null); return ( {({ open }) => ( <>
setOpenChildFor(null)} className={`group flex items-center justify-between gap-2 rounded-md border px-3 py-1.5 text-xs shadow-sm duration-300 focus:border-indigo-500 focus:outline-none focus:ring-1 focus:ring-indigo-500 ${ open ? "bg-gray-100 text-gray-900" : "text-gray-500" }`} > {label}
{options.map((option) => (
{ if (option.children) { if (openChildFor === option.id) { e.stopPropagation(); e.preventDefault(); setOpenChildFor(null); } else { e.stopPropagation(); e.preventDefault(); setOpenChildFor(option.id); } } else { onSelect(option.value); } }} className="w-full" > {({ active }) => ( <>
{direction === "left" && option.children && (
)}
{option.children && option.id === openChildFor && (
{option.children.map((child) => ( { onSelect(child.value); }} className={({ active }) => `${ active || option.selected ? "bg-gray-100" : "text-gray-900" } flex w-full items-center rounded px-1 py-1.5 capitalize` } > {child.label} ))}
)}
))}
)}
); };