keycloak-scim/apps/admin-ui/src/components/keycloak-card/KeycloakCard.tsx

81 lines
1.9 KiB
TypeScript
Raw Normal View History

import {
CardActions,
CardBody,
CardFooter,
CardHeader,
CardTitle,
Dropdown,
2020-11-18 15:06:56 +00:00
Flex,
FlexItem,
KebabToggle,
Label,
} from "@patternfly/react-core";
import { ReactElement, useState } from "react";
import { To, useNavigate } from "react-router-dom-v5-compat";
import { ClickableCard } from "./ClickableCard";
import "./keycloak-card.css";
export type KeycloakCardProps = {
title: string;
dropdownItems?: ReactElement[];
labelText?: string;
labelColor?: any;
footerText?: string;
to: To;
};
export const KeycloakCard = ({
title,
dropdownItems,
labelText,
labelColor,
footerText,
to,
}: KeycloakCardProps) => {
const navigate = useNavigate();
const [isDropdownOpen, setIsDropdownOpen] = useState(false);
const onDropdownToggle = () => {
setIsDropdownOpen(!isDropdownOpen);
};
const handleCardMenuClick = (e: any) => {
e.stopPropagation();
};
return (
<ClickableCard isSelectable onClick={() => navigate(to)}>
<CardHeader>
<CardActions>
{dropdownItems && (
<Dropdown
2021-02-19 21:22:05 +00:00
data-testid={`${title}-dropdown`}
isPlain
position={"right"}
toggle={<KebabToggle onToggle={onDropdownToggle} />}
onClick={(e) => handleCardMenuClick(e)}
isOpen={isDropdownOpen}
dropdownItems={dropdownItems}
/>
)}
</CardActions>
2021-02-19 21:22:05 +00:00
<CardTitle data-testid="keycloak-card-title">{title}</CardTitle>
</CardHeader>
<CardBody />
<CardFooter>
2020-11-18 15:06:56 +00:00
<Flex>
<FlexItem className="keycloak--keycloak-card__footer">
{footerText && footerText}
</FlexItem>
<FlexItem>
{labelText && (
<Label color={labelColor || "gray"}>{labelText}</Label>
)}
</FlexItem>
</Flex>
</CardFooter>
</ClickableCard>
);
};