diff options
| author | andrewdkim <adkim414@gmail.com> | 2019-07-26 17:37:12 -0400 | 
|---|---|---|
| committer | andrewdkim <adkim414@gmail.com> | 2019-07-26 17:37:12 -0400 | 
| commit | 2dfd6378cf3f472132143bc231090777e49eeec7 (patch) | |
| tree | 34e631e0551391e5786ae136ba1d596dbc876c76 /src/new_fields/ScriptField.ts | |
| parent | 7cb850105aeefd1234f76aaab5badd45a8660dc4 (diff) | |
| parent | e189378e5ce01eedd1373172fbd8d8dabf2ad197 (diff) | |
Merge branch 'master' of https://github.com/browngraphicslab/Dash-Web into animationtimeline
Diffstat (limited to 'src/new_fields/ScriptField.ts')
| -rw-r--r-- | src/new_fields/ScriptField.ts | 22 | 
1 files changed, 20 insertions, 2 deletions
diff --git a/src/new_fields/ScriptField.ts b/src/new_fields/ScriptField.ts index e5ec34f57..00b4dec2c 100644 --- a/src/new_fields/ScriptField.ts +++ b/src/new_fields/ScriptField.ts @@ -2,10 +2,11 @@ import { ObjectField } from "./ObjectField";  import { CompiledScript, CompileScript, scriptingGlobal } 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 } from "../client/util/SerializationHelper"; +import { Deserializable, autoObject } from "../client/util/SerializationHelper";  import { Doc } from "../new_fields/Doc";  import { Plugins } from "./util";  import { computedFn } from "mobx-utils"; +import { ProxyField } from "./Proxy";  function optional(propSchema: PropSchema) {      return custom(value => { @@ -34,7 +35,16 @@ const scriptSchema = createSimpleSchema({      originalScript: true  }); -function deserializeScript(script: ScriptField) { +async function deserializeScript(script: ScriptField) { +    const captures: ProxyField<Doc> = (script as any).captures; +    if (captures) { +        const doc = (await captures.value())!; +        const captured: any = {}; +        const keys = Object.keys(doc); +        const vals = await Promise.all(keys.map(key => doc[key]) as any); +        keys.forEach((key, i) => captured[key] = vals[i]); +        (script.script.options as any).capturedVariables = captured; +    }      const comp = CompileScript(script.script.originalScript, script.script.options);      if (!comp.compiled) {          throw new Error("Couldn't compile loaded script"); @@ -48,9 +58,17 @@ export class ScriptField extends ObjectField {      @serializable(object(scriptSchema))      readonly script: CompiledScript; +    @serializable(autoObject()) +    private captures?: ProxyField<Doc>; +      constructor(script: CompiledScript) {          super(); +        if (script && script.options.capturedVariables) { +            const doc = Doc.assign(new Doc, script.options.capturedVariables); +            this.captures = new ProxyField(doc); +        } +          this.script = script;      }  | 
