diff options
author | bob <bcz@cs.brown.edu> | 2019-02-05 17:41:12 -0500 |
---|---|---|
committer | bob <bcz@cs.brown.edu> | 2019-02-05 17:41:12 -0500 |
commit | 26af9562cc515627be4be8759b70ebfbab8bb83c (patch) | |
tree | f2148b4ca0aee6eecc063a9d3f65c910b404ad51 /src/views/nodes/FormattedTextBox.tsx | |
parent | 6e66f8b227c730e07863a93a8bce5ee0d51d2ddc (diff) |
first changes
Diffstat (limited to 'src/views/nodes/FormattedTextBox.tsx')
-rw-r--r-- | src/views/nodes/FormattedTextBox.tsx | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/src/views/nodes/FormattedTextBox.tsx b/src/views/nodes/FormattedTextBox.tsx index 9c4b24226..f0385c096 100644 --- a/src/views/nodes/FormattedTextBox.tsx +++ b/src/views/nodes/FormattedTextBox.tsx @@ -5,7 +5,7 @@ import { keymap } from "prosemirror-keymap"; import { schema } from "prosemirror-schema-basic"; import { EditorState, Transaction } from "prosemirror-state"; import { EditorView } from "prosemirror-view"; -import { Opt } from "../../fields/Field"; +import { Opt, WAITING } from "../../fields/Field"; import { SelectionManager } from "../../util/SelectionManager"; import "./FormattedTextBox.scss"; import React = require("react") @@ -46,7 +46,7 @@ export class FormattedTextBox extends React.Component<FieldViewProps> { } dispatchTransaction = (tx: Transaction) => { - if (this._editorView) { + if (this._editorView && this._editorView != WAITING) { const state = this._editorView.state.apply(tx); this._editorView.updateState(state); const { doc, fieldKey } = this.props; @@ -67,7 +67,7 @@ export class FormattedTextBox extends React.Component<FieldViewProps> { }; let field = doc.GetFieldT(fieldKey, RichTextField); - if (field) { + if (field && field != WAITING) { // bcz: don't think this works state = EditorState.fromJSON(config, JSON.parse(field.Data)); } else { state = EditorState.create(config); @@ -81,19 +81,19 @@ export class FormattedTextBox extends React.Component<FieldViewProps> { this._reactionDisposer = reaction(() => { const field = this.props.doc.GetFieldT(this.props.fieldKey, RichTextField); - return field ? field.Data : undefined; + return field && field != WAITING ? field.Data : undefined; }, (field) => { - if (field && this._editorView) { + if (field && this._editorView && this._editorView != WAITING) { this._editorView.updateState(EditorState.fromJSON(config, JSON.parse(field))); } }) } componentWillUnmount() { - if (this._editorView) { + if (this._editorView && this._editorView != WAITING) { this._editorView.destroy(); } - if (this._reactionDisposer) { + if (this._reactionDisposer && this._reactionDisposer != WAITING) { this._reactionDisposer(); } } |