import { action } from "mobx"; import { observer } from "mobx-react"; import { NumCast } from "../../../new_fields/Types"; import { FieldView, FieldViewProps } from "../nodes/FieldView"; import { VideoBox } from "../nodes/VideoBox"; import { CollectionBaseView, CollectionRenderProps, CollectionViewType } from "./CollectionBaseView"; import { CollectionFreeFormView } from "./collectionFreeForm/CollectionFreeFormView"; import "./CollectionVideoView.scss"; import React = require("react"); @observer export class CollectionVideoView extends React.Component { private _videoBox?: VideoBox; public static LayoutString(fieldKey: string = "data", fieldExt: string = "annotations") { return FieldView.LayoutString(CollectionVideoView, fieldKey, fieldExt); } private get uIButtons() { let scaling = Math.min(1.8, this.props.ScreenToLocalTransform().Scale); let curTime = NumCast(this.props.Document.curPage); return (VideoBox._showControls ? [] : [
{"" + Math.round(curTime)} {" " + Math.round((curTime - Math.trunc(curTime)) * 100)}
,
{this._videoBox && this._videoBox.Playing ? "\"" : ">"}
,
F
]); } @action onPlayDown = () => { if (this._videoBox) { if (this._videoBox.Playing) { this._videoBox.Pause(); } else { this._videoBox.Play(); } } } @action onFullDown = (e: React.PointerEvent) => { if (this._videoBox) { this._videoBox.FullScreen(); e.stopPropagation(); e.preventDefault(); } } @action onResetDown = () => { if (this._videoBox) { this._videoBox.Pause(); this.props.Document.curPage = 0; } } setVideoBox = (videoBox: VideoBox) => { this._videoBox = videoBox; }; private subView = (_type: CollectionViewType, renderProps: CollectionRenderProps) => { let props = { ...this.props, ...renderProps }; return (<> {this.props.isSelected() ? this.uIButtons : (null)} ); } render() { return ( {this.subView} ); } }