import React = require("react"); import { observable, action, runInAction } from "mobx"; import "./PresentationModeMenu.scss"; import { observer } from "mobx-react"; import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"; export interface PresModeMenuProps { next: () => void; back: () => void; presStatus: boolean; startOrResetPres: () => void; closePresMode: () => void; } @observer export default class PresModeMenu extends React.Component { @observable private _top: number = 20; @observable private _right: number = 0; @observable private _opacity: number = 1; @observable private _transition: string = "opacity 0.5s"; @observable private _transitionDelay: string = ""; //@observable private Pinned: boolean = false; private _mainCont: React.RefObject = React.createRef(); @action pointerEntered = (e: React.PointerEvent) => { this._transition = "opacity 0.1s"; this._transitionDelay = ""; this._opacity = 1; } @action dragging = (e: PointerEvent) => { this._right -= e.movementX; this._top += e.movementY; e.stopPropagation(); e.preventDefault(); } dragEnd = (e: PointerEvent) => { document.removeEventListener("pointermove", this.dragging); document.removeEventListener("pointerup", this.dragEnd); e.stopPropagation(); e.preventDefault(); } dragStart = (e: React.PointerEvent) => { document.removeEventListener("pointermove", this.dragging); document.addEventListener("pointermove", this.dragging); document.removeEventListener("pointerup", this.dragEnd); document.addEventListener("pointerup", this.dragEnd); let clientRect = this._mainCont.current!.getBoundingClientRect(); // runInAction(() => this._left = (clientRect.width - e.nativeEvent.offsetX) + clientRect.left); // runInAction(() => this._top = e.nativeEvent.offsetY); e.stopPropagation(); e.preventDefault(); } renderPlayPauseButton = () => { if (this.props.presStatus) { return ; } else { return ; } } render() { return (
{this.renderPlayPauseButton()}
); } }