aboutsummaryrefslogtreecommitdiff
path: root/src/client/views/nodes/RecordingBox/RecordingBox.tsx
blob: 0ff7c429248f00d69a20481dbb46d13a78bc8de5 (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
import { action, observable } from "mobx";
import { observer } from "mobx-react";
import * as React from "react";
import { VideoField } from "../../../../fields/URLField";
import { Upload } from "../../../../server/SharedMediaTypes";
import { ViewBoxBaseComponent } from "../../DocComponent";
import { FieldView } from "../FieldView";
import { VideoBox } from "../VideoBox";
import { RecordingView } from './RecordingView';
import { DocumentType } from "../../../documents/DocumentTypes";
import { Presentation } from "../../../util/TrackMovements";
import { Doc } from "../../../../fields/Doc";
import { Id } from "../../../../fields/FieldSymbols";


@observer
export class RecordingBox extends ViewBoxBaseComponent() {

      public static LayoutString(fieldKey: string) { return FieldView.LayoutString(RecordingBox, fieldKey); }

      private _ref: React.RefObject<HTMLDivElement> = React.createRef();

      constructor(props: any) {
        super(props);
      }

      componentDidMount() {
            Doc.SetNativeWidth(this.dataDoc, 1280);
            Doc.SetNativeHeight(this.dataDoc, 720);
      }

      @observable result: Upload.AccessPathInfo | undefined = undefined
      @observable videoDuration: number | undefined = undefined

      @action
      setVideoDuration = (duration: number) => {
            this.videoDuration = duration
      }

      @action
      setResult = (info: Upload.AccessPathInfo, presentation?: Presentation) => {
            this.result = info
            this.dataDoc.type = DocumentType.VID;
            this.dataDoc[this.fieldKey + "-duration"] = this.videoDuration;

            this.dataDoc.layout = VideoBox.LayoutString(this.fieldKey);
            this.dataDoc[this.props.fieldKey] = new VideoField(this.result.accessPaths.client);
            this.dataDoc[this.fieldKey + "-recorded"] = true;
            // stringify the presentation and store it
            presentation?.movements && (this.dataDoc[this.fieldKey + "-presentation"] = JSON.stringify(presentation));
      }

      render() {
            return <div className="recordingBox" ref={this._ref}>
                  {!this.result && <RecordingView setResult={this.setResult} setDuration={this.setVideoDuration} id={this.rootDoc.proto?.[Id] || ''} />}
            </div>;
      }
}