@hmcts/ccd-case-ui-toolkit 7.2.57 → 7.2.58-update-all-error-message-1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,6 @@
1
1
  import { Component, ElementRef } from '@angular/core';
2
2
  import { ActivatedRoute } from '@angular/router';
3
+ import { HttpErrorResponse, HttpStatusCode } from '@angular/common/http';
3
4
  import { fromEvent, of } from 'rxjs';
4
5
  import { catchError, finalize, map, switchMap, takeUntil } from 'rxjs/operators';
5
6
  import { CaseFileViewService, DocumentManagementService, LoadingService, SessionStorageService } from '../../../services';
@@ -153,8 +154,8 @@ export class CaseFileViewFieldComponent {
153
154
  this.caseFileViewService.updateDocumentCategory(cid, this.caseVersion, data.document.attribute_path, data.newCategory)
154
155
  .pipe(finalize(() => {
155
156
  this.loadingService.unregister(loadingToken);
156
- }), catchError(() => {
157
- this.errorMessages = ['You do not have permission to move this document to the selected folder.'];
157
+ }), catchError((err) => {
158
+ this.errorMessages = [this.moveDocumentError(err)];
158
159
  return of(null);
159
160
  }))
160
161
  .subscribe(res => {
@@ -178,6 +179,31 @@ export class CaseFileViewFieldComponent {
178
179
  isIcpEnabled() {
179
180
  return this.icpEnabled && ((this.icp_jurisdictions?.length < 1) || this.icp_jurisdictions.includes(this.caseNotifier?.cachedCaseView?.case_type?.jurisdiction.id));
180
181
  }
182
+ moveDocumentError(err) {
183
+ const defaultMsg = 'We couldn\'t move the document. Please try again.';
184
+ if (!(err instanceof HttpErrorResponse)) {
185
+ return defaultMsg;
186
+ }
187
+ switch (err.status) {
188
+ case HttpStatusCode.BadRequest:
189
+ // e.g. malformed PUT, invalid attribute_path, invalid target category
190
+ return 'The request was invalid. Check the document path and destination folder.';
191
+ case HttpStatusCode.Conflict:
192
+ // optimistic concurrency / stale case version
193
+ return 'This case changed since you opened it. Refresh and try again.';
194
+ case HttpStatusCode.NotFound:
195
+ return 'The document or destination folder could not be found.';
196
+ case HttpStatusCode.Forbidden:
197
+ case HttpStatusCode.Unauthorized:
198
+ return 'You do not have permission to move this document to the selected folder.';
199
+ case HttpStatusCode.ServiceUnavailable:
200
+ case HttpStatusCode.GatewayTimeout:
201
+ return 'The service is temporarily unavailable. Please try again in a moment.';
202
+ default:
203
+ // Any other status (including 500)
204
+ return defaultMsg;
205
+ }
206
+ }
181
207
  static ɵfac = function CaseFileViewFieldComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || CaseFileViewFieldComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.ActivatedRoute), i0.ɵɵdirectiveInject(i2.CaseFileViewService), i0.ɵɵdirectiveInject(i2.DocumentManagementService), i0.ɵɵdirectiveInject(i2.LoadingService), i0.ɵɵdirectiveInject(i2.SessionStorageService), i0.ɵɵdirectiveInject(i3.CaseNotifier), i0.ɵɵdirectiveInject(i4.AbstractAppConfig)); };
182
208
  static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: CaseFileViewFieldComponent, selectors: [["ccd-case-file-view-field"]], decls: 3, vars: 3, consts: [[4, "ngIf"], ["class", "govuk-grid-column-two-thirds", 4, "ngIf"], ["id", "case-file-view-field-errors", "data-module", "govuk-error-summary", 1, "govuk-error-summary", "govuk-!-margin-bottom-4"], ["role", "alert"], [1, "govuk-error-summary__title"], [1, "govuk-error-summary__body"], [1, "govuk-list", "govuk-error-summary__list"], [4, "ngFor", "ngForOf"], ["type", "button", 1, "govuk-js-link"], [1, "govuk-grid-column-two-thirds"], [1, "govuk-heading-xl"], [1, "govuk-body"], [1, "govuk-heading-l"], ["id", "case-file-view", 1, "govuk-form-group"], [1, "document-tree-container"], [1, "document-tree-container__tree", 3, "clickedDocument", "moveDocument", "categoriesAndDocuments", "allowMoving"], [1, "slider"], [1, "media-viewer-container"], [3, "url", "downloadFileName", "showToolbar", "contentType", "enableAnnotations", "enableRedactions", "height", "caseId", "multimediaPlayerEnabled", "enableICP"]], template: function CaseFileViewFieldComponent_Template(rf, ctx) { if (rf & 1) {
183
209
  i0.ɵɵtemplate(0, CaseFileViewFieldComponent_ng_container_0_Template, 8, 1, "ng-container", 0)(1, CaseFileViewFieldComponent_div_1_Template, 5, 0, "div", 1)(2, CaseFileViewFieldComponent_div_2_Template, 9, 3, "div", 0);
@@ -193,5 +219,5 @@ export class CaseFileViewFieldComponent {
193
219
  type: Component,
194
220
  args: [{ selector: 'ccd-case-file-view-field', template: "<ng-container *ngIf=\"errorMessages?.length\">\n <div\n id=\"case-file-view-field-errors\"\n class=\"govuk-error-summary govuk-!-margin-bottom-4\"\n data-module=\"govuk-error-summary\"\n >\n <div role=\"alert\">\n <h2 class=\"govuk-error-summary__title\">There is a problem</h2>\n <div class=\"govuk-error-summary__body\">\n <ul class=\"govuk-list govuk-error-summary__list\">\n <li *ngFor=\"let errorMessage of errorMessages\">\n <button type=\"button\" class=\"govuk-js-link\">{{ errorMessage }}</button>\n </li>\n </ul>\n </div>\n </div>\n </div>\n</ng-container>\n\n<div\n *ngIf=\"getCategoriesAndDocumentsError\"\n class=\"govuk-grid-column-two-thirds\"\n>\n <h1 class=\"govuk-heading-xl\">Sorry, there is a problem with the service</h1>\n <p class=\"govuk-body\">Try again later.</p>\n</div>\n<div *ngIf=\"!getCategoriesAndDocumentsError\">\n <h2 class=\"govuk-heading-l\">Case file</h2>\n <div class=\"govuk-form-group\" id=\"case-file-view\">\n <!-- Document tree -->\n <div class=\"document-tree-container\">\n <ccd-case-file-view-folder \n class=\"document-tree-container__tree\"\n [categoriesAndDocuments]=\"categoriesAndDocuments$\"\n (clickedDocument)=\"setMediaViewerFile($event); resetErrorMessages()\" \n (moveDocument)=\"moveDocument($event)\"\n [allowMoving]=\"allowMoving\">\n </ccd-case-file-view-folder>\n </div>\n <!-- Slider -->\n <div class=\"slider\"></div>\n <!-- Media viewer -->\n <div class=\"media-viewer-container\">\n <ng-container *ngIf=\"currentDocument\">\n <mv-media-viewer\n [url]=\"currentDocument.document_binary_url\"\n [downloadFileName]=\"currentDocument.document_filename\"\n [showToolbar]=\"true\"\n [contentType]=\"currentDocument.content_type\"\n [enableAnnotations]=\"true\"\n [enableRedactions]=\"true\"\n [height]=\"'94.5vh'\"\n [caseId]=\"caseId\"\n [multimediaPlayerEnabled]=\"true\"\n [enableICP]=\"isIcpEnabled()\"\n >\n </mv-media-viewer>\n </ng-container>\n </div>\n </div>\n</div>\n", styles: ["#case-file-view{display:flex;border:2px solid #C9C9C9;height:100vh;position:relative}#case-file-view .document-tree-container{background-color:#faf8f8;width:30%;min-height:400px;min-width:10%}#case-file-view .slider{width:.2%;background-color:#6b6b6b}#case-file-view .slider:hover,#case-file-view .slider:focus{cursor:col-resize}#case-file-view .media-viewer-container{background-color:#dee0e2;flex:1 1 0;overflow:hidden}\n"] }]
195
221
  }], () => [{ type: i0.ElementRef }, { type: i1.ActivatedRoute }, { type: i2.CaseFileViewService }, { type: i2.DocumentManagementService }, { type: i2.LoadingService }, { type: i2.SessionStorageService }, { type: i3.CaseNotifier }, { type: i4.AbstractAppConfig }], null); })();
