diff options
Diffstat (limited to 'src/new_fields')
| -rw-r--r-- | src/new_fields/Doc.ts | 113 | ||||
| -rw-r--r-- | src/new_fields/ScriptField.ts | 36 | 
2 files changed, 65 insertions, 84 deletions
| diff --git a/src/new_fields/Doc.ts b/src/new_fields/Doc.ts index 01a064b69..fef3b8cc5 100644 --- a/src/new_fields/Doc.ts +++ b/src/new_fields/Doc.ts @@ -2,7 +2,7 @@ import { observable, ObservableMap, runInAction, action } from "mobx";  import { alias, map, serializable } from "serializr";  import { DocServer } from "../client/DocServer";  import { DocumentType } from "../client/documents/DocumentTypes"; -import { CompileScript, Scripting, scriptingGlobal } from "../client/util/Scripting"; +import { Scripting, scriptingGlobal } from "../client/util/Scripting";  import { afterDocDeserialize, autoObject, Deserializable, SerializationHelper } from "../client/util/SerializationHelper";  import { Copy, HandleUpdate, Id, OnUpdate, Parent, Self, SelfProxy, ToScriptString, Update } from "./FieldSymbols";  import { List } from "./List"; @@ -144,12 +144,12 @@ export class Doc extends RefField {      private [Self] = this;      private [SelfProxy]: any;      public [WidthSym] = () => { -        let iconAnimating = this[SelfProxy].isIconAnimating ? Array.from(Cast(this[SelfProxy].isIconAnimating, listSpec("number"))!) : undefined; -        return iconAnimating ? iconAnimating[0] : NumCast(this[SelfProxy].width); +        let animDims = this[SelfProxy].animateToDimensions ? Array.from(Cast(this[SelfProxy].animateToDimensions, listSpec("number"))!) : undefined; +        return animDims ? animDims[0] : NumCast(this[SelfProxy].width);      }      public [HeightSym] = () => { -        let iconAnimating = this[SelfProxy].isIconAnimating ? Array.from(Cast(this[SelfProxy].isIconAnimating, listSpec("number"))!) : undefined; -        return iconAnimating ? iconAnimating[1] : NumCast(this[SelfProxy].height); +        let animDims = this[SelfProxy].animateToDimensions ? Array.from(Cast(this[SelfProxy].animateToDimensions, listSpec("number"))!) : undefined; +        return animDims ? animDims[1] : NumCast(this[SelfProxy].height);      }      [ToScriptString]() { @@ -382,13 +382,13 @@ export namespace Doc {      }      // -    // Resolves a reference to a field by returning 'doc' if field extension is specified, +    // Resolves a reference to a field by returning 'doc' if no field extension is specified,      // otherwise, it returns the extension document stored in doc.<fieldKey>_ext.      // This mechanism allows any fields to be extended with an extension document that can      // be used to capture field-specific metadata.  For example, an image field can be extended      // to store annotations, ink, and other data.      // -    export function resolvedFieldDataDoc(doc: Doc, fieldKey: string, fieldExt: string) { +    export function fieldExtensionDoc(doc: Doc, fieldKey: string, fieldExt: string = "yes") {          return fieldExt && doc[fieldKey + "_ext"] instanceof Doc ? doc[fieldKey + "_ext"] as Doc : doc;      } @@ -405,29 +405,28 @@ export namespace Doc {          return docExtensionForField;      } -    export function UpdateDocumentExtensionForField(doc: Doc, fieldKey: string) { +    export function UpdateDocumentExtensionForField(doc: Doc, fieldKey: string, immediate: boolean = false) {          let docExtensionForField = doc[fieldKey + "_ext"] as Doc;          if (docExtensionForField === undefined) { -            setTimeout(() => { -                CreateDocumentExtensionForField(doc, fieldKey); -            }, 0); +            if (immediate) CreateDocumentExtensionForField(doc, fieldKey); +            else setTimeout(() => CreateDocumentExtensionForField(doc, fieldKey), 0);          } else if (doc instanceof Doc) { // backward compatibility -- add fields for docs that don't have them already              docExtensionForField.extendsDoc === undefined && setTimeout(() => docExtensionForField.extendsDoc = doc, 0);              docExtensionForField.type === undefined && setTimeout(() => docExtensionForField.type = DocumentType.EXTENSION, 0);          }      } +    export function MakeTitled(title: string) { +        let doc = new Doc(); +        doc.title = title; +        return doc; +    }      export function MakeAlias(doc: Doc) {          let alias = !GetT(doc, "isPrototype", "boolean", true) ? Doc.MakeCopy(doc) : Doc.MakeDelegate(doc);          if (alias.layout instanceof Doc) { -            alias.layout = Doc.MakeAlias(alias.layout as Doc); +            alias.layout = Doc.MakeAlias(alias.layout);          }          let aliasNumber = Doc.GetProto(doc).aliasNumber = NumCast(Doc.GetProto(doc).aliasNumber) + 1; -        let script = `return renameAlias(self, ${aliasNumber})`; -        //let script = "StrCast(self.title).replace(/\\([0-9]*\\)/, \"\") + `(${n})`"; -        let compiled = CompileScript(script, { params: { this: "Doc" }, capturedVariables: { self: doc }, typecheck: false }); -        if (compiled.compiled) { -            alias.title = new ComputedField(compiled); -        } +        alias.title = ComputedField.MakeFunction(`renameAlias(this, ${aliasNumber})`);          return alias;      } @@ -478,7 +477,7 @@ export namespace Doc {          let resolvedDataDoc = !doc.isTemplate && dataDoc !== doc && dataDoc ? Doc.GetDataDoc(dataDoc) : undefined;          if (resolvedDataDoc && Doc.WillExpandTemplateLayout(childDocLayout, resolvedDataDoc)) {              Doc.UpdateDocumentExtensionForField(resolvedDataDoc, fieldKey); -            let fieldExtensionDoc = Doc.resolvedFieldDataDoc(resolvedDataDoc, StrCast(childDocLayout.templateField, StrCast(childDocLayout.title)), "dummy"); +            let fieldExtensionDoc = Doc.fieldExtensionDoc(resolvedDataDoc, StrCast(childDocLayout.templateField, StrCast(childDocLayout.title)), "dummy");              layoutDoc = Doc.expandTemplateLayout(childDocLayout, fieldExtensionDoc !== resolvedDataDoc ? fieldExtensionDoc : undefined);          } else layoutDoc = Doc.expandTemplateLayout(childDocLayout, resolvedDataDoc);          return { layout: layoutDoc, data: resolvedDataDoc }; @@ -545,22 +544,9 @@ export namespace Doc {      let _applyCount: number = 0;      export function ApplyTemplate(templateDoc: Doc) { -        if (!templateDoc) return undefined; -        let datadoc = new Doc(); -        let otherdoc = Doc.MakeDelegate(datadoc); -        otherdoc.width = templateDoc[WidthSym](); -        otherdoc.height = templateDoc[HeightSym](); -        otherdoc.title = templateDoc.title + "(..." + _applyCount++ + ")"; -        otherdoc.layout = Doc.MakeDelegate(templateDoc); -        otherdoc.miniLayout = StrCast(templateDoc.miniLayout); -        otherdoc.detailedLayout = otherdoc.layout; -        otherdoc.type = DocumentType.TEMPLATE; -        !templateDoc.nativeWidth && (otherdoc.nativeWidth = 0); -        !templateDoc.nativeHeight && (otherdoc.nativeHeight = 0); -        !templateDoc.nativeWidth && (otherdoc.ignoreAspect = true); -        return otherdoc; -    } -    export function ApplyTemplateTo(templateDoc: Doc, target: Doc, targetData?: Doc, useTemplateDoc?: boolean) { +        return !templateDoc ? undefined : ApplyTemplateTo(templateDoc, Doc.MakeDelegate(new Doc()), templateDoc.title + "(..." + _applyCount++ + ")"); +    } +    export function ApplyTemplateTo(templateDoc: Doc, target: Doc, titleTarget: string | undefined = undefined) {          if (!templateDoc) {              target.layout = undefined;              target.nativeWidth = undefined; @@ -569,25 +555,24 @@ export namespace Doc {              target.type = undefined;              return;          } -        let temp = useTemplateDoc ? templateDoc : Doc.MakeDelegate(templateDoc); -        target.nativeWidth = Doc.GetProto(target).nativeWidth = undefined; -        target.nativeHeight = Doc.GetProto(target).nativeHeight = undefined; -        !templateDoc.nativeWidth && (target.nativeWidth = 0); -        !templateDoc.nativeHeight && (target.nativeHeight = 0); -        !templateDoc.nativeHeight && (target.ignoreAspect = true); + +        let layoutCustom = Doc.MakeTitled("layoutCustom"); +        let layoutCustomLayout = Doc.MakeDelegate(templateDoc); + +        titleTarget && (target.title = titleTarget); +        target.type = DocumentType.TEMPLATE;          target.width = templateDoc.width;          target.height = templateDoc.height; +        target.nativeWidth = templateDoc.nativeWidth ? templateDoc.nativeWidth : 0; +        target.nativeHeight = templateDoc.nativeHeight ? templateDoc.nativeHeight : 0; +        target.ignoreAspect = templateDoc.nativeWidth ? true : false;          target.onClick = templateDoc.onClick instanceof ObjectField && templateDoc.onClick[Copy](); -        target.type = DocumentType.TEMPLATE; -        if (targetData && targetData.layout === target) { -            targetData.layout = temp; -            targetData.miniLayout = StrCast(templateDoc.miniLayout); -            targetData.detailedLayout = targetData.layout; -        } else { -            target.layout = temp; -            target.miniLayout = StrCast(templateDoc.miniLayout); -            target.detailedLayout = target.layout; -        } +        target.layout = layoutCustomLayout; +        target.backgroundLayout = layoutCustomLayout.backgroundLayout; + +        target.layoutNative = Cast(templateDoc.layoutNative, Doc) as Doc; +        target.layoutCustom = layoutCustom; +        return target;      }      export function MakeMetadataFieldTemplate(fieldTemplate: Doc, templateDataDoc: Doc, suppressTitle: boolean = false) { @@ -629,30 +614,6 @@ export namespace Doc {          }), 0);      } -    export function ToggleDetailLayout(d: Doc) { -        runInAction(async () => { -            let miniLayout = await PromiseValue(d.miniLayout); -            let detailLayout = await PromiseValue(d.detailedLayout); -            d.layout !== miniLayout ? miniLayout && (d.layout = d.miniLayout) : detailLayout && (d.layout = detailLayout); -            if (d.layout === detailLayout) d.nativeWidth = d.nativeHeight = 0; -            if (StrCast(d.layout) !== "") d.nativeWidth = d.nativeHeight = undefined; -        }); -    } -    export function UseDetailLayout(d: Doc) { -        runInAction(async () => { -            let detailLayout = await d.detailedLayout; -            if (detailLayout) { -                d.layout = detailLayout; -                d.nativeWidth = d.nativeHeight = undefined; -                if (detailLayout instanceof Doc) { -                    let delegDetailLayout = Doc.MakeDelegate(detailLayout); -                    d.layout = delegDetailLayout; -                    delegDetailLayout.layout = await delegDetailLayout.detailedLayout; -                } -            } -        }); -    } -      export function isBrushedHighlightedDegree(doc: Doc) {          if (Doc.IsHighlighted(doc)) {              return 3; @@ -722,7 +683,7 @@ export namespace Doc {          manager.BrushedDoc.clear();      }  } -Scripting.addGlobal(function renameAlias(doc: any, n: any) { return StrCast(doc.title).replace(/\([0-9]*\)/, "") + `(${n})`; }); +Scripting.addGlobal(function renameAlias(doc: any, n: any) { return StrCast(Doc.GetProto(doc).title).replace(/\([0-9]*\)/, "") + `(${n})`; });  Scripting.addGlobal(function getProto(doc: any) { return Doc.GetProto(doc); });  Scripting.addGlobal(function copyField(field: any) { return ObjectField.MakeCopy(field); });  Scripting.addGlobal(function aliasDocs(field: any) { return new List<Doc>(field.map((d: any) => Doc.MakeAlias(d))); }); diff --git a/src/new_fields/ScriptField.ts b/src/new_fields/ScriptField.ts index 83fb52d07..cdc9871a8 100644 --- a/src/new_fields/ScriptField.ts +++ b/src/new_fields/ScriptField.ts @@ -1,5 +1,5 @@  import { ObjectField } from "./ObjectField"; -import { CompiledScript, CompileScript, scriptingGlobal } from "../client/util/Scripting"; +import { CompiledScript, CompileScript, scriptingGlobal, ScriptOptions } from "../client/util/Scripting";  import { Copy, ToScriptString, Parent, SelfProxy } from "./FieldSymbols";  import { serializable, createSimpleSchema, map, primitive, object, deserialize, PropSchema, custom, SKIP } from "serializr";  import { Deserializable, autoObject } from "../client/util/SerializationHelper"; @@ -101,19 +101,39 @@ export class ScriptField extends ObjectField {      [ToScriptString]() {          return "script field";      } +    public static CompileScript(script: string, params: object = {}, addReturn = false) { +        let compiled = CompileScript(script, { +            params: { this: Doc.name, ...params }, +            typecheck: false, +            editable: true, +            addReturn: addReturn +        }); +        return compiled; +    } +    public static MakeFunction(script: string, params: object = {}) { +        let compiled = ScriptField.CompileScript(script, params, true); +        return compiled.compiled ? new ScriptField(compiled) : undefined; +    } + +    public static MakeScript(script: string, params: object = {}) { +        let compiled = ScriptField.CompileScript(script, params, false); +        return compiled.compiled ? new ScriptField(compiled) : undefined; +    }  }  @scriptingGlobal  @Deserializable("computed", deserializeScript)  export class ComputedField extends ScriptField {      //TODO maybe add an observable cache based on what is passed in for doc, considering there shouldn't really be that many possible values for doc -    value = computedFn((doc: Doc) => { -        const val = this.script.run({ this: doc }); -        if (val.success) { -            return val.result; -        } -        return undefined; -    }); +    value = computedFn((doc: Doc) => this.script.run({ this: doc }, console.log).result); +    public static MakeScript(script: string, params: object = {}, ) { +        let compiled = ScriptField.CompileScript(script, params, false); +        return compiled.compiled ? new ComputedField(compiled) : undefined; +    } +    public static MakeFunction(script: string, params: object = {}) { +        let compiled = ScriptField.CompileScript(script, params, true); +        return compiled.compiled ? new ComputedField(compiled) : undefined; +    }  }  export namespace ComputedField { | 
