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 (
e.preventDefault()}>
{options.map((option, idx) => (
-
))}
);
}
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(),
);
}
},
};