import React from "react"; import { Popover } from "./Popover"; import { render, unmountComponentAtNode } from "react-dom"; import "./ContextMenu.css"; type ContextMenuOption = { label: string; action(): void; }; type Props = { options: ContextMenuOption[]; onCloseRequest?(): void; top: number; left: number; }; function ContextMenu({ options, onCloseRequest, top, left }: Props) { return ( ); } function ContextMenuOption({ label, action }: ContextMenuOption) { return ( ); } let contextMenuNode: HTMLDivElement; function getContextMenuNode(): HTMLDivElement { if (contextMenuNode) { return contextMenuNode; } const div = document.createElement("div"); document.body.appendChild(div); return (contextMenuNode = div); } type ContextMenuParams = { options: (ContextMenuOption | false | null | undefined)[]; top: number; left: number; }; function handleClose() { unmountComponentAtNode(getContextMenuNode()); } export default { push(params: ContextMenuParams) { const options = Array.of(); params.options.forEach(option => { if (option) { options.push(option); } }); if (options.length) { render( , getContextMenuNode() ); } } };