diff options
Diffstat (limited to 'src/client/util')
| -rw-r--r-- | src/client/util/CurrentUserUtils.ts | 7 | ||||
| -rw-r--r-- | src/client/util/SharingManager.tsx | 24 | 
2 files changed, 26 insertions, 5 deletions
| diff --git a/src/client/util/CurrentUserUtils.ts b/src/client/util/CurrentUserUtils.ts index f1357e3d7..fdceb60f3 100644 --- a/src/client/util/CurrentUserUtils.ts +++ b/src/client/util/CurrentUserUtils.ts @@ -1189,7 +1189,7 @@ export class CurrentUserUtils {          const toggleComic = ScriptField.MakeScript(`toggleComicMode()`);          const snapshotDashboard = ScriptField.MakeScript(`snapshotDashboard()`);          const createDashboard = ScriptField.MakeScript(`createNewDashboard()`); -        const shareDashboard = ScriptField.MakeScript(`shareDashboard()`); +        const shareDashboard = ScriptField.MakeScript(`shareDashboard(self)`);          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"]); @@ -1244,9 +1244,8 @@ 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); +Scripting.addGlobal(function shareDashboard(dashboard: Doc) { +    SharingManager.Instance.open(undefined, dashboard);  },      "opens sharing dialog for Dashboard");  Scripting.addGlobal(function addToDashboards(dashboard: Doc) { Doc.AddDocToList(CurrentUserUtils.MyDashboards, "data", dashboard); }, diff --git a/src/client/util/SharingManager.tsx b/src/client/util/SharingManager.tsx index ded56d1da..ca14154b2 100644 --- a/src/client/util/SharingManager.tsx +++ b/src/client/util/SharingManager.tsx @@ -5,7 +5,7 @@ import { observer } from "mobx-react";  import * as React from "react";  import Select from "react-select";  import * as RequestPromise from "request-promise"; -import { AclAddonly, AclAdmin, AclEdit, AclPrivate, AclReadonly, AclSym, DataSym, Doc, DocListCast, DocListCastAsync, Opt } from "../../fields/Doc"; +import { AclAddonly, AclAdmin, AclEdit, AclPrivate, AclReadonly, AclSym, AclUnset, DataSym, Doc, DocListCast, DocListCastAsync, Opt } from "../../fields/Doc";  import { List } from "../../fields/List";  import { Cast, StrCast } from "../../fields/Types";  import { distributeAcls, GetEffectiveAcl, normalizeEmail, SharingPermissions, TraceMobx } from "../../fields/util"; @@ -17,6 +17,7 @@ import { MainViewModal } from "../views/MainViewModal";  import { DocumentView } from "../views/nodes/DocumentView";  import { TaskCompletionBox } from "../views/nodes/TaskCompletedBox";  import { SearchBox } from "../views/search/SearchBox"; +import { CurrentUserUtils } from "./CurrentUserUtils";  import { DocumentManager } from "./DocumentManager";  import { GroupManager, UserOptions } from "./GroupManager";  import { GroupMemberView } from "./GroupMemberView"; @@ -170,6 +171,7 @@ export class SharingManager extends React.Component<{}> {              doc.author === Doc.CurrentUserEmail && !doc[myAcl] && distributeAcls(myAcl, SharingPermissions.Admin, doc);              distributeAcls(acl, permission as SharingPermissions, doc); +            this.setDashboardBackground(doc, permission as SharingPermissions);              if (permission !== SharingPermissions.None) return Doc.AddDocToList(sharingDoc, storage, doc);              else return GetEffectiveAcl(doc, user.email) === AclPrivate && Doc.RemoveDocFromList(sharingDoc, storage, (doc.aliasOf as Doc || doc));          }).some(success => !success); @@ -192,6 +194,7 @@ export class SharingManager extends React.Component<{}> {          return !docs.map(doc => {              doc.author === Doc.CurrentUserEmail && !doc[`acl-${Doc.CurrentUserEmailNormalized}`] && distributeAcls(`acl-${Doc.CurrentUserEmailNormalized}`, SharingPermissions.Admin, doc);              distributeAcls(acl, permission as SharingPermissions, doc); +            this.setDashboardBackground(doc, permission as SharingPermissions);              if (group instanceof Doc) {                  const members: string[] = JSON.parse(StrCast(group.members)); @@ -247,6 +250,25 @@ export class SharingManager extends React.Component<{}> {      }      /** +     * Sets the background of the Dashboard if it has been shared as a visual indicator +     */ +    setDashboardBackground = async (doc: Doc, permission: SharingPermissions) => { +        if (Doc.IndexOf(doc, DocListCast(CurrentUserUtils.MyDashboards.data)) !== -1) { +            if (permission !== SharingPermissions.None) { +                doc.isShared = true; +                doc.backgroundColor = "green"; +            } +            else { +                const acls = doc[DataSym][AclSym]; +                if (Object.keys(acls).every(key => key === `acl-${Doc.CurrentUserEmailNormalized}` ? true : [AclUnset, AclPrivate].includes(acls[key]))) { +                    doc.isShared = undefined; +                    doc.backgroundColor = undefined; +                } +            } +        } +    } + +    /**       * Removes the documents shared with a user through a group when the user is removed from the group.       * @param group        * @param emailId  | 
