diff options
Diffstat (limited to 'src/client/views/nodes/PDFBox.tsx')
| -rw-r--r-- | src/client/views/nodes/PDFBox.tsx | 112 | 
1 files changed, 60 insertions, 52 deletions
| diff --git a/src/client/views/nodes/PDFBox.tsx b/src/client/views/nodes/PDFBox.tsx index 8f61e252b..23236cf20 100644 --- a/src/client/views/nodes/PDFBox.tsx +++ b/src/client/views/nodes/PDFBox.tsx @@ -3,13 +3,13 @@ import { action, computed, IReactionDisposer, observable, reaction, runInAction  import { observer } from "mobx-react";  import * as Pdfjs from "pdfjs-dist";  import "pdfjs-dist/web/pdf_viewer.css"; -import { Doc, Opt, WidthSym } from "../../../fields/Doc"; +import { Doc, Opt, WidthSym, DocListCast } from "../../../fields/Doc";  import { documentSchema } from '../../../fields/documentSchemas';  import { makeInterface } from "../../../fields/Schema"; -import { Cast, NumCast, StrCast } from '../../../fields/Types'; +import { Cast, NumCast, StrCast, BoolCast } from '../../../fields/Types';  import { PdfField } from "../../../fields/URLField";  import { TraceMobx } from '../../../fields/util'; -import { Utils, setupMoveUpEvents, emptyFunction } from '../../../Utils'; +import { Utils, setupMoveUpEvents, emptyFunction, returnOne } from '../../../Utils';  import { Docs } from '../../documents/Documents';  import { KeyCodes } from '../../util/KeyCodes';  import { undoBatch } from '../../util/UndoManager'; @@ -31,6 +31,7 @@ const PdfDocument = makeInterface(documentSchema, panZoomSchema, pageSchema);  @observer  export class PDFBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps & FieldViewProps, PdfDocument>(PdfDocument) {      public static LayoutString(fieldKey: string) { return FieldView.LayoutString(PDFBox, fieldKey); } +    public static openSidebarWidth = 250;      private _searchString: string = "";      private _initialScrollTarget: Opt<Doc>;      private _pdfViewer: PDFViewer | undefined; @@ -53,30 +54,6 @@ export class PDFBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps              if (PDFBox.pdfcache.get(this.pdfUrl.url.href)) runInAction(() => this._pdf = PDFBox.pdfcache.get(this.pdfUrl!.url.href));              else if (PDFBox.pdfpromise.get(this.pdfUrl.url.href)) PDFBox.pdfpromise.get(this.pdfUrl.url.href)?.then(action(pdf => this._pdf = pdf));          } - -        const backup = "oldPath"; -        const href = this.pdfUrl?.url.href; -        if (href) { -            const pathCorrectionTest = /upload\_[a-z0-9]{32}.(.*)/g; -            const matches = pathCorrectionTest.exec(href); -            // console.log("\nHere's the { url } being fed into the outer regex:"); -            // console.log(href); -            // console.log("And here's the 'properPath' build from the captured filename:\n"); -            if (matches !== null && href.startsWith(window.location.origin)) { -                const properPath = Utils.prepend(`/files/pdfs/${matches[0]}`); -                //console.log(properPath); -                if (!properPath.includes(href)) { -                    console.log(`The two (url and proper path) were not equal`); -                    const proto = Doc.GetProto(this.props.Document); -                    proto[this.props.fieldKey] = new PdfField(properPath); -                    proto[backup] = href; -                } else { -                    //console.log(`The two (url and proper path) were equal`); -                } -            } else { -                console.log("Outer matches was null!"); -            } -        }      }      componentWillUnmount() { this._selectReactionDisposer?.(); } @@ -90,6 +67,9 @@ export class PDFBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps      }      scrollFocus = (doc: Doc, smooth: boolean) => { +        if (DocListCast(this.props.Document[this.fieldKey + "-sidebar"]).includes(doc) && !this.SidebarShown) { +            this.toggleSidebar(!smooth); +        }          if (this._sidebarRef?.current?.makeDocUnfiltered(doc)) return 1;          this._initialScrollTarget = doc;          return this._pdfViewer?.scrollFocus(doc, smooth); @@ -165,15 +145,24 @@ export class PDFBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps                  this.layoutDoc._showSidebar = nativeWidth !== this.layoutDoc._nativeWidth;              }              return false; -        }, emptyFunction, this.toggleSidebar); +        }, emptyFunction, () => this.toggleSidebar());      } -    toggleSidebar = action(() => { +    @observable _previewNativeWidth: Opt<number> = undefined; +    @observable _previewWidth: Opt<number> = undefined; +    toggleSidebar = action((preview: boolean = false) => {          const nativeWidth = NumCast(this.layoutDoc[this.fieldKey + "-nativeWidth"]); -        const ratio = ((!this.layoutDoc.nativeWidth || this.layoutDoc.nativeWidth === nativeWidth ? 250 : 0) + nativeWidth) / nativeWidth; +        const ratio = ((!this.layoutDoc.nativeWidth || this.layoutDoc.nativeWidth === nativeWidth ? PDFBox.openSidebarWidth : 0) + nativeWidth) / nativeWidth;          const curNativeWidth = NumCast(this.layoutDoc.nativeWidth, nativeWidth); -        this.layoutDoc.nativeWidth = nativeWidth * ratio; -        this.layoutDoc._width = this.layoutDoc[WidthSym]() * nativeWidth * ratio / curNativeWidth; -        this.layoutDoc._showSidebar = nativeWidth !== this.layoutDoc._nativeWidth; +        if (preview) { +            this._previewNativeWidth = nativeWidth * ratio; +            this._previewWidth = this.layoutDoc[WidthSym]() * nativeWidth * ratio / curNativeWidth; +            this._showSidebar = true; +        } +        else { +            this.layoutDoc.nativeWidth = nativeWidth * ratio; +            this.layoutDoc._width = this.layoutDoc[WidthSym]() * nativeWidth * ratio / curNativeWidth; +            this.layoutDoc._showSidebar = nativeWidth !== this.layoutDoc._nativeWidth; +        }      });      settingsPanel() {          const pageBtns = <> @@ -226,7 +215,9 @@ export class PDFBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps                  </button>              </div>;      } -    sidebarWidth = () => !this.layoutDoc._showSidebar ? 0 : (NumCast(this.layoutDoc.nativeWidth) - Doc.NativeWidth(this.dataDoc)) * this.props.PanelWidth() / NumCast(this.layoutDoc.nativeWidth); +    sidebarWidth = () => !this.SidebarShown ? 0 : +        this._previewWidth ? PDFBox.openSidebarWidth : +            (NumCast(this.layoutDoc.nativeWidth) - Doc.NativeWidth(this.dataDoc)) * this.props.PanelWidth() / NumCast(this.layoutDoc.nativeWidth)      specificContextMenu = (e: React.MouseEvent): void => {          const funcs: ContextMenuProps[] = []; @@ -247,38 +238,55 @@ export class PDFBox extends ViewBoxAnnotatableComponent<ViewBoxAnnotatableProps      }      anchorMenuClick = () => this._sidebarRef.current?.anchorMenuClick; +    @observable _showSidebar = false; +    @computed get SidebarShown() { return this._showSidebar || this.layoutDoc._showSidebar ? true : false; } +    contentScaling = () => { +        return 1; +    }      @computed get renderPdfView() {          TraceMobx(); +        const previewScale = this._previewNativeWidth ? 1 - this.sidebarWidth() / this._previewNativeWidth : 1; +        const scale = previewScale * (this.props.scaling?.() || 1);          return <div className={"pdfBox"} onContextMenu={this.specificContextMenu}              style={{                  height: this.props.Document._scrollTop && !this.Document._fitWidth && (window.screen.width > 600) ?                      NumCast(this.Document._height) * this.props.PanelWidth() / NumCast(this.Document._width) : undefined              }}>              <div className="pdfBox-background" /> -            <PDFViewer {...this.props} -                rootDoc={this.rootDoc} -                layoutDoc={this.layoutDoc} -                dataDoc={this.dataDoc} -                pdf={this._pdf!} -                url={this.pdfUrl!.url.pathname} -                isContentActive={this.isContentActive} -                anchorMenuClick={this.anchorMenuClick} -                loaded={!Doc.NativeAspect(this.dataDoc) ? this.loaded : undefined} -                setPdfViewer={this.setPdfViewer} -                addDocument={this.addDocument} -                moveDocument={this.moveDocument} -                removeDocument={this.removeDocument} -                whenChildContentsActiveChanged={this.whenChildContentsActiveChanged} -                startupLive={true} -                ContentScaling={this.props.scaling} -                sidebarWidth={this.sidebarWidth} -            /> +            <div style={{ +                width: `calc(${100 / scale}% - ${this.sidebarWidth() / scale * (this._previewWidth ? scale : 1)}px)`, +                height: `${100 / scale}%`, +                transform: `scale(${scale})`, +                position: "absolute", +                transformOrigin: "top left", +                top: 0 +            }}> +                <PDFViewer {...this.props} +                    rootDoc={this.rootDoc} +                    layoutDoc={this.layoutDoc} +                    dataDoc={this.dataDoc} +                    pdf={this._pdf!} +                    url={this.pdfUrl!.url.pathname} +                    isContentActive={this.isContentActive} +                    anchorMenuClick={this.anchorMenuClick} +                    loaded={!Doc.NativeAspect(this.dataDoc) ? this.loaded : undefined} +                    setPdfViewer={this.setPdfViewer} +                    addDocument={this.addDocument} +                    moveDocument={this.moveDocument} +                    removeDocument={this.removeDocument} +                    whenChildContentsActiveChanged={this.whenChildContentsActiveChanged} +                    startupLive={true} +                    ContentScaling={returnOne} +                /> +            </div>              <SidebarAnnos ref={this._sidebarRef}                  {...this.props}                  rootDoc={this.rootDoc}                  layoutDoc={this.layoutDoc}                  dataDoc={this.dataDoc} +                nativeWidth={this._previewNativeWidth ?? NumCast(this.layoutDoc._nativeWidth)} +                showSidebar={this.SidebarShown}                  whenChildContentsActiveChanged={this.whenChildContentsActiveChanged}                  sidebarAddDocument={this.sidebarAddDocument}                  moveDocument={this.moveDocument} | 
