diff options
Diffstat (limited to 'src/client/documents')
| -rw-r--r-- | src/client/documents/DocumentTypes.ts | 2 | ||||
| -rw-r--r-- | src/client/documents/Documents.ts | 90 | 
2 files changed, 69 insertions, 23 deletions
| diff --git a/src/client/documents/DocumentTypes.ts b/src/client/documents/DocumentTypes.ts index 454fb2ad2..86d8c6db7 100644 --- a/src/client/documents/DocumentTypes.ts +++ b/src/client/documents/DocumentTypes.ts @@ -33,8 +33,10 @@ export enum DocumentType {      DOCHOLDER = "docholder",    // nested document (view of a document)      SEARCHITEM= "searchitem",      COMPARISON = "comparison",   // before/after view with slider (view of 2 images) +    GROUP = "group",            // group of users      LINKDB = "linkdb",          // database of links  ??? why do we have this      SCRIPTDB = "scriptdb",          // database of scripts      RECOMMENDATION = "recommendation", // view of a recommendation +    GROUPDB = "groupdb"         // database of groups  }
\ No newline at end of file diff --git a/src/client/documents/Documents.ts b/src/client/documents/Documents.ts index 56c384eca..5a2d746d6 100644 --- a/src/client/documents/Documents.ts +++ b/src/client/documents/Documents.ts @@ -1,5 +1,5 @@  import { runInAction } from "mobx"; -import { extname } from "path"; +import { extname, basename } from "path";  import { DateField } from "../../fields/DateField";  import { Doc, DocListCast, DocListCastAsync, Field, HeightSym, Opt, WidthSym } from "../../fields/Doc";  import { HtmlField } from "../../fields/HtmlField"; @@ -49,6 +49,9 @@ import { WebBox } from "../views/nodes/WebBox";  import { PresElementBox } from "../views/presentationview/PresElementBox";  import { RecommendationsBox } from "../views/RecommendationsBox";  import { DashWebRTCVideo } from "../views/webcam/DashWebRTCVideo"; +import { DocumentType } from "./DocumentTypes"; +import { Networking } from "../Network"; +import { Upload } from "../../server/SharedMediaTypes";  const path = require('path');  export interface DocumentOptions { @@ -63,7 +66,7 @@ export interface DocumentOptions {      _dimUnit?: string; // "px" or "*" (default = "*")      _fitWidth?: boolean;      _fitToBox?: boolean; // whether a freeformview should zoom/scale to create a shrinkwrapped view of its contents -    _LODdisable?: boolean; +    _freeformLOD?: boolean; // whether to use LOD to render a freeform document      _showTitleHover?: string; //       _showTitle?: string; // which field to display in the title area.  leave empty to have no title      _showCaption?: string; // which field to display in the caption area.  leave empty to have no caption @@ -100,7 +103,7 @@ export interface DocumentOptions {      childLayoutTemplate?: Doc; // template for collection to use to render its children (see PresBox or Buxton layout in tree view)      childLayoutString?: string; // template string for collection to use to render its children      hideFilterView?: boolean; // whether to hide the filter popout on collections -    hideHeadings?: boolean; // whether stacking view column headings should be hidden +    _columnsHideIfEmpty?: boolean; // whether stacking view column headings should be hidden      isTemplateForField?: string; // the field key for which the containing document is a rendering template      isTemplateDoc?: boolean;      targetScriptKey?: string; // where to write a template script (used by collections with click templates which need to target onClick, onDoubleClick, etc) @@ -120,7 +123,7 @@ export interface DocumentOptions {      defaultBackgroundColor?: string;      isBackground?: boolean;      isLinkButton?: boolean; -    columnWidth?: number; +    _columnWidth?: number;      _fontSize?: number;      _fontFamily?: string;      curPage?: number; @@ -138,7 +141,8 @@ export interface DocumentOptions {      "onCheckedClick-rawScript"?: string; // onChecked script in raw text form      "onCheckedClick-params"?: List<string>; // parameter list for onChecked treeview functions      _pivotField?: string; // field key used to determine headings for sections in stacking, masonry, pivot views -    schemaColumns?: List<SchemaHeaderField>; +    _columnHeaders?: List<SchemaHeaderField>; // headers for stacking views +    _schemaHeaders?: List<SchemaHeaderField>; // headers for schema view      dockingConfig?: string;      annotationOn?: Doc;      removeDropProperties?: List<string>; // list of properties that should be removed from a document when it is dropped.  e.g., a creator button may be forceActive to allow it be dragged, but the forceActive property can be removed from the dropped document @@ -316,6 +320,14 @@ export namespace Docs {              [DocumentType.COMPARISON, {                  layout: { view: ComparisonBox, dataField: defaultDataKey },              }], +            [DocumentType.GROUPDB, { +                data: new List<Doc>(), +                layout: { view: EmptyBox, dataField: defaultDataKey }, +                options: { childDropAction: "alias", title: "Global Group Database" } +            }], +            [DocumentType.GROUP, { +                layout: { view: EmptyBox, dataField: defaultDataKey } +            }]          ]);          // All document prototypes are initialized with at least these values @@ -379,6 +391,13 @@ export namespace Docs {          }          /** +         * A collection of all groups in the database +         */ +        export function MainGroupDocument() { +            return Prototypes.get(DocumentType.GROUPDB); +        } + +        /**           * This is a convenience method that is used to initialize           * prototype documents for the first time.           *  @@ -403,7 +422,7 @@ export namespace Docs {              // synthesize the default options, the type and title from computed values and              // whatever options pertain to this specific prototype              const options = { title, type, baseProto: true, ...defaultOptions, ...(template.options || {}) }; -            options.layout = layout.view.LayoutString(layout.dataField); +            options.layout = layout.view?.LayoutString(layout.dataField);              const doc = Doc.assign(new Doc(prototypeId, true), { layoutKey: "layout", ...options });              doc.layout_keyValue = KeyValueBox.LayoutString("");              return doc; @@ -433,8 +452,7 @@ export namespace Docs {              const parent = TreeDocument([loading], {                  title: "The Buxton Collection",                  _width: 400, -                _height: 400, -                _LODdisable: true +                _height: 400              });              const parentProto = Doc.GetProto(parent);              const { _socket } = DocServer; @@ -470,7 +488,7 @@ export namespace Docs {                          return imageDoc;                      });                      // the main document we create -                    const doc = StackingDocument(deviceImages, { title, _LODdisable: true, hero: new ImageField(constructed[0].url) }); +                    const doc = StackingDocument(deviceImages, { title, hero: new ImageField(constructed[0].url) });                      doc.nameAliases = new List<string>([title.toLowerCase()]);                      // add the parsed attributes to this main document                      Doc.Get.FromJson({ data: device, appendToExisting: { targetDoc: Doc.GetProto(doc) } }); @@ -703,15 +721,15 @@ export namespace Docs {          }          export function FreeformDocument(documents: Array<Doc>, options: DocumentOptions, id?: string) { -            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", schemaColumns: new List([new SchemaHeaderField("title", "#f1efeb")]), ...options, _viewType: CollectionViewType.Freeform }, id); +            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", ...options, _viewType: CollectionViewType.Freeform }, id);          }          export function PileDocument(documents: Array<Doc>, options: DocumentOptions, id?: string) { -            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", backgroundColor: "black", schemaColumns: new List([new SchemaHeaderField("title", "#f1efeb")]), ...options, _viewType: CollectionViewType.Pile }, id); +            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", backgroundColor: "black", ...options, _viewType: CollectionViewType.Pile }, id);          }          export function LinearDocument(documents: Array<Doc>, options: DocumentOptions, id?: string) { -            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", backgroundColor: "black", schemaColumns: new List([new SchemaHeaderField("title", "#f1efeb")]), ...options, _viewType: CollectionViewType.Linear }, id); +            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", backgroundColor: "black", ...options, _viewType: CollectionViewType.Linear }, id);          }          export function MapDocument(documents: Array<Doc>, options: DocumentOptions = {}) { @@ -719,35 +737,35 @@ export namespace Docs {          }          export function CarouselDocument(documents: Array<Doc>, options: DocumentOptions) { -            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", schemaColumns: new List([new SchemaHeaderField("title", "#f1efeb")]), ...options, _viewType: CollectionViewType.Carousel }); +            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", ...options, _viewType: CollectionViewType.Carousel });          }          export function Carousel3DDocument(documents: Array<Doc>, options: DocumentOptions) { -            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", schemaColumns: new List([new SchemaHeaderField("title", "#f1efeb")]), ...options, _viewType: CollectionViewType.Carousel3D }); +            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", ...options, _viewType: CollectionViewType.Carousel3D });          } -        export function SchemaDocument(schemaColumns: SchemaHeaderField[], documents: Array<Doc>, options: DocumentOptions) { -            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", schemaColumns: new List(schemaColumns.length ? schemaColumns : [new SchemaHeaderField("title", "#f1efeb")]), ...options, _viewType: CollectionViewType.Schema }); +        export function SchemaDocument(schemaHeaders: SchemaHeaderField[], documents: Array<Doc>, options: DocumentOptions) { +            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", _schemaHeaders: schemaHeaders.length ? new List(schemaHeaders) : undefined, ...options, _viewType: CollectionViewType.Schema });          }          export function TreeDocument(documents: Array<Doc>, options: DocumentOptions, id?: string) { -            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", schemaColumns: new List([new SchemaHeaderField("title", "#f1efeb")]), ...options, _viewType: CollectionViewType.Tree }, id); +            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", ...options, _viewType: CollectionViewType.Tree }, id);          }          export function StackingDocument(documents: Array<Doc>, options: DocumentOptions, id?: string) { -            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", schemaColumns: new List([new SchemaHeaderField("title", "#f1efeb")]), ...options, _viewType: CollectionViewType.Stacking }, id); +            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", ...options, _viewType: CollectionViewType.Stacking }, id);          }          export function MulticolumnDocument(documents: Array<Doc>, options: DocumentOptions) { -            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", schemaColumns: new List([new SchemaHeaderField("title", "#f1efeb")]), ...options, _viewType: CollectionViewType.Multicolumn }); +            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", ...options, _viewType: CollectionViewType.Multicolumn });          }          export function MultirowDocument(documents: Array<Doc>, options: DocumentOptions) { -            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", schemaColumns: new List([new SchemaHeaderField("title", "#f1efeb")]), ...options, _viewType: CollectionViewType.Multirow }); +            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", ...options, _viewType: CollectionViewType.Multirow });          }          export function MasonryDocument(documents: Array<Doc>, options: DocumentOptions) { -            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", schemaColumns: new List([new SchemaHeaderField("title", "#f1efeb")]), ...options, _viewType: CollectionViewType.Masonry }); +            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { _chromeStatus: "collapsed", ...options, _viewType: CollectionViewType.Masonry });          }          export function LabelDocument(options?: DocumentOptions) { @@ -971,7 +989,7 @@ export namespace DocUtils {          });          ContextMenu.Instance.addItem({              description: "Add Template Doc ...", -            subitems: DocListCast(Cast(Doc.UserDoc().dockedBtns, Doc, null)?.data).map(btnDoc => Cast(btnDoc?.dragFactory, Doc, null)).filter(doc => doc).map((dragDoc, i) => ({ +            subitems: DocListCast(Cast(Doc.UserDoc().myItemCreators, Doc, null)?.data).map(btnDoc => Cast(btnDoc?.dragFactory, Doc, null)).filter(doc => doc).map((dragDoc, i) => ({                  description: ":" + StrCast(dragDoc.title),                  event: (args: { x: number, y: number }) => {                      const newDoc = Doc.ApplyTemplate(dragDoc); @@ -1063,7 +1081,7 @@ export namespace DocUtils {              });          });          if (x !== undefined && y !== undefined) { -            const newCollection = Docs.Create.PileDocument(docList, { title: "pileup", x: x - 55, y: y - 55, _width: 110, _height: 100, _LODdisable: true }); +            const newCollection = Docs.Create.PileDocument(docList, { title: "pileup", x: x - 55, y: y - 55, _width: 110, _height: 100 });              newCollection.x = NumCast(newCollection.x) + NumCast(newCollection._width) / 2 - 55;              newCollection.y = NumCast(newCollection.y) + NumCast(newCollection._height) / 2 - 55;              newCollection._width = newCollection._height = 110; @@ -1098,6 +1116,32 @@ export namespace DocUtils {          });          return optionsCollection;      } + +    export async function uploadFilesToDocs(files: File[], options: DocumentOptions) { +        const generatedDocuments: Doc[] = []; +        for (const { source: { name, type }, result } of await Networking.UploadFilesToServer(files)) { +            if (result instanceof Error) { +                alert(`Upload failed: ${result.message}`); +                return []; +            } +            const full = { ...options, _width: 400, title: name }; +            const pathname = Utils.prepend(result.accessPaths.agnostic.client); +            const doc = await DocUtils.DocumentFromType(type, pathname, full); +            if (!doc) { +                continue; +            } +            const proto = Doc.GetProto(doc); +            proto.text = result.rawText; +            proto.fileUpload = basename(pathname).replace("upload_", "").replace(/\.[a-z0-9]*$/, ""); +            if (Upload.isImageInformation(result)) { +                proto["data-nativeWidth"] = (result.nativeWidth > result.nativeHeight) ? 400 * result.nativeWidth / result.nativeHeight : 400; +                proto["data-nativeHeight"] = (result.nativeWidth > result.nativeHeight) ? 400 : 400 / (result.nativeWidth / result.nativeHeight); +                proto.contentSize = result.contentSize; +            } +            generatedDocuments.push(doc); +        } +        return generatedDocuments; +    }  }  Scripting.addGlobal("Docs", Docs); | 
