@hmcts/media-viewer
Version:
82 lines • 13.8 kB
JavaScript
import { Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
import { ViewerException } from '../viewer-exception.model';
import { select } from '@ngrx/store';
import * as fromDocumentActions from '../../store/actions/document.actions';
import * as fromSelectors from '../../store/selectors/document.selectors';
import { filter } from 'rxjs/operators';
import * as i0 from "@angular/core";
import * as i1 from "@ngrx/store";
import * as i2 from "@angular/common";
import * as i3 from "../pdf-viewer/pdf-viewer.component";
export class ConvertibleContentViewerComponent {
constructor(store) {
this.store = store;
this.mediaLoadStatus = new EventEmitter();
this.viewerException = new EventEmitter();
this.documentTitle = new EventEmitter();
}
ngOnInit() {
this.$subscription = this.store.pipe(select(fromSelectors.getConvertedDocument), filter(value => !!value))
.subscribe((docInfo) => {
if (docInfo.url) {
this.convertedUrl = docInfo.url;
this.store.dispatch(new fromDocumentActions.ClearConvertDocUrl());
}
else {
this.onLoadException(new ViewerException(docInfo.error));
}
});
}
ngOnChanges(changes) {
if (changes.originalUrl?.currentValue && changes.originalUrl.currentValue !== changes.originalUrl.previousValue) {
this.store.dispatch(new fromDocumentActions.Convert(this.extractDMStoreDocId(this.originalUrl)));
}
}
ngOnDestroy() {
this.$subscription.unsubscribe();
}
onMediaLoad(status) {
this.mediaLoadStatus.emit(status);
}
onLoadException(exception) {
this.viewerException.emit(exception);
}
onDocumentTitleChange(title) {
this.documentTitle.emit(title);
}
// todo move this to common place for media viewer and pdf
extractDMStoreDocId(url) {
if (url.includes('/documents/')) {
url = url.split('/documents/')[1];
}
else if (url.includes('/documentsv2/')) {
url = url.split('/documentsv2/')[1];
}
return url.replace('/binary', '');
}
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ConvertibleContentViewerComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ConvertibleContentViewerComponent, selector: "mv-conversion-viewer", inputs: { originalUrl: "originalUrl", downloadFileName: "downloadFileName", height: "height", enableAnnotations: "enableAnnotations", enableRedactions: "enableRedactions", annotationSet: "annotationSet" }, outputs: { mediaLoadStatus: "mediaLoadStatus", viewerException: "viewerException", documentTitle: "documentTitle" }, usesOnChanges: true, ngImport: i0, template: "<mv-pdf-viewer *ngIf=\"convertedUrl\"\n (mediaLoadStatus)=\"onMediaLoad($event)\"\n (pdfViewerException)=\"onLoadException($event)\"\n (documentTitle)=\"onDocumentTitleChange($event)\"\n [url]=\"convertedUrl\"\n [downloadUrl]=\"originalUrl\"\n [enableAnnotations]=\"enableAnnotations\"\n [enableRedactions]=\"enableRedactions\"\n [annotationSet]=\"enableAnnotations ? annotationSet : null\"\n [downloadFileName]=\"downloadFileName\"\n [height]=\"height\">\n</mv-pdf-viewer>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.PdfViewerComponent, selector: "mv-pdf-viewer", inputs: ["downloadUrl", "url", "downloadFileName", "enableAnnotations", "enableRedactions", "enableICP", "annotationSet", "enableRedactSearch", "height", "caseId", "searchBarHidden"], outputs: ["mediaLoadStatus", "pdfViewerException", "documentTitle"] }], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ConvertibleContentViewerComponent, decorators: [{
type: Component,
args: [{ selector: 'mv-conversion-viewer', encapsulation: ViewEncapsulation.None, template: "<mv-pdf-viewer *ngIf=\"convertedUrl\"\n (mediaLoadStatus)=\"onMediaLoad($event)\"\n (pdfViewerException)=\"onLoadException($event)\"\n (documentTitle)=\"onDocumentTitleChange($event)\"\n [url]=\"convertedUrl\"\n [downloadUrl]=\"originalUrl\"\n [enableAnnotations]=\"enableAnnotations\"\n [enableRedactions]=\"enableRedactions\"\n [annotationSet]=\"enableAnnotations ? annotationSet : null\"\n [downloadFileName]=\"downloadFileName\"\n [height]=\"height\">\n</mv-pdf-viewer>\n" }]
}], ctorParameters: () => [{ type: i1.Store }], propDecorators: { originalUrl: [{
type: Input
}], downloadFileName: [{
type: Input
}], height: [{
type: Input
}], enableAnnotations: [{
type: Input
}], enableRedactions: [{
type: Input
}], annotationSet: [{
type: Input
}], mediaLoadStatus: [{
type: Output
}], viewerException: [{
type: Output
}], documentTitle: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"convertible-content-viewer.component.js","sourceRoot":"","sources":["../../../../../../projects/media-viewer/src/lib/viewers/convertible-content-viewer/convertible-content-viewer.component.ts","../../../../../../projects/media-viewer/src/lib/viewers/convertible-content-viewer/convertible-content-viewer.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAgC,MAAM,EAAiB,iBAAiB,EAAE,MAAM,eAAe,CAAC;AACvI,OAAO,EAAgB,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC1E,OAAO,EAAE,MAAM,EAAS,MAAM,aAAa,CAAC;AAE5C,OAAO,KAAK,mBAAmB,MAAM,sCAAsC,CAAC;AAE5E,OAAO,KAAK,aAAa,MAAM,0CAA0C,CAAC;AAE1E,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;;;;;AAOxC,MAAM,OAAO,iCAAiC;IAmB5C,YAAoB,KAAqC;QAArC,UAAK,GAAL,KAAK,CAAgC;QAP/C,oBAAe,GAAG,IAAI,YAAY,EAAgB,CAAC;QACnD,oBAAe,GAAG,IAAI,YAAY,EAAmB,CAAC;QACtD,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;IAMrD,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,oBAAoB,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;aACvG,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;YACrB,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;gBAChB,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,GAAG,CAAC;gBAChC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,mBAAmB,CAAC,kBAAkB,EAAE,CAAC,CAAC;YACpE,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,eAAe,CAAC,IAAI,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;YAC3D,CAAC;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,WAAW,EAAE,YAAY,IAAI,OAAO,CAAC,WAAW,CAAC,YAAY,KAAK,OAAO,CAAC,WAAW,CAAC,aAAa,EAAE,CAAC;YAChH,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,mBAAmB,CAAC,OAAO,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;QACnG,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;IACnC,CAAC;IAED,WAAW,CAAC,MAAoB;QAC9B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAED,eAAe,CAAC,SAA0B;QACxC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACvC,CAAC;IAED,qBAAqB,CAAC,KAAa;QACjC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,0DAA0D;IAClD,mBAAmB,CAAC,GAAW;QAErC,IAAI,GAAG,CAAC,QAAQ,CAAC,aAAa,CAAC,EAAE,CAAC;YAChC,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;QACpC,CAAC;aAAM,IAAI,GAAG,CAAC,QAAQ,CAAC,eAAe,CAAC,EAAE,CAAC;YACzC,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;QACtC,CAAC;QACD,OAAO,GAAG,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;IACpC,CAAC;kIAjEU,iCAAiC;sHAAjC,iCAAiC,oZCf9C,ymBAYA;;4FDGa,iCAAiC;kBAL7C,SAAS;+BACE,sBAAsB,iBAEjB,iBAAiB,CAAC,IAAI;0EAI5B,WAAW;sBAAnB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAEG,MAAM;sBAAd,KAAK;gBAEG,iBAAiB;sBAAzB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBAGI,eAAe;sBAAxB,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBACG,aAAa;sBAAtB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, ViewEncapsulation } from '@angular/core';\nimport { ResponseType, ViewerException } from '../viewer-exception.model';\nimport { select, Store } from '@ngrx/store';\nimport * as fromStore from '../../store/reducers/document.reducer';\nimport * as fromDocumentActions from '../../store/actions/document.actions';\nimport { Subscription } from 'rxjs';\nimport * as fromSelectors from '../../store/selectors/document.selectors';\nimport { AnnotationSet } from '../../annotations/annotation-set/annotation-set.model';\nimport { filter } from 'rxjs/operators';\n\n@Component({\n  selector: 'mv-conversion-viewer',\n  templateUrl: './convertible-content-viewer.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class ConvertibleContentViewerComponent implements OnInit, OnDestroy, OnChanges {\n\n  @Input() originalUrl;\n  @Input() downloadFileName: string;\n\n  @Input() height;\n\n  @Input() enableAnnotations: boolean;\n  @Input() enableRedactions: boolean;\n  @Input() annotationSet: AnnotationSet | null;\n\n\n  @Output() mediaLoadStatus = new EventEmitter<ResponseType>();\n  @Output() viewerException = new EventEmitter<ViewerException>();\n  @Output() documentTitle = new EventEmitter<string>();\n\n  private $subscription: Subscription;\n  convertedUrl: string;\n\n  constructor(private store: Store<fromStore.DocumentState>) {\n  }\n\n  ngOnInit(): void {\n    this.$subscription = this.store.pipe(select(fromSelectors.getConvertedDocument), filter(value => !!value))\n      .subscribe((docInfo) => {\n        if (docInfo.url) {\n          this.convertedUrl = docInfo.url;\n          this.store.dispatch(new fromDocumentActions.ClearConvertDocUrl());\n        } else {\n          this.onLoadException(new ViewerException(docInfo.error));\n        }\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.originalUrl?.currentValue && changes.originalUrl.currentValue !== changes.originalUrl.previousValue) {\n      this.store.dispatch(new fromDocumentActions.Convert(this.extractDMStoreDocId(this.originalUrl)));\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.$subscription.unsubscribe();\n  }\n\n  onMediaLoad(status: ResponseType) {\n    this.mediaLoadStatus.emit(status);\n  }\n\n  onLoadException(exception: ViewerException) {\n    this.viewerException.emit(exception);\n  }\n\n  onDocumentTitleChange(title: string) {\n    this.documentTitle.emit(title);\n  }\n\n  // todo move this to common place for media viewer and pdf\n  private extractDMStoreDocId(url: string): string {\n\n    if (url.includes('/documents/')) {\n      url = url.split('/documents/')[1];\n    } else if (url.includes('/documentsv2/')) {\n      url = url.split('/documentsv2/')[1];\n    }\n    return url.replace('/binary', '');\n  }\n}\n","<mv-pdf-viewer *ngIf=\"convertedUrl\"\n               (mediaLoadStatus)=\"onMediaLoad($event)\"\n               (pdfViewerException)=\"onLoadException($event)\"\n               (documentTitle)=\"onDocumentTitleChange($event)\"\n               [url]=\"convertedUrl\"\n               [downloadUrl]=\"originalUrl\"\n               [enableAnnotations]=\"enableAnnotations\"\n               [enableRedactions]=\"enableRedactions\"\n               [annotationSet]=\"enableAnnotations ? annotationSet : null\"\n               [downloadFileName]=\"downloadFileName\"\n               [height]=\"height\">\n</mv-pdf-viewer>\n"]}