diff options
| author | Eleanor Eng <eleanor_eng@brown.edu> | 2019-05-04 16:44:22 -0400 | 
|---|---|---|
| committer | Eleanor Eng <eleanor_eng@brown.edu> | 2019-05-04 16:44:40 -0400 | 
| commit | cecd09917f23fc83c87cffc4fddf5fe1f8331bac (patch) | |
| tree | ab7144d36046aaada287c2ce14d2fe7722585dce /src/server/authentication | |
| parent | 0bf0b028b1af8b9481e369c754277af5fb8b3fcd (diff) | |
| parent | 1ccabe155cb4f23c0aa7e37f91cd4a303008b8c7 (diff) | |
merge with master
Diffstat (limited to 'src/server/authentication')
3 files changed, 22 insertions, 107 deletions
| diff --git a/src/server/authentication/controllers/WorkspacesMenu.css b/src/server/authentication/controllers/WorkspacesMenu.css deleted file mode 100644 index b89039965..000000000 --- a/src/server/authentication/controllers/WorkspacesMenu.css +++ /dev/null @@ -1,3 +0,0 @@ -.ids:hover { -    color: darkblue; -}
\ No newline at end of file diff --git a/src/server/authentication/controllers/WorkspacesMenu.tsx b/src/server/authentication/controllers/WorkspacesMenu.tsx deleted file mode 100644 index b08c1aebe..000000000 --- a/src/server/authentication/controllers/WorkspacesMenu.tsx +++ /dev/null @@ -1,89 +0,0 @@ -import * as React from 'react'; -import { observable, action, configure, reaction, computed, ObservableMap, runInAction } from 'mobx'; -import { observer } from "mobx-react"; -import './WorkspacesMenu.css'; -import { Document } from '../../../fields/Document'; -import { EditableView } from '../../../client/views/EditableView'; -import { KeyStore } from '../../../fields/KeyStore'; - -export interface WorkspaceMenuProps { -    active: Document | undefined; -    open: (workspace: Document) => void; -    new: () => void; -    allWorkspaces: Document[]; -    isShown: () => boolean; -    toggle: () => void; -} - -@observer -export class WorkspacesMenu extends React.Component<WorkspaceMenuProps> { -    constructor(props: WorkspaceMenuProps) { -        super(props); -        this.addNewWorkspace = this.addNewWorkspace.bind(this); -    } - -    @action -    addNewWorkspace() { -        this.props.new(); -        this.props.toggle(); -    } - -    render() { -        return ( -            <div -                style={{ -                    width: "auto", -                    maxHeight: '200px', -                    overflow: 'scroll', -                    borderRadius: 5, -                    position: "absolute", -                    top: 78, -                    left: this.props.isShown() ? 11 : -500, -                    background: "white", -                    border: "black solid 2px", -                    transition: "all 1s ease", -                    zIndex: 15, -                    padding: 10, -                    paddingRight: 12, -                }}> -                <img -                    src="https://bit.ly/2IBBkxk" -                    style={{ -                        width: 20, -                        height: 20, -                        marginTop: 3, -                        marginLeft: 3, -                        marginBottom: 3, -                        cursor: "grab" -                    }} -                    onClick={this.addNewWorkspace} -                /> -                {this.props.allWorkspaces.map((s, i) => -                    <div -                        key={s.Id} -                        onContextMenu={(e) => { -                            e.preventDefault(); -                            this.props.open(s); -                        }} -                        style={{ -                            marginTop: 10, -                            color: s === this.props.active ? "red" : "black" -                        }} -                    > -                        <span>{i + 1} - </span> -                        <EditableView -                            display={"inline"} -                            GetValue={() => s.Title} -                            SetValue={(title: string): boolean => { -                                s.SetText(KeyStore.Title, title); -                                return true; -                            }} -                            contents={s.Title} -                            height={20} -                        /> -                    </div> -                )} -            </div> -        ); -    } -}
\ No newline at end of file diff --git a/src/server/authentication/models/current_user_utils.ts b/src/server/authentication/models/current_user_utils.ts index 5d4479c88..5f45d7bcc 100644 --- a/src/server/authentication/models/current_user_utils.ts +++ b/src/server/authentication/models/current_user_utils.ts @@ -1,19 +1,20 @@  import { computed, observable, action, runInAction } from "mobx";  import * as rp from 'request-promise'; -import { Documents } from "../../../client/documents/Documents"; +import { Docs } from "../../../client/documents/Documents";  import { Attribute, AttributeGroup, Catalog, Schema } from "../../../client/northstar/model/idea/idea";  import { ArrayUtil } from "../../../client/northstar/utils/ArrayUtil"; -import { Server } from "../../../client/Server"; -import { Document } from "../../../fields/Document"; -import { KeyStore } from "../../../fields/KeyStore"; -import { ListField } from "../../../fields/ListField";  import { RouteStore } from "../../RouteStore"; -import { ServerUtils } from "../../ServerUtil"; +import { DocServer } from "../../../client/DocServer"; +import { Doc } from "../../../new_fields/Doc"; +import { List } from "../../../new_fields/List"; +import { CollectionViewType } from "../../../client/views/collections/CollectionBaseView"; +import { CollectionTreeView } from "../../../client/views/collections/CollectionTreeView"; +import { CollectionView } from "../../../client/views/collections/CollectionView";  export class CurrentUserUtils {      private static curr_email: string;      private static curr_id: string; -    @observable private static user_document: Document; +    @observable private static user_document: Doc;      //TODO tfs: these should be temporary...      private static mainDocId: string | undefined; @@ -23,15 +24,21 @@ export class CurrentUserUtils {      public static get MainDocId() { return this.mainDocId; }      public static set MainDocId(id: string | undefined) { this.mainDocId = id; } -    private static createUserDocument(id: string): Document { -        let doc = new Document(id); -        doc.Set(KeyStore.Workspaces, new ListField<Document>()); -        doc.Set(KeyStore.OptionalRightCollection, Documents.SchemaDocument([], { title: "Pending documents" })); +    private static createUserDocument(id: string): Doc { +        let doc = new Doc(id, true); +        doc.viewType = CollectionViewType.Tree; +        doc.layout = CollectionView.LayoutString(); +        doc.title = this.email; +        doc.data = new List<Doc>(); +        doc.excludeFromLibrary = true; +        doc.optionalRightCollection = Docs.SchemaDocument([], { title: "Pending documents" }); +        // doc.library = Docs.TreeDocument([doc], { title: `Library: ${CurrentUserUtils.email}` }); +        // (doc.library as Doc).excludeFromLibrary = true;          return doc;      }      public static loadCurrentUser(): Promise<any> { -        let userPromise = rp.get(ServerUtils.prepend(RouteStore.getCurrUser)).then(response => { +        let userPromise = rp.get(DocServer.prepend(RouteStore.getCurrUser)).then(response => {              if (response) {                  let obj = JSON.parse(response);                  CurrentUserUtils.curr_id = obj.id as string; @@ -40,10 +47,10 @@ export class CurrentUserUtils {                  throw new Error("There should be a user! Why does Dash think there isn't one?");              }          }); -        let userDocPromise = rp.get(ServerUtils.prepend(RouteStore.getUserDocumentId)).then(id => { +        let userDocPromise = rp.get(DocServer.prepend(RouteStore.getUserDocumentId)).then(id => {              if (id) { -                return Server.GetField(id).then(field => -                    runInAction(() => this.user_document = field instanceof Document ? field : this.createUserDocument(id))); +                return DocServer.GetRefField(id).then(field => +                    runInAction(() => this.user_document = field instanceof Doc ? field : this.createUserDocument(id)));              } else {                  throw new Error("There should be a user id! Why does Dash think there isn't one?");              } | 
