aboutsummaryrefslogtreecommitdiff
path: root/src/client/views/presentationview/PresentationModeMenu.tsx
blob: b3edeb1e259bb5397e20ad4f15e46d624b6f554e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
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<PresModeMenuProps> {

    @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<HTMLDivElement> = 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 <button title="Reset Presentation" className="presMenu-button" onClick={this.props.startOrResetPres}><FontAwesomeIcon icon="stop" /></button>;
        } else {
            return <button title="Start Presentation From Start" className="presMenu-button" onClick={this.props.startOrResetPres}><FontAwesomeIcon icon="play" /></button>;
        }
    }

    render() {
        return (
            <div className="presMenu-cont" onPointerEnter={this.pointerEntered} ref={this._mainCont}
                style={{ right: this._right, top: this._top, opacity: this._opacity, transition: this._transition, transitionDelay: this._transitionDelay }}>
                <button title="Back" className="presMenu-button" onClick={this.props.back}><FontAwesomeIcon icon={"arrow-left"} /></button>
                {this.renderPlayPauseButton()}
                <button title="Next" className="presMenu-button" onClick={this.props.next}><FontAwesomeIcon icon={"arrow-right"} /></button>
                <button className="presMenu-button" title="Close Presentation Menu" onClick={this.props.closePresMode}>
                    <FontAwesomeIcon icon="times" size="lg" />
                </button>
                <div className="presMenu-dragger" onPointerDown={this.dragStart} style={{ width: "20px" }} />
            </div >
        );
    }




}