2021-09-15 12:33:00 +00:00
|
|
|
import { CheckCircleIcon } from "@heroicons/react/outline";
|
|
|
|
import * as DropdownMenuPrimitive from "@radix-ui/react-dropdown-menu";
|
|
|
|
import { ComponentProps, forwardRef } from "react";
|
2021-06-05 22:53:33 +00:00
|
|
|
|
2021-09-15 12:33:00 +00:00
|
|
|
export const Dropdown = DropdownMenuPrimitive.Root;
|
2021-06-05 22:53:33 +00:00
|
|
|
|
2021-09-15 12:33:00 +00:00
|
|
|
type DropdownMenuTriggerProps = ComponentProps<typeof DropdownMenuPrimitive["Trigger"]>;
|
|
|
|
export const DropdownMenuTrigger = forwardRef<HTMLButtonElement, DropdownMenuTriggerProps>(
|
|
|
|
({ className = "", ...props }, forwardedRef) => (
|
|
|
|
<DropdownMenuPrimitive.Trigger
|
|
|
|
{...props}
|
|
|
|
className={
|
|
|
|
props.asChild
|
|
|
|
? className
|
|
|
|
: `relative inline-flex items-center px-3 py-2 ml-2 text-sm font-medium text-gray-700 bg-transparent rounded-sm hover:bg-gray-50 focus:outline-none focus:ring-2 focus:ring-offset-1 focus:bg-gray-100 focus:ring-neutral-500 group-hover:text-black ${className}`
|
2021-06-05 22:53:33 +00:00
|
|
|
}
|
2021-09-15 12:33:00 +00:00
|
|
|
ref={forwardedRef}
|
|
|
|
/>
|
|
|
|
)
|
|
|
|
);
|
|
|
|
DropdownMenuTrigger.displayName = "DropdownMenuTrigger";
|
|
|
|
|
|
|
|
type DropdownMenuContentProps = ComponentProps<typeof DropdownMenuPrimitive["Content"]>;
|
|
|
|
export const DropdownMenuContent = forwardRef<HTMLDivElement, DropdownMenuContentProps>(
|
|
|
|
({ children, ...props }, forwardedRef) => {
|
|
|
|
return (
|
|
|
|
<DropdownMenuPrimitive.Content
|
|
|
|
{...props}
|
|
|
|
className="z-10 mt-1 text-sm origin-top-right bg-white rounded-sm shadow-lg w-44 ring-1 ring-black ring-opacity-5 focus:outline-none"
|
|
|
|
ref={forwardedRef}>
|
|
|
|
{children}
|
|
|
|
<DropdownMenuPrimitive.Arrow />
|
|
|
|
</DropdownMenuPrimitive.Content>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
DropdownMenuContent.displayName = "DropdownMenuContent";
|
|
|
|
|
|
|
|
type DropdownMenuLabelProps = ComponentProps<typeof DropdownMenuPrimitive["Label"]>;
|
|
|
|
export const DropdownMenuLabel = (props: DropdownMenuLabelProps) => (
|
|
|
|
<DropdownMenuPrimitive.Label {...props} className="px-3 py-2 text-neutral-500" />
|
|
|
|
);
|
|
|
|
|
|
|
|
type DropdownMenuItemProps = ComponentProps<typeof DropdownMenuPrimitive["CheckboxItem"]>;
|
|
|
|
export const DropdownMenuItem = forwardRef<HTMLDivElement, DropdownMenuItemProps>(
|
|
|
|
({ className = "", ...props }, forwardedRef) => (
|
|
|
|
<DropdownMenuPrimitive.Item
|
|
|
|
className={`text-sm text-gray-700 hover:bg-gray-100 hover:text-gray-900 ${className}`}
|
|
|
|
{...props}
|
|
|
|
ref={forwardedRef}
|
|
|
|
/>
|
|
|
|
)
|
|
|
|
);
|
|
|
|
DropdownMenuItem.displayName = "DropdownMenuItem";
|
|
|
|
|
|
|
|
export const DropdownMenuGroup = DropdownMenuPrimitive.Group;
|
|
|
|
|
|
|
|
type DropdownMenuCheckboxItemProps = ComponentProps<typeof DropdownMenuPrimitive["CheckboxItem"]>;
|
|
|
|
export const DropdownMenuCheckboxItem = forwardRef<HTMLDivElement, DropdownMenuCheckboxItemProps>(
|
|
|
|
({ children, ...props }, forwardedRef) => {
|
|
|
|
return (
|
|
|
|
<DropdownMenuPrimitive.CheckboxItem {...props} ref={forwardedRef}>
|
|
|
|
{children}
|
|
|
|
<DropdownMenuPrimitive.ItemIndicator>
|
|
|
|
<CheckCircleIcon />
|
|
|
|
</DropdownMenuPrimitive.ItemIndicator>
|
|
|
|
</DropdownMenuPrimitive.CheckboxItem>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
DropdownMenuCheckboxItem.displayName = "DropdownMenuCheckboxItem";
|
|
|
|
|
|
|
|
export const DropdownMenuRadioGroup = DropdownMenuPrimitive.RadioGroup;
|
|
|
|
|
|
|
|
type DropdownMenuRadioItemProps = ComponentProps<typeof DropdownMenuPrimitive["RadioItem"]>;
|
|
|
|
export const DropdownMenuRadioItem = forwardRef<HTMLDivElement, DropdownMenuRadioItemProps>(
|
|
|
|
({ children, ...props }, forwardedRef) => {
|
|
|
|
return (
|
|
|
|
<DropdownMenuPrimitive.RadioItem {...props} ref={forwardedRef}>
|
|
|
|
{children}
|
|
|
|
<DropdownMenuPrimitive.ItemIndicator>
|
|
|
|
<CheckCircleIcon />
|
|
|
|
</DropdownMenuPrimitive.ItemIndicator>
|
|
|
|
</DropdownMenuPrimitive.RadioItem>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
DropdownMenuRadioItem.displayName = "DropdownMenuRadioItem";
|
|
|
|
|
|
|
|
export const DropdownMenuSeparator = DropdownMenuPrimitive.Separator;
|
|
|
|
|
|
|
|
export default Dropdown;
|