196
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(CaseFileViewFieldComponent, { className: "CaseFileViewFieldComponent", filePath: "lib/shared/components/palette/case-file-view/case-file-view-field.component.ts", lineNumber: 17 }); })();
197
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"case-file-view-field.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/case-file-view/case-file-view-field.component.ts","../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/case-file-view/case-file-view-field.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,UAAU,EAAqB,MAAM,eAAe,CAAC;AACxF,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAc,EAAE,EAAgB,MAAM,MAAM,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAIjF,OAAO,EAAE,mBAAmB,EAAE,yBAAyB,EAAE,cAAc,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAC1H,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;;;;;;;ICE9C,AADF,0BAA+C,gBACD;IAAA,YAAkB;IAChE,AADgE,iBAAS,EACpE;;;IADyC,eAAkB;IAAlB,qCAAkB;;;IAX1E,6BAA4C;IAOtC,AADF,AALF,8BAIC,aACmB,YACuB;IAAA,kCAAkB;IAAA,iBAAK;IAE5D,AADF,8BAAuC,YACY;IAC/C,wFAA+C;IAMvD,AADE,AADE,AADE,iBAAK,EACD,EACF,EACF;;;;IAN+B,eAAgB;IAAhB,8CAAgB;;;IAarD,AAJF,8BAGC,aAC8B;IAAA,0DAA0C;IAAA,iBAAK;IAC5E,6BAAsB;IAAA,gCAAgB;IACxC,AADwC,iBAAI,EACtC;;;IAkBA,6BAAsC;IACpC,sCAYkB;;;;IAXhB,cAA2C;IAS3C,AADA,AADA,AADA,AADA,AADA,AADA,AADA,AADA,AADA,gEAA2C,8DACW,qBAClC,oDACwB,2BAClB,0BACD,oBACN,yBACF,iCACe,oCACJ;;;;IA3BpC,AADF,2BAA6C,aACf;IAAA,yBAAS;IAAA,iBAAK;IAItC,AADF,AAFF,+BAAkD,cAEX,oCAMH;IAD5B,AADA,6MAAmB,iCAA0B,wBAAE,2BAAoB,KAAC,gNACpD,2BAAoB,KAAC;IAG3C,AADE,iBAA4B,EACxB;IAEN,0BAA0B;IAE1B,+BAAoC;IAClC,oGAAsC;IAiB5C,AADE,AADE,iBAAM,EACF,EACF;;;IA3BI,eAAkD;IAGlD,AAHA,uEAAkD,mCAGvB;IAOhB,eAAqB;IAArB,6CAAqB;;AD3B1C,MAAM,OAAO,0BAA0B;IAcR;IACV;IACT;IACA;IACS;IACA;IACA;IACA;IApBZ,MAAM,CAAU,aAAa,GAAG,KAAK,CAAC;IACtC,WAAW,GAAG,IAAI,CAAC;IACnB,uBAAuB,CAAqC;IAC5D,kCAAkC,CAAe;IACjD,8BAA8B,GAAG,KAAK,CAAC;IACvC,eAAe,CAAmC;IAClD,aAAa,GAAG,EAAc,CAAC;IAC9B,WAAW,CAAS;IACrB,SAAS,CAAY;IACrB,iBAAiB,GAAa,EAAE,CAAC;IACjC,UAAU,GAAY,KAAK,CAAC;IAC5B,MAAM,CAAS;IAEtB,YAA6B,UAAsB,EAChC,KAAqB,EAC9B,mBAAwC,EACxC,yBAAoD,EAC3C,cAA8B,EAC9B,qBAA4C,EAC5C,YAA0B,EAC1B,cAAiC;QAPvB,eAAU,GAAV,UAAU,CAAY;QAChC,UAAK,GAAL,KAAK,CAAgB;QAC9B,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,8BAAyB,GAAzB,yBAAyB,CAA2B;QAC3C,mBAAc,GAAd,cAAc,CAAgB;QAC9B,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,iBAAY,GAAZ,YAAY,CAAc;QAC1B,mBAAc,GAAd,cAAc,CAAmB;IAChD,CAAC;IAEE,QAAQ;QACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,0BAA0B,CAAC,aAAa,CAAC,CAAC;QACzF,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,mBAAmB,CAAC,yBAAyB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC/F,IAAI,CAAC,kCAAkC,GAAG,IAAI,CAAC,uBAAuB,CAAC,SAAS,CAAC;YAC/E,IAAI,EAAE,IAAI,CAAC,EAAE;gBACX,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC;YACvC,CAAC;YACD,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,8BAA8B,GAAG,IAAI;SACvD,CAAC,CAAC;QAEH,YAAY;QACZ,MAAM,QAAQ,GAAa,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC;QACzF,yDAAyD;QACzD,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;QAClF,gFAAgF;QAChF,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAChD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,cAAc,CAAC,mBAAmB,EAAE,CAAC;QACnE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IACvD,CAAC;IAEM,eAAe;QACpB,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;QACtE,MAAM,qBAAqB,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,0BAA0B,CAAC,CAAC;QAEtG,MAAM,UAAU,GAAG,SAAS,CAAa,MAAM,EAAE,WAAW,CAAC,CAAC;QAC9D,MAAM,UAAU,GAAG,SAAS,CAAa,QAAQ,EAAE,WAAW,CAAC,CAAC;QAChE,MAAM,QAAQ,GAAG,SAAS,CAAa,QAAQ,EAAE,SAAS,CAAC,CAAC;QAC5D,MAAM,KAAK,GAAG,UAAU,CAAC,IAAI,CAC3B,SAAS,CACP,CAAC,KAAK,EAAE,EAAE;YACR,MAAM,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC;YACxB,MAAM,0BAA0B,GAAG,qBAAqB,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;YACvF,OAAO,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;gBAChC,IAAI,CAAC,cAAc,EAAE,CAAC;gBACtB,OAAO;oBACL,EAAE,EAAE,IAAI,CAAC,OAAO,GAAG,CAAC;oBACpB,0BAA0B;iBAC3B,CAAC;YACJ,CAAC,CAAC,EACA,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;QACzB,CAAC,CACF,CACF,CAAC;QAEF,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YACpB,MAAM,eAAe,GAAG,CAAC,CAAC,GAAG,CAAC,0BAA0B,GAAG,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,GAAG,MAAM,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;YAC/H,qBAAqB,CAAC,YAAY,CAAC,OAAO,EAAE,UAAU,eAAe,GAAG,CAAC,CAAC;QAC5E,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,kBAAkB,CAAC,QAA0B;QAClD,MAAM,eAAe,GAAG,IAAI,CAAC,yBAAyB,CAAC,kBAAkB,CAAC;YACxE,mBAAmB,EAAE,QAAQ,CAAC,mBAAmB;YACjD,iBAAiB,EAAE,QAAQ,CAAC,iBAAiB;SAC9C,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;IACrD,CAAC;IAEM,YAAY,CAAC,IAAyD;QAC3E,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,0BAA0B,CAAC,aAAa,CAAC,CAAC;QACvF,MAAM,YAAY,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;QACpD,IAAI,CAAC,mBAAmB,CAAC,sBAAsB,CAAC,GAAG,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,cAAc,EAAE,IAAI,CAAC,WAAW,CAAC;aACnH,IAAI,CACH,QAAQ,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;QAC/C,CAAC,CAAC,EACF,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,aAAa,GAAG,CAAC,0EAA0E,CAAC,CAAC;YAClG,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC,CAAC,CACH;aACA,SAAS,CAAC,GAAG,CAAC,EAAE;YACf,IAAI,GAAG,EAAE,CAAC;gBACR,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBAC1B,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,CAAC;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,UAAU;QACf,QAAQ,CAAC,MAAM,EAAE,CAAC;IACpB,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;IAC1B,CAAC;IAEM,WAAW;QAChB,IAAI,IAAI,CAAC,kCAAkC,EAAE,CAAC;YAC5C,IAAI,CAAC,kCAAkC,CAAC,WAAW,EAAE,CAAC;QACxD,CAAC;IACH,CAAC;IAEM,YAAY;QACjB,OAAO,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,MAAM,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAChG,IAAI,CAAC,YAAY,EAAE,cAAc,EAAE,SAAS,EAAE,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC;IACpE,CAAC;oHAxHU,0BAA0B;6DAA1B,0BAA0B;YCUvC,AAPA,AAnBA,6FAA4C,8DAsB3C,8DAI4C;;YA1B9B,kFAA2B;YAoBvC,cAAoC;YAApC,yDAAoC;YAMjC,cAAqC;YAArC,0DAAqC;;;iFDV9B,0BAA0B;cALtC,SAAS;2BACE,0BAA0B;;kFAIzB,0BAA0B","sourcesContent":["import { AfterViewInit, Component, ElementRef, OnDestroy, OnInit } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { fromEvent, Observable, of, Subscription } from 'rxjs';\nimport { catchError, finalize, map, switchMap, takeUntil } from 'rxjs/operators';\nimport { CaseField } from '../../../domain';\nimport { CaseFileViewDocument, CategoriesAndDocuments, DocumentTreeNode } from '../../../domain/case-file-view';\nimport { UserInfo } from '../../../domain/user/user-info.model';\nimport { CaseFileViewService, DocumentManagementService, LoadingService, SessionStorageService } from '../../../services';\nimport { AbstractAppConfig } from '../../../../app.config';\nimport { CaseNotifier } from '../../case-editor/services';\n\n@Component({\n  selector: 'ccd-case-file-view-field',\n  templateUrl: './case-file-view-field.component.html',\n  styleUrls: ['./case-file-view-field.component.scss'],\n})\nexport class CaseFileViewFieldComponent implements OnInit, AfterViewInit, OnDestroy {\n  public static readonly PARAM_CASE_ID = 'cid';\n  public allowMoving = true;\n  public categoriesAndDocuments$: Observable<CategoriesAndDocuments>;\n  public categoriesAndDocumentsSubscription: Subscription;\n  public getCategoriesAndDocumentsError = false;\n  public currentDocument: CaseFileViewDocument | undefined;\n  public errorMessages = [] as string[];\n  private caseVersion: number;\n  public caseField: CaseField;\n  public icp_jurisdictions: string[] = [];\n  public icpEnabled: boolean = false;\n  public caseId: string;\n\n  constructor(private readonly elementRef: ElementRef,\n    private readonly route: ActivatedRoute,\n    private caseFileViewService: CaseFileViewService,\n    private documentManagementService: DocumentManagementService,\n    private readonly loadingService: LoadingService,\n    private readonly sessionStorageService: SessionStorageService,\n    private readonly caseNotifier: CaseNotifier,\n    private readonly abstractConfig: AbstractAppConfig,\n  ) { }\n\n  public ngOnInit(): void {\n    this.caseId = this.route.snapshot.paramMap.get(CaseFileViewFieldComponent.PARAM_CASE_ID);\n    this.categoriesAndDocuments$ = this.caseFileViewService.getCategoriesAndDocuments(this.caseId);\n    this.categoriesAndDocumentsSubscription = this.categoriesAndDocuments$.subscribe({\n      next: data => {\n        this.caseVersion = data.case_version;\n      },\n      error: _ => this.getCategoriesAndDocumentsError = true\n    });\n\n    // EXUI-8000\n    const userInfo: UserInfo = JSON.parse(this.sessionStorageService.getItem('userDetails'));\n    // Get acls that intersects from acl roles and user roles\n    const acls = this.caseField.acls.filter(acl => userInfo.roles.includes(acl.role));\n    // As there can be more than one intersecting role, if any acls are update: true\n    this.allowMoving = acls.some(acl => acl.update);\n    this.icp_jurisdictions = this.abstractConfig.getIcpJurisdictions();\n    this.icpEnabled = this.abstractConfig.getIcpEnable();\n  }\n\n  public ngAfterViewInit(): void {\n    const slider = this.elementRef.nativeElement.querySelector('.slider');\n    const documentTreeContainer = this.elementRef.nativeElement.querySelector('.document-tree-container');\n\n    const mousedown$ = fromEvent<MouseEvent>(slider, 'mousedown');\n    const mousemove$ = fromEvent<MouseEvent>(document, 'mousemove');\n    const mouseup$ = fromEvent<MouseEvent>(document, 'mouseup');\n    const drag$ = mousedown$.pipe(\n      switchMap(\n        (start) => {\n          const x = start.clientX;\n          const documentTreeContainerWidth = documentTreeContainer.getBoundingClientRect().width;\n          return mousemove$.pipe(map(move => {\n            move.preventDefault();\n            return {\n              dx: move.clientX - x,\n              documentTreeContainerWidth\n            };\n          }),\n            takeUntil(mouseup$));\n        }\n      )\n    );\n\n    drag$.subscribe(pos => {\n      const calculatedWidth = ((pos.documentTreeContainerWidth + pos.dx) * 100) / slider.parentElement.getBoundingClientRect().width;\n      documentTreeContainer.setAttribute('style', `width: ${calculatedWidth}%`);\n    });\n  }\n\n  public setMediaViewerFile(document: DocumentTreeNode): void {\n    const mediaViewerInfo = this.documentManagementService.getMediaViewerInfo({\n      document_binary_url: document.document_binary_url,\n      document_filename: document.document_filename\n    });\n    this.currentDocument = JSON.parse(mediaViewerInfo);\n  }\n\n  public moveDocument(data: { document: DocumentTreeNode, newCategory: string }): void {\n    const cid = this.route.snapshot.paramMap.get(CaseFileViewFieldComponent.PARAM_CASE_ID);\n    const loadingToken = this.loadingService.register();\n    this.caseFileViewService.updateDocumentCategory(cid, this.caseVersion, data.document.attribute_path, data.newCategory)\n      .pipe(\n        finalize(() => {\n          this.loadingService.unregister(loadingToken);\n        }),\n        catchError(() => {\n          this.errorMessages = ['You do not have permission to move this document to the selected folder.'];\n          return of(null);\n        }),\n      )\n      .subscribe(res => {\n        if (res) {\n          this.resetErrorMessages();\n          this.reloadPage();\n        }\n      });\n  }\n\n  public reloadPage(): void {\n    location.reload();\n  }\n\n  public resetErrorMessages(): void {\n    this.errorMessages = [];\n  }\n\n  public ngOnDestroy(): void {\n    if (this.categoriesAndDocumentsSubscription) {\n      this.categoriesAndDocumentsSubscription.unsubscribe();\n    }\n  }\n\n  public isIcpEnabled(): boolean {\n    return this.icpEnabled && ((this.icp_jurisdictions?.length < 1) || this.icp_jurisdictions.includes(\n      this.caseNotifier?.cachedCaseView?.case_type?.jurisdiction.id));\n  }\n}\n","<ng-container *ngIf=\"errorMessages?.length\">\n  <div\n    id=\"case-file-view-field-errors\"\n    class=\"govuk-error-summary govuk-!-margin-bottom-4\"\n    data-module=\"govuk-error-summary\"\n  >\n    <div role=\"alert\">\n      <h2 class=\"govuk-error-summary__title\">There is a problem</h2>\n      <div class=\"govuk-error-summary__body\">\n        <ul class=\"govuk-list govuk-error-summary__list\">\n          <li *ngFor=\"let errorMessage of errorMessages\">\n            <button type=\"button\" class=\"govuk-js-link\">{{ errorMessage }}</button>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </div>\n</ng-container>\n\n<div\n  *ngIf=\"getCategoriesAndDocumentsError\"\n  class=\"govuk-grid-column-two-thirds\"\n>\n  <h1 class=\"govuk-heading-xl\">Sorry, there is a problem with the service</h1>\n  <p class=\"govuk-body\">Try again later.</p>\n</div>\n<div *ngIf=\"!getCategoriesAndDocumentsError\">\n  <h2 class=\"govuk-heading-l\">Case file</h2>\n  <div class=\"govuk-form-group\" id=\"case-file-view\">\n    <!-- Document tree -->\n    <div class=\"document-tree-container\">\n      <ccd-case-file-view-folder \n          class=\"document-tree-container__tree\"\n          [categoriesAndDocuments]=\"categoriesAndDocuments$\"\n          (clickedDocument)=\"setMediaViewerFile($event); resetErrorMessages()\" \n          (moveDocument)=\"moveDocument($event)\"\n          [allowMoving]=\"allowMoving\">\n      </ccd-case-file-view-folder>\n    </div>\n    <!-- Slider -->\n    <div class=\"slider\"></div>\n    <!-- Media viewer -->\n    <div class=\"media-viewer-container\">\n      <ng-container *ngIf=\"currentDocument\">\n        <mv-media-viewer\n          [url]=\"currentDocument.document_binary_url\"\n          [downloadFileName]=\"currentDocument.document_filename\"\n          [showToolbar]=\"true\"\n          [contentType]=\"currentDocument.content_type\"\n          [enableAnnotations]=\"true\"\n          [enableRedactions]=\"true\"\n          [height]=\"'94.5vh'\"\n          [caseId]=\"caseId\"\n          [multimediaPlayerEnabled]=\"true\"\n          [enableICP]=\"isIcpEnabled()\"\n        >\n        </mv-media-viewer>\n      </ng-container>\n    </div>\n  </div>\n</div>\n"]}
222
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(CaseFileViewFieldComponent, { className: "CaseFileViewFieldComponent", filePath: "lib/shared/components/palette/case-file-view/case-file-view-field.component.ts", lineNumber: 18 }); })();
223
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"case-file-view-field.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/case-file-view/case-file-view-field.component.ts","../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/case-file-view/case-file-view-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, OnDestroy, OnInit } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { HttpErrorResponse, HttpStatusCode } from '@angular/common/http';\nimport { fromEvent, Observable, of, Subscription } from 'rxjs';\nimport { catchError, finalize, map, switchMap, takeUntil } from 'rxjs/operators';\nimport { CaseField } from '../../../domain';\nimport { CaseFileViewDocument, CategoriesAndDocuments, DocumentTreeNode } from '../../../domain/case-file-view';\nimport { UserInfo } from '../../../domain/user/user-info.model';\nimport { CaseFileViewService, DocumentManagementService, LoadingService, SessionStorageService } from '../../../services';\nimport { AbstractAppConfig } from '../../../../app.config';\nimport { CaseNotifier } from '../../case-editor/services';\n\n@Component({\n  selector: 'ccd-case-file-view-field',\n  templateUrl: './case-file-view-field.component.html',\n  styleUrls: ['./case-file-view-field.component.scss'],\n})\nexport class CaseFileViewFieldComponent implements OnInit, AfterViewInit, OnDestroy {\n  public static readonly PARAM_CASE_ID = 'cid';\n  public allowMoving = true;\n  public categoriesAndDocuments$: Observable<CategoriesAndDocuments>;\n  public categoriesAndDocumentsSubscription: Subscription;\n  public getCategoriesAndDocumentsError = false;\n  public currentDocument: CaseFileViewDocument | undefined;\n  public errorMessages = [] as string[];\n  private caseVersion: number;\n  public caseField: CaseField;\n  public icp_jurisdictions: string[] = [];\n  public icpEnabled: boolean = false;\n  public caseId: string;\n\n  constructor(private readonly elementRef: ElementRef,\n    private readonly route: ActivatedRoute,\n    private caseFileViewService: CaseFileViewService,\n    private documentManagementService: DocumentManagementService,\n    private readonly loadingService: LoadingService,\n    private readonly sessionStorageService: SessionStorageService,\n    private readonly caseNotifier: CaseNotifier,\n    private readonly abstractConfig: AbstractAppConfig,\n  ) { }\n\n  public ngOnInit(): void {\n    this.caseId = this.route.snapshot.paramMap.get(CaseFileViewFieldComponent.PARAM_CASE_ID);\n    this.categoriesAndDocuments$ = this.caseFileViewService.getCategoriesAndDocuments(this.caseId);\n    this.categoriesAndDocumentsSubscription = this.categoriesAndDocuments$.subscribe({\n      next: data => {\n        this.caseVersion = data.case_version;\n      },\n      error: _ => this.getCategoriesAndDocumentsError = true\n    });\n\n    // EXUI-8000\n    const userInfo: UserInfo = JSON.parse(this.sessionStorageService.getItem('userDetails'));\n    // Get acls that intersects from acl roles and user roles\n    const acls = this.caseField.acls.filter(acl => userInfo.roles.includes(acl.role));\n    // As there can be more than one intersecting role, if any acls are update: true\n    this.allowMoving = acls.some(acl => acl.update);\n    this.icp_jurisdictions = this.abstractConfig.getIcpJurisdictions();\n    this.icpEnabled = this.abstractConfig.getIcpEnable();\n  }\n\n  public ngAfterViewInit(): void {\n    const slider = this.elementRef.nativeElement.querySelector('.slider');\n    const documentTreeContainer = this.elementRef.nativeElement.querySelector('.document-tree-container');\n\n    const mousedown$ = fromEvent<MouseEvent>(slider, 'mousedown');\n    const mousemove$ = fromEvent<MouseEvent>(document, 'mousemove');\n    const mouseup$ = fromEvent<MouseEvent>(document, 'mouseup');\n    const drag$ = mousedown$.pipe(\n      switchMap(\n        (start) => {\n          const x = start.clientX;\n          const documentTreeContainerWidth = documentTreeContainer.getBoundingClientRect().width;\n          return mousemove$.pipe(map(move => {\n            move.preventDefault();\n            return {\n              dx: move.clientX - x,\n              documentTreeContainerWidth\n            };\n          }),\n          takeUntil(mouseup$));\n        }\n      )\n    );\n\n    drag$.subscribe(pos => {\n      const calculatedWidth = ((pos.documentTreeContainerWidth + pos.dx) * 100) / slider.parentElement.getBoundingClientRect().width;\n      documentTreeContainer.setAttribute('style', `width: ${calculatedWidth}%`);\n    });\n  }\n\n  public setMediaViewerFile(document: DocumentTreeNode): void {\n    const mediaViewerInfo = this.documentManagementService.getMediaViewerInfo({\n      document_binary_url: document.document_binary_url,\n      document_filename: document.document_filename\n    });\n    this.currentDocument = JSON.parse(mediaViewerInfo);\n  }\n\n  public moveDocument(data: { document: DocumentTreeNode, newCategory: string }): void {\n    const cid = this.route.snapshot.paramMap.get(CaseFileViewFieldComponent.PARAM_CASE_ID);\n    const loadingToken = this.loadingService.register();\n    this.caseFileViewService.updateDocumentCategory(cid, this.caseVersion, data.document.attribute_path, data.newCategory)\n      .pipe(\n        finalize(() => {\n          this.loadingService.unregister(loadingToken);\n        }),\n        catchError((err) => {\n          this.errorMessages = [this.moveDocumentError(err)];\n          return of(null);\n        }),\n      )\n      .subscribe(res => {\n        if (res) {\n          this.resetErrorMessages();\n          this.reloadPage();\n        }\n      });\n  }\n\n  public reloadPage(): void {\n    location.reload();\n  }\n\n  public resetErrorMessages(): void {\n    this.errorMessages = [];\n  }\n\n  public ngOnDestroy(): void {\n    if (this.categoriesAndDocumentsSubscription) {\n      this.categoriesAndDocumentsSubscription.unsubscribe();\n    }\n  }\n\n  public isIcpEnabled(): boolean {\n    return this.icpEnabled && ((this.icp_jurisdictions?.length < 1) || this.icp_jurisdictions.includes(\n      this.caseNotifier?.cachedCaseView?.case_type?.jurisdiction.id));\n  }\n\n  private moveDocumentError(err): string {\n    const defaultMsg = 'We couldn\\'t move the document. Please try again.';\n\n    if (!(err instanceof HttpErrorResponse)) {\n      return defaultMsg;\n    }\n\n    switch (err.status) {\n      case HttpStatusCode.BadRequest:\n      // e.g. malformed PUT, invalid attribute_path, invalid target category\n        return 'The request was invalid. Check the document path and destination folder.';\n      case HttpStatusCode.Conflict:\n      // optimistic concurrency / stale case version\n        return 'This case changed since you opened it. Refresh and try again.';\n      case HttpStatusCode.NotFound:\n        return 'The document or destination folder could not be found.';\n      case HttpStatusCode.Forbidden:\n      case HttpStatusCode.Unauthorized:\n        return 'You do not have permission to move this document to the selected folder.';\n      case HttpStatusCode.ServiceUnavailable:\n      case HttpStatusCode.GatewayTimeout:\n        return 'The service is temporarily unavailable. Please try again in a moment.';\n      default:\n      // Any other status (including 500)\n        return defaultMsg;\n    }\n  }\n}\n","<ng-container *ngIf=\"errorMessages?.length\">\n  <div\n    id=\"case-file-view-field-errors\"\n    class=\"govuk-error-summary govuk-!-margin-bottom-4\"\n    data-module=\"govuk-error-summary\"\n  >\n    <div role=\"alert\">\n      <h2 class=\"govuk-error-summary__title\">There is a problem</h2>\n      <div class=\"govuk-error-summary__body\">\n        <ul class=\"govuk-list govuk-error-summary__list\">\n          <li *ngFor=\"let errorMessage of errorMessages\">\n            <button type=\"button\" class=\"govuk-js-link\">{{ errorMessage }}</button>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </div>\n</ng-container>\n\n<div\n  *ngIf=\"getCategoriesAndDocumentsError\"\n  class=\"govuk-grid-column-two-thirds\"\n>\n  <h1 class=\"govuk-heading-xl\">Sorry, there is a problem with the service</h1>\n  <p class=\"govuk-body\">Try again later.</p>\n</div>\n<div *ngIf=\"!getCategoriesAndDocumentsError\">\n  <h2 class=\"govuk-heading-l\">Case file</h2>\n  <div class=\"govuk-form-group\" id=\"case-file-view\">\n    <!-- Document tree -->\n    <div class=\"document-tree-container\">\n      <ccd-case-file-view-folder \n          class=\"document-tree-container__tree\"\n          [categoriesAndDocuments]=\"categoriesAndDocuments$\"\n          (clickedDocument)=\"setMediaViewerFile($event); resetErrorMessages()\" \n          (moveDocument)=\"moveDocument($event)\"\n          [allowMoving]=\"allowMoving\">\n      </ccd-case-file-view-folder>\n    </div>\n    <!-- Slider -->\n    <div class=\"slider\"></div>\n    <!-- Media viewer -->\n    <div class=\"media-viewer-container\">\n      <ng-container *ngIf=\"currentDocument\">\n        <mv-media-viewer\n          [url]=\"currentDocument.document_binary_url\"\n          [downloadFileName]=\"currentDocument.document_filename\"\n          [showToolbar]=\"true\"\n          [contentType]=\"currentDocument.content_type\"\n          [enableAnnotations]=\"true\"\n          [enableRedactions]=\"true\"\n          [height]=\"'94.5vh'\"\n          [caseId]=\"caseId\"\n          [multimediaPlayerEnabled]=\"true\"\n          [enableICP]=\"isIcpEnabled()\"\n        >\n        </mv-media-viewer>\n      </ng-container>\n    </div>\n  </div>\n</div>\n"]}
@@ -10,7 +10,7 @@ import * as i4 from '@angular/forms';
10
10
  import { NG_VALUE_ACCESSOR, NG_VALIDATORS, FormArray, FormGroup, FormControl, Validators, ReactiveFormsModule, FormsModule } from '@angular/forms';
