2022-11-03 14:06:26 +00:00
|
|
|
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";
|
2023-05-02 09:57:36 +00:00
|
|
|
import { DefaultAvatar } from "./DefaultAvatar";
|
2022-11-03 14:06:26 +00:00
|
|
|
|
|
|
|
type BrandLogo = BrandProps & {
|
2023-05-26 10:57:25 +00:00
|
|
|
href: string;
|
2022-11-03 14:06:26 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
type KeycloakMastheadProps = PageHeaderProps & {
|
|
|
|
brand: BrandLogo;
|
|
|
|
avatar?: AvatarProps;
|
|
|
|
features?: {
|
|
|
|
hasLogout?: boolean;
|
|
|
|
hasManageAccount?: boolean;
|
|
|
|
hasUsername?: boolean;
|
|
|
|
};
|
|
|
|
keycloak?: Keycloak;
|
|
|
|
kebabDropdownItems?: ReactNode[];
|
2023-05-02 09:58:56 +00:00
|
|
|
dropdownItems?: ReactNode[];
|
|
|
|
toolbarItems?: ReactNode[];
|
2022-11-03 14:06:26 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
const KeycloakMasthead = ({
|
2023-05-26 10:57:25 +00:00
|
|
|
brand: { href: brandHref, ...brandProps },
|
2022-11-03 14:06:26 +00:00
|
|
|
avatar,
|
|
|
|
features: {
|
|
|
|
hasLogout = true,
|
|
|
|
hasManageAccount = true,
|
|
|
|
hasUsername = true,
|
|
|
|
} = {},
|
|
|
|
keycloak,
|
|
|
|
kebabDropdownItems,
|
2023-05-02 09:58:56 +00:00
|
|
|
dropdownItems = [],
|
|
|
|
toolbarItems,
|
2022-11-03 14:06:26 +00:00
|
|
|
...rest
|
|
|
|
}: KeycloakMastheadProps) => {
|
|
|
|
const { t } = useTranslation();
|
|
|
|
const extraItems = [];
|
|
|
|
if (hasManageAccount) {
|
|
|
|
extraItems.push(
|
|
|
|
<DropdownItem
|
|
|
|
key="manageAccount"
|
|
|
|
onClick={() => keycloak?.accountManagement()}
|
|
|
|
>
|
|
|
|
{t("manageAccount")}
|
2023-07-11 14:03:21 +00:00
|
|
|
</DropdownItem>,
|
2022-11-03 14:06:26 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
if (hasLogout) {
|
|
|
|
extraItems.push(
|
|
|
|
<DropdownItem key="signOut" onClick={() => keycloak?.logout()}>
|
|
|
|
{t("signOut")}
|
2023-07-11 14:03:21 +00:00
|
|
|
</DropdownItem>,
|
2022-11-03 14:06:26 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
const picture = keycloak?.tokenParsed?.picture;
|
|
|
|
return (
|
|
|
|
<PageHeader
|
|
|
|
{...rest}
|
2023-05-26 10:57:25 +00:00
|
|
|
logo={<Brand {...brandProps} />}
|
|
|
|
logoProps={{ href: brandHref }}
|
2022-11-03 14:06:26 +00:00
|
|
|
headerTools={
|
|
|
|
<PageHeaderTools>
|
|
|
|
<PageHeaderToolsGroup>
|
|
|
|
<PageHeaderToolsItem
|
|
|
|
visibility={{
|
|
|
|
md: "hidden",
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<KeycloakDropdown
|
2023-07-07 14:34:54 +00:00
|
|
|
data-testid="options-kebab"
|
2022-11-03 14:06:26 +00:00
|
|
|
isKebab
|
|
|
|
dropDownItems={[
|
|
|
|
...(kebabDropdownItems || dropdownItems),
|
|
|
|
extraItems,
|
|
|
|
]}
|
|
|
|
/>
|
|
|
|
</PageHeaderToolsItem>
|
2023-05-02 09:58:56 +00:00
|
|
|
<PageHeaderToolsItem>{toolbarItems}</PageHeaderToolsItem>
|
2022-11-03 14:06:26 +00:00
|
|
|
<PageHeaderToolsItem
|
|
|
|
visibility={{
|
|
|
|
default: "hidden",
|
|
|
|
md: "visible",
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<KeycloakDropdown
|
2023-07-07 14:34:54 +00:00
|
|
|
data-testid="options"
|
2022-11-03 14:06:26 +00:00
|
|
|
dropDownItems={[...dropdownItems, extraItems]}
|
|
|
|
title={
|
|
|
|
hasUsername && keycloak
|
|
|
|
? loggedInUserName(keycloak, t)
|
|
|
|
: undefined
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
</PageHeaderToolsItem>
|
|
|
|
</PageHeaderToolsGroup>
|
2023-05-02 09:57:36 +00:00
|
|
|
{picture || avatar?.src ? (
|
|
|
|
<Avatar {...{ src: picture, alt: t("avatar"), ...avatar }} />
|
|
|
|
) : (
|
|
|
|
<DefaultAvatar {...avatar} />
|
|
|
|
)}
|
2022-11-03 14:06:26 +00:00
|
|
|
</PageHeaderTools>
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default KeycloakMasthead;
|