/** * Copyright (c) OpenLens Authors. All rights reserved. * Licensed under MIT License. See LICENSE in root directory for more information. */ import React from "react"; import { cssNames, hasDefiniteField } from "../../utils"; import type { MenuActionsProps } from "../menu/menu-actions"; import { MenuActions } from "../menu/menu-actions"; import type { CatalogEntity, CatalogEntityContextMenu } from "../../api/catalog-entity"; import { observer } from "mobx-react"; import { observable } from "mobx"; import { MenuItem } from "../menu"; import { Icon } from "../icon"; import { HotbarToggleMenuItem } from "./hotbar-toggle-menu-item"; import type { VisitEntityContextMenu } from "../../../common/catalog/visit-entity-context-menu.injectable"; import visitEntityContextMenuInjectable from "../../../common/catalog/visit-entity-context-menu.injectable"; import { withInjectables } from "@ogre-tools/injectable-react"; import type { Navigate } from "../../navigation/navigate.injectable"; import navigateInjectable from "../../navigation/navigate.injectable"; import type { NormalizeCatalogEntityContextMenu } from "../../catalog/normalize-menu-item.injectable"; import normalizeCatalogEntityContextMenuInjectable from "../../catalog/normalize-menu-item.injectable"; export interface CatalogEntityDrawerMenuProps extends MenuActionsProps { entity: Entity; } interface Dependencies { normalizeMenuItem: NormalizeCatalogEntityContextMenu; navigate: Navigate; visitEntityContextMenu: VisitEntityContextMenu; } @observer class NonInjectedCatalogEntityDrawerMenu extends React.Component & Dependencies> { private readonly menuItems = observable.array(); componentDidMount() { this.props.visitEntityContextMenu(this.props.entity, { menuItems: this.menuItems, navigate: this.props.navigate, }); } getMenuItems(entity: T): React.ReactChild[] { if (!entity) { return []; } const items = this.menuItems .map(this.props.normalizeMenuItem) .filter(hasDefiniteField("icon")) .map(menuItem => ( )); items.push( )} removeContent={( )} />, ); return items; } render() { const { className, entity, ...menuProps } = this.props; if (!this.menuItems.length || !entity.isEnabled()) { return null; } return ( {this.getMenuItems(entity)} ); } } export const CatalogEntityDrawerMenu = withInjectables>(NonInjectedCatalogEntityDrawerMenu, { getProps: (di, props) => ({ ...props, visitEntityContextMenu: di.inject(visitEntityContextMenuInjectable), normalizeMenuItem: di.inject(normalizeCatalogEntityContextMenuInjectable), navigate: di.inject(navigateInjectable), }), }) as (props: CatalogEntityDrawerMenuProps) => JSX.Element;