UNPKG

@hmcts/annotation-ui-lib

Version:

PDF Viewer and ability to highlight text with and comment tracking

310 lines 29.1 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ViewChild, ElementRef, Input, ChangeDetectorRef, Renderer2 } from '@angular/core'; import { PdfService } from '../../data/pdf.service'; import { AnnotationStoreService } from '../../data/annotation-store.service'; import { Annotation } from '../../data/annotation-set.model'; import { NpaService } from '../../data/npa.service'; import { ApiHttpService } from '../../data/api-http.service'; import { Utils } from '../../data/utils'; import { PdfAnnotateWrapper } from '../../data/js-wrapper/pdf-annotate-wrapper'; import { CommentsComponent } from './comments/comments.component'; import { ContextualToolbarComponent } from './contextual-toolbar/contextual-toolbar.component'; import { EmLoggerService } from '../../logging/em-logger.service'; import { RenderOptions } from '../../data/js-wrapper/renderOptions.model'; import { PdfRenderService } from '../../data/pdf-render.service'; import { RotationFactoryService } from './rotation-toolbar/rotation-factory.service'; export class AnnotationPdfViewerComponent { /** * @param {?} pdfService * @param {?} npaService * @param {?} apiHttpService * @param {?} annotationStoreService * @param {?} utils * @param {?} ref * @param {?} renderer * @param {?} pdfAnnotateWrapper * @param {?} pdfRenderService * @param {?} rotationFactoryService * @param {?} log */ constructor(pdfService, npaService, apiHttpService, annotationStoreService, utils, ref, renderer, pdfAnnotateWrapper, pdfRenderService, rotationFactoryService, log) { this.pdfService = pdfService; this.npaService = npaService; this.apiHttpService = apiHttpService; this.annotationStoreService = annotationStoreService; this.utils = utils; this.ref = ref; this.renderer = renderer; this.pdfAnnotateWrapper = pdfAnnotateWrapper; this.pdfRenderService = pdfRenderService; this.rotationFactoryService = rotationFactoryService; this.log = log; this.rotationComponents = []; } /** * @return {?} */ ngOnInit() { this.loadAnnotations(this.annotate); this.pdfService.preRun(); this.pdfRenderService.setRenderOptions(new RenderOptions(this.url, null, parseFloat('1.33'), 0, [])); if (this.rotate) { this.pdfPageSubscription = this.pdfRenderService.listPagesSubject .subscribe((listPages) => { this.rotationComponents.forEach(rc => rc.destroy()); listPages.forEach(pageDetails => { this.rotationComponents.push(this.rotationFactoryService.addToDom(pageDetails)); }); }); } this.pdfRenderService.render(this.viewerElementRef); this.pdfService.setAnnotationWrapper(this.annotationWrapper); this.pageNumberSubscription = this.pdfService.getPageNumber() .subscribe(page => this.page = page); this.focusedAnnotationSubscription = this.annotationStoreService.getAnnotationFocusSubject() .subscribe(focusedAnnotation => this.focusHighlightStyle(focusedAnnotation)); } /** * @return {?} */ ngAfterViewInit() { this.pdfAnnotateWrapper.getUi().addEventListener('annotation:click', this.handleAnnotationClick.bind(this)); } /** * @return {?} */ ngOnDestroy() { if (this.pageNumberSubscription) { this.pageNumberSubscription.unsubscribe(); } if (this.focusedAnnotationSubscription) { this.focusedAnnotationSubscription.unsubscribe(); } if (this.pdfPageSubscription) { this.pdfPageSubscription.unsubscribe(); } } /** * @param {?} annotate * @return {?} */ loadAnnotations(annotate) { if (annotate) { this.log.info('annotations are enabled'); this.apiHttpService.setBaseUrl(this.baseUrl); this.annotationStoreService.preLoad(this.annotationSet); this.npaService.outputDmDocumentId.next(this.outputDmDocumentId); } else { this.log.info('annotations are disabled'); this.annotationStoreService.preLoad(null); } } /** * @param {?} event * @param {?=} isPage * @return {?} */ handleClick(event, isPage) { if (this.annotate) { if (!this.utils.clickIsHighlight(event)) { this.unfocusAnnotation(); this.annotationStoreService.setToolBarUpdate(null, null); } this.commentsComponent.handleAnnotationBlur(); if (isPage) { this.pdfService.setPageNumber(this.utils.getClickedPage(event)); } } } /** * @return {?} */ renderComments() { this.unfocusAnnotation(); this.commentsComponent.showAllComments(); } /** * @return {?} */ unfocusAnnotation() { this.annotationStoreService.setAnnotationFocusSubject(new Annotation()); this.annotationStoreService.setCommentBtnSubject(null); this.annotationStoreService.setCommentFocusSubject(new Annotation(), null); } /** * @param {?} event * @return {?} */ handleAnnotationClick(event) { if (!this.contextualToolbar.isShowToolbar) { /** @type {?} */ const annotationId = event.getAttribute('data-pdf-annotate-id'); this.annotationStoreService.getAnnotationById(annotationId) .then((annotation) => { this.annotationStoreService.setAnnotationFocusSubject(annotation); this.annotationStoreService.setCommentFocusSubject(annotation); this.annotationStoreService.setToolBarUpdate(annotation, true); }); } } /** * @param {?} focusedAnnotation * @return {?} */ focusHighlightStyle(focusedAnnotation) { Array.from(this.viewerElementRef.nativeElement.querySelector(`#pageContainer${this.page} .annotationLayer`).childNodes) .forEach((annotationDom) => { if (annotationDom.dataset.pdfAnnotateId === focusedAnnotation.id) { this.renderer.addClass(annotationDom, 'comment-selected'); } else { this.renderer.removeClass(annotationDom, 'comment-selected'); } }); if (!this.ref['destroyed']) { this.ref.detectChanges(); } } } AnnotationPdfViewerComponent.decorators = [ { type: Component, args: [{ selector: 'app-annotation-pdf-viewer', template: "\n<app-comments (click)=\"handleClick($event, false)\" #commentsComponent\n *ngIf=\"annotate\"></app-comments>\n\n<div id=\"annotation-wrapper\" #annotationWrapper>\n <app-contextual-toolbar (deletedAnnotation)=\"renderComments()\" #contextualToolbar></app-contextual-toolbar>\n\n <div id=\"content-wrapper\"\n #contentWrapper\n (click)=\"handleClick($event, true)\">\n <div id=\"viewer\" #viewer class=\"pdfViewer\"></div>\n </div>\n</div>\n", styles: ["#annotation-wrapper{position:relative;width:100%}#content-wrapper{overflow:hidden}"] }] } ]; AnnotationPdfViewerComponent.ctorParameters = () => [ { type: PdfService }, { type: NpaService }, { type: ApiHttpService }, { type: AnnotationStoreService }, { type: Utils }, { type: ChangeDetectorRef }, { type: Renderer2 }, { type: PdfAnnotateWrapper }, { type: PdfRenderService }, { type: RotationFactoryService }, { type: EmLoggerService } ]; AnnotationPdfViewerComponent.propDecorators = { annotate: [{ type: Input }], dmDocumentId: [{ type: Input }], outputDmDocumentId: [{ type: Input }], url: [{ type: Input }], annotationSet: [{ type: Input }], baseUrl: [{ type: Input }], rotate: [{ type: Input }], contentWrapper: [{ type: ViewChild, args: ['contentWrapper',] }], viewerElementRef: [{ type: ViewChild, args: ['viewer',] }], annotationWrapper: [{ type: ViewChild, args: ['annotationWrapper',] }], commentsComponent: [{ type: ViewChild, args: ['commentsComponent',] }], contextualToolbar: [{ type: ViewChild, args: ['contextualToolbar',] }] }; if (false) { /** @type {?} */ AnnotationPdfViewerComponent.prototype.annotate; /** @type {?} */ AnnotationPdfViewerComponent.prototype.dmDocumentId; /** @type {?} */ AnnotationPdfViewerComponent.prototype.outputDmDocumentId; /** @type {?} */ AnnotationPdfViewerComponent.prototype.url; /** @type {?} */ AnnotationPdfViewerComponent.prototype.annotationSet; /** @type {?} */ AnnotationPdfViewerComponent.prototype.baseUrl; /** @type {?} */ AnnotationPdfViewerComponent.prototype.rotate; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.page; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.focusedAnnotationSubscription; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.pageNumberSubscription; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.pdfPageSubscription; /** @type {?} */ AnnotationPdfViewerComponent.prototype.rotationComponents; /** @type {?} */ AnnotationPdfViewerComponent.prototype.contentWrapper; /** @type {?} */ AnnotationPdfViewerComponent.prototype.viewerElementRef; /** @type {?} */ AnnotationPdfViewerComponent.prototype.annotationWrapper; /** @type {?} */ AnnotationPdfViewerComponent.prototype.commentsComponent; /** @type {?} */ AnnotationPdfViewerComponent.prototype.contextualToolbar; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.pdfService; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.npaService; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.apiHttpService; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.annotationStoreService; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.utils; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.ref; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.renderer; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.pdfAnnotateWrapper; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.pdfRenderService; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.rotationFactoryService; /** * @type {?} * @private */ AnnotationPdfViewerComponent.prototype.log; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"annotation-pdf-viewer.component.js","sourceRoot":"ng://@hmcts/annotation-ui-lib/","sources":["lib/viewers/annotation-pdf-viewer/annotation-pdf-viewer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, ViewChild, ElementRef, Input, ChangeDetectorRef, Renderer2, OnDestroy, AfterViewInit, ComponentRef} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport {PdfService} from '../../data/pdf.service';\nimport {AnnotationStoreService} from '../../data/annotation-store.service';\nimport {IAnnotationSet, Annotation} from '../../data/annotation-set.model';\nimport {NpaService} from '../../data/npa.service';\nimport {ApiHttpService} from '../../data/api-http.service';\nimport { Utils } from '../../data/utils';\nimport { PdfAnnotateWrapper } from '../../data/js-wrapper/pdf-annotate-wrapper';\nimport { CommentsComponent } from './comments/comments.component';\nimport { ContextualToolbarComponent } from './contextual-toolbar/contextual-toolbar.component';\nimport { EmLoggerService } from '../../logging/em-logger.service';\nimport { RenderOptions } from '../../data/js-wrapper/renderOptions.model';\nimport { PdfRenderService } from '../../data/pdf-render.service';\nimport { RotationFactoryService } from './rotation-toolbar/rotation-factory.service';\nimport { RotationComponent } from './rotation-toolbar/rotation.component';\nimport { RotationModel } from '../../model/rotation-factory.model';\n\n\n@Component({\n    selector: 'app-annotation-pdf-viewer',\n    templateUrl: './annotation-pdf-viewer.component.html',\n    styleUrls: ['./annotation-pdf-viewer.component.scss']\n})\nexport class AnnotationPdfViewerComponent implements OnInit, AfterViewInit, OnDestroy {\n\n    @Input() annotate: boolean;\n    @Input() dmDocumentId: string;\n    @Input() outputDmDocumentId: string;\n    @Input() url: string;\n    @Input() annotationSet: IAnnotationSet;\n    @Input() baseUrl: string;\n    @Input() rotate: boolean;\n\n    private page: number;\n    private focusedAnnotationSubscription: Subscription;\n    private pageNumberSubscription: Subscription;\n    private pdfPageSubscription: Subscription;\n    rotationComponents: ComponentRef<RotationComponent>[] = [];\n\n    @ViewChild('contentWrapper') contentWrapper: ElementRef;\n    @ViewChild('viewer') viewerElementRef: ElementRef;\n    @ViewChild('annotationWrapper') annotationWrapper: ElementRef;\n    @ViewChild('commentsComponent') commentsComponent: CommentsComponent;\n    @ViewChild('contextualToolbar') contextualToolbar: ContextualToolbarComponent;\n\n    constructor(private pdfService: PdfService,\n                private npaService: NpaService,\n                private apiHttpService: ApiHttpService,\n                private annotationStoreService: AnnotationStoreService,\n                private utils: Utils,\n                private ref: ChangeDetectorRef,\n                private renderer: Renderer2,\n                private pdfAnnotateWrapper: PdfAnnotateWrapper,\n                private pdfRenderService: PdfRenderService,\n                private rotationFactoryService: RotationFactoryService,\n                private log: EmLoggerService) {\n    }\n\n    ngOnInit() {\n        this.loadAnnotations(this.annotate);\n        this.pdfService.preRun();\n        this.pdfRenderService.setRenderOptions(new RenderOptions(\n            this.url,\n            null,\n            parseFloat('1.33'),\n            0,\n            []\n        ));\n\n        if (this.rotate) {\n            this.pdfPageSubscription = this.pdfRenderService.listPagesSubject\n              .subscribe((listPages: RotationModel[]) => {\n                this.rotationComponents.forEach(rc => rc.destroy());\n                listPages.forEach(pageDetails => {\n                  this.rotationComponents.push(this.rotationFactoryService.addToDom(pageDetails));\n                });\n              });\n        }\n\n        this.pdfRenderService.render(this.viewerElementRef);\n        this.pdfService.setAnnotationWrapper(this.annotationWrapper);\n\n        this.pageNumberSubscription = this.pdfService.getPageNumber()\n            .subscribe(page => this.page = page);\n        this.focusedAnnotationSubscription = this.annotationStoreService.getAnnotationFocusSubject()\n            .subscribe(focusedAnnotation => this.focusHighlightStyle(focusedAnnotation));\n    }\n\n    ngAfterViewInit() {\n        this.pdfAnnotateWrapper.getUi().addEventListener('annotation:click', this.handleAnnotationClick.bind(this));\n    }\n\n    ngOnDestroy() {\n        if (this.pageNumberSubscription) {\n            this.pageNumberSubscription.unsubscribe();\n        }\n        if (this.focusedAnnotationSubscription) {\n            this.focusedAnnotationSubscription.unsubscribe();\n        }\n        if (this.pdfPageSubscription) {\n            this.pdfPageSubscription.unsubscribe();\n        }\n    }\n\n    loadAnnotations(annotate: boolean) {\n        if (annotate) {\n            this.log.info('annotations are enabled');\n            this.apiHttpService.setBaseUrl(this.baseUrl);\n            this.annotationStoreService.preLoad(this.annotationSet);\n            this.npaService.outputDmDocumentId.next(this.outputDmDocumentId);\n        } else {\n            this.log.info('annotations are disabled');\n            this.annotationStoreService.preLoad(null);\n        }\n    }\n\n    handleClick(event: any, isPage?: boolean) {\n        if (this.annotate) {\n            if (!this.utils.clickIsHighlight(event)) {\n                this.unfocusAnnotation();\n                this.annotationStoreService.setToolBarUpdate(null, null);\n            }\n            this.commentsComponent.handleAnnotationBlur();\n\n            if (isPage) {\n                this.pdfService.setPageNumber(this.utils.getClickedPage(event));\n            }\n        }\n    }\n\n    renderComments() {\n        this.unfocusAnnotation();\n        this.commentsComponent.showAllComments();\n    }\n\n    unfocusAnnotation() {\n        this.annotationStoreService.setAnnotationFocusSubject(new Annotation());\n        this.annotationStoreService.setCommentBtnSubject(null);\n        this.annotationStoreService.setCommentFocusSubject(new Annotation(), null);\n    }\n\n    handleAnnotationClick(event) {\n        if (!this.contextualToolbar.isShowToolbar) {\n            const annotationId = event.getAttribute('data-pdf-annotate-id');\n            this.annotationStoreService.getAnnotationById(annotationId)\n                .then((annotation: Annotation) => {\n                    this.annotationStoreService.setAnnotationFocusSubject(annotation);\n                    this.annotationStoreService.setCommentFocusSubject(annotation);\n                    this.annotationStoreService.setToolBarUpdate(annotation, true);\n                });\n        }\n    }\n\n    focusHighlightStyle(focusedAnnotation: Annotation) {\n        Array.from(this.viewerElementRef.nativeElement.querySelector(`#pageContainer${this.page} .annotationLayer`).childNodes)\n            .forEach((annotationDom: HTMLInputElement) => {\n                if (annotationDom.dataset.pdfAnnotateId === focusedAnnotation.id) {\n                    this.renderer.addClass(annotationDom, 'comment-selected');\n                } else {\n                    this.renderer.removeClass(annotationDom, 'comment-selected');\n                }\n            });\n        if (!this.ref['destroyed']) {\n            this.ref.detectChanges();\n        }\n    }\n\n}\n"]}