diff options
Diffstat (limited to 'src/client/util/DocumentManager.ts')
| -rw-r--r-- | src/client/util/DocumentManager.ts | 90 | 
1 files changed, 75 insertions, 15 deletions
| diff --git a/src/client/util/DocumentManager.ts b/src/client/util/DocumentManager.ts index 69964e2c9..65c4b9e4b 100644 --- a/src/client/util/DocumentManager.ts +++ b/src/client/util/DocumentManager.ts @@ -1,8 +1,14 @@  import { computed, observable } from 'mobx';  import { DocumentView } from '../views/nodes/DocumentView'; -import { Doc } from '../../new_fields/Doc'; -import { FieldValue, Cast } from '../../new_fields/Types'; +import { Doc, DocListCast, Opt } from '../../new_fields/Doc'; +import { FieldValue, Cast, NumCast, BoolCast } from '../../new_fields/Types';  import { listSpec } from '../../new_fields/Schema'; +import { undoBatch } from './UndoManager'; +import { CollectionDockingView } from '../views/collections/CollectionDockingView'; +import { CollectionView } from '../views/collections/CollectionView'; +import { CollectionPDFView } from '../views/collections/CollectionPDFView'; +import { CollectionVideoView } from '../views/collections/CollectionVideoView'; +import { Id } from '../../new_fields/FieldSymbols';  export class DocumentManager { @@ -24,28 +30,35 @@ export class DocumentManager {          // this.DocumentViews = new Array<DocumentView>();      } -    public getDocumentView(toFind: Doc): DocumentView | null { +    public getDocumentViewById(id: string, preferredCollection?: CollectionView | CollectionPDFView | CollectionVideoView): DocumentView | null {          let toReturn: DocumentView | null = null; +        let passes = preferredCollection ? [preferredCollection, undefined] : [undefined]; -        //gets document view that is in a freeform canvas collection -        DocumentManager.Instance.DocumentViews.map(view => { -            if (view.props.Document === toFind) { -                toReturn = view; -                return; -            } -        }); -        if (!toReturn) { +        for (let i = 0; i < passes.length; i++) {              DocumentManager.Instance.DocumentViews.map(view => { -                let doc = view.props.Document.proto; -                if (doc && Object.is(doc, toFind)) { +                if (view.props.Document[Id] === id && (!passes[i] || view.props.ContainingCollectionView === preferredCollection)) {                      toReturn = view; +                    return;                  }              }); +            if (!toReturn) { +                DocumentManager.Instance.DocumentViews.map(view => { +                    let doc = view.props.Document.proto; +                    if (doc && doc[Id] === id && (!passes[i] || view.props.ContainingCollectionView === preferredCollection)) { +                        toReturn = view; +                    } +                }); +            }          }          return toReturn;      } + +    public getDocumentView(toFind: Doc, preferredCollection?: CollectionView | CollectionPDFView | CollectionVideoView): DocumentView | null { +        return this.getDocumentViewById(toFind[Id], preferredCollection); +    } +      public getDocumentViews(toFind: Doc): DocumentView[] {          let toReturn: DocumentView[] = []; @@ -70,8 +83,8 @@ export class DocumentManager {      @computed      public get LinkedDocumentViews() { -        return DocumentManager.Instance.DocumentViews.reduce((pairs, dv) => { -            let linksList = Cast(dv.props.Document.linkedToDocs, listSpec(Doc)); +        return DocumentManager.Instance.DocumentViews.filter(dv => dv.isSelected() || BoolCast(dv.props.Document.libraryBrush, false)).reduce((pairs, dv) => { +            let linksList = DocListCast(dv.props.Document.linkedToDocs);              if (linksList && linksList.length) {                  pairs.push(...linksList.reduce((pairs, link) => {                      if (link) { @@ -84,7 +97,54 @@ export class DocumentManager {                      return pairs;                  }, [] as { a: DocumentView, b: DocumentView, l: Doc }[]));              } +            linksList = DocListCast(dv.props.Document.linkedFromDocs); +            if (linksList && linksList.length) { +                pairs.push(...linksList.reduce((pairs, link) => { +                    if (link) { +                        let linkFromDoc = FieldValue(Cast(link.linkedFrom, Doc)); +                        if (linkFromDoc) { +                            DocumentManager.Instance.getDocumentViews(linkFromDoc).map(docView1 => +                                pairs.push({ a: dv, b: docView1, l: link })); +                        } +                    } +                    return pairs; +                }, pairs)); +            }              return pairs;          }, [] as { a: DocumentView, b: DocumentView, l: Doc }[]);      } + +    @undoBatch +    public jumpToDocument = async (docDelegate: Doc, forceDockFunc: boolean = false, dockFunc?: (doc: Doc) => void, linkPage?: number): Promise<void> => { +        let doc = Doc.GetProto(docDelegate); +        const contextDoc = await Cast(doc.annotationOn, Doc); +        if (contextDoc) { +            const page = NumCast(doc.page, linkPage || 0); +            const curPage = NumCast(contextDoc.curPage, page); +            if (page !== curPage) contextDoc.curPage = page; +        } +        let docView: DocumentView | null; +        // using forceDockFunc as a flag for splitting linked to doc to the right...can change later if needed +        if (!forceDockFunc && (docView = DocumentManager.Instance.getDocumentView(doc))) { +            docView.props.Document.libraryBrush = true; +            if (linkPage !== undefined) docView.props.Document.curPage = linkPage; +            docView.props.focus(docView.props.Document); +        } else { +            if (!contextDoc) { +                const actualDoc = Doc.MakeAlias(docDelegate); +                actualDoc.libraryBrush = true; +                if (linkPage !== undefined) actualDoc.curPage = linkPage; +                (dockFunc || CollectionDockingView.Instance.AddRightSplit)(actualDoc); +            } else { +                let contextView: DocumentView | null; +                docDelegate.libraryBrush = true; +                if (!forceDockFunc && (contextView = DocumentManager.Instance.getDocumentView(contextDoc))) { +                    contextDoc.panTransformType = "Ease"; +                    contextView.props.focus(contextDoc); +                } else { +                    (dockFunc || CollectionDockingView.Instance.AddRightSplit)(contextDoc); +                } +            } +        } +    }  }
\ No newline at end of file | 
