diff options
| author | andrewdkim <adkim414@gmail.com> | 2019-09-29 14:18:45 -0400 | 
|---|---|---|
| committer | andrewdkim <adkim414@gmail.com> | 2019-09-29 14:18:45 -0400 | 
| commit | 97f8d0fc8c0ccf79c2b858a2181e201960d01d8b (patch) | |
| tree | 16853d246ade3925bc6b424f3b83dd3534fa1e9a /src/client/views/nodes/PDFBox.tsx | |
| parent | 8c018a7a686a752ef1b86b852ec2d298792aa354 (diff) | |
| parent | c40480ec1a2da84b4223b0605bea2fe19df1104c (diff) | |
Merge branch 'master' of https://github.com/browngraphicslab/Dash-Web into animationtimeline_two
Diffstat (limited to 'src/client/views/nodes/PDFBox.tsx')
| -rw-r--r-- | src/client/views/nodes/PDFBox.tsx | 20 | 
1 files changed, 16 insertions, 4 deletions
| diff --git a/src/client/views/nodes/PDFBox.tsx b/src/client/views/nodes/PDFBox.tsx index 0fcbaaa7c..fe71e76fd 100644 --- a/src/client/views/nodes/PDFBox.tsx +++ b/src/client/views/nodes/PDFBox.tsx @@ -20,6 +20,9 @@ import { pageSchema } from "./ImageBox";  import "./PDFBox.scss";  import React = require("react");  import { undoBatch } from '../../util/UndoManager'; +import { ContextMenuProps } from '../ContextMenuItem'; +import { ContextMenu } from '../ContextMenu'; +import { Utils } from '../../../Utils';  type PdfDocument = makeInterface<[typeof documentSchema, typeof panZoomSchema, typeof pageSchema]>;  const PdfDocument = makeInterface(documentSchema, panZoomSchema, pageSchema); @@ -58,7 +61,7 @@ export class PDFBox extends DocComponent<FieldViewProps, PdfDocument>(PdfDocumen              this.Document.nativeWidth = nw * 96 / 72;              this.Document.nativeHeight = this.Document.nativeHeight ? nw * 96 / 72 * oldaspect : nh * 96 / 72;          } -        this.Document.height = this.Document[WidthSym]() * (nh / nw); +        !this.Document.fitWidth && !this.Document.ignoreAspect && (this.Document.height = this.Document[WidthSym]() * (nh / nw));      }      public search(string: string, fwd: boolean) { this._pdfViewer && this._pdfViewer.search(string, fwd); } @@ -165,14 +168,23 @@ export class PDFBox extends DocComponent<FieldViewProps, PdfDocument>(PdfDocumen              </div>);      } +    specificContextMenu = (e: React.MouseEvent): void => { +        const pdfUrl = Cast(this.dataDoc[this.props.fieldKey], PdfField); +        let funcs: ContextMenuProps[] = []; +        pdfUrl && funcs.push({ description: "Copy path", event: () => Utils.CopyText(pdfUrl.url.pathname), icon: "expand-arrows-alt" }); +        funcs.push({ description: "Toggle Fit Width " + (this.Document.fitWidth ? "Off" : "On"), event: () => this.Document.fitWidth = !this.Document.fitWidth, icon: "expand-arrows-alt" }); + +        ContextMenu.Instance.addItem({ description: "Pdf Funcs...", subitems: funcs, icon: "asterisk" }); +    } +      render() {          const pdfUrl = Cast(this.dataDoc[this.props.fieldKey], PdfField);          let classname = "pdfBox-cont" + (InkingControl.Instance.selectedTool || !this.active ? "" : "-interactive");          return (!(pdfUrl instanceof PdfField) || !this._pdf ?              <div>{`pdf, ${this.dataDoc[this.props.fieldKey]}, not found`}</div> : -            <div className={classname} onPointerDown={(e: React.PointerEvent) => { +            <div className={classname} onContextMenu={this.specificContextMenu} onPointerDown={(e: React.PointerEvent) => {                  let hit = document.elementFromPoint(e.clientX, e.clientY); -                if (hit && hit.localName === "span" && this.props.isSelected()) { +                if (hit && hit.localName === "span" && this.props.isSelected()) {  // drag selecting text stops propagation                      e.button === 0 && e.stopPropagation();                  }              }}> @@ -182,7 +194,7 @@ export class PDFBox extends DocComponent<FieldViewProps, PdfDocument>(PdfDocumen                      Document={this.props.Document} DataDoc={this.dataDoc} ContentScaling={this.props.ContentScaling}                      addDocTab={this.props.addDocTab} GoToPage={this.gotoPage}                      pinToPres={this.props.pinToPres} addDocument={this.props.addDocument} -                    ScreenToLocalTransform={this.props.ScreenToLocalTransform} +                    ScreenToLocalTransform={this.props.ScreenToLocalTransform} select={this.props.select}                      isSelected={this.props.isSelected} whenActiveChanged={this.whenActiveChanged}                      fieldKey={this.props.fieldKey} fieldExtensionDoc={this.extensionDoc} />                  {this.settingsPanel()} | 
