@hmcts/annotation-ui-lib
Version:
PDF Viewer and ability to highlight text with and comment tracking
310 lines • 29.1 kB
JavaScript
/**
* @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"]}