diff options
Diffstat (limited to 'src/client/views/nodes/formattedText/FormattedTextBox.tsx')
| -rw-r--r-- | src/client/views/nodes/formattedText/FormattedTextBox.tsx | 29 | 
1 files changed, 15 insertions, 14 deletions
| diff --git a/src/client/views/nodes/formattedText/FormattedTextBox.tsx b/src/client/views/nodes/formattedText/FormattedTextBox.tsx index 8078a29b7..c3946dd57 100644 --- a/src/client/views/nodes/formattedText/FormattedTextBox.tsx +++ b/src/client/views/nodes/formattedText/FormattedTextBox.tsx @@ -11,7 +11,7 @@ import { EditorState, NodeSelection, Plugin, TextSelection, Transaction } from "  import { ReplaceStep } from 'prosemirror-transform';  import { EditorView } from "prosemirror-view";  import { DateField } from '../../../../fields/DateField'; -import { DataSym, Doc, DocListCast, DocListCastAsync, Field, HeightSym, Opt, WidthSym, AclEdit, AclAdmin } from "../../../../fields/Doc"; +import { DataSym, Doc, DocListCast, DocListCastAsync, Field, HeightSym, Opt, WidthSym, AclEdit, AclAdmin, UpdatingFromServer } from "../../../../fields/Doc";  import { documentSchema } from '../../../../fields/documentSchemas';  import applyDevTools = require("prosemirror-dev-tools");  import { removeMarkWithAttrs } from "./prosemirrorPatches"; @@ -22,7 +22,7 @@ import { RichTextField } from "../../../../fields/RichTextField";  import { RichTextUtils } from '../../../../fields/RichTextUtils';  import { makeInterface } from "../../../../fields/Schema";  import { Cast, DateCast, NumCast, StrCast, ScriptCast, BoolCast } from "../../../../fields/Types"; -import { TraceMobx, OVERRIDE_acl, GetEffectiveAcl } from '../../../../fields/util'; +import { TraceMobx, GetEffectiveAcl } from '../../../../fields/util';  import { addStyleSheet, addStyleSheetRule, clearStyleSheetRules, emptyFunction, numberRange, returnOne, returnZero, Utils, setupMoveUpEvents, OmitKeys } from '../../../../Utils';  import { GoogleApiClientUtils, Pulls, Pushes } from '../../../apis/google_docs/GoogleApiClientUtils';  import { DocServer } from "../../../DocServer"; @@ -289,10 +289,12 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp                      }                  }              } else { - -                const json = JSON.parse(Cast(this.dataDoc[this.fieldKey], RichTextField)?.Data!); -                json.selection = state.toJSON().selection; -                this._editorView.updateState(EditorState.fromJSON(this.config, json)); +                const jsonstring = Cast(this.dataDoc[this.fieldKey], RichTextField)?.Data!; +                if (jsonstring) { +                    const json = JSON.parse(jsonstring); +                    json.selection = state.toJSON().selection; +                    this._editorView.updateState(EditorState.fromJSON(this.config, json)); +                }              }          }      } @@ -803,9 +805,9 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp                      tr = tr.addMark(pos, pos + node.nodeSize, link);                  }              }); -            OVERRIDE_acl(true); +            this.dataDoc[UpdatingFromServer] = true;  // need to allow permissions for adding links to readonly/augment only documents              this._editorView!.dispatch(tr.removeMark(sel.from, sel.to, splitter)); -            OVERRIDE_acl(false); +            this.dataDoc[UpdatingFromServer] = false;          }      }      componentDidMount() { @@ -883,7 +885,7 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp              ({ width, autoHeight }) => width !== undefined && setTimeout(() => this.tryUpdateHeight(), 0)          );          this._disposers.height = reaction( -            () => NumCast(this.layoutDoc._height), +            () => Cast(this.layoutDoc._height, "number", null),              action(height => {                  if (height !== undefined && height <= 20 && height < NumCast(this.layoutDoc._delayAutoHeight, 20)) {                      this.layoutDoc._delayAutoHeight = height; @@ -1512,7 +1514,6 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp      @action      tryUpdateHeight(limitHeight?: number) {          let scrollHeight = this.ProseRef?.scrollHeight || 0; -        this.rootDoc[this.fieldKey + "-height"] = 0;          if (this.props.renderDepth && this.layoutDoc._autoHeight && !this.props.ignoreAutoHeight && scrollHeight && !this.props.dontRegisterView) {  // if top === 0, then the text box is growing upward (as the overlay caption) which doesn't contribute to the height computation              scrollHeight = scrollHeight * NumCast(this.layoutDoc._viewScale, 1);              if (limitHeight && scrollHeight > limitHeight) { @@ -1543,7 +1544,7 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp                      this.rootDoc[this.fieldKey + "-height"] = finalHeight;                  } catch (e) { console.log("Error in tryUpdateHeight"); }              } -        } +        } else this.rootDoc[this.fieldKey + "-height"] = 0;      }      @computed get audioHandle() { @@ -1554,7 +1555,7 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp      }      @computed get sidebarHandle() { -        const annotated = DocListCast(this.dataDoc[this.annotationKey]).filter(d => d?.title).length; +        const annotated = DocListCast(this.dataDoc[this.annotationKey]).filter(d => d?.author).length;          return !this.props.isSelected() && !(annotated && !this.sidebarWidth()) ? (null) :              <div className="formattedTextBox-sidebar-handle"                  style={{ left: `max(0px, calc(100% - ${this.sidebarWidthPercent} ${this.sidebarWidth() ? "- 5px" : "- 10px"}))`, background: annotated ? "lightBlue" : undefined }} @@ -1607,7 +1608,7 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp          const scale = this.props.hideOnLeave ? 1 : this.props.ContentScaling() * NumCast(this.layoutDoc._viewScale, 1);          const rounded = StrCast(this.layoutDoc.borderRounding) === "100%" ? "-rounded" : "";          const interactive = (Doc.GetSelectedTool() === InkTool.None || SnappingManager.GetIsDragging()) && !this.layoutDoc._isBackground; -        if (!selected && FormattedTextBoxComment.textBox === this) { FormattedTextBoxComment.Hide(); } +        if (!selected && FormattedTextBoxComment.textBox === this) setTimeout(() => FormattedTextBoxComment.Hide());          const minimal = this.props.ignoreAutoHeight;          const margins = NumCast(this.layoutDoc._yMargin, this.props.yMargin || 0);          const selPad = Math.min(margins, 10); @@ -1654,7 +1655,7 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp                      })}                      onDoubleClick={this.onDoubleClick}                  > -                    <div className={`formattedTextBox-outer`} ref={this._scrollRef} +                    <div className={`formattedTextBox-outer${selclass}`} ref={this._scrollRef}                          style={{ width: `calc(100% - ${this.sidebarWidthPercent})`, pointerEvents: !active && !SnappingManager.GetIsDragging() ? "none" : undefined }}                          onScroll={this.onscrolled} onDrop={this.ondrop} >                          <div className={minimal ? "formattedTextBox-minimal" : `formattedTextBox-inner${rounded}${selclass}`} ref={this.createDropTarget} | 
