UNPKG

@hmcts/annotation-ui-lib

Version:

PDF Viewer and ability to highlight text with and comment tracking

203 lines 17.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Injectable } from '@angular/core'; import { PdfWrapper } from './js-wrapper/pdf-wrapper'; import { PdfAnnotateWrapper } from './js-wrapper/pdf-annotate-wrapper'; import { BehaviorSubject, Subject } from 'rxjs'; import { EmLoggerService } from '../logging/em-logger.service'; import { RotationModel } from '../model/rotation-factory.model'; export class PdfRenderService { /** * @param {?} pdfWrapper * @param {?} log * @param {?} pdfAnnotateWrapper */ constructor(pdfWrapper, log, pdfAnnotateWrapper) { this.pdfWrapper = pdfWrapper; this.log = log; this.pdfAnnotateWrapper = pdfAnnotateWrapper; this.listPages = []; this.log.setClass('PdfRenderService'); this.dataLoadedSubject = new BehaviorSubject(false); this.listPagesSubject = new Subject(); } /** * @return {?} */ getDataLoadedSub() { return this.dataLoadedSubject; } /** * @param {?} isLoaded * @return {?} */ dataLoadedUpdate(isLoaded) { this.dataLoadedSubject.next(isLoaded); } /** * @return {?} */ getRenderOptions() { return Object.assign({}, this.RENDER_OPTIONS); } /** * @param {?} RENDER_OPTIONS * @return {?} */ setRenderOptions(RENDER_OPTIONS) { this.RENDER_OPTIONS = RENDER_OPTIONS; } /** * @return {?} */ getViewerElementRef() { return this.viewerElementRef; } /** * @return {?} */ getPdfPages() { return this.pdfPages; } /** * @param {?=} viewerElementRef * @return {?} */ render(viewerElementRef) { if (viewerElementRef != null) { this.viewerElementRef = viewerElementRef; } /** @type {?} */ const renderOptions = this.getRenderOptions(); this.pdfWrapper.getDocument(renderOptions.documentId) .then(pdf => { renderOptions.pdfDocument = pdf; /** @type {?} */ const viewer = this.viewerElementRef.nativeElement; viewer.innerHTML = ''; this.pdfPages = pdf.pdfInfo.numPages; this.listPages = []; for (let i = 1; i < this.pdfPages + 1; i++) { /** @type {?} */ const pageDom = this.pdfAnnotateWrapper.createPage(i); // Create a copy of the render options for each page. /** @type {?} */ const pageOptions = Object.assign({}, renderOptions); viewer.appendChild(pageDom); this.addDomPage(pageDom, i); pdf.getPage(i).then((pdfPage) => { // Get current page rotation from page rotation objects pageOptions.rotate = this.addPageRotation(renderOptions, pageOptions, pdfPage); setTimeout(() => { this.pdfAnnotateWrapper.renderPage(i, pageOptions).then(() => { if (i === this.pdfPages) { this.setRenderOptions(renderOptions); this.dataLoadedUpdate(true); this.listPagesSubject.next(this.listPages); } }); }); }); } }).catch((error) => { /** @type {?} */ const errorMessage = new Error('Unable to render your supplied PDF. ' + renderOptions.documentId + '. Error is: ' + error); this.log.error('Encountered error while rendering the PDF:' + errorMessage); }); } /** * @param {?} pageDom * @param {?} pageNumber * @return {?} */ addDomPage(pageDom, pageNumber) { /** @type {?} */ const pagedetails = new RotationModel(pageNumber, pageDom); /** @type {?} */ const index = this.listPages.findIndex(pageElement => pageElement.pageNumber === pageNumber); if (index > 0) { this.listPages[index] = pagedetails; } else { this.listPages.push(pagedetails); } } /** * @param {?} renderOptions * @param {?} pageOptions * @param {?} pdfPage * @return {?} */ addPageRotation(renderOptions, pageOptions, pdfPage) { /** @type {?} */ let rotation = this.getPageRotation(pageOptions, pdfPage); if (!rotation) { renderOptions.rotationPages.push({ page: pdfPage.pageNumber, rotate: pdfPage.rotate }); rotation = pdfPage.rotate; } return rotation; } /** * @param {?} pageOptions * @param {?} pdfPage * @return {?} */ getPageRotation(pageOptions, pdfPage) { return pageOptions.rotationPages .filter(rotateObj => rotateObj.page === pdfPage.pageNumber) .map(rotateObj => rotateObj.rotate)[0]; } } PdfRenderService.decorators = [ { type: Injectable } ]; PdfRenderService.ctorParameters = () => [ { type: PdfWrapper }, { type: EmLoggerService }, { type: PdfAnnotateWrapper } ]; if (false) { /** * @type {?} * @private */ PdfRenderService.prototype.viewerElementRef; /** * @type {?} * @private */ PdfRenderService.prototype.RENDER_OPTIONS; /** * @type {?} * @private */ PdfRenderService.prototype.pdfPages; /** * @type {?} * @private */ PdfRenderService.prototype.dataLoadedSubject; /** @type {?} */ PdfRenderService.prototype.listPagesSubject; /** @type {?} */ PdfRenderService.prototype.listPages; /** * @type {?} * @private */ PdfRenderService.prototype.pdfWrapper; /** * @type {?} * @private */ PdfRenderService.prototype.log; /** * @type {?} * @private */ PdfRenderService.prototype.pdfAnnotateWrapper; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pdf-render.service.js","sourceRoot":"ng://@hmcts/annotation-ui-lib/","sources":["lib/data/pdf-render.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, ElementRef } from '@angular/core';\nimport { RenderOptions } from './js-wrapper/renderOptions.model';\nimport { PdfWrapper } from './js-wrapper/pdf-wrapper';\nimport { PdfAnnotateWrapper } from './js-wrapper/pdf-annotate-wrapper';\nimport { BehaviorSubject, Subject } from 'rxjs';\nimport { EmLoggerService } from '../logging/em-logger.service';\nimport { RotationModel } from '../model/rotation-factory.model';\n\n@Injectable()\nexport class PdfRenderService {\n\n    private viewerElementRef: ElementRef;\n    private RENDER_OPTIONS: RenderOptions;\n    private pdfPages: number;\n    private dataLoadedSubject: BehaviorSubject<boolean>;\n\n    listPagesSubject: Subject<RotationModel[]>;\n    listPages: RotationModel[] = [];\n\n    constructor(private pdfWrapper: PdfWrapper,\n                private log: EmLoggerService,\n                private pdfAnnotateWrapper: PdfAnnotateWrapper) {\n        this.log.setClass('PdfRenderService');\n        this.dataLoadedSubject = new BehaviorSubject(false);\n        this.listPagesSubject = new Subject();\n    }\n\n    getDataLoadedSub(): BehaviorSubject<boolean> {\n        return this.dataLoadedSubject;\n    }\n\n    dataLoadedUpdate(isLoaded: boolean) {\n        this.dataLoadedSubject.next(isLoaded);\n    }\n\n    getRenderOptions() {\n        return Object.assign({}, this.RENDER_OPTIONS);\n    }\n\n    setRenderOptions(RENDER_OPTIONS: RenderOptions): any {\n        this.RENDER_OPTIONS = RENDER_OPTIONS;\n    }\n\n    getViewerElementRef(): ElementRef {\n        return this.viewerElementRef;\n    }\n\n    getPdfPages(): number {\n        return this.pdfPages;\n    }\n    \n    render(viewerElementRef?: ElementRef) {\n        if (viewerElementRef != null) {\n            this.viewerElementRef = viewerElementRef;\n        }\n\n        const renderOptions = this.getRenderOptions();\n        this.pdfWrapper.getDocument(renderOptions.documentId)\n            .then(pdf => {\n                renderOptions.pdfDocument = pdf;\n                const viewer = this.viewerElementRef.nativeElement;\n                viewer.innerHTML = '';\n                this.pdfPages = pdf.pdfInfo.numPages;\n                this.listPages = [];\n\n                for (let i = 1; i < this.pdfPages + 1; i++) {\n                    const pageDom = this.pdfAnnotateWrapper.createPage(i);\n                    // Create a copy of the render options for each page.\n                    const pageOptions = Object.assign({}, renderOptions);\n                    viewer.appendChild(pageDom);\n                    this.addDomPage(pageDom, i);\n                    pdf.getPage(i).then((pdfPage) => {\n                        // Get current page rotation from page rotation objects\n                        pageOptions.rotate = this.addPageRotation(renderOptions, pageOptions, pdfPage);\n                        setTimeout(() => {\n                            this.pdfAnnotateWrapper.renderPage(i, pageOptions).then(() => {\n                                if (i === this.pdfPages) {\n                                    this.setRenderOptions(renderOptions);\n                                    this.dataLoadedUpdate(true);\n                                    this.listPagesSubject.next(this.listPages);\n                                }\n                            });\n                        });\n                    });\n                }\n            }).catch(\n            (error) => {\n                const errorMessage = new Error('Unable to render your supplied PDF. ' +\n                renderOptions.documentId + '. Error is: ' + error);\n                this.log.error('Encountered error while rendering the PDF:' + errorMessage);\n            });\n    }\n\n    addDomPage(pageDom: any, pageNumber: number) {\n        const pagedetails = new RotationModel(pageNumber, pageDom);\n        const index = this.listPages.findIndex(pageElement => pageElement.pageNumber === pageNumber);\n        if (index > 0) {\n            this.listPages[index] = pagedetails;\n        } else {\n            this.listPages.push(pagedetails);\n        }\n    }\n\n    addPageRotation(renderOptions: RenderOptions, pageOptions: RenderOptions, pdfPage: any): number {\n        let rotation = this.getPageRotation(pageOptions, pdfPage);\n        if (!rotation) {\n            renderOptions.rotationPages.push({page: pdfPage.pageNumber, rotate: pdfPage.rotate});\n            rotation = pdfPage.rotate;\n        }\n        return rotation;\n    }\n\n    getPageRotation(pageOptions: RenderOptions, pdfPage: any): number {\n      return pageOptions.rotationPages\n        .filter(rotateObj => rotateObj.page === pdfPage.pageNumber)\n        .map(rotateObj => rotateObj.rotate)[0];\n    }\n}\n"]}