diff options
Diffstat (limited to 'src/client/views/pdf/PDFViewer.tsx')
| -rw-r--r-- | src/client/views/pdf/PDFViewer.tsx | 46 | 
1 files changed, 26 insertions, 20 deletions
| diff --git a/src/client/views/pdf/PDFViewer.tsx b/src/client/views/pdf/PDFViewer.tsx index 02010e123..3f7f38bdf 100644 --- a/src/client/views/pdf/PDFViewer.tsx +++ b/src/client/views/pdf/PDFViewer.tsx @@ -2,14 +2,13 @@ import { action, computed, IReactionDisposer, observable, ObservableMap, reactio  import { observer } from "mobx-react";  import * as Pdfjs from "pdfjs-dist";  import "pdfjs-dist/web/pdf_viewer.css"; -import { DataSym, Doc, DocListCast, Field, HeightSym, Opt, WidthSym } from "../../../fields/Doc"; +import { Doc, DocListCast, Field, HeightSym, Opt, WidthSym } from "../../../fields/Doc";  import { Id } from "../../../fields/FieldSymbols";  import { InkTool } from "../../../fields/InkField"; -import { createSchema } from "../../../fields/Schema";  import { Cast, NumCast, ScriptCast, StrCast } from "../../../fields/Types";  import { PdfField } from "../../../fields/URLField";  import { TraceMobx } from "../../../fields/util"; -import { addStyleSheet, addStyleSheetRule, clearStyleSheetRules, emptyFunction, OmitKeys, smoothScroll, Utils, returnFalse, returnEmptyString, returnEmptyFilter } from "../../../Utils"; +import { addStyleSheet, addStyleSheetRule, clearStyleSheetRules, emptyFunction, OmitKeys, smoothScroll, Utils } from "../../../Utils";  import { DocUtils } from "../../documents/Documents";  import { Networking } from "../../Network";  import { CurrentUserUtils } from "../../util/CurrentUserUtils"; @@ -17,10 +16,13 @@ import { CompiledScript, CompileScript } from "../../util/Scripting";  import { SelectionManager } from "../../util/SelectionManager";  import { SharingManager } from "../../util/SharingManager";  import { SnappingManager } from "../../util/SnappingManager"; +import { MarqueeOptionsMenu } from "../collections/collectionFreeForm";  import { CollectionFreeFormView } from "../collections/collectionFreeForm/CollectionFreeFormView";  import { MarqueeAnnotator } from "../MarqueeAnnotator"; +import { DocumentViewProps } from "../nodes/DocumentView";  import { FieldViewProps } from "../nodes/FieldView";  import { LinkDocPreview } from "../nodes/LinkDocPreview"; +import { StyleProp } from "../StyleProvider";  import { AnchorMenu } from "./AnchorMenu";  import { Annotation } from "./Annotation";  import "./PDFViewer.scss"; @@ -126,12 +128,6 @@ export class PDFViewer extends React.Component<IViewerProps> {                  }              }); -        this._disposers.searchMatch = reaction(() => Doc.IsSearchMatch(this.props.rootDoc), -            m => { -                if (m) (this._lastSearch = true) && this.search(Doc.SearchQuery(), m.searchMatch > 0); -                else !(this._lastSearch = false) && setTimeout(() => !this._lastSearch && this.search("", false, true), 200); -            }, { fireImmediately: true }); -          this._disposers.selected = reaction(() => this.props.isSelected(),              selected => {                  // if (!selected) { @@ -186,7 +182,7 @@ export class PDFViewer extends React.Component<IViewerProps> {          let focusSpeed: Opt<number>;          if (doc !== this.props.rootDoc && mainCont) {              const windowHeight = this.props.PanelHeight() / (this.props.scaling?.() || 1); -            const scrollTo = Utils.scrollIntoView(NumCast(doc.y), doc[HeightSym](), NumCast(this.props.layoutDoc._scrollTop), windowHeight, .1 * windowHeight); +            const scrollTo = doc.unrendered ? NumCast(doc.y) : Utils.scrollIntoView(NumCast(doc.y), doc[HeightSym](), NumCast(this.props.layoutDoc._scrollTop), windowHeight, .1 * windowHeight);              if (scrollTo !== undefined) {                  focusSpeed = 500; @@ -338,10 +334,10 @@ export class PDFViewer extends React.Component<IViewerProps> {      }      @action -    search = (searchString: string, fwd: boolean, clear: boolean = false) => { +    search = (searchString: string, bwd?: boolean, clear: boolean = false) => {          const findOpts = {              caseSensitive: false, -            findPrevious: !fwd, +            findPrevious: bwd,              highlightAll: true,              phraseSearch: true,              query: searchString @@ -349,7 +345,7 @@ export class PDFViewer extends React.Component<IViewerProps> {          if (clear) {              this._pdfViewer?.findController.executeCommand('reset', { query: "" });          } else if (!searchString) { -            fwd ? this.nextAnnotation() : this.prevAnnotation(); +            bwd ? this.prevAnnotation() : this.nextAnnotation();          } else if (this._pdfViewer?.pageViewsReady) {              this._pdfViewer.findController.executeCommand('findagain', findOpts);          } @@ -358,6 +354,7 @@ export class PDFViewer extends React.Component<IViewerProps> {              this._mainCont.current.addEventListener("pagesloaded", executeFind);              this._mainCont.current.addEventListener("pagerendered", executeFind);          } +        return true;      }      @action @@ -487,11 +484,12 @@ export class PDFViewer extends React.Component<IViewerProps> {          }      } +    pointerEvents = () => this.props.isContentActive() && this.props.pointerEvents !== "none" && !MarqueeOptionsMenu.Instance.isShown() ? "all" : SnappingManager.GetIsDragging() ? undefined : "none";      @computed get annotationLayer() { +        const pe = this.pointerEvents();          return <div className="pdfViewerDash-annotationLayer" style={{ height: Doc.NativeHeight(this.props.Document), transform: `scale(${this._zoomed})` }} ref={this._annotationLayer}>              {this.inlineTextAnnotations.sort((a, b) => NumCast(a.y) - NumCast(b.y)).map(anno => -                <Annotation {...this.props} fieldKey={this.props.fieldKey + "-annotations"} showInfo={this.showInfo} dataDoc={this.props.dataDoc} anno={anno} key={`${anno[Id]}-annotation`} />) -            } +                <Annotation {...this.props} fieldKey={this.props.fieldKey + "-annotations"} pointerEvents={pe} showInfo={this.showInfo} dataDoc={this.props.dataDoc} anno={anno} key={`${anno[Id]}-annotation`} />)}          </div>;      } @@ -508,8 +506,16 @@ export class PDFViewer extends React.Component<IViewerProps> {      overlayTransform = () => this.scrollXf().scale(1 / this._zoomed);      panelWidth = () => this.props.PanelWidth() / (this.props.scaling?.() || 1); // (this.Document.scrollHeight || Doc.NativeHeight(this.Document) || 0);      panelHeight = () => this.props.PanelHeight() / (this.props.scaling?.() || 1); // () => this._pageSizes.length && this._pageSizes[0] ? this._pageSizes[0].width : Doc.NativeWidth(this.Document); +    basicFilter = () => [...this.props.docFilters(), Utils.PropUnsetFilter("textInlineAnnotations")];      transparentFilter = () => [...this.props.docFilters(), Utils.IsTransparentFilter()];      opaqueFilter = () => [...this.props.docFilters(), Utils.IsOpaqueFilter()]; +    childStyleProvider = (doc: (Doc | undefined), props: Opt<DocumentViewProps>, property: string): any => { +        if (doc instanceof Doc && property === StyleProp.PointerEvents) { +            if (doc.textInlineAnnotations) return "none"; +            return "all"; +        } +        return this.props.styleProvider?.(doc, props, property); +    }      @computed get overlayLayer() {          const renderAnnotations = (docFilters?: () => string[]) =>              <CollectionFreeFormView {...OmitKeys(this.props, ["NativeWidth", "NativeHeight", "setContentView"]).omit} @@ -522,12 +528,12 @@ export class PDFViewer extends React.Component<IViewerProps> {                  select={emptyFunction}                  ContentScaling={this.contentZoom}                  bringToFront={emptyFunction} -                docFilters={docFilters || this.props.docFilters} +                docFilters={docFilters || this.basicFilter} +                styleProvider={this.childStyleProvider}                  dontRenderDocuments={docFilters ? false : true}                  CollectionView={undefined}                  ScreenToLocalTransform={this.overlayTransform} -                renderDepth={this.props.renderDepth + 1} -                childPointerEvents={true} />; +                renderDepth={this.props.renderDepth + 1} />;          return <div>              <div className={`pdfViewerDash-overlay${CurrentUserUtils.SelectedTool !== InkTool.None || SnappingManager.GetIsDragging() ? "-inking" : ""}`}                  style={{ @@ -549,7 +555,7 @@ export class PDFViewer extends React.Component<IViewerProps> {          </div>;      }      @computed get pdfViewerDiv() { -        return <div className={"pdfViewerDash-text" + (this._textSelecting && (this.props.isSelected() || this.props.isContentActive()) ? "-selected" : "")} ref={this._viewer} />; +        return <div className={"pdfViewerDash-text" + (this.props.pointerEvents !== "none" && this._textSelecting && (this.props.isSelected() || this.props.isContentActive()) ? "-selected" : "")} ref={this._viewer} />;      }      @computed get contentScaling() { return this.props.ContentScaling?.() || 1; }      @computed get standinViews() { @@ -562,7 +568,7 @@ export class PDFViewer extends React.Component<IViewerProps> {      render() {          TraceMobx();          return <div className="pdfViewer-content"> -            <div className={`pdfViewerDash${this.props.isContentActive() ? "-interactive" : ""}`} ref={this._mainCont} +            <div className={`pdfViewerDash${this.props.isContentActive() && this.props.pointerEvents !== "none" ? "-interactive" : ""}`} ref={this._mainCont}                  onScroll={this.onScroll} onWheel={this.onZoomWheel} onPointerDown={this.onPointerDown} onClick={this.onClick}                  style={{                      overflowX: this._zoomed !== 1 ? "scroll" : undefined, | 
