diff options
| author | usodhi <61431818+usodhi@users.noreply.github.com> | 2021-04-02 19:04:09 -0400 | 
|---|---|---|
| committer | usodhi <61431818+usodhi@users.noreply.github.com> | 2021-04-02 19:04:09 -0400 | 
| commit | bd6b9c40f150fab76e8907c45e29fa809f9acae0 (patch) | |
| tree | 30ee435654f640476a4745bf47524c2ff1f53d51 | |
| parent | ec2748cf3deaa791c5aae6eae11b36f3cd4c0099 (diff) | |
dashboard sharing initial setup, inherits acls from dashboard - looks like it works
| -rw-r--r-- | src/client/documents/Documents.ts | 4 | ||||
| -rw-r--r-- | src/client/util/CurrentUserUtils.ts | 20 | ||||
| -rw-r--r-- | src/client/views/DocComponent.tsx | 10 | ||||
| -rw-r--r-- | src/fields/Doc.ts | 9 | ||||
| -rw-r--r-- | src/fields/util.ts | 15 | 
5 files changed, 45 insertions, 13 deletions
| diff --git a/src/client/documents/Documents.ts b/src/client/documents/Documents.ts index f02298f36..2a679ec95 100644 --- a/src/client/documents/Documents.ts +++ b/src/client/documents/Documents.ts @@ -836,8 +836,8 @@ export namespace Docs {              return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { schemaHeaders: new List(schemaHeaders), ...options, _viewType: CollectionViewType.Schema });          } -        export function TreeDocument(documents: Array<Doc>, options: DocumentOptions, id?: string) { -            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { ...options, _viewType: CollectionViewType.Tree }, id); +        export function TreeDocument(documents: Array<Doc>, options: DocumentOptions, id?: string, protoId?: string) { +            return InstanceFromProto(Prototypes.get(DocumentType.COL), new List(documents), { ...options, _viewType: CollectionViewType.Tree }, id, undefined, protoId);          }          export function StackingDocument(documents: Array<Doc>, options: DocumentOptions, id?: string, protoId?: string) { diff --git a/src/client/util/CurrentUserUtils.ts b/src/client/util/CurrentUserUtils.ts index 849020392..f1357e3d7 100644 --- a/src/client/util/CurrentUserUtils.ts +++ b/src/client/util/CurrentUserUtils.ts @@ -35,6 +35,7 @@ import { UndoManager } from "./UndoManager";  import { SnappingManager } from "./SnappingManager";  import { InkTool } from "../../fields/InkField";  import { computedFn } from "mobx-utils"; +import { SharingManager } from "./SharingManager";  export let resolvedPorts: { server: number, socket: number }; @@ -907,9 +908,9 @@ export class CurrentUserUtils {          if (doc.mySharedDocs === undefined) {              let sharedDocs = Docs.newAccount ? undefined : await DocServer.GetRefField(sharingDocumentId + "outer");              if (!sharedDocs) { -                sharedDocs = Docs.Create.StackingDocument([], { -                    title: "My SharedDocs", childDropAction: "alias", system: true, contentPointerEvents: "none", childLimitHeight: 0, _yMargin: 50, _gridGap: 15, -                    _showTitle: "title", ignoreClick: true, _lockedPosition: true, "acl-Public": SharingPermissions.Add, "_acl-Public": SharingPermissions.Add, _chromeHidden: true, +                sharedDocs = Docs.Create.TreeDocument([], { +                    title: "My SharedDocs", childDropAction: "alias", system: true, contentPointerEvents: "all", childLimitHeight: 0, _yMargin: 50, _gridGap: 15, +                    _showTitle: "title", ignoreClick: false, _lockedPosition: true, "acl-Public": SharingPermissions.Add, "_acl-Public": SharingPermissions.Add, _chromeHidden: true,                  }, sharingDocumentId + "outer", sharingDocumentId);                  (sharedDocs as Doc)["acl-Public"] = (sharedDocs as Doc)[DataSym]["acl-Public"] = SharingPermissions.Add;              } @@ -1188,8 +1189,10 @@ export class CurrentUserUtils {          const toggleComic = ScriptField.MakeScript(`toggleComicMode()`);          const snapshotDashboard = ScriptField.MakeScript(`snapshotDashboard()`);          const createDashboard = ScriptField.MakeScript(`createNewDashboard()`); -        dashboardDoc.contextMenuScripts = new List<ScriptField>([toggleTheme!, toggleComic!, snapshotDashboard!, createDashboard!]); -        dashboardDoc.contextMenuLabels = new List<string>(["Toggle Theme Colors", "Toggle Comic Mode", "Snapshot Dashboard", "Create Dashboard"]); +        const shareDashboard = ScriptField.MakeScript(`shareDashboard()`); +        const addToDashboards = ScriptField.MakeScript(`addToDashboards(self)`); +        dashboardDoc.contextMenuScripts = new List<ScriptField>([toggleTheme!, toggleComic!, snapshotDashboard!, createDashboard!, shareDashboard!, addToDashboards!]); +        dashboardDoc.contextMenuLabels = new List<string>(["Toggle Theme Colors", "Toggle Comic Mode", "Snapshot Dashboard", "Create Dashboard", "Share Dashboard", "Add to Dashboards"]);          Doc.AddDocToList(dashboards, "data", dashboardDoc);          CurrentUserUtils.openDashboard(userDoc, dashboardDoc); @@ -1241,3 +1244,10 @@ Scripting.addGlobal(function links(doc: any) { return new List(LinkManager.Insta      "returns all the links to the document or its annotations", "(doc: any)");  Scripting.addGlobal(function importDocument() { return CurrentUserUtils.importDocument(); },      "imports files from device directly into the import sidebar"); +Scripting.addGlobal(function shareDashboard() { +    CurrentUserUtils.ActiveDashboard.isShared = true; +    SharingManager.Instance.open(undefined, CurrentUserUtils.ActiveDashboard); +}, +    "opens sharing dialog for Dashboard"); +Scripting.addGlobal(function addToDashboards(dashboard: Doc) { Doc.AddDocToList(CurrentUserUtils.MyDashboards, "data", dashboard); }, +    "adds Dashboard to set of Dashboards");
\ No newline at end of file diff --git a/src/client/views/DocComponent.tsx b/src/client/views/DocComponent.tsx index 90449ab6c..447daeb02 100644 --- a/src/client/views/DocComponent.tsx +++ b/src/client/views/DocComponent.tsx @@ -7,7 +7,7 @@ import { InteractionUtils } from '../util/InteractionUtils';  import { List } from '../../fields/List';  import { DateField } from '../../fields/DateField';  import { ScriptField } from '../../fields/ScriptField'; -import { GetEffectiveAcl, SharingPermissions, distributeAcls, denormalizeEmail } from '../../fields/util'; +import { GetEffectiveAcl, SharingPermissions, distributeAcls, denormalizeEmail, inheritParentAcls } from '../../fields/util';  import { CurrentUserUtils } from '../util/CurrentUserUtils';  import { DocUtils } from '../documents/Documents';  import { returnFalse } from '../../Utils'; @@ -198,15 +198,15 @@ export function ViewBoxAnnotatableComponent<P extends ViewBoxAnnotatableProps, T                      if (this.props.Document[AclSym] && Object.keys(this.props.Document[AclSym]).length) {                          added.forEach(d => {                              for (const [key, value] of Object.entries(this.props.Document[AclSym])) { -                                if (d.author === denormalizeEmail(key.substring(4)) && !d.aliasOf) distributeAcls(key, SharingPermissions.Admin, d, true); -                                //else if (this.props.Document[key] === SharingPermissions.Admin) distributeAcls(key, SharingPermissions.Add, d, true); -                                // else distributeAcls(key, this.AclMap.get(value) as SharingPermissions, d, true); +                                if (d.author === denormalizeEmail(key.substring(4)) && !d.aliasOf) distributeAcls(key, SharingPermissions.Admin, d);                              }                          });                      }                      if (effectiveAcl === AclAddonly) {                          added.map(doc => { + +                            if ([AclAdmin, AclEdit].includes(GetEffectiveAcl(doc))) inheritParentAcls(CurrentUserUtils.ActiveDashboard, doc);                              doc.context = this.props.Document;                              if (annotationKey ?? this._annotationKey) Doc.GetProto(doc).annotationOn = this.props.Document;                              this.props.layerProvider?.(doc, true); @@ -220,6 +220,8 @@ export function ViewBoxAnnotatableComponent<P extends ViewBoxAnnotatableProps, T                              doc._stayInCollection = undefined;                              doc.context = this.props.Document;                              if (annotationKey ?? this._annotationKey) Doc.GetProto(doc).annotationOn = this.props.Document; + +                            inheritParentAcls(CurrentUserUtils.ActiveDashboard, doc);                          });                          const annoDocs = targetDataDoc[annotationKey ?? this.annotationKey] as List<Doc>;                          if (annoDocs) annoDocs.push(...added); diff --git a/src/fields/Doc.ts b/src/fields/Doc.ts index 5b3e21e34..b37c2fdfe 100644 --- a/src/fields/Doc.ts +++ b/src/fields/Doc.ts @@ -22,8 +22,9 @@ import { listSpec } from "./Schema";  import { ComputedField, ScriptField } from "./ScriptField";  import { Cast, FieldValue, NumCast, StrCast, ToConstructor } from "./Types";  import { AudioField, ImageField, PdfField, VideoField, WebField } from "./URLField"; -import { deleteProperty, GetEffectiveAcl, getField, getter, makeEditable, makeReadOnly, normalizeEmail, setter, SharingPermissions, updateFunction } from "./util"; +import { deleteProperty, getField, getter, inheritParentAcls, makeEditable, makeReadOnly, normalizeEmail, setter, SharingPermissions, updateFunction } from "./util";  import JSZip = require("jszip"); +import { CurrentUserUtils } from "../client/util/CurrentUserUtils";  export namespace Field {      export function toKeyValueString(doc: Doc, key: string): string { @@ -424,6 +425,9 @@ export namespace Doc {          return Array.from(results);      } +    /** +     * @returns the index of doc toFind in list of docs, -1 otherwise +     */      export function IndexOf(toFind: Doc, list: Doc[], allowProtos: boolean = true) {          let index = list.reduce((p, v, i) => (v instanceof Doc && v === toFind) ? i : p, -1);          index = allowProtos && index !== -1 ? index : list.reduce((p, v, i) => (v instanceof Doc && Doc.AreProtosEqual(v, toFind)) ? i : p, -1); @@ -1148,6 +1152,9 @@ export namespace Doc {              dragFactory["dragFactory-count"] = NumCast(dragFactory["dragFactory-count"]) + 1;              Doc.SetInPlace(ndoc, "title", ndoc.title + " " + NumCast(dragFactory["dragFactory-count"]).toString(), true);          } + +        if (ndoc) inheritParentAcls(CurrentUserUtils.ActiveDashboard, ndoc); +          return ndoc;      }      export function delegateDragFactory(dragFactory: Doc) { diff --git a/src/fields/util.ts b/src/fields/util.ts index ea91cc057..a4c99928a 100644 --- a/src/fields/util.ts +++ b/src/fields/util.ts @@ -131,6 +131,19 @@ export function denormalizeEmail(email: string) {  //     playgroundMode = !playgroundMode;  // } + +/** + * Copies parent's acl fields to the child + */ +export function inheritParentAcls(parent: Doc, child: Doc) { +    if (parent.isShared) { +        const dataDoc = parent[DataSym]; +        for (const key of Object.keys(dataDoc)) { +            key.startsWith("acl") && distributeAcls(key, dataDoc[key], child); +        } +    } +} +  /**   * These are the various levels of access a user can have to a document.   *  @@ -245,7 +258,7 @@ export function distributeAcls(key: string, acl: SharingPermissions, target: Doc              dataDocChanged = true;          } -        // maps over the aliases of the document +        // maps over the links of the document          const links = DocListCast(dataDoc.links);          links.forEach(link => distributeAcls(key, acl, link, inheritingFromCollection, visited)); | 
