diff options
Diffstat (limited to 'src/client/util/DocumentManager.ts')
| -rw-r--r-- | src/client/util/DocumentManager.ts | 51 | 
1 files changed, 35 insertions, 16 deletions
| diff --git a/src/client/util/DocumentManager.ts b/src/client/util/DocumentManager.ts index cb0ee411c..9e190ad02 100644 --- a/src/client/util/DocumentManager.ts +++ b/src/client/util/DocumentManager.ts @@ -1,19 +1,21 @@  import { action, observable, runInAction } from 'mobx';  import { Doc, DocListCast, DocListCastAsync, Opt } from '../../fields/Doc';  import { Id } from '../../fields/FieldSymbols'; -import { Cast, NumCast, StrCast } from '../../fields/Types'; +import { Cast } from '../../fields/Types';  import { returnFalse } from '../../Utils';  import { DocumentType } from '../documents/DocumentTypes';  import { CollectionDockingView } from '../views/collections/CollectionDockingView';  import { CollectionView } from '../views/collections/CollectionView';  import { LightboxView } from '../views/LightboxView';  import { DocumentView, ViewAdjustment } from '../views/nodes/DocumentView'; +import { LinkAnchorBox } from '../views/nodes/LinkAnchorBox';  import { Scripting } from './Scripting';  export class DocumentManager {      //global holds all of the nodes (regardless of which collection they're in)      @observable public DocumentViews: DocumentView[] = []; +    @observable public LinkAnchorBoxViews: DocumentView[] = [];      @observable public RecordingEvent = 0;      @observable public LinkedDocumentViews: { a: DocumentView, b: DocumentView, l: Doc }[] = []; @@ -25,24 +27,41 @@ export class DocumentManager {      @action      public AddView = (view: DocumentView) => { -        DocListCast(view.rootDoc.links).forEach(link => { -            const whichOtherAnchor = view.props.LayoutTemplateString?.includes("anchor2") ? "anchor1" : "anchor2"; -            const otherDoc = link && (link[whichOtherAnchor] as Doc); -            const otherDocAnno = DocumentType.MARKER === otherDoc?.type ? otherDoc.annotationOn as Doc : undefined; -            otherDoc && DocumentManager.Instance.DocumentViews?.filter(dv => Doc.AreProtosEqual(dv.rootDoc, otherDoc) || Doc.AreProtosEqual(dv.rootDoc, otherDocAnno)). -                forEach(otherView => { -                    if (otherView.rootDoc.type !== DocumentType.LINK || otherView.props.LayoutTemplateString !== view.props.LayoutTemplateString) { -                        this.LinkedDocumentViews.push({ a: whichOtherAnchor === "anchor1" ? otherView : view, b: whichOtherAnchor === "anchor1" ? view : otherView, l: link }); -                    } -                }); -        }); -        this.DocumentViews.push(view); +        //console.log("MOUNT " + view.props.Document.title + "/" + view.props.LayoutTemplateString); +        if (view.props.LayoutTemplateString?.includes(LinkAnchorBox.name)) { +            const viewAnchorIndex = view.props.LayoutTemplateString.includes("anchor2") ? "anchor2" : "anchor1"; +            DocListCast(view.rootDoc.links).forEach(link => { +                this.LinkAnchorBoxViews?.filter(dv => Doc.AreProtosEqual(dv.rootDoc, link) && !dv.props.LayoutTemplateString?.includes(viewAnchorIndex)). +                    forEach(otherView => this.LinkedDocumentViews.push( +                        { +                            a: viewAnchorIndex === "anchor2" ? otherView : view, +                            b: viewAnchorIndex === "anchor2" ? view : otherView, +                            l: link +                        }) +                    ); +            }); +            this.LinkAnchorBoxViews.push(view); +            // this.LinkedDocumentViews.forEach(view => console.log("  LV = " + view.a.props.Document.title + "/" + view.a.props.LayoutTemplateString + " --> " + +            //     view.b.props.Document.title + "/" + view.b.props.LayoutTemplateString)); +        } else { +            this.DocumentViews.push(view); +        }      }      public RemoveView = action((view: DocumentView) => { -        const index = this.DocumentViews.indexOf(view); -        index !== -1 && this.DocumentViews.splice(index, 1); +        this.LinkedDocumentViews.slice().forEach(action(pair => { +            if (pair.a === view || pair.b === view) { +                const li = this.LinkedDocumentViews.indexOf(pair); +                li !== -1 && this.LinkedDocumentViews.splice(li, 1); +            } +        })); -        this.LinkedDocumentViews.slice().forEach(action((pair, i) => pair.a === view || pair.b === view ? this.LinkedDocumentViews.splice(i, 1) : null)); +        if (view.props.LayoutTemplateString?.includes(LinkAnchorBox.name)) { +            const index = this.LinkAnchorBoxViews.indexOf(view); +            this.LinkAnchorBoxViews.splice(index, 1); +        } else { +            const index = this.DocumentViews.indexOf(view); +            index !== -1 && this.DocumentViews.splice(index, 1); +        }      });      //gets all views | 
