2023-08-14 13:48:38 +00:00
|
|
|
import React, { Fragment } from "react";
|
2023-08-30 11:57:49 +00:00
|
|
|
|
2023-08-14 13:48:38 +00:00
|
|
|
// headless ui
|
|
|
|
import { Popover, Transition } from "@headlessui/react";
|
2023-08-30 11:57:49 +00:00
|
|
|
// icons
|
2023-10-16 14:57:22 +00:00
|
|
|
import { ChevronDown, ChevronUp } from "lucide-react";
|
2023-08-14 13:48:38 +00:00
|
|
|
|
|
|
|
export const CustomPopover = ({
|
|
|
|
children,
|
|
|
|
label,
|
|
|
|
placeholder = "Select",
|
|
|
|
}: {
|
|
|
|
children: React.ReactNode;
|
|
|
|
label?: string;
|
|
|
|
placeholder?: string;
|
|
|
|
}) => (
|
|
|
|
<div className="relative">
|
|
|
|
<Popover className="relative">
|
|
|
|
{({ open }) => (
|
|
|
|
<>
|
2023-12-10 10:18:10 +00:00
|
|
|
<Popover.Button className={`${open ? "" : ""} relative flex items-center gap-1 outline-none ring-0`}>
|
2023-08-30 11:57:49 +00:00
|
|
|
<div className="text-sm">{label ?? placeholder}</div>
|
2023-12-10 10:18:10 +00:00
|
|
|
<div className="grid h-5 w-5 place-items-center">
|
2023-10-16 14:57:22 +00:00
|
|
|
{!open ? <ChevronDown className="h-4 w-4" /> : <ChevronUp className="h-4 w-4" />}
|
2023-08-14 13:48:38 +00:00
|
|
|
</div>
|
|
|
|
</Popover.Button>
|
|
|
|
|
|
|
|
<Transition
|
|
|
|
as={Fragment}
|
|
|
|
enter="transition ease-out duration-200"
|
|
|
|
enterFrom="opacity-0 translate-y-1"
|
|
|
|
enterTo="opacity-100 translate-y-0"
|
|
|
|
leave="transition ease-in duration-150"
|
|
|
|
leaveFrom="opacity-100 translate-y-0"
|
|
|
|
leaveTo="opacity-0 translate-y-1"
|
|
|
|
>
|
2023-08-30 11:57:49 +00:00
|
|
|
<Popover.Panel className="absolute right-0 z-10 mt-1 min-w-[150px]">
|
2024-01-30 06:46:21 +00:00
|
|
|
<div className="mt-1 overflow-hidden overflow-y-auto rounded border border-neutral-border-medium bg-neutral-component-surface-medium shadow-custom-shadow-2xs focus:outline-none">
|
2023-08-14 13:48:38 +00:00
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
</Popover.Panel>
|
|
|
|
</Transition>
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
</Popover>
|
|
|
|
</div>
|
|
|
|
);
|