import * as React from "react"; import { observable, action, runInAction } from "mobx"; import { observer } from "mobx-react"; import "./TimelineMenu.scss"; import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"; import { faChartLine, faRoad, faClipboard, faPen, faTrash, faTable } from "@fortawesome/free-solid-svg-icons"; import { Utils } from "../../../Utils"; @observer export class TimelineMenu extends React.Component { public static Instance: TimelineMenu; @observable private _opacity = 0; @observable private _x = 0; @observable private _y = 0; @observable private _currentMenu: JSX.Element[] = []; constructor(props: Readonly<{}>) { super(props); TimelineMenu.Instance = this; } @action openMenu = (x?: number, y?: number) => { this._opacity = 1; x ? this._x = x : this._x = 0; y ? this._y = y : this._y = 0; } @action closeMenu = () => { this._opacity = 0; this._currentMenu = []; this._x = -1000000; this._y = -1000000; } @action addItem = (type: "input" | "button", title: string, event: (e: any, ...args: any[]) => void) => { if (type === "input") { const inputRef = React.createRef(); let text = ""; this._currentMenu.push(
{ e.stopPropagation(); text = e.target.value; }} onKeyDown={(e) => { if (e.keyCode === 13) { event(text); this.closeMenu(); e.stopPropagation(); } }} />
); } else if (type === "button") { this._currentMenu.push(

{ e.preventDefault(); e.stopPropagation(); event(e); this.closeMenu(); }}>{title}

); } } @action addMenu = (title: string) => { this._currentMenu.unshift(

{title}

); } render() { return (
{this._currentMenu}
); } }