mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com> Signed-off-by: Jim Ehrismann <jehrismann@mirantis.com>
95 lines
2.7 KiB
TypeScript
95 lines
2.7 KiB
TypeScript
/**
|
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
*/
|
|
|
|
import styles from "./hotbar-icon.module.scss";
|
|
|
|
import React, { useState } from "react";
|
|
|
|
import type { CatalogEntityContextMenu } from "../../../common/catalog";
|
|
import { cssNames } from "../../utils";
|
|
import { ConfirmDialog } from "../confirm-dialog";
|
|
import { Menu, MenuItem } from "../menu";
|
|
import { observer } from "mobx-react";
|
|
import { Avatar, AvatarProps } from "../avatar";
|
|
import { Icon } from "../icon";
|
|
import { Tooltip } from "../tooltip";
|
|
|
|
export interface Props extends AvatarProps {
|
|
uid: string;
|
|
source: string;
|
|
material?: string;
|
|
onMenuOpen?: () => void;
|
|
active?: boolean;
|
|
menuItems?: CatalogEntityContextMenu[];
|
|
disabled?: boolean;
|
|
tooltip?: string;
|
|
}
|
|
|
|
function onMenuItemClick(menuItem: CatalogEntityContextMenu) {
|
|
if (menuItem.confirm) {
|
|
ConfirmDialog.open({
|
|
okButtonProps: {
|
|
primary: false,
|
|
accent: true,
|
|
},
|
|
ok: () => {
|
|
menuItem.onClick();
|
|
},
|
|
message: menuItem.confirm.message,
|
|
});
|
|
} else {
|
|
menuItem.onClick();
|
|
}
|
|
}
|
|
|
|
export const HotbarIcon = observer(({ menuItems = [], size = 40, tooltip, ...props }: Props) => {
|
|
const { uid, title, src, material, active, className, source, disabled, onMenuOpen, onClick, children, ...rest } = props;
|
|
const id = `hotbarIcon-${uid}`;
|
|
const [menuOpen, setMenuOpen] = useState(false);
|
|
|
|
const toggleMenu = () => {
|
|
setMenuOpen(!menuOpen);
|
|
};
|
|
|
|
return (
|
|
<div className={cssNames(styles.HotbarIcon, className, { [styles.contextMenuAvailable]: menuItems.length > 0 })}>
|
|
{tooltip && <Tooltip targetId={id}>{tooltip}</Tooltip>}
|
|
<Avatar
|
|
{...rest}
|
|
id={id}
|
|
title={title}
|
|
colorHash={`${title}-${source}`}
|
|
className={cssNames(styles.avatar, { [styles.active]: active, [styles.hasImage]: !!src })}
|
|
disabled={disabled}
|
|
size={size}
|
|
src={src}
|
|
onClick={(event) => !disabled && onClick?.(event)}
|
|
>
|
|
{material && <Icon material={material} />}
|
|
</Avatar>
|
|
{children}
|
|
<Menu
|
|
usePortal
|
|
htmlFor={id}
|
|
isOpen={menuOpen}
|
|
toggleEvent="contextmenu"
|
|
position={{ right: true, bottom: true }} // FIXME: position does not work
|
|
open={() => {
|
|
onMenuOpen?.();
|
|
toggleMenu();
|
|
}}
|
|
close={() => toggleMenu()}>
|
|
{
|
|
menuItems.map((menuItem) => (
|
|
<MenuItem key={menuItem.title} onClick={() => onMenuItemClick(menuItem)}>
|
|
{menuItem.title}
|
|
</MenuItem>
|
|
))
|
|
}
|
|
</Menu>
|
|
</div>
|
|
);
|
|
});
|