aboutsummaryrefslogtreecommitdiff
path: root/src/client/views/nodes/DocumentView.tsx
diff options
context:
space:
mode:
authorBob Zeleznik <zzzman@gmail.com>2019-03-17 22:17:21 -0400
committerBob Zeleznik <zzzman@gmail.com>2019-03-17 22:17:21 -0400
commitbd3ffb97a92f5983ea86d8a5a69f2cdc24374a37 (patch)
treefcd24aee16f17b3fb611d7a5fe48f1fbc818818f /src/client/views/nodes/DocumentView.tsx
parent1328b125d2b414380d037206ab6f39b9d12f1ff1 (diff)
parent1bf3a5a0108704a0204cedcbad6e6d52d19cf982 (diff)
Merge branch 'DocContents' into server_dev
Diffstat (limited to 'src/client/views/nodes/DocumentView.tsx')
-rw-r--r--src/client/views/nodes/DocumentView.tsx58
1 files changed, 6 insertions, 52 deletions
diff --git a/src/client/views/nodes/DocumentView.tsx b/src/client/views/nodes/DocumentView.tsx
index 76127a7f3..1f803bd45 100644
--- a/src/client/views/nodes/DocumentView.tsx
+++ b/src/client/views/nodes/DocumentView.tsx
@@ -1,11 +1,12 @@
import { action, computed, IReactionDisposer, reaction, runInAction } from "mobx";
import { observer } from "mobx-react";
import { Document } from "../../../fields/Document";
-import { Field, FieldWaiting, Opt } from "../../../fields/Field";
+import { Field, Opt } from "../../../fields/Field";
import { Key } from "../../../fields/Key";
import { KeyStore } from "../../../fields/KeyStore";
import { ListField } from "../../../fields/ListField";
import { TextField } from "../../../fields/TextField";
+import { Utils } from "../../../Utils";
import { Documents } from "../../documents/Documents";
import { DocumentManager } from "../../util/DocumentManager";
import { DragManager } from "../../util/DragManager";
@@ -14,23 +15,9 @@ import { Transform } from "../../util/Transform";
import { CollectionDockingView } from "../collections/CollectionDockingView";
import { CollectionView, CollectionViewType } from "../collections/CollectionView";
import { ContextMenu } from "../ContextMenu";
-import { FormattedTextBox } from "../nodes/FormattedTextBox"
-import { ImageBox } from "../nodes/ImageBox";
-import { CollectionFreeFormView } from "../collections/CollectionFreeFormView"
-import { PDFBox } from "../nodes/PDFBox";
-import { WebBox } from "../nodes/WebBox"
-import { CollectionSchemaView } from "../collections/CollectionSchemaView"
-import { AudioBox } from "../nodes/AudioBox";
-import { VideoBox } from "../nodes/VideoBox";
-import { CollectionPDFView } from "../collections/CollectionPDFView"
-import { CollectionVideoView } from "../collections/CollectionVideoView"
-import { KeyValueBox } from "../nodes/KeyValueBox"
+import { DocumentContentsView } from "./DocumentContentsView";
import "./DocumentView.scss";
import React = require("react");
-import { DocumentContentsView } from "./DocumentContentsView";
-import { Utils } from "../../../Utils";
-import { faUserPlus } from "@fortawesome/free-solid-svg-icons";
-const JsxParser = require('react-jsx-parser').default; //TODO Why does this need to be imported like this?
export interface DocumentViewProps {
@@ -88,7 +75,7 @@ export function FakeJsxArgs(keys: string[], fields: string[] = []): JsxArgs {
return args;
}
-interface JsxBindings {
+export interface JsxBindings {
Document: Document;
isSelected: () => boolean;
select: (isCtrlPressed: boolean) => void;
@@ -97,40 +84,7 @@ interface JsxBindings {
[prop: string]: any;
}
-@observer
-export class DocumentContents extends React.Component<DocumentViewProps & {
- isSelected: () => boolean,
- select: (ctrl: boolean) => void,
- layoutKey: Key
-}> {
- @computed get layout(): string { return this.props.Document.GetText(this.props.layoutKey, "<p>Error loading layout data</p>"); }
- @computed get layoutKeys(): Key[] { return this.props.Document.GetData(KeyStore.LayoutKeys, ListField, new Array<Key>()); }
- @computed get layoutFields(): Key[] { return this.props.Document.GetData(KeyStore.LayoutFields, ListField, new Array<Key>()); }
-
- CreateBindings(): JsxBindings {
- let bindings: JsxBindings = {
- ...this.props,
- };
- for (const key of this.layoutKeys) {
- bindings[key.Name + "Key"] = key; // this maps string values of the form <keyname>Key to an actual key Kestore.keyname e.g, "DataKey" => KeyStore.Data
- }
- for (const key of this.layoutFields) {
- let field = this.props.Document.Get(key);
- bindings[key.Name] = field && field != FieldWaiting ? field.GetValue() : field;
- }
- return bindings;
- }
- render() {
- return <JsxParser
- components={{ FormattedTextBox, ImageBox, CollectionFreeFormView, CollectionDockingView, CollectionSchemaView, CollectionView, CollectionPDFView, CollectionVideoView, WebBox, KeyValueBox, PDFBox, VideoBox, AudioBox }}
- bindings={this.CreateBindings()}
- jsx={this.layout}
- showWarnings={true}
- onError={(test: any) => { console.log(test) }}
- />
- }
-}
@observer
export class DocumentView extends React.Component<DocumentViewProps> {
@@ -378,8 +332,8 @@ export class DocumentView extends React.Component<DocumentViewProps> {
onDrop={this.onDrop}
onContextMenu={this.onContextMenu}
onPointerDown={this.onPointerDown} >
- <DocumentContents {...this.props} isSelected={this.isSelected} select={this.select} layoutKey={KeyStore.Layout} />
- </div>
+ <DocumentContentsView {...this.props} isSelected={this.isSelected} select={this.select} layoutKey={KeyStore.Layout} />
+ </div >
)
}
} \ No newline at end of file