diff options
author | tschicke-brown <tyler_schicke@brown.edu> | 2019-07-16 14:38:34 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-07-16 14:38:34 -0400 |
commit | 98c3a06256d2cbd720b2c193e5aa282c5dc25350 (patch) | |
tree | 5bb7e5a0fa44183bd3824ce94971d2715631a445 /src/new_fields/Doc.ts | |
parent | c6b933c6e89d5f438c434e8676cce9a6a577edbc (diff) | |
parent | 520fbe435330c8e426e2d504585ba1559300eadb (diff) |
Merge branch 'master' into search_virt
Diffstat (limited to 'src/new_fields/Doc.ts')
-rw-r--r-- | src/new_fields/Doc.ts | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/src/new_fields/Doc.ts b/src/new_fields/Doc.ts index c5f9e7adf..0d9fa540f 100644 --- a/src/new_fields/Doc.ts +++ b/src/new_fields/Doc.ts @@ -312,16 +312,20 @@ export namespace Doc { } export function UpdateDocumentExtensionForField(doc: Doc, fieldKey: string) { - if (doc[fieldKey + "_ext"] === undefined) { + let extensionDoc = doc[fieldKey + "_ext"]; + if (extensionDoc === undefined) { setTimeout(() => { let docExtensionForField = new Doc(doc[Id] + fieldKey, true); docExtensionForField.title = "Extension of " + doc.title + "'s field:" + fieldKey; + docExtensionForField.extendsDoc = doc; let proto: Doc | undefined = doc; while (proto && !Doc.IsPrototype(proto)) { proto = proto.proto; } (proto ? proto : doc)[fieldKey + "_ext"] = docExtensionForField; }, 0); + } else if (extensionDoc instanceof Doc && extensionDoc.extendsDoc === undefined) { + setTimeout(() => (extensionDoc as Doc).extendsDoc = doc, 0); } } export function MakeAlias(doc: Doc) { |