diff options
| author | Bob Zeleznik <zzzman@gmail.com> | 2020-04-28 17:32:59 -0400 | 
|---|---|---|
| committer | Bob Zeleznik <zzzman@gmail.com> | 2020-04-28 17:32:59 -0400 | 
| commit | d020ab540abaf279414aa682c8930a4b280ace55 (patch) | |
| tree | 2cab1b330659a97664af86e34f52d2d1b0ed49e1 /src/client/util/DropConverter.ts | |
| parent | 4ecf08b5c5cdc4ddb3a997e2f3a2188e921ff430 (diff) | |
| parent | 6b2896756c55727ed397c223187cb03fe8a51a59 (diff) | |
merged with master
Diffstat (limited to 'src/client/util/DropConverter.ts')
| -rw-r--r-- | src/client/util/DropConverter.ts | 45 | 
1 files changed, 35 insertions, 10 deletions
| diff --git a/src/client/util/DropConverter.ts b/src/client/util/DropConverter.ts index d0f1d86cb..60a6bbb3c 100644 --- a/src/client/util/DropConverter.ts +++ b/src/client/util/DropConverter.ts @@ -1,5 +1,5 @@  import { DragManager } from "./DragManager"; -import { Doc, DocListCast } from "../../new_fields/Doc"; +import { Doc, DocListCast, Opt } from "../../new_fields/Doc";  import { DocumentType } from "../documents/DocumentTypes";  import { ObjectField } from "../../new_fields/ObjectField";  import { StrCast } from "../../new_fields/Types"; @@ -8,39 +8,64 @@ import { ScriptField, ComputedField } from "../../new_fields/ScriptField";  import { RichTextField } from "../../new_fields/RichTextField";  import { ImageField } from "../../new_fields/URLField"; -export function makeTemplate(doc: Doc): boolean { +//  +// converts 'doc' into a template that can be used to render other documents. +// the title of doc is used to determine which field is being templated, so +// passing a value for 'rename' allows the doc to be given a meangingful name  +// after it has been converted to +export function makeTemplate(doc: Doc, first: boolean = true, rename: Opt<string> = undefined): boolean {      const layoutDoc = doc.layout instanceof Doc && doc.layout.isTemplateForField ? doc.layout : doc; +    if (layoutDoc.layout instanceof Doc) { // its already a template +        return true; +    }      const layout = StrCast(layoutDoc.layout).match(/fieldKey={'[^']*'}/)![0];      const fieldKey = layout.replace("fieldKey={'", "").replace(/'}$/, "");      const docs = DocListCast(layoutDoc[fieldKey]);      let any = false;      docs.forEach(d => {          if (!StrCast(d.title).startsWith("-")) { -            any = Doc.MakeMetadataFieldTemplate(d, Doc.GetProto(layoutDoc)) || any; +            const params = StrCast(d.title).match(/\(([a-zA-Z0-9._\-]*)\)/)?.[1].replace("()", ""); +            if (params) { +                any = makeTemplate(d, false) || any; +                d.PARAMS = params; +            } else { +                any = Doc.MakeMetadataFieldTemplate(d, Doc.GetProto(layoutDoc)) || any; +            }          } else if (d.type === DocumentType.COL || d.data instanceof RichTextField) { -            any = makeTemplate(d) || any; +            any = makeTemplate(d, false) || any;          }      }); +    if (first) { +        if (docs.length) { // bcz: feels hacky : if the root level document has items, it's not a field template, but we still want its caption to be a textTemplate +            if (doc.caption instanceof RichTextField && !doc.caption.Empty()) { +                doc["caption-textTemplate"] = ComputedField.MakeFunction(`copyField(this.caption)`); +            } +        } else { +            any = Doc.MakeMetadataFieldTemplate(doc, Doc.GetProto(layoutDoc)) || any; +        } +    }      if (layoutDoc[fieldKey] instanceof RichTextField || layoutDoc[fieldKey] instanceof ImageField) {          if (!StrCast(layoutDoc.title).startsWith("-")) {              any = Doc.MakeMetadataFieldTemplate(layoutDoc, Doc.GetProto(layoutDoc));          }      } +    rename && (doc.title = rename);      return any;  }  export function convertDropDataToButtons(data: DragManager.DocumentDragData) {      data && data.draggedDocuments.map((doc, i) => {          let dbox = doc;          // bcz: isButtonBar is intended to allow a collection of linear buttons to be dropped and nested into another collection of buttons... it's not being used yet, and isn't very elegant -        if (!doc.onDragStart && !doc.onClick && !doc.isButtonBar) { +        if (!doc.onDragStart && !doc.isButtonBar) {              const layoutDoc = doc.layout instanceof Doc && doc.layout.isTemplateForField ? doc.layout : doc; -            if (layoutDoc.type === DocumentType.COL || layoutDoc.type === DocumentType.TEXT || layoutDoc.type === DocumentType.IMG) { -                makeTemplate(layoutDoc); -            } else { -                (layoutDoc.layout instanceof Doc) && !data.userDropAction; +            if (layoutDoc.type !== DocumentType.FONTICON) { +                !layoutDoc.isTemplateDoc && makeTemplate(layoutDoc);              }              layoutDoc.isTemplateDoc = true; -            dbox = Docs.Create.FontIconDocument({ _nativeWidth: 100, _nativeHeight: 100, _width: 100, _height: 100, backgroundColor: StrCast(doc.backgroundColor), title: "Custom", icon: layoutDoc.isTemplateDoc ? "font" : "bolt" }); +            dbox = Docs.Create.FontIconDocument({ +                _nativeWidth: 100, _nativeHeight: 100, _width: 100, _height: 100, +                backgroundColor: StrCast(doc.backgroundColor), title: StrCast(layoutDoc.title), icon: layoutDoc.isTemplateDoc ? "font" : "bolt" +            });              dbox.dragFactory = layoutDoc;              dbox.removeDropProperties = doc.removeDropProperties instanceof ObjectField ? ObjectField.MakeCopy(doc.removeDropProperties) : undefined;              dbox.onDragStart = ScriptField.MakeFunction('getCopy(this.dragFactory, true)'); | 
