@hmcts/annotation-ui-lib
Version:
PDF Viewer and ability to highlight text with and comment tracking
165 lines • 16.1 kB
JavaScript
/**
* @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';
export class ViewerFactoryService {
/**
* @param {?} componentFactoryResolver
* @param {?} annotationStoreService
* @param {?} urlFixer
* @param {?} log
*/
constructor(componentFactoryResolver, annotationStoreService, urlFixer, log) {
this.componentFactoryResolver = componentFactoryResolver;
this.annotationStoreService = annotationStoreService;
this.urlFixer = urlFixer;
this.log = log;
this.log.setClass('ViewerFactoryService');
}
/**
* @private
* @param {?} mimeType
* @return {?}
*/
static determineComponent(mimeType) {
if (ViewerFactoryService.isImage(mimeType)) {
return ImageViewerComponent;
}
return UnsupportedViewerComponent;
}
/**
* @private
* @param {?} mimeType
* @return {?}
*/
static isImage(mimeType) {
return mimeType.startsWith('image/') || mimeType === 'image';
}
/**
* @private
* @param {?} mimeType
* @return {?}
*/
static isPdf(mimeType) {
return mimeType === 'application/pdf' || mimeType === 'pdf';
}
/**
* @param {?} documentMetaData
* @return {?}
*/
getDocumentId(documentMetaData) {
/** @type {?} */
const 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 {?}
*/
buildComponent(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 {?}
*/
buildAnnotateUi(url, viewContainerRef, baseUrl, annotate, annotationSet, rotate) {
viewContainerRef.clear();
/** @type {?} */
const componentFactory = this.componentFactoryResolver.resolveComponentFactory(AnnotationPdfViewerComponent);
/** @type {?} */
const 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 {?}
*/
createComponent(component, viewContainerRef, originalUrl, url, rotate) {
/** @type {?} */
const componentFactory = this.componentFactoryResolver.resolveComponentFactory(component);
viewContainerRef.clear();
/** @type {?} */
const 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 = () => [
{ type: ComponentFactoryResolver },
{ type: AnnotationStoreService },
{ type: UrlFixerService },
{ type: EmLoggerService }
];
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"]}