UNPKG

@hmcts/annotation-ui-lib

Version:

PDF Viewer and ability to highlight text with and comment tracking

208 lines 17.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { ComponentFactoryResolver, Injectable } from '@angular/core'; import { UrlFixerService } from '../data/url-fixer.service'; import { AnnotationStoreService } from '../data/annotation-store.service'; import { ImageViewerComponent } from './image-viewer/image-viewer.component'; import { UnsupportedViewerComponent } from './unsupported-viewer/unsupported-viewer.component'; import { AnnotationPdfViewerComponent } from './annotation-pdf-viewer/annotation-pdf-viewer.component'; import { EmLoggerService } from '../logging/em-logger.service'; var ViewerFactoryService = /** @class */ (function () { function ViewerFactoryService(componentFactoryResolver, annotationStoreService, urlFixer, log) { this.componentFactoryResolver = componentFactoryResolver; this.annotationStoreService = annotationStoreService; this.urlFixer = urlFixer; this.log = log; this.log.setClass('ViewerFactoryService'); } /** * @private * @param {?} mimeType * @return {?} */ ViewerFactoryService.determineComponent = /** * @private * @param {?} mimeType * @return {?} */ function (mimeType) { if (ViewerFactoryService.isImage(mimeType)) { return ImageViewerComponent; } return UnsupportedViewerComponent; }; /** * @private * @param {?} mimeType * @return {?} */ ViewerFactoryService.isImage = /** * @private * @param {?} mimeType * @return {?} */ function (mimeType) { return mimeType.startsWith('image/') || mimeType === 'image'; }; /** * @private * @param {?} mimeType * @return {?} */ ViewerFactoryService.isPdf = /** * @private * @param {?} mimeType * @return {?} */ function (mimeType) { return mimeType === 'application/pdf' || mimeType === 'pdf'; }; /** * @param {?} documentMetaData * @return {?} */ ViewerFactoryService.prototype.getDocumentId = /** * @param {?} documentMetaData * @return {?} */ function (documentMetaData) { /** @type {?} */ var docArray = documentMetaData._links.self.href.split('/'); return docArray[docArray.length - 1]; }; /** * @param {?} viewContainerRef * @param {?} contentType * @param {?} url * @param {?} baseUrl * @param {?} originalUrl * @param {?} annotate * @param {?} annotationSet * @param {?} rotate * @return {?} */ ViewerFactoryService.prototype.buildComponent = /** * @param {?} viewContainerRef * @param {?} contentType * @param {?} url * @param {?} baseUrl * @param {?} originalUrl * @param {?} annotate * @param {?} annotationSet * @param {?} rotate * @return {?} */ function (viewContainerRef, contentType, url, baseUrl, originalUrl, annotate, annotationSet, rotate) { if (ViewerFactoryService.isPdf(contentType) && annotate) { this.log.info('Selected pdf viewer with annotations enabled'); return this.buildAnnotateUi(url, viewContainerRef, baseUrl, annotate, annotationSet, rotate); } else if (ViewerFactoryService.isPdf(contentType) && !annotate) { this.log.info('Selected pdf viewer with annotations disabled'); return this.buildAnnotateUi(url, viewContainerRef, baseUrl, annotate, null, rotate); } else if (ViewerFactoryService.isImage(contentType)) { this.log.info('Selected image viewer'); return this.createComponent(ImageViewerComponent, viewContainerRef, originalUrl, url, rotate); } else { this.log.info('Unsupported type for viewer'); return this.createComponent(UnsupportedViewerComponent, viewContainerRef, originalUrl, url); } }; /** * @param {?} url * @param {?} viewContainerRef * @param {?} baseUrl * @param {?} annotate * @param {?} annotationSet * @param {?} rotate * @return {?} */ ViewerFactoryService.prototype.buildAnnotateUi = /** * @param {?} url * @param {?} viewContainerRef * @param {?} baseUrl * @param {?} annotate * @param {?} annotationSet * @param {?} rotate * @return {?} */ function (url, viewContainerRef, baseUrl, annotate, annotationSet, rotate) { viewContainerRef.clear(); /** @type {?} */ var componentFactory = this.componentFactoryResolver.resolveComponentFactory(AnnotationPdfViewerComponent); /** @type {?} */ var componentRef = viewContainerRef.createComponent(componentFactory); componentRef.instance.annotate = annotate; componentRef.instance.annotationSet = annotationSet; componentRef.instance.outputDmDocumentId = null; // '4fbdde23-e9a7-4843-b6c0-24d5bf2140ab'; componentRef.instance.baseUrl = baseUrl; componentRef.instance.url = url; componentRef.instance.rotate = rotate; return componentRef.instance; }; /** * @param {?} component * @param {?} viewContainerRef * @param {?} originalUrl * @param {?} url * @param {?=} rotate * @return {?} */ ViewerFactoryService.prototype.createComponent = /** * @param {?} component * @param {?} viewContainerRef * @param {?} originalUrl * @param {?} url * @param {?=} rotate * @return {?} */ function (component, viewContainerRef, originalUrl, url, rotate) { /** @type {?} */ var componentFactory = this.componentFactoryResolver.resolveComponentFactory(component); viewContainerRef.clear(); /** @type {?} */ var componentRef = viewContainerRef.createComponent(componentFactory); componentRef.instance.originalUrl = originalUrl; componentRef.instance.url = url; componentRef.instance.rotate = rotate; return componentRef.instance; }; ViewerFactoryService.decorators = [ { type: Injectable } ]; ViewerFactoryService.ctorParameters = function () { return [ { type: ComponentFactoryResolver }, { type: AnnotationStoreService }, { type: UrlFixerService }, { type: EmLoggerService } ]; }; return ViewerFactoryService; }()); export { ViewerFactoryService }; if (false) { /** * @type {?} * @private */ ViewerFactoryService.prototype.componentFactoryResolver; /** * @type {?} * @private */ ViewerFactoryService.prototype.annotationStoreService; /** * @type {?} * @private */ ViewerFactoryService.prototype.urlFixer; /** * @type {?} * @private */ ViewerFactoryService.prototype.log; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewer-factory.service.js","sourceRoot":"ng://@hmcts/annotation-ui-lib/","sources":["lib/viewers/viewer-factory.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {ComponentFactoryResolver, ComponentRef, Injectable, ViewContainerRef} from '@angular/core';\nimport { UrlFixerService } from '../data/url-fixer.service';\nimport { AnnotationStoreService } from '../data/annotation-store.service';\nimport { ImageViewerComponent } from './image-viewer/image-viewer.component';\nimport { UnsupportedViewerComponent } from './unsupported-viewer/unsupported-viewer.component';\nimport { IAnnotationSet } from '../data/annotation-set.model';\nimport { AnnotationPdfViewerComponent } from './annotation-pdf-viewer/annotation-pdf-viewer.component';\nimport { EmLoggerService } from '../logging/em-logger.service';\n\n@Injectable()\nexport class ViewerFactoryService {\n\n    constructor(private componentFactoryResolver: ComponentFactoryResolver,\n                private annotationStoreService: AnnotationStoreService,\n                private urlFixer: UrlFixerService,\n                private log: EmLoggerService) {\n        this.log.setClass('ViewerFactoryService');\n    }\n\n    private static determineComponent(mimeType: string) {\n        if (ViewerFactoryService.isImage(mimeType)) {\n            return ImageViewerComponent;\n        }\n        return UnsupportedViewerComponent;\n    }\n\n    private static isImage(mimeType: String) {\n        return mimeType.startsWith('image/') || mimeType === 'image';\n    }\n\n    private static isPdf(mimeType: String) {\n        return mimeType === 'application/pdf' || mimeType === 'pdf';\n    }\n\n    public getDocumentId(documentMetaData: any) {\n        const docArray = documentMetaData._links.self.href.split('/');\n        return docArray[docArray.length - 1];\n    }\n\n    buildComponent(viewContainerRef: ViewContainerRef, contentType: string,\n                  url: string, baseUrl: string, originalUrl: string, annotate: boolean, annotationSet: any, rotate: boolean) {\n        if (ViewerFactoryService.isPdf(contentType) && annotate) {\n            this.log.info('Selected pdf viewer with annotations enabled');\n            return this.buildAnnotateUi(url, viewContainerRef, baseUrl, annotate, annotationSet, rotate);\n\n        } else if (ViewerFactoryService.isPdf(contentType) && !annotate) {\n            this.log.info('Selected pdf viewer with annotations disabled');\n            return this.buildAnnotateUi(url, viewContainerRef, baseUrl, annotate, null, rotate);\n        } else if (ViewerFactoryService.isImage(contentType)) {\n            this.log.info('Selected image viewer');\n            return this.createComponent(ImageViewerComponent, viewContainerRef, originalUrl, url, rotate);\n\n        } else {\n            this.log.info('Unsupported type for viewer');\n            return this.createComponent(UnsupportedViewerComponent, viewContainerRef, originalUrl, url);\n        }\n    }\n\n    buildAnnotateUi(url: any, viewContainerRef: ViewContainerRef, baseUrl: string,\n                    annotate: boolean, annotationSet: IAnnotationSet, rotate: boolean): ComponentRef<any>['instance'] {\n\n      viewContainerRef.clear();\n      const componentFactory = this.componentFactoryResolver.resolveComponentFactory(AnnotationPdfViewerComponent);\n\n      const componentRef: ComponentRef<any> = viewContainerRef.createComponent(componentFactory);\n      componentRef.instance.annotate = annotate;\n      componentRef.instance.annotationSet = annotationSet;\n      componentRef.instance.outputDmDocumentId = null; // '4fbdde23-e9a7-4843-b6c0-24d5bf2140ab';\n      componentRef.instance.baseUrl = baseUrl;\n      componentRef.instance.url = url;\n      componentRef.instance.rotate = rotate;\n\n      return componentRef.instance;\n    }\n\n    createComponent(component: any, viewContainerRef: ViewContainerRef, originalUrl: string, url: string, rotate?: boolean) {\n      const componentFactory = this.componentFactoryResolver.resolveComponentFactory(component);\n      viewContainerRef.clear();\n\n      const componentRef: ComponentRef<any> = viewContainerRef.createComponent(componentFactory);\n      componentRef.instance.originalUrl = originalUrl;\n      componentRef.instance.url = url;\n      componentRef.instance.rotate = rotate;\n      return componentRef.instance;\n    }\n\n}\n"]}