import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; import { action, observable } from 'mobx'; import { observer } from 'mobx-react'; import { Docs } from '../client/documents/Documents'; import { Transform } from '../client/util/Transform'; import { ContextMenu } from '../client/views/ContextMenu'; import { DictationOverlay } from '../client/views/DictationOverlay'; import { MainViewModal } from '../client/views/MainViewModal'; import { DocumentView } from '../client/views/nodes/DocumentView'; import { RichTextMenu } from '../client/views/nodes/formattedText/RichTextMenu'; import { Doc } from '../fields/Doc'; import { listSpec } from '../fields/Schema'; import { Cast, FieldValue } from '../fields/Types'; import { nullAudio } from '../fields/URLField'; import { emptyFunction, returnEmptyDoclist, returnEmptyFilter, returnFalse, returnTrue, emptyPath } from '../Utils'; import "./ImageUpload.scss"; import { MobileInterface } from './MobileInterface'; import React = require('react'); @observer export class AudioUpload extends React.Component { @observable public _audioCol: Doc = FieldValue(Cast(Docs.Create.FreeformDocument([Cast(Docs.Create.AudioDocument(nullAudio, { title: "mobile audio", _width: 500, _height: 100 }), Doc) as Doc], { title: "mobile audio", _width: 300, _height: 300, _fitContentsToBox: true, boxShadow: "0 0" }), Doc)) as Doc; /** * Handles the onclick functionality for the 'Restart' button * Resets the document to its default view */ @action clearUpload = () => { for (let i = 1; i < 8; i++) { this.setOpacity(i, "0.2"); } this._audioCol = FieldValue(Cast( Docs.Create.FreeformDocument( [Cast(Docs.Create.AudioDocument(nullAudio, { title: "mobile audio", _width: 500, _height: 100 }), Doc) as Doc], { title: "mobile audio", _width: 300, _height: 300, _fitContentsToBox: true, boxShadow: "0 0" }), Doc)) as Doc; } /** * Handles the onClick of the 'Close' button * Reset upload interface and toggle audio */ closeUpload = () => { this.clearUpload(); MobileInterface.Instance.toggleAudio(); } /** * Handles the on click of the 'Upload' button. * Pushing the audio doc onto Dash Web through the right side bar */ uploadAudio = () => { const audioRightSidebar = Cast(Doc.SharingDoc(), Doc, null); const audioDoc = this._audioCol; const data = Cast(audioRightSidebar.data, listSpec(Doc)); for (let i = 1; i < 8; i++) { setTimeout(() => this.setOpacity(i, "1"), i * 200); } if (data) { data.push(audioDoc); } // Resets uploader after 3 seconds setTimeout(this.clearUpload, 3000); } // Returns the upload audio menu private get uploadInterface() { return ( <>
this.closeUpload()}>
600} PanelHeight={() => 400} renderDepth={0} isDocumentActive={returnTrue} isContentActive={emptyFunction} focus={emptyFunction} styleProvider={() => "rgba(0,0,0,0)"} docViewPath={returnEmptyDoclist} whenChildContentsActiveChanged={emptyFunction} bringToFront={emptyFunction} ContainingCollectionView={undefined} ContainingCollectionDoc={undefined} />
Restart
Upload
); } // Handles the setting of the loading bar setOpacity = (index: number, opacity: string) => { const slab = document.getElementById("slab0" + index); if (slab) { slab.style.opacity = opacity; } } @observable private dialogueBoxOpacity = 1; @observable private overlayOpacity = 0.4; render() { return ( ); } }