11
11
  import { BehaviorSubject, throwError, Subject, EMPTY, Observable, of, combineLatest, timer, forkJoin, fromEvent, Subscription } from 'rxjs';
12
12
  import * as i1$2 from '@angular/common/http';
13
- import { HttpErrorResponse, HttpHeaders, HttpParams } from '@angular/common/http';
13
+ import { HttpErrorResponse, HttpHeaders, HttpParams, HttpStatusCode } from '@angular/common/http';
14
14
  import { distinctUntilChanged, catchError, map, publish, refCount, switchMap, debounceTime, take, delay, finalize, timeout, mergeMap, retryWhen, tap, delayWhen, publishReplay, first, takeUntil, filter } from 'rxjs/operators';
15
15
  import { polling } from 'rx-polling-hmcts';
16
16
  import { Type, Exclude, Expose, plainToClassFromExist, plainToClass } from 'class-transformer';
@@ -13079,8 +13079,8 @@ class CaseFileViewFieldComponent {
13079
13079
  this.caseFileViewService.updateDocumentCategory(cid, this.caseVersion, data.document.attribute_path, data.newCategory)
13080
13080
  .pipe(finalize(() => {
13081
13081
  this.loadingService.unregister(loadingToken);
13082
- }), catchError(() => {
13083
- this.errorMessages = ['You do not have permission to move this document to the selected folder.'];
13082
+ }), catchError((err) => {
13083
+ this.errorMessages = [this.moveDocumentError(err)];
13084
13084
  return of(null);
13085
13085
  }))
13086
13086
  .subscribe(res => {
@@ -13104,6 +13104,31 @@ class CaseFileViewFieldComponent {
13104
13104
  isIcpEnabled() {
13105
13105
  return this.icpEnabled && ((this.icp_jurisdictions?.length < 1) || this.icp_jurisdictions.includes(this.caseNotifier?.cachedCaseView?.case_type?.jurisdiction.id));
13106
13106
  }
13107
+ moveDocumentError(err) {
13108
+ const defaultMsg = 'We couldn\'t move the document. Please try again.';
13109
+ if (!(err instanceof HttpErrorResponse)) {
13110
+ return defaultMsg;
13111
+ }
13112
+ switch (err.status) {
13113
+ case HttpStatusCode.BadRequest:
13114
+ // e.g. malformed PUT, invalid attribute_path, invalid target category
13115
+ return 'The request was invalid. Check the document path and destination folder.';
13116
+ case HttpStatusCode.Conflict:
13117
+ // optimistic concurrency / stale case version
13118
+ return 'This case changed since you opened it. Refresh and try again.';
13119
+ case HttpStatusCode.NotFound:
13120
+ return 'The document or destination folder could not be found.';
13121
+ case HttpStatusCode.Forbidden:
13122
+ case HttpStatusCode.Unauthorized:
13123
+ return 'You do not have permission to move this document to the selected folder.';
13124
+ case HttpStatusCode.ServiceUnavailable:
13125
+ case HttpStatusCode.GatewayTimeout:
13126
+ return 'The service is temporarily unavailable. Please try again in a moment.';
13127
+ default:
13128
+ // Any other status (including 500)
13129
+ return defaultMsg;
13130
+ }
13131
+ }
13107
13132
  static ɵfac = function CaseFileViewFieldComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || CaseFileViewFieldComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1$1.ActivatedRoute), i0.ɵɵdirectiveInject(CaseFileViewService), i0.ɵɵdirectiveInject(DocumentManagementService), i0.ɵɵdirectiveInject(LoadingService), i0.ɵɵdirectiveInject(SessionStorageService), i0.ɵɵdirectiveInject(CaseNotifier), i0.ɵɵdirectiveInject(AbstractAppConfig)); };
13108
13133
  static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: CaseFileViewFieldComponent, selectors: [["ccd-case-file-view-field"]], decls: 3, vars: 3, consts: [[4, "ngIf"], ["class", "govuk-grid-column-two-thirds", 4, "ngIf"], ["id", "case-file-view-field-errors", "data-module", "govuk-error-summary", 1, "govuk-error-summary", "govuk-!-margin-bottom-4"], ["role", "alert"], [1, "govuk-error-summary__title"], [1, "govuk-error-summary__body"], [1, "govuk-list", "govuk-error-summary__list"], [4, "ngFor", "ngForOf"], ["type", "button", 1, "govuk-js-link"], [1, "govuk-grid-column-two-thirds"], [1, "govuk-heading-xl"], [1, "govuk-body"], [1, "govuk-heading-l"], ["id", "case-file-view", 1, "govuk-form-group"], [1, "document-tree-container"], [1, "document-tree-container__tree", 3, "clickedDocument", "moveDocument", "categoriesAndDocuments", "allowMoving"], [1, "slider"], [1, "media-viewer-container"], [3, "url", "downloadFileName", "showToolbar", "contentType", "enableAnnotations", "enableRedactions", "height", "caseId", "multimediaPlayerEnabled", "enableICP"]], template: function CaseFileViewFieldComponent_Template(rf, ctx) { if (rf & 1) {
13109
13134
  i0.ɵɵtemplate(0, CaseFileViewFieldComponent_ng_container_0_Template, 8, 1, "ng-container", 0)(1, CaseFileViewFieldComponent_div_1_Template, 5, 0, "div", 1)(2, CaseFileViewFieldComponent_div_2_Template, 9, 3, "div", 0);
@@ -13119,7 +13144,7 @@ class CaseFileViewFieldComponent {
13119
13144
  type: Component,
13120
13145
  args: [{ selector: 'ccd-case-file-view-field', template: "<ng-container *ngIf=\"errorMessages?.length\">\n <div\n id=\"case-file-view-field-errors\"\n class=\"govuk-error-summary govuk-!-margin-bottom-4\"\n data-module=\"govuk-error-summary\"\n >\n <div role=\"alert\">\n <h2 class=\"govuk-error-summary__title\">There is a problem</h2>\n <div class=\"govuk-error-summary__body\">\n <ul class=\"govuk-list govuk-error-summary__list\">\n <li *ngFor=\"let errorMessage of errorMessages\">\n <button type=\"button\" class=\"govuk-js-link\">{{ errorMessage }}</button>\n </li>\n </ul>\n </div>\n </div>\n </div>\n</ng-container>\n\n<div\n *ngIf=\"getCategoriesAndDocumentsError\"\n class=\"govuk-grid-column-two-thirds\"\n>\n <h1 class=\"govuk-heading-xl\">Sorry, there is a problem with the service</h1>\n <p class=\"govuk-body\">Try again later.</p>\n</div>\n<div *ngIf=\"!getCategoriesAndDocumentsError\">\n <h2 class=\"govuk-heading-l\">Case file</h2>\n <div class=\"govuk-form-group\" id=\"case-file-view\">\n <!-- Document tree -->\n <div class=\"document-tree-container\">\n <ccd-case-file-view-folder \n class=\"document-tree-container__tree\"\n [categoriesAndDocuments]=\"categoriesAndDocuments$\"\n (clickedDocument)=\"setMediaViewerFile($event); resetErrorMessages()\" \n (moveDocument)=\"moveDocument($event)\"\n [allowMoving]=\"allowMoving\">\n </ccd-case-file-view-folder>\n </div>\n <!-- Slider -->\n <div class=\"slider\"></div>\n <!-- Media viewer -->\n <div class=\"media-viewer-container\">\n <ng-container *ngIf=\"currentDocument\">\n <mv-media-viewer\n [url]=\"currentDocument.document_binary_url\"\n [downloadFileName]=\"currentDocument.document_filename\"\n [showToolbar]=\"true\"\n [contentType]=\"currentDocument.content_type\"\n [enableAnnotations]=\"true\"\n [enableRedactions]=\"true\"\n [height]=\"'94.5vh'\"\n [caseId]=\"caseId\"\n [multimediaPlayerEnabled]=\"true\"\n [enableICP]=\"isIcpEnabled()\"\n >\n </mv-media-viewer>\n </ng-container>\n </div>\n </div>\n</div>\n", styles: ["#case-file-view{display:flex;border:2px solid #C9C9C9;height:100vh;position:relative}#case-file-view .document-tree-container{background-color:#faf8f8;width:30%;min-height:400px;min-width:10%}#case-file-view .slider{width:.2%;background-color:#6b6b6b}#case-file-view .slider:hover,#case-file-view .slider:focus{cursor:col-resize}#case-file-view .media-viewer-container{background-color:#dee0e2;flex:1 1 0;overflow:hidden}\n"] }]
13121
13146
  }], () => [{ type: i0.ElementRef }, { type: i1$1.ActivatedRoute }, { type: CaseFileViewService }, { type: DocumentManagementService }, { type: LoadingService }, { type: SessionStorageService }, { type: CaseNotifier }, { type: AbstractAppConfig }], null); })();
13122
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(CaseFileViewFieldComponent, { className: "CaseFileViewFieldComponent", filePath: "lib/shared/components/palette/case-file-view/case-file-view-field.component.ts", lineNumber: 17 }); })();
13147
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(CaseFileViewFieldComponent, { className: "CaseFileViewFieldComponent", filePath: "lib/shared/components/palette/case-file-view/case-file-view-field.component.ts", lineNumber: 18 }); })();
13123
13148
 
13124
13149
  function ReadCaseFlagFieldComponent_ng_container_0_Template(rf, ctx) { if (rf & 1) {
13125
13150
  const _r1 = i0.ɵɵgetCurrentView();