diff options
Diffstat (limited to 'src/client')
6 files changed, 38 insertions, 31 deletions
| diff --git a/src/client/util/CurrentUserUtils.ts b/src/client/util/CurrentUserUtils.ts index a0883fb8a..3dc16b864 100644 --- a/src/client/util/CurrentUserUtils.ts +++ b/src/client/util/CurrentUserUtils.ts @@ -85,23 +85,6 @@ export class CurrentUserUtils {              });          } -        if (doc["template-button-header"] === undefined) { -            const headerTemplate = Doc.MakeDelegate(Docs.Create.TextDocument(" ", { title: "header", _autoHeight: true, system: true }, "header")); // text needs to be a space to allow templateText to be created -            headerTemplate.system = true; -            headerTemplate[DataSym].layout = -                "<div>" + -                "    <FormattedTextBox {...props} dontSelectOnLoad={'true'} ignoreAutoHeight={'true'} height='{this._headerHeight||75}px' background='{this._headerColor||`orange`}' fieldKey={'header'}/>" + -                "    <FormattedTextBox {...props} position='absolute' top='{(this._headerHeight||75)*scale}px' height='calc({100/scale}% - {this._headerHeight||75}px)' fieldKey={'text'}/>" + -                "</div>"; -            (headerTemplate.proto as Doc).isTemplateDoc = makeTemplate(headerTemplate.proto as Doc, true, "headerView"); - -            doc["template-button-header"] = CurrentUserUtils.ficon({ -                onDragStart: ScriptField.MakeFunction('makeDelegate(this.dragFactory)'), -                dragFactory: new PrefetchProxy(headerTemplate) as any as Doc, -                removeDropProperties: new List<string>(["dropAction"]), title: "header view", icon: "window-maximize", system: true -            }); -        } -          if (doc["template-button-link"] === undefined) {  // set _backgroundColor to transparent to prevent link dot from obscuring document it's attached to.              const linkTemplate = Doc.MakeDelegate(Docs.Create.TextDocument(" ", { title: "header", _autoHeight: true, system: true }, "header")); // text needs to be a space to allow templateText to be created              linkTemplate.system = true; @@ -253,7 +236,6 @@ export class CurrentUserUtils {          const requiredTypes = [              doc["template-button-slides"] as Doc, -            doc["template-button-header"] as Doc,              doc["template-mobile-button"] as Doc,              doc["template-button-detail"] as Doc,              doc["template-button-simple"] as Doc, @@ -426,6 +408,17 @@ export class CurrentUserUtils {              FormattedTextBox.SelectOnLoad = textDoc[Id];              doc.emptySlide = textDoc;          } +        if (doc.emptyHeader === undefined) { +            const headerTemplate = Docs.Create.TextDocument(" ", { title: "header", _autoHeight: true, system: true, cloneFieldFilter: new List<string>(["system"]) }, "header"); // text needs to be a space to allow templateText to be created +            headerTemplate[DataSym].layout = +                "<div>" + +                "    <FormattedTextBox {...props} dontSelectOnLoad={'true'} ignoreAutoHeight={'true'} height='{this._headerHeight||75}px' background='{this._headerColor||`orange`}' fieldKey={'header'}/>" + +                "    <FormattedTextBox {...props} position='absolute' top='{(this._headerHeight||75)*scale}px' height='calc({100/scale}% - {this._headerHeight||75}px)' fieldKey={'text'}/>" + +                "</div>"; +            (headerTemplate.proto as Doc).isTemplateDoc = makeTemplate(headerTemplate.proto as Doc, true, "headerView"); +            doc.emptyHeader = headerTemplate; +            ((doc.emptyHeader as Doc).proto as Doc)["dragFactory-count"] = 0; +        }          if (doc.emptyComparison === undefined) {              doc.emptyComparison = Docs.Create.ComparisonDocument({ title: "compare", _width: 300, _height: 300, system: true, cloneFieldFilter: new List<string>(["system"]) });          } @@ -471,6 +464,7 @@ export class CurrentUserUtils {              { toolTip: "Tap to create a scripting box in a new pane, drag for a scripting box", title: "Script", icon: "terminal", click: 'openOnRight(copyDragFactory(this.dragFactory))', drag: 'copyDragFactory(this.dragFactory)', dragFactory: doc.emptyScript as Doc },              { toolTip: "Tap to create a mobile view in a new pane, drag for a mobile view", title: "Phone", icon: "mobile", click: 'openOnRight(Doc.UserDoc().activeMobileMenu)', drag: 'this.dragFactory', dragFactory: doc.activeMobileMenu as Doc },              { toolTip: "Tap to create a document previewer in a new pane, drag for a document previewer", title: "Prev", icon: "expand", click: 'openOnRight(copyDragFactory(this.dragFactory))', drag: 'copyDragFactory(this.dragFactory)', dragFactory: doc.emptyDocHolder as Doc }, +            { toolTip: "Tap to create a custom header note document, drag for a custom header note", title: "Custom", icon: "window-maximize", click: 'openOnRight(delegateDragFactory(this.dragFactory))', drag: 'delegateDragFactory(this.dragFactory)', dragFactory: doc.emptyHeader as Doc, noviceMode: true },              { toolTip: "Toggle a Calculator REPL", title: "repl", icon: "calculator", click: 'addOverlayWindow("ScriptingRepl", { x: 300, y: 100, width: 200, height: 200, title: "Scripting REPL" })' },          ]; diff --git a/src/client/views/nodes/DocumentView.tsx b/src/client/views/nodes/DocumentView.tsx index b372f3691..ad99001dd 100644 --- a/src/client/views/nodes/DocumentView.tsx +++ b/src/client/views/nodes/DocumentView.tsx @@ -987,6 +987,7 @@ export class DocumentView extends DocComponent<DocumentViewProps, Document>(Docu                      yMargin={10}                      xMargin={10}                      hideOnLeave={true} +                    dontRegisterView={true}                      LayoutTemplateString={`<FormattedTextBox {...props} fieldKey={'${showCaption}'}/>`}                      ContentScaling={returnOne}                      ChromeHeight={this.chromeHeight} diff --git a/src/client/views/nodes/formattedText/DashFieldView.tsx b/src/client/views/nodes/formattedText/DashFieldView.tsx index f14a57e31..0332bb4fd 100644 --- a/src/client/views/nodes/formattedText/DashFieldView.tsx +++ b/src/client/views/nodes/formattedText/DashFieldView.tsx @@ -1,5 +1,5 @@  import { IReactionDisposer, observable, runInAction, computed, action } from "mobx"; -import { Doc, DocListCast, Field } from "../../../../fields/Doc"; +import { Doc, DocListCast, Field, LayoutSym } from "../../../../fields/Doc";  import { List } from "../../../../fields/List";  import { listSpec } from "../../../../fields/Schema";  import { SchemaHeaderField } from "../../../../fields/SchemaHeaderField"; @@ -70,7 +70,7 @@ export class DashFieldViewInternal extends React.Component<IDashFieldViewInterna              DocServer.GetRefField(this.props.docid).                  then(action(async dashDoc => dashDoc instanceof Doc && (this._dashDoc = dashDoc)));          } else { -            this._dashDoc = this.props.tbox.props.DataDoc || this.props.tbox.dataDoc; +            this._dashDoc = this.props.tbox.rootDoc;          }      }      componentWillUnmount() { @@ -92,7 +92,10 @@ export class DashFieldViewInternal extends React.Component<IDashFieldViewInterna                  return <input                      className="dashFieldView-fieldCheck"                      type="checkbox" checked={boolVal} -                    onChange={e => this._dashDoc![this._fieldKey] = e.target.checked} +                    onChange={e => { +                        if (this._fieldKey.startsWith("_")) Doc.Layout(this._textBoxDoc)[this._fieldKey] = e.target.checked; +                        this._dashDoc![this._fieldKey] = e.target.checked; +                    }}                  />;              }              else // field value is a string, so display it as an editable span @@ -159,9 +162,16 @@ export class DashFieldViewInternal extends React.Component<IDashFieldViewInterna                  } else if (nodeText.startsWith("=:=")) {                      Doc.Layout(this._textBoxDoc)[this._fieldKey] = ComputedField.MakeFunction(nodeText.substring(3));                  } else { -                    const splits = newText.split(this.multiValueDelimeter); -                    if (this._fieldKey !== "PARAMS" || !this._textBoxDoc[this._fieldKey] || this._dashDoc?.PARAMS) { -                        this._dashDoc![this._fieldKey] = splits.length > 1 ? new List<string>(splits) : newText; +                    if (Number(newText).toString() === newText) { +                        if (this._fieldKey.startsWith("_")) Doc.Layout(this._textBoxDoc)[this._fieldKey] = Number(newText); +                        this._dashDoc![this._fieldKey] = Number(newText); +                    } else { +                        const splits = newText.split(this.multiValueDelimeter); +                        if (this._fieldKey !== "PARAMS" || !this._textBoxDoc[this._fieldKey] || this._dashDoc?.PARAMS) { +                            const strVal = splits.length > 1 ? new List<string>(splits) : newText; +                            if (this._fieldKey.startsWith("_")) Doc.Layout(this._textBoxDoc)[this._fieldKey] = strVal; +                            this._dashDoc![this._fieldKey] = strVal; +                        }                      }                  }              }); diff --git a/src/client/views/nodes/formattedText/FormattedTextBox.tsx b/src/client/views/nodes/formattedText/FormattedTextBox.tsx index 873d88f7e..4cc0309eb 100644 --- a/src/client/views/nodes/formattedText/FormattedTextBox.tsx +++ b/src/client/views/nodes/formattedText/FormattedTextBox.tsx @@ -348,7 +348,7 @@ export class FormattedTextBox extends ViewBoxAnnotatableComponent<(FieldViewProp      }      updateTitle = () => { -        if ((this.props.Document.isTemplateForField === "text" || !this.props.Document.isTemplateForField) && // only update the title if the data document's data field is changing +        if (!this.props.dontRegisterView &&  // (this.props.Document.isTemplateForField === "text" || !this.props.Document.isTemplateForField) && // only update the title if the data document's data field is changing              StrCast(this.dataDoc.title).startsWith("-") && this._editorView && !this.dataDoc["title-custom"] &&              Doc.LayoutFieldKey(this.rootDoc) === this.fieldKey) {              let node = this._editorView.state.doc; diff --git a/src/client/views/nodes/formattedText/ProsemirrorExampleTransfer.ts b/src/client/views/nodes/formattedText/ProsemirrorExampleTransfer.ts index e77cc2692..f1a0188c5 100644 --- a/src/client/views/nodes/formattedText/ProsemirrorExampleTransfer.ts +++ b/src/client/views/nodes/formattedText/ProsemirrorExampleTransfer.ts @@ -217,11 +217,13 @@ export function buildKeymap<S extends Schema<any>>(schema: S, props: any, mapKey                  const fromattrs = state.selection.$from.node().attrs;                  if (!splitBlockKeepMarks(state, (tx3: Transaction) => {                      const tonode = tx3.selection.$to.node(); -                    const tx4 = tx3.setNodeMarkup(tx3.selection.to - 1, tonode.type, fromattrs, tonode.marks); -                    splitMetadata(marks, tx4); -                    if (!liftListItem(schema.nodes.list_item)(tx4, dispatch as ((tx: Transaction<Schema<any, any>>) => void))) { -                        dispatch(tx4); -                    } +                    if (tx3.doc.nodeAt(tx3.selection.to - 1)) { +                        const tx4 = tx3.setNodeMarkup(tx3.selection.to - 1, tonode.type, fromattrs, tonode.marks); +                        splitMetadata(marks, tx4); +                        if (!liftListItem(schema.nodes.list_item)(tx4, dispatch as ((tx: Transaction<Schema<any, any>>) => void))) { +                            dispatch(tx4); +                        } +                    } else dispatch(tx3.insertText("\r"));                  })) {                      return false;                  } diff --git a/src/client/views/nodes/formattedText/RichTextRules.ts b/src/client/views/nodes/formattedText/RichTextRules.ts index 02f9c6268..06c73265a 100644 --- a/src/client/views/nodes/formattedText/RichTextRules.ts +++ b/src/client/views/nodes/formattedText/RichTextRules.ts @@ -324,7 +324,7 @@ export class RichTextRules {                      this.Document[DataSym]["#" + tag] = "#" + tag;                      const tags = StrCast(this.Document.tags, ":");                      if (!tags.includes(`#${tag}:`)) { -                        this.Document[DataSym].tags = `"${tags + "#" + tag + ':'}"`; +                        this.Document[DataSym].tags = `${tags + "#" + tag + ':'}`;                      }                      const fieldView = state.schema.nodes.dashField.create({ fieldKey: "#" + tag });                      return state.tr.deleteRange(start, end).insert(start, fieldView); | 
