keycloak-scim/js/libs/keycloak-masthead/src/KeycloakDropdown.tsx
2023-07-07 14:34:54 +00:00

39 lines
804 B
TypeScript

import { ReactNode, useState } from "react";
import {
Dropdown,
DropdownProps,
DropdownToggle,
KebabToggle,
} from "@patternfly/react-core";
type KeycloakDropdownProps = Omit<DropdownProps, "toggle"> & {
isKebab?: boolean;
title?: ReactNode;
dropDownItems: ReactNode[];
};
export const KeycloakDropdown = ({
isKebab = false,
title,
dropDownItems,
...rest
}: KeycloakDropdownProps) => {
const [open, setOpen] = useState(false);
return (
<Dropdown
{...rest}
isPlain
position="right"
toggle={
isKebab ? (
<KebabToggle onToggle={setOpen}>{title}</KebabToggle>
) : (
<DropdownToggle onToggle={setOpen}>{title}</DropdownToggle>
)
}
isOpen={open}
dropdownItems={dropDownItems}
/>
);
};