diff options
| author | Andy Rickert <andrew_rickert@brown.edu> | 2020-04-15 20:02:58 -0700 | 
|---|---|---|
| committer | Andy Rickert <andrew_rickert@brown.edu> | 2020-04-15 20:02:58 -0700 | 
| commit | 1d5c4510dff326a0f12b914868ac8614ab460e83 (patch) | |
| tree | 7173f465175c6eb6b5bbfe96c932b49fd621f0b0 /src/new_fields/ScriptField.ts | |
| parent | c7c146adbd0b188eba56139ab914edaf73774d3f (diff) | |
| parent | e0f16b89cba102a4fcd156bb3d4148432eca2ab7 (diff) | |
merge
Diffstat (limited to 'src/new_fields/ScriptField.ts')
| -rw-r--r-- | src/new_fields/ScriptField.ts | 10 | 
1 files changed, 7 insertions, 3 deletions
| diff --git a/src/new_fields/ScriptField.ts b/src/new_fields/ScriptField.ts index 148886848..8d0ddf94c 100644 --- a/src/new_fields/ScriptField.ts +++ b/src/new_fields/ScriptField.ts @@ -98,12 +98,15 @@ export class ScriptField extends ObjectField {      [Copy](): ObjectField {          return new ScriptField(this.script);      } +    toString() { +        return `${this.script.originalScript}`; +    }      [ToScriptString]() {          return "script field";      }      [ToString]() { -        return "script field"; +        return this.script.originalScript;      }      public static CompileScript(script: string, params: object = {}, addReturn = false, capturedVariables?: { [name: string]: Field }) {          const compiled = CompileScript(script, { @@ -131,7 +134,8 @@ export class ScriptField extends ObjectField {  export class ComputedField extends ScriptField {      _lastComputedResult: any;      //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) => this._lastComputedResult = this.script.run({ this: doc, self: Cast(doc.rootDocument, Doc, null) || doc, _last_: this._lastComputedResult }, console.log).result); +    value = computedFn((doc: Doc) => this._valueOutsideReaction(doc)); +    _valueOutsideReaction = (doc: Doc) => this._lastComputedResult = this.script.run({ this: doc, self: Cast(doc.rootDocument, Doc, null) || doc, _last_: this._lastComputedResult }, console.log).result;      public static MakeScript(script: string, params: object = {}) {          const compiled = ScriptField.CompileScript(script, params, false);          return compiled.compiled ? new ComputedField(compiled) : undefined; @@ -166,7 +170,7 @@ export namespace ComputedField {      export function initPlugin() {          Plugins.addGetterPlugin((doc, _, value) => {              if (useComputed && value instanceof ComputedField) { -                return { value: value.value(doc), shouldReturn: true }; +                return { value: value._valueOutsideReaction(doc), shouldReturn: true };              }          });      } | 
