aboutsummaryrefslogtreecommitdiff
path: root/src/client/util/LinkManager.ts
blob: 99fb4c6c0552aa06bdf3dccbe8c283e0aa20cb69 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
import { observable, computed, action } from "mobx";
import React = require("react");
import { SelectionManager } from "./SelectionManager";
import { observer } from "mobx-react";
import { props } from "bluebird";
import { DocumentView } from "../views/nodes/DocumentView";
import { link } from "fs";
import { StrCast, Cast } from "../../new_fields/Types";
import { Doc } from "../../new_fields/Doc";
import { listSpec } from "../../new_fields/Schema";
import { List } from "../../new_fields/List";

export namespace LinkUtils {
    export function findOppositeAnchor(link: Doc, anchor: Doc): Doc {
        if (Doc.AreProtosEqual(anchor, Cast(link.anchor1, Doc, new Doc))) {
            return Cast(link.anchor2, Doc, new Doc);
        } else {
            return Cast(link.anchor1, Doc, new Doc);
        }
    }

    // export function getAnchorGroups(link: Doc, anchor: Doc): Doc[] {
    //     let groups;
    //     if (Doc.AreProtosEqual(anchor, Cast(link.anchor1, Doc, new Doc))) {
    //         groups = Cast(link.anchor1Groups, listSpec(Doc), []);
    //     } else {
    //         groups = Cast(link.anchor2Groups, listSpec(Doc), []);
    //     }

    //     if (groups instanceof Doc[]) {
    //         return groups;
    //     } else {
    //         return [];
    //     }
    //     // if (Doc.AreProtosEqual(anchor, Cast(link.anchor1, Doc, new Doc))) {
    //     //     returnCast(link.anchor1Groups, listSpec(Doc), []);
    //     // } else {
    //     //     return Cast(link.anchor2Groups, listSpec(Doc), []);
    //     // }
    // }

    export function setAnchorGroups(link: Doc, anchor: Doc, groups: Doc[]) {
        if (Doc.AreProtosEqual(anchor, Cast(link.anchor1, Doc, new Doc))) {
            link.anchor1Groups = new List<Doc>(groups);
        } else {
            link.anchor2Groups = new List<Doc>(groups);
        }
    }
}

export class LinkManager {
    private static _instance: LinkManager;
    public static get Instance(): LinkManager {
        return this._instance || (this._instance = new this());
    }
    private constructor() {
    }

    @observable public allLinks: Array<Doc> = [];
    @observable public allGroups: Map<string, Array<string>> = new Map();

    public findAllRelatedLinks(anchor: Doc): Array<Doc> {
        return LinkManager.Instance.allLinks.filter(
            link => Doc.AreProtosEqual(anchor, Cast(link.anchor1, Doc, new Doc)) || Doc.AreProtosEqual(anchor, Cast(link.anchor2, Doc, new Doc)));
    }

    public findRelatedGroupedLinks(anchor: Doc): Map<string, Array<Doc>> {
        let related = this.findAllRelatedLinks(anchor);

        let anchorGroups = new Map();
        related.forEach(link => {
            // get groups of given doc
            let oppGroups = (Doc.AreProtosEqual(anchor, Cast(link.anchor1, Doc, new Doc))) ? Cast(link.anchor1Groups, listSpec(Doc), []) : Cast(link.anchor2Groups, listSpec(Doc), []);
            if (oppGroups) {
                if (oppGroups.length > 0) {
                    oppGroups.forEach(groupDoc => {
                        if (groupDoc instanceof Doc) {
                            let groupType = StrCast(groupDoc.proto!.type);
                            let group = anchorGroups.get(groupType); // TODO: clean this up lol
                            if (group) group.push(link);
                            else group = [link];
                            anchorGroups.set(groupType, group);
                        } else {
                            // promise doc
                        }

                    })
                }
                else {
                    // if link is in no groups then put it in default group
                    let group = anchorGroups.get("*");
                    if (group) group.push(link);
                    else group = [link];
                    anchorGroups.set("*", group);
                }
            }


            //     let anchor = this.findOppositeAnchor(link, source);
            //     let group = categories.get(link.linkTags);
            //     if (group) group.push(link);
            //     else group = [link];
            //     categories.set(link.linkTags, group);
        })
        return anchorGroups;
    }




    // public findAnchorTags(link: Doc, source: Doc): Doc[] {
    //     if (source)
    // }

}