import {
Avatar,
AvatarProps,
Brand,
BrandProps,
DropdownItem,
PageHeader,
PageHeaderProps,
PageHeaderTools,
PageHeaderToolsGroup,
PageHeaderToolsItem,
} from "@patternfly/react-core";
import Keycloak from "keycloak-js";
import { ReactNode } from "react";
import { KeycloakDropdown } from "./KeycloakDropdown";
import { useTranslation } from "./translation/useTranslation";
import { loggedInUserName } from "./util";
import { DefaultAvatar } from "./DefaultAvatar";
type BrandLogo = BrandProps & {
onClick?: () => void;
};
type KeycloakMastheadProps = PageHeaderProps & {
brand: BrandLogo;
avatar?: AvatarProps;
features?: {
hasLogout?: boolean;
hasManageAccount?: boolean;
hasUsername?: boolean;
};
keycloak?: Keycloak;
kebabDropdownItems?: ReactNode[];
dropdownItems?: ReactNode[];
toolbarItems?: ReactNode[];
};
const KeycloakMasthead = ({
brand: { onClick: onBrandLogoClick, ...brandProps },
avatar,
features: {
hasLogout = true,
hasManageAccount = true,
hasUsername = true,
} = {},
keycloak,
kebabDropdownItems,
dropdownItems = [],
toolbarItems,
...rest
}: KeycloakMastheadProps) => {
const { t } = useTranslation();
const extraItems = [];
if (hasManageAccount) {
extraItems.push(
keycloak?.accountManagement()}
>
{t("manageAccount")}
);
}
if (hasLogout) {
extraItems.push(
keycloak?.logout()}>
{t("signOut")}
);
}
const picture = keycloak?.tokenParsed?.picture;
return (
}
logoComponent="div"
headerTools={
{toolbarItems}
{picture || avatar?.src ? (
) : (
)}
}
/>
);
};
export default KeycloakMasthead;