diff options
author | bob <bcz@cs.brown.edu> | 2019-07-16 11:58:35 -0400 |
---|---|---|
committer | bob <bcz@cs.brown.edu> | 2019-07-16 11:58:35 -0400 |
commit | f59e4c19bb759c9179157744bbcb46ff578351d1 (patch) | |
tree | 02cb9c86c59e14a8b57d0241685ab2be6bb1d984 /src/new_fields/Doc.ts | |
parent | f36afcf2b00da1df5aa39deff5d9e931a823605c (diff) | |
parent | bbfc935958b88c7ecaeb9a1e06a255cac958ec4c (diff) |
Merge branch 'youtubebites'
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) { |