UNPKG

ngx-extended-pdf-viewer

Version:

Embedding PDF files in your Angular application. Highly configurable viewer including the toolbar, sidebar, and all the features you're used to.

229 lines 21.2 kB
/** * @fileoverview added by tsickle * Generated from: lib/sidebar/pdf-sidebar/pdf-sidebar-content/pdf-sidebar-content.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, TemplateRef, ViewChild, ElementRef, EventEmitter, Output } from '@angular/core'; /** @type {?} */ var THUMBNAIL_CANVAS_BORDER_WIDTH = 1; // px var PdfSidebarContentComponent = /** @class */ (function () { function PdfSidebarContentComponent() { var _this = this; this.thumbnailDrawn = new EventEmitter(); this.top = '32px'; this._hideSidebarToolbar = false; if (typeof window !== 'undefined') { ((/** @type {?} */ (window))).pdfThumbnailGeneratorReady = (/** * @return {?} */ function () { return _this.pdfThumbnailGeneratorReady(); }); ((/** @type {?} */ (window))).pdfThumbnailGenerator = (/** * @param {?} pdfThumbnailView * @param {?} linkService * @param {?} id * @param {?} container * @param {?} thumbPageTitlePromise * @return {?} */ function (pdfThumbnailView, linkService, id, container, thumbPageTitlePromise) { return _this.createThumbnail(pdfThumbnailView, linkService, id, container, thumbPageTitlePromise); }); } } /** * @return {?} */ PdfSidebarContentComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.linkService = undefined; }; /** * @return {?} */ PdfSidebarContentComponent.prototype.pdfThumbnailGeneratorReady = /** * @return {?} */ function () { if (!this.thumbnailViewTemplate) { return false; } /** @type {?} */ var t = (/** @type {?} */ (this.thumbnailViewTemplate.nativeElement)); return !!t && !!t.innerHTML && t.innerHTML.length > 0; }; /** * @private * @param {?} pdfThumbnailView * @param {?} linkService * @param {?} id * @param {?} container * @param {?} thumbPageTitlePromise * @return {?} */ PdfSidebarContentComponent.prototype.createThumbnail = /** * @private * @param {?} pdfThumbnailView * @param {?} linkService * @param {?} id * @param {?} container * @param {?} thumbPageTitlePromise * @return {?} */ function (pdfThumbnailView, linkService, id, container, thumbPageTitlePromise) { this.linkService = linkService; /** @type {?} */ var template = this.thumbnailViewTemplate; // get the inner HTML without the attributes and classes added by Angular /** @type {?} */ var inner = template.nativeElement.innerHTML .split(/_ng\w+-\w+-\w+=""/g) .join('') .split(/ng-\w+-\w+/g) .join('') .split(/<!--[\s\S]*?-->/g) .join(''); /** @type {?} */ var borderAdjustment = 2 * THUMBNAIL_CANVAS_BORDER_WIDTH; /** @type {?} */ var widthOfRing = pdfThumbnailView.canvasWidth + borderAdjustment + 'px'; /** @type {?} */ var heightOfRing = pdfThumbnailView.canvasHeight + borderAdjustment + 'px'; /** @type {?} */ var newHtml = inner.split('WIDTH_OF_RING').join(widthOfRing).split('HEIGHT_OF_RING').join(heightOfRing).split('PAGE_NUMBER').join(id); /** @type {?} */ var newElement = this.createElementFromHTML(newHtml); newElement.classList.remove('pdf-viewer-template'); /** @type {?} */ var anchor = (/** @type {?} */ (newElement)); anchor.href = linkService.getAnchorUrl('#page=' + id); thumbPageTitlePromise.then((/** * @param {?} msg * @return {?} */ function (msg) { anchor.title = msg; })); anchor.onclick = (/** * @return {?} */ function () { linkService.page = id; return false; }); pdfThumbnailView.anchor = anchor; /** @type {?} */ var ring = (/** @type {?} */ (newElement.getElementsByClassName('image-container')[0])); pdfThumbnailView.ring = ring; pdfThumbnailView.div = (/** @type {?} */ (newElement.getElementsByClassName('thumbnail')[0])); container.appendChild(newElement); /** @type {?} */ var thumbnailDrawnEvent = { thumbnail: newElement, container: container, pageId: id, }; this.thumbnailDrawn.emit(thumbnailDrawnEvent); }; /** * @private * @param {?} htmlString * @return {?} */ PdfSidebarContentComponent.prototype.createElementFromHTML = /** * @private * @param {?} htmlString * @return {?} */ function (htmlString) { /** @type {?} */ var div = document.createElement('div'); div.innerHTML = htmlString.trim(); // Change this to div.childNodes to support multiple top-level nodes return (/** @type {?} */ (div.firstChild)); }; /** * @param {?} event * @return {?} */ PdfSidebarContentComponent.prototype.onKeyDown = /** * @param {?} event * @return {?} */ function (event) { if (event.code === 'ArrowDown') { if (this.linkService) { if (event.ctrlKey || event.metaKey) { this.linkService.page = this.linkService.pagesCount; } else if (this.linkService.page < this.linkService.pagesCount) { this.linkService.page = this.linkService.page + 1; } event.preventDefault(); } } else if (event.code === 'ArrowUp') { if (this.linkService) { if (event.ctrlKey || event.metaKey) { this.linkService.page = 1; } else if (this.linkService.page > 1) { this.linkService.page = this.linkService.page - 1; } event.preventDefault(); } } }; Object.defineProperty(PdfSidebarContentComponent.prototype, "hideSidebarToolbar", { set: /** * @param {?} h * @return {?} */ function (h) { this._hideSidebarToolbar = h; if (this._hideSidebarToolbar) { this.top = '0'; } else { this.top = '32px'; } }, enumerable: true, configurable: true }); PdfSidebarContentComponent.decorators = [ { type: Component, args: [{ selector: 'pdf-sidebar-content', template: "<div id=\"sidebarContent\" [style.top]=\"top\">\n <div #thumbnailViewTemplate>\n <ng-content *ngTemplateOutlet=\"customThumbnail ? customThumbnail : defaultThumbnail\"></ng-content>\n </div>\n <div id=\"thumbnailView\" (keydown)=\"onKeyDown($event)\"></div>\n <div id=\"outlineView\" class=\"hidden\"></div>\n <div id=\"attachmentsView\" class=\"hidden\"></div>\n <div id=\"layersView\" class=\"hidden\"></div>\n</div>\n\n<ng-template #defaultThumbnail>\n <a class=\"pdf-viewer-template\">\n <div class=\"thumbnail\" data-page-number=\"$page\">\n <div class=\"thumbnailSelectionRing image-container\" style=\"width: WIDTH_OF_RING; height: HEIGHT_OF_RING\">\n <!-- image is automatically inserted here -->\n <!-- <img class=\"thumbnailImage\" style=\"width: 98px; height: 73px;\" /> -->\n </div>\n </div>\n </a>\n</ng-template>\n", styles: [""] }] } ]; /** @nocollapse */ PdfSidebarContentComponent.ctorParameters = function () { return []; }; PdfSidebarContentComponent.propDecorators = { customThumbnail: [{ type: Input }], thumbnailViewTemplate: [{ type: ViewChild, args: ['thumbnailViewTemplate',] }], thumbnailDrawn: [{ type: Output }], hideSidebarToolbar: [{ type: Input }] }; return PdfSidebarContentComponent; }()); export { PdfSidebarContentComponent }; if (false) { /** @type {?} */ PdfSidebarContentComponent.prototype.customThumbnail; /** @type {?} */ PdfSidebarContentComponent.prototype.thumbnailViewTemplate; /** * @type {?} * @private */ PdfSidebarContentComponent.prototype.linkService; /** @type {?} */ PdfSidebarContentComponent.prototype.thumbnailDrawn; /** @type {?} */ PdfSidebarContentComponent.prototype.top; /** @type {?} */ PdfSidebarContentComponent.prototype._hideSidebarToolbar; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pdf-sidebar-content.component.js","sourceRoot":"ng://ngx-extended-pdf-viewer/","sources":["lib/sidebar/pdf-sidebar/pdf-sidebar-content/pdf-sidebar-content.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, TemplateRef, ViewChild, ElementRef, OnDestroy, EventEmitter, Output } from '@angular/core';\nimport { PdfThumbnailDrawnEvent } from '../../../events/pdf-thumbnail-drawn-event';\n\ndeclare class PDFThumbnailView {\n  anchor: HTMLAnchorElement;\n  div: HTMLElement;\n  ring: HTMLElement;\n  canvasWidth: number;\n  canvasHeight: number;\n}\n\ndeclare class PDFLinkService {\n  public page: number;\n  public pagesCount: number;\n  public getAnchorUrl(targetUrl: string): string;\n}\n\nconst THUMBNAIL_CANVAS_BORDER_WIDTH = 1; // px\n\n@Component({\n  selector: 'pdf-sidebar-content',\n  templateUrl: './pdf-sidebar-content.component.html',\n  styleUrls: ['./pdf-sidebar-content.component.css'],\n})\nexport class PdfSidebarContentComponent implements OnDestroy {\n  @Input()\n  public customThumbnail: TemplateRef<any>;\n\n  @ViewChild('thumbnailViewTemplate')\n  public thumbnailViewTemplate: ElementRef;\n\n  private linkService: PDFLinkService | undefined;\n\n  @Output()\n  public thumbnailDrawn = new EventEmitter<PdfThumbnailDrawnEvent>();\n\n  public top = '32px';\n\n  public _hideSidebarToolbar = false;\n\n  constructor() {\n    if (typeof window !== 'undefined') {\n      (window as any).pdfThumbnailGeneratorReady = () => this.pdfThumbnailGeneratorReady();\n      (window as any).pdfThumbnailGenerator = (\n        pdfThumbnailView: PDFThumbnailView,\n        linkService: any,\n        id: number,\n        container: HTMLDivElement,\n        thumbPageTitlePromise: Promise<string>\n      ) => this.createThumbnail(pdfThumbnailView, linkService, id, container, thumbPageTitlePromise);\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.linkService = undefined;\n  }\n\n  public pdfThumbnailGeneratorReady(): boolean {\n    if (!this.thumbnailViewTemplate) {\n      return false;\n    }\n    const t = this.thumbnailViewTemplate.nativeElement as HTMLElement;\n    return !!t && !!t.innerHTML && t.innerHTML.length > 0;\n  }\n\n  private createThumbnail(\n    pdfThumbnailView: PDFThumbnailView,\n    linkService: PDFLinkService,\n    id: number,\n    container: HTMLDivElement,\n    thumbPageTitlePromise: Promise<string>\n  ) {\n    this.linkService = linkService;\n    const template = this.thumbnailViewTemplate;\n    // get the inner HTML without the attributes and classes added by Angular\n    const inner = template.nativeElement.innerHTML\n      .split(/_ng\\w+-\\w+-\\w+=\"\"/g)\n      .join('')\n      .split(/ng-\\w+-\\w+/g)\n      .join('')\n      .split(/<!--[\\s\\S]*?-->/g)\n      .join('');\n\n    const borderAdjustment = 2 * THUMBNAIL_CANVAS_BORDER_WIDTH;\n\n    const widthOfRing = pdfThumbnailView.canvasWidth + borderAdjustment + 'px';\n    const heightOfRing = pdfThumbnailView.canvasHeight + borderAdjustment + 'px';\n\n    const newHtml = inner.split('WIDTH_OF_RING').join(widthOfRing).split('HEIGHT_OF_RING').join(heightOfRing).split('PAGE_NUMBER').join(id);\n    const newElement = this.createElementFromHTML(newHtml);\n    newElement.classList.remove('pdf-viewer-template');\n\n    const anchor = newElement as HTMLAnchorElement;\n    anchor.href = linkService.getAnchorUrl('#page=' + id);\n    thumbPageTitlePromise.then((msg) => {\n      anchor.title = msg;\n    });\n    anchor.onclick = function () {\n      linkService.page = id;\n      return false;\n    };\n    pdfThumbnailView.anchor = anchor;\n\n    const ring = newElement.getElementsByClassName('image-container')[0] as HTMLElement;\n    pdfThumbnailView.ring = ring;\n    pdfThumbnailView.div = newElement.getElementsByClassName('thumbnail')[0] as HTMLElement;\n\n    container.appendChild(newElement);\n\n    const thumbnailDrawnEvent: PdfThumbnailDrawnEvent = {\n      thumbnail: newElement,\n      container: container,\n      pageId: id,\n    };\n    this.thumbnailDrawn.emit(thumbnailDrawnEvent);\n  }\n\n  private createElementFromHTML(htmlString): HTMLElement {\n    const div = document.createElement('div');\n    div.innerHTML = htmlString.trim();\n\n    // Change this to div.childNodes to support multiple top-level nodes\n    return div.firstChild as HTMLElement;\n  }\n\n  public onKeyDown(event: KeyboardEvent): void {\n    if (event.code === 'ArrowDown') {\n      if (this.linkService) {\n        if (event.ctrlKey || event.metaKey) {\n          this.linkService.page = this.linkService.pagesCount;\n        } else if (this.linkService.page < this.linkService.pagesCount) {\n          this.linkService.page = this.linkService.page + 1;\n        }\n        event.preventDefault();\n      }\n    } else if (event.code === 'ArrowUp') {\n      if (this.linkService) {\n        if (event.ctrlKey || event.metaKey) {\n          this.linkService.page = 1;\n        } else if (this.linkService.page > 1) {\n          this.linkService.page = this.linkService.page - 1;\n        }\n        event.preventDefault();\n      }\n    }\n  }\n\n  @Input()\n  public set hideSidebarToolbar(h: boolean) {\n    this._hideSidebarToolbar = h;\n    if (this._hideSidebarToolbar) {\n      this.top = '0';\n    } else {\n      this.top = '32px';\n    }\n  }\n}\n"]}