@hmcts/ccd-case-ui-toolkit 7.2.20--extra-text → 7.2.20-multiple-followup

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.
Files changed (29) hide show
  1. package/esm2022/lib/app.config.mjs +3 -1
  2. package/esm2022/lib/shared/components/palette/query-management/components/query-case-details-header/query-case-details-header.component.mjs +3 -3
  3. package/esm2022/lib/shared/components/palette/query-management/components/query-check-your-answers/query-check-your-answers.component.mjs +12 -8
  4. package/esm2022/lib/shared/components/palette/query-management/components/query-details/query-details.component.mjs +52 -8
  5. package/esm2022/lib/shared/components/palette/query-management/components/query-write/query-write-raise-query/query-write-raise-query.component.mjs +58 -64
  6. package/esm2022/lib/shared/components/palette/query-management/components/query-write/query-write-respond-to-query/query-write-respond-to-query.component.mjs +13 -19
  7. package/esm2022/lib/shared/components/palette/query-management/models/case-queries-collection.model.mjs +1 -1
  8. package/esm2022/lib/shared/components/palette/query-management/models/query-list/query-list-item/query-list-item.model.mjs +13 -2
  9. package/esm2022/lib/shared/components/palette/query-management/read-query-management-field.component.mjs +74 -24
  10. package/esm2022/lib/shared/components/palette/query-management/utils/query-management.utils.mjs +10 -3
  11. package/esm2022/lib/shared/utils.mjs +1 -1
  12. package/fesm2022/hmcts-ccd-case-ui-toolkit.mjs +219 -122
  13. package/fesm2022/hmcts-ccd-case-ui-toolkit.mjs.map +1 -1
  14. package/lib/app.config.d.ts +3 -0
  15. package/lib/app.config.d.ts.map +1 -1
  16. package/lib/shared/components/palette/query-management/components/query-check-your-answers/query-check-your-answers.component.d.ts +2 -1
  17. package/lib/shared/components/palette/query-management/components/query-check-your-answers/query-check-your-answers.component.d.ts.map +1 -1
  18. package/lib/shared/components/palette/query-management/components/query-details/query-details.component.d.ts +15 -3
  19. package/lib/shared/components/palette/query-management/components/query-details/query-details.component.d.ts.map +1 -1
  20. package/lib/shared/components/palette/query-management/models/case-queries-collection.model.d.ts +1 -0
  21. package/lib/shared/components/palette/query-management/models/case-queries-collection.model.d.ts.map +1 -1
  22. package/lib/shared/components/palette/query-management/models/query-list/query-list-item/query-list-item.model.d.ts +1 -0
  23. package/lib/shared/components/palette/query-management/models/query-list/query-list-item/query-list-item.model.d.ts.map +1 -1
  24. package/lib/shared/components/palette/query-management/read-query-management-field.component.d.ts +15 -3
  25. package/lib/shared/components/palette/query-management/read-query-management-field.component.d.ts.map +1 -1
  26. package/lib/shared/components/palette/query-management/utils/query-management.utils.d.ts +1 -1
  27. package/lib/shared/components/palette/query-management/utils/query-management.utils.d.ts.map +1 -1
  28. package/lib/shared/utils.d.ts +1 -1
  29. package/package.json +1 -1
@@ -3,10 +3,14 @@ import { ActivatedRoute, Router } from '@angular/router';
3
3
  import { SessionStorageService } from '../../../../../services';
4
4
  import { isInternalUser } from '../../../../../utils';
5
5
  import { QueryItemResponseStatus } from '../../enums';
6
- import { QueryListItem } from '../../models';
6
+ import { QueryCreateContext, QueryListItem } from '../../models';
7
+ import { CaseNotifier } from '../../../../case-editor/services/case.notifier';
8
+ import { AbstractAppConfig } from '../../../../../../app.config';
7
9
  import * as i0 from "@angular/core";
8
10
  import * as i1 from "../../../../../services";
9
11
  import * as i2 from "@angular/router";
12
+ import * as i3 from "../../../../../../app.config";
13
+ import * as i4 from "../../../../case-editor/services/case.notifier";
10
14
  function QueryDetailsComponent_ng_container_0_p_1_Template(rf, ctx) { if (rf & 1) {
11
15
  const _r1 = i0.ɵɵgetCurrentView();
12
16
  i0.ɵɵelementStart(0, "p");
@@ -217,10 +221,12 @@ function QueryDetailsComponent_ng_container_0_ng_container_44_ng_container_1_Tem
217
221
  i0.ɵɵtemplate(1, QueryDetailsComponent_ng_container_0_ng_container_44_ng_container_1_ng_container_1_Template, 23, 19, "ng-container", 15)(2, QueryDetailsComponent_ng_container_0_ng_container_44_ng_container_1_ng_template_2_Template, 27, 22, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
218
222
  i0.ɵɵelementContainerEnd();
219
223
  } if (rf & 2) {
224
+ const child_r3 = ctx.$implicit;
220
225
  const i_r4 = ctx.index;
221
226
  const followUpMessage_r5 = i0.ɵɵreference(3);
227
+ const ctx_r1 = i0.ɵɵnextContext(3);
222
228
  i0.ɵɵadvance();
223
- i0.ɵɵproperty("ngIf", i_r4 % 2 === 0)("ngIfElse", followUpMessage_r5);
229
+ i0.ɵɵproperty("ngIf", i_r4 % 2 === 0 && !(child_r3 == null ? null : child_r3.messageType) || child_r3 && (child_r3 == null ? null : child_r3.messageType) === ctx_r1.respondToQuery)("ngIfElse", followUpMessage_r5);
224
230
  } }
225
231
  function QueryDetailsComponent_ng_container_0_ng_container_44_Template(rf, ctx) { if (rf & 1) {
226
232
  i0.ɵɵelementContainerStart(0);
@@ -324,6 +330,8 @@ export class QueryDetailsComponent {
324
330
  sessionStorageService;
325
331
  route;
326
332
  router;
333
+ abstractConfig;
334
+ caseNotifier;
327
335
  query;
328
336
  caseId;
329
337
  queryResponseStatus;
@@ -333,10 +341,18 @@ export class QueryDetailsComponent {
333
341
  static QUERY_ITEM_RESPOND = '3';
334
342
  static QUERY_ITEM_FOLLOW_UP = '4';
335
343
  queryItemId;
336
- constructor(sessionStorageService, route, router) {
344
+ followUpQuery = QueryCreateContext.FOLLOWUP;
345
+ respondToQuery = QueryCreateContext.RESPOND;
346
+ enableServiceSpecificMultiFollowups;
347
+ currentJurisdictionId;
348
+ isMultipleFollowUpEnabled = false;
349
+ caseSubscription;
350
+ constructor(sessionStorageService, route, router, abstractConfig, caseNotifier) {
337
351
  this.sessionStorageService = sessionStorageService;
338
352
  this.route = route;
339
353
  this.router = router;
354
+ this.abstractConfig = abstractConfig;
355
+ this.caseNotifier = caseNotifier;
340
356
  }
341
357
  onBack() {
342
358
  this.backClicked.emit(true);
@@ -344,10 +360,23 @@ export class QueryDetailsComponent {
344
360
  isInternalUser() {
345
361
  return isInternalUser(this.sessionStorageService);
346
362
  }
363
+ ngOnInit() {
364
+ this.enableServiceSpecificMultiFollowups = this.abstractConfig.getEnableServiceSpecificMultiFollowups() || [];
365
+ this.caseSubscription = this.caseNotifier.caseView.subscribe((caseView) => {
366
+ if (caseView?.case_type?.jurisdiction?.id) {
367
+ this.currentJurisdictionId = caseView.case_type.jurisdiction.id;
368
+ this.isMultipleFollowUpEnabled = this.enableServiceSpecificMultiFollowups.includes(this.currentJurisdictionId);
369
+ this.hasRespondedToQuery();
370
+ }
371
+ });
372
+ }
347
373
  ngOnChanges() {
348
374
  this.toggleLinkVisibility();
349
375
  this.hasRespondedToQuery();
350
376
  }
377
+ ngOnDestroy() {
378
+ this.caseSubscription?.unsubscribe();
379
+ }
351
380
  toggleLinkVisibility() {
352
381
  this.queryItemId = this.route.snapshot.params.qid;
353
382
  if (this.queryItemId === QueryDetailsComponent.QUERY_ITEM_RESPOND || this.queryItemId === QueryDetailsComponent.QUERY_ITEM_FOLLOW_UP) {
@@ -360,6 +389,21 @@ export class QueryDetailsComponent {
360
389
  this.hasResponded.emit(true);
361
390
  return true;
362
391
  }
392
+ const lastChild = this.query?.children?.[this.query.children.length - 1];
393
+ const isFollowUp = lastChild?.messageType === this.followUpQuery;
394
+ const isRespond = lastChild?.messageType === this.respondToQuery;
395
+ if (this.queryResponseStatus === QueryItemResponseStatus.CLOSED) {
396
+ this.hasResponded.emit(true);
397
+ return true;
398
+ }
399
+ if (isFollowUp && this.isMultipleFollowUpEnabled) {
400
+ this.hasResponded.emit(false);
401
+ return false;
402
+ }
403
+ if (isRespond) {
404
+ this.hasResponded.emit(false);
405
+ return false;
406
+ }
363
407
  if (this.isInternalUser()) {
364
408
  if (isAwaiting) {
365
409
  this.hasResponded.emit(false);
@@ -375,7 +419,7 @@ export class QueryDetailsComponent {
375
419
  this.hasResponded.emit(false);
376
420
  return false;
377
421
  }
378
- static ɵfac = function QueryDetailsComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || QueryDetailsComponent)(i0.ɵɵdirectiveInject(i1.SessionStorageService), i0.ɵɵdirectiveInject(i2.ActivatedRoute), i0.ɵɵdirectiveInject(i2.Router)); };
422
+ static ɵfac = function QueryDetailsComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || QueryDetailsComponent)(i0.ɵɵdirectiveInject(i1.SessionStorageService), i0.ɵɵdirectiveInject(i2.ActivatedRoute), i0.ɵɵdirectiveInject(i2.Router), i0.ɵɵdirectiveInject(i3.AbstractAppConfig), i0.ɵɵdirectiveInject(i4.CaseNotifier)); };
379
423
  static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: QueryDetailsComponent, selectors: [["ccd-query-details"]], inputs: { query: "query", caseId: "caseId", queryResponseStatus: "queryResponseStatus" }, outputs: { backClicked: "backClicked", hasResponded: "hasResponded" }, features: [i0.ɵɵNgOnChangesFeature], decls: 1, vars: 1, consts: [["followUpMessage", ""], [4, "ngIf"], [1, "govuk-table", "query-details-table"], [1, "govuk-table__caption", "govuk-table__caption--l"], [1, "govuk-table__body"], [1, "govuk-table__row"], ["scope", "row", 1, "govuk-table__header"], [1, "govuk-table__cell"], ["class", "govuk-table__row govuk-table__row--isHearingRelated", 4, "ngIf"], ["class", "govuk-table__row", 4, "ngIf"], ["href", "javascript:void(0)", 1, "govuk-link", 3, "click"], [1, "govuk-table__row", "govuk-table__row--isHearingRelated"], [3, "attachments", 4, "ngIf"], [3, "attachments"], [4, "ngFor", "ngForOf"], [4, "ngIf", "ngIfElse"]], template: function QueryDetailsComponent_Template(rf, ctx) { if (rf & 1) {
380
424
  i0.ɵɵtemplate(0, QueryDetailsComponent_ng_container_0_Template, 45, 41, "ng-container", 1);
381
425
  } if (rf & 2) {
@@ -384,8 +428,8 @@ export class QueryDetailsComponent {
384
428
  }
385
429
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(QueryDetailsComponent, [{
386
430
  type: Component,
387
- args: [{ selector: 'ccd-query-details', template: "<ng-container *ngIf=\"query\">\n <p *ngIf=\"showItem\">\n <br />\n <a class=\"govuk-link\" href=\"javascript:void(0)\" (click)=\"onBack()\">{{ 'Back to query list' | rpxTranslate }}</a>\n </p>\n <div>\n <table class=\"govuk-table query-details-table\" [attr.aria-describedby]=\"'Details of the query' | rpxTranslate\">\n <caption class=\"govuk-table__caption govuk-table__caption--l\">\n <div>{{ 'Query details' | rpxTranslate }}</div>\n </caption>\n <tbody class=\"govuk-table__body\">\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last submitted by' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ query.lastSubmittedBy }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Submission date' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ query.createdOn | date: 'dd MMMM YYYY HH:mm' }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Query subject' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ query.subject }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Query body' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ query.body }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\" [class.govuk-table__header--no-border]=\"query.isHearingRelated\">\n {{ 'Is the query hearing related?' | rpxTranslate }}\n </th>\n <td class=\"govuk-table__cell\" [class.govuk-table__cell--no-border]=\"query.isHearingRelated\">\n {{ 'Is the query hearing related?' | rpxTranslate: null : (query.isHearingRelated) }}</td>\n </tr>\n <tr class=\"govuk-table__row govuk-table__row--isHearingRelated\" *ngIf=\"query.isHearingRelated === 'Yes'\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'What is the date of the hearing?' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ query.hearingDate | date: 'dd MMM yyyy' }}</td>\n </tr>\n <tr class=\"govuk-table__row\" *ngIf=\"query.attachments.length > 0\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Attachments' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">\n <ccd-query-attachments-read\n *ngIf=\"query.attachments\"\n [attachments]=\"query.attachments\"\n >\n </ccd-query-attachments-read>\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n <ng-container *ngIf=\"query.children?.length > 0\">\n <ng-container *ngFor=\"let child of query.children; let i = index;\">\n <ng-container *ngIf=\"i % 2 === 0; else followUpMessage\">\n <table class=\"govuk-table query-details-table\" [attr.aria-describedby]=\"'Response of the query' | rpxTranslate\">\n <caption class=\"govuk-table__caption govuk-table__caption--l\">\n <div>{{ 'Response' | rpxTranslate }}</div>\n </caption>\n <tbody class=\"govuk-table__body\">\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last response date' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ child.createdOn | date: 'dd MMMM YYYY HH:mm' }}</td>\n </tr>\n\n <tr *ngIf=\"isInternalUser()\" class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Caseworker name' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ child.name }}</td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Response detail' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ child.body }}</td>\n </tr>\n\n <tr class=\"govuk-table__row\" *ngIf=\"child.attachments.length > 0\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Attachments' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">\n <ccd-query-attachments-read\n *ngIf=\"child.attachments\"\n [attachments]=\"child.attachments\"\n >\n </ccd-query-attachments-read>\n </td>\n </tr>\n </tbody>\n </table>\n </ng-container>\n\n <ng-template #followUpMessage>\n <!-- <div class=\"query_details_caption\">{{ 'Follow-up' | rpxTranslate }}</div> -->\n <table class=\"govuk-table query-details-table\"\n [attr.aria-describedby]=\"'Follow-up of the response' | rpxTranslate\">\n <caption class=\"govuk-table__caption govuk-table__caption--l\">\n <div>{{ 'Follow up query' | rpxTranslate }}</div>\n </caption>\n <tbody class=\"govuk-table__body\">\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last submission date' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ child.createdOn | date: 'dd MMMM YYYY HH:mm'}}</td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last submitted by' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ child.name }}</td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Query detail' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ child.body }}</td>\n </tr>\n\n <tr class=\"govuk-table__row\" *ngIf=\"child.attachments.length > 0\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Attachments' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">\n <ccd-query-attachments-read\n *ngIf=\"child.attachments\"\n [attachments]=\"child.attachments\"\n >\n </ccd-query-attachments-read>\n </td>\n </tr>\n </tbody>\n </table>\n </ng-template>\n </ng-container>\n </ng-container>\n</ng-container>\n", styles: [".query-details-table .govuk-table__header{width:330px}\n"] }]
388
- }], () => [{ type: i1.SessionStorageService }, { type: i2.ActivatedRoute }, { type: i2.Router }], { query: [{
431
+ args: [{ selector: 'ccd-query-details', template: "<ng-container *ngIf=\"query\">\n <p *ngIf=\"showItem\">\n <br />\n <a class=\"govuk-link\" href=\"javascript:void(0)\" (click)=\"onBack()\">{{ 'Back to query list' | rpxTranslate }}</a>\n </p>\n <div>\n <table class=\"govuk-table query-details-table\" [attr.aria-describedby]=\"'Details of the query' | rpxTranslate\">\n <caption class=\"govuk-table__caption govuk-table__caption--l\">\n <div>{{ 'Query details' | rpxTranslate }}</div>\n </caption>\n <tbody class=\"govuk-table__body\">\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last submitted by' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ query.lastSubmittedBy }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Submission date' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ query.createdOn | date: 'dd MMMM YYYY HH:mm' }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Query subject' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ query.subject }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Query body' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ query.body }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\" [class.govuk-table__header--no-border]=\"query.isHearingRelated\">\n {{ 'Is the query hearing related?' | rpxTranslate }}\n </th>\n <td class=\"govuk-table__cell\" [class.govuk-table__cell--no-border]=\"query.isHearingRelated\">\n {{ 'Is the query hearing related?' | rpxTranslate: null : (query.isHearingRelated) }}</td>\n </tr>\n <tr class=\"govuk-table__row govuk-table__row--isHearingRelated\" *ngIf=\"query.isHearingRelated === 'Yes'\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'What is the date of the hearing?' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ query.hearingDate | date: 'dd MMM yyyy' }}</td>\n </tr>\n <tr class=\"govuk-table__row\" *ngIf=\"query.attachments.length > 0\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Attachments' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">\n <ccd-query-attachments-read\n *ngIf=\"query.attachments\"\n [attachments]=\"query.attachments\"\n >\n </ccd-query-attachments-read>\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n <ng-container *ngIf=\"query.children?.length > 0\">\n <ng-container *ngFor=\"let child of query.children; let i = index;\">\n <ng-container *ngIf=\"(i % 2 === 0 && !child?.messageType) || (child && child?.messageType === respondToQuery); else followUpMessage\">\n <table class=\"govuk-table query-details-table\" [attr.aria-describedby]=\"'Response of the query' | rpxTranslate\">\n <caption class=\"govuk-table__caption govuk-table__caption--l\">\n <div>{{ 'Response' | rpxTranslate }}</div>\n </caption>\n <tbody class=\"govuk-table__body\">\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last response date' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ child.createdOn | date: 'dd MMMM YYYY HH:mm' }}</td>\n </tr>\n\n <tr *ngIf=\"isInternalUser()\" class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Caseworker name' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ child.name }}</td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Response detail' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ child.body }}</td>\n </tr>\n\n <tr class=\"govuk-table__row\" *ngIf=\"child.attachments.length > 0\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Attachments' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">\n <ccd-query-attachments-read\n *ngIf=\"child.attachments\"\n [attachments]=\"child.attachments\"\n >\n </ccd-query-attachments-read>\n </td>\n </tr>\n </tbody>\n </table>\n </ng-container>\n\n <ng-template #followUpMessage>\n <!-- <div class=\"query_details_caption\">{{ 'Follow-up' | rpxTranslate }}</div> -->\n <table class=\"govuk-table query-details-table\"\n [attr.aria-describedby]=\"'Follow-up of the response' | rpxTranslate\">\n <caption class=\"govuk-table__caption govuk-table__caption--l\">\n <div>{{ 'Follow up query' | rpxTranslate }}</div>\n </caption>\n <tbody class=\"govuk-table__body\">\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last submission date' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ child.createdOn | date: 'dd MMMM YYYY HH:mm'}}</td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last submitted by' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ child.name }}</td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Query detail' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">{{ child.body }}</td>\n </tr>\n\n <tr class=\"govuk-table__row\" *ngIf=\"child.attachments.length > 0\">\n <th scope=\"row\" class=\"govuk-table__header\">{{ 'Attachments' | rpxTranslate }}</th>\n <td class=\"govuk-table__cell\">\n <ccd-query-attachments-read\n *ngIf=\"child.attachments\"\n [attachments]=\"child.attachments\"\n >\n </ccd-query-attachments-read>\n </td>\n </tr>\n </tbody>\n </table>\n </ng-template>\n </ng-container>\n </ng-container>\n</ng-container>\n", styles: [".query-details-table .govuk-table__header{width:330px}\n"] }]
432
+ }], () => [{ type: i1.SessionStorageService }, { type: i2.ActivatedRoute }, { type: i2.Router }, { type: i3.AbstractAppConfig }, { type: i4.CaseNotifier }], { query: [{
389
433
  type: Input
390
434
  }], caseId: [{
391
435
  type: Input
@@ -396,5 +440,5 @@ export class QueryDetailsComponent {
396
440
  }], hasResponded: [{
397
441
  type: Output
398
442
  }] }); })();
399
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(QueryDetailsComponent, { className: "QueryDetailsComponent", filePath: "lib/shared/components/palette/query-management/components/query-details/query-details.component.ts", lineNumber: 14 }); })();
400
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-details.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/query-management/components/query-details/query-details.component.ts","../../../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/query-management/components/query-details/query-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, Output } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\n\nimport { SessionStorageService } from '../../../../../services';\nimport { isInternalUser } from '../../../../../utils';\nimport { QueryItemResponseStatus } from '../../enums';\nimport { QueryListItem } from '../../models';\n\n@Component({\n  selector: 'ccd-query-details',\n  templateUrl: './query-details.component.html',\n  styleUrls: ['./query-details.component.scss']\n})\nexport class QueryDetailsComponent implements OnChanges{\n  @Input() public query: QueryListItem;\n  @Input() public caseId: string;\n  @Input() public queryResponseStatus: string;\n\n  @Output() public backClicked: EventEmitter<boolean> = new EventEmitter();\n  @Output() public hasResponded: EventEmitter<boolean> = new EventEmitter();\n\n  public showItem: boolean = true;\n\n  private static readonly QUERY_ITEM_RESPOND = '3';\n  private static readonly QUERY_ITEM_FOLLOW_UP = '4';\n  private queryItemId: string;\n\n  constructor(\n    private readonly sessionStorageService: SessionStorageService,\n    private readonly route: ActivatedRoute,\n    private readonly router: Router) { }\n\n  public onBack(): void {\n    this.backClicked.emit(true);\n  }\n\n  public isInternalUser(): boolean {\n    return isInternalUser(this.sessionStorageService);\n  }\n\n  public ngOnChanges(): void {\n    this.toggleLinkVisibility();\n    this.hasRespondedToQuery();\n  }\n\n  public toggleLinkVisibility(): void {\n    this.queryItemId = this.route.snapshot.params.qid as string;\n    if (this.queryItemId === QueryDetailsComponent.QUERY_ITEM_RESPOND || this.queryItemId === QueryDetailsComponent.QUERY_ITEM_FOLLOW_UP) {\n      this.showItem = false;\n    }\n  }\n\n  public hasRespondedToQuery(): boolean {\n    const isAwaiting = this.queryResponseStatus === undefined || this.queryResponseStatus === QueryItemResponseStatus.AWAITING;\n    if (this.queryResponseStatus === QueryItemResponseStatus.CLOSED) {\n      this.hasResponded.emit(true);\n      return true;\n    }\n\n    if (this.isInternalUser()) {\n      if (isAwaiting) {\n        this.hasResponded.emit(false);\n        return false;\n      }\n\n      this.hasResponded.emit(true);\n      return true;\n    }\n\n    if (isAwaiting) {\n      this.hasResponded.emit(true);\n      return false; // Don't show message\n    }\n\n    this.hasResponded.emit(false);\n    return false;\n  }\n}\n","<ng-container *ngIf=\"query\">\n  <p *ngIf=\"showItem\">\n    <br />\n    <a class=\"govuk-link\" href=\"javascript:void(0)\" (click)=\"onBack()\">{{ 'Back to query list' | rpxTranslate }}</a>\n  </p>\n  <div>\n    <table class=\"govuk-table query-details-table\" [attr.aria-describedby]=\"'Details of the query' | rpxTranslate\">\n      <caption class=\"govuk-table__caption govuk-table__caption--l\">\n        <div>{{ 'Query details' | rpxTranslate }}</div>\n      </caption>\n      <tbody class=\"govuk-table__body\">\n      <tr class=\"govuk-table__row\">\n        <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last submitted by' | rpxTranslate }}</th>\n        <td class=\"govuk-table__cell\">{{ query.lastSubmittedBy }}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n        <th scope=\"row\" class=\"govuk-table__header\">{{ 'Submission date' | rpxTranslate }}</th>\n        <td class=\"govuk-table__cell\">{{ query.createdOn | date: 'dd MMMM YYYY HH:mm' }}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n        <th scope=\"row\" class=\"govuk-table__header\">{{ 'Query subject' | rpxTranslate }}</th>\n        <td class=\"govuk-table__cell\">{{ query.subject }}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n        <th scope=\"row\" class=\"govuk-table__header\">{{ 'Query body' | rpxTranslate }}</th>\n        <td class=\"govuk-table__cell\">{{ query.body }}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n        <th scope=\"row\" class=\"govuk-table__header\" [class.govuk-table__header--no-border]=\"query.isHearingRelated\">\n          {{ 'Is the query hearing related?' | rpxTranslate }}\n        </th>\n        <td class=\"govuk-table__cell\" [class.govuk-table__cell--no-border]=\"query.isHearingRelated\">\n          {{ 'Is the query hearing related?' | rpxTranslate: null : (query.isHearingRelated) }}</td>\n      </tr>\n      <tr class=\"govuk-table__row govuk-table__row--isHearingRelated\" *ngIf=\"query.isHearingRelated === 'Yes'\">\n        <th scope=\"row\" class=\"govuk-table__header\">{{ 'What is the date of the hearing?' | rpxTranslate }}</th>\n        <td class=\"govuk-table__cell\">{{ query.hearingDate | date: 'dd MMM yyyy' }}</td>\n      </tr>\n      <tr class=\"govuk-table__row\" *ngIf=\"query.attachments.length > 0\">\n        <th scope=\"row\" class=\"govuk-table__header\">{{ 'Attachments' | rpxTranslate }}</th>\n        <td class=\"govuk-table__cell\">\n          <ccd-query-attachments-read\n            *ngIf=\"query.attachments\"\n            [attachments]=\"query.attachments\"\n          >\n          </ccd-query-attachments-read>\n        </td>\n      </tr>\n      </tbody>\n    </table>\n  </div>\n  <ng-container *ngIf=\"query.children?.length > 0\">\n    <ng-container *ngFor=\"let child of query.children; let i = index;\">\n      <ng-container *ngIf=\"i % 2 === 0; else followUpMessage\">\n        <table class=\"govuk-table query-details-table\" [attr.aria-describedby]=\"'Response of the query' | rpxTranslate\">\n          <caption class=\"govuk-table__caption govuk-table__caption--l\">\n            <div>{{ 'Response' | rpxTranslate }}</div>\n          </caption>\n          <tbody class=\"govuk-table__body\">\n          <tr class=\"govuk-table__row\">\n            <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last response date' | rpxTranslate }}</th>\n            <td class=\"govuk-table__cell\">{{ child.createdOn | date: 'dd MMMM YYYY HH:mm'  }}</td>\n          </tr>\n\n            <tr *ngIf=\"isInternalUser()\" class=\"govuk-table__row\">\n              <th scope=\"row\" class=\"govuk-table__header\">{{ 'Caseworker name' | rpxTranslate }}</th>\n              <td class=\"govuk-table__cell\">{{ child.name }}</td>\n            </tr>\n\n            <tr class=\"govuk-table__row\">\n              <th scope=\"row\" class=\"govuk-table__header\">{{ 'Response detail' | rpxTranslate }}</th>\n              <td class=\"govuk-table__cell\">{{ child.body }}</td>\n            </tr>\n\n          <tr class=\"govuk-table__row\" *ngIf=\"child.attachments.length > 0\">\n            <th scope=\"row\" class=\"govuk-table__header\">{{ 'Attachments' | rpxTranslate }}</th>\n            <td class=\"govuk-table__cell\">\n              <ccd-query-attachments-read\n                *ngIf=\"child.attachments\"\n                [attachments]=\"child.attachments\"\n              >\n              </ccd-query-attachments-read>\n            </td>\n          </tr>\n          </tbody>\n        </table>\n      </ng-container>\n\n      <ng-template #followUpMessage>\n        <!-- <div class=\"query_details_caption\">{{ 'Follow-up' | rpxTranslate }}</div> -->\n        <table class=\"govuk-table query-details-table\"\n               [attr.aria-describedby]=\"'Follow-up of the response' | rpxTranslate\">\n          <caption class=\"govuk-table__caption govuk-table__caption--l\">\n            <div>{{ 'Follow up query' | rpxTranslate }}</div>\n          </caption>\n          <tbody class=\"govuk-table__body\">\n          <tr class=\"govuk-table__row\">\n            <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last submission date' | rpxTranslate }}</th>\n            <td class=\"govuk-table__cell\">{{ child.createdOn | date: 'dd MMMM YYYY HH:mm'}}</td>\n          </tr>\n\n          <tr class=\"govuk-table__row\">\n            <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last submitted by' | rpxTranslate }}</th>\n            <td class=\"govuk-table__cell\">{{ child.name }}</td>\n          </tr>\n\n            <tr class=\"govuk-table__row\">\n              <th scope=\"row\" class=\"govuk-table__header\">{{ 'Query detail' | rpxTranslate }}</th>\n              <td class=\"govuk-table__cell\">{{ child.body }}</td>\n            </tr>\n\n            <tr class=\"govuk-table__row\" *ngIf=\"child.attachments.length > 0\">\n              <th scope=\"row\" class=\"govuk-table__header\">{{ 'Attachments' | rpxTranslate }}</th>\n              <td class=\"govuk-table__cell\">\n                <ccd-query-attachments-read\n                  *ngIf=\"child.attachments\"\n                  [attachments]=\"child.attachments\"\n                >\n                </ccd-query-attachments-read>\n              </td>\n            </tr>\n          </tbody>\n        </table>\n      </ng-template>\n    </ng-container>\n  </ng-container>\n</ng-container>\n"]}
443
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(QueryDetailsComponent, { className: "QueryDetailsComponent", filePath: "lib/shared/components/palette/query-management/components/query-details/query-details.component.ts", lineNumber: 17 }); })();
444
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-details.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/query-management/components/query-details/query-details.component.ts","../../../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/query-management/components/query-details/query-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\n\nimport { SessionStorageService } from '../../../../../services';\nimport { isInternalUser } from '../../../../../utils';\nimport { QueryItemResponseStatus } from '../../enums';\nimport { QueryCreateContext, QueryListItem } from '../../models';\nimport { CaseNotifier } from '../../../../case-editor/services/case.notifier';\nimport { AbstractAppConfig } from '../../../../../../app.config';\nimport { Subscription } from 'rxjs';\n\n@Component({\n  selector: 'ccd-query-details',\n  templateUrl: './query-details.component.html',\n  styleUrls: ['./query-details.component.scss']\n})\nexport class QueryDetailsComponent implements OnChanges, OnInit, OnDestroy {\n  @Input() public query: QueryListItem;\n  @Input() public caseId: string;\n  @Input() public queryResponseStatus: string;\n\n  @Output() public backClicked: EventEmitter<boolean> = new EventEmitter();\n  @Output() public hasResponded: EventEmitter<boolean> = new EventEmitter();\n\n  public showItem: boolean = true;\n\n  private static readonly QUERY_ITEM_RESPOND = '3';\n  private static readonly QUERY_ITEM_FOLLOW_UP = '4';\n  private queryItemId: string;\n\n  public followUpQuery: string = QueryCreateContext.FOLLOWUP;\n  public respondToQuery: string = QueryCreateContext.RESPOND;\n  public enableServiceSpecificMultiFollowups: string[];\n  public currentJurisdictionId: string;\n  public isMultipleFollowUpEnabled: boolean = false;\n\n  private caseSubscription: Subscription;\n\n  constructor(\n    private readonly sessionStorageService: SessionStorageService,\n    private readonly route: ActivatedRoute,\n    private readonly router: Router,\n    private readonly abstractConfig: AbstractAppConfig,\n    private readonly caseNotifier: CaseNotifier) { }\n\n  public onBack(): void {\n    this.backClicked.emit(true);\n  }\n\n  public isInternalUser(): boolean {\n    return isInternalUser(this.sessionStorageService);\n  }\n\n  public ngOnInit(): void {\n    this.enableServiceSpecificMultiFollowups = this.abstractConfig.getEnableServiceSpecificMultiFollowups() || [];\n\n    this.caseSubscription = this.caseNotifier.caseView.subscribe((caseView) => {\n      if (caseView?.case_type?.jurisdiction?.id) {\n        this.currentJurisdictionId = caseView.case_type.jurisdiction.id;\n        this.isMultipleFollowUpEnabled = this.enableServiceSpecificMultiFollowups.includes(this.currentJurisdictionId);\n\n        this.hasRespondedToQuery();\n      }\n    });\n  }\n\n  public ngOnChanges(): void {\n    this.toggleLinkVisibility();\n    this.hasRespondedToQuery();\n  }\n\n  public ngOnDestroy(): void {\n    this.caseSubscription?.unsubscribe();\n  }\n\n  public toggleLinkVisibility(): void {\n    this.queryItemId = this.route.snapshot.params.qid as string;\n    if (this.queryItemId === QueryDetailsComponent.QUERY_ITEM_RESPOND || this.queryItemId === QueryDetailsComponent.QUERY_ITEM_FOLLOW_UP) {\n      this.showItem = false;\n    }\n  }\n\n  public hasRespondedToQuery(): boolean {\n    const isAwaiting = this.queryResponseStatus === undefined || this.queryResponseStatus === QueryItemResponseStatus.AWAITING;\n    if (this.queryResponseStatus === QueryItemResponseStatus.CLOSED) {\n      this.hasResponded.emit(true);\n      return true;\n    }\n\n    const lastChild = this.query?.children?.[this.query.children.length - 1];\n    const isFollowUp = lastChild?.messageType === this.followUpQuery;\n    const isRespond = lastChild?.messageType === this.respondToQuery;\n\n    if (this.queryResponseStatus === QueryItemResponseStatus.CLOSED) {\n      this.hasResponded.emit(true);\n      return true;\n    }\n\n    if (isFollowUp && this.isMultipleFollowUpEnabled) {\n      this.hasResponded.emit(false);\n      return false;\n    }\n\n    if (isRespond) {\n      this.hasResponded.emit(false);\n      return false;\n    }\n\n    if (this.isInternalUser()) {\n      if (isAwaiting) {\n        this.hasResponded.emit(false);\n        return false;\n      }\n\n      this.hasResponded.emit(true);\n      return true;\n    }\n\n    if (isAwaiting) {\n      this.hasResponded.emit(true);\n      return false; // Don't show message\n    }\n\n    this.hasResponded.emit(false);\n    return false;\n  }\n}\n","<ng-container *ngIf=\"query\">\n  <p *ngIf=\"showItem\">\n    <br />\n    <a class=\"govuk-link\" href=\"javascript:void(0)\" (click)=\"onBack()\">{{ 'Back to query list' | rpxTranslate }}</a>\n  </p>\n  <div>\n    <table class=\"govuk-table query-details-table\" [attr.aria-describedby]=\"'Details of the query' | rpxTranslate\">\n      <caption class=\"govuk-table__caption govuk-table__caption--l\">\n        <div>{{ 'Query details' | rpxTranslate }}</div>\n      </caption>\n      <tbody class=\"govuk-table__body\">\n      <tr class=\"govuk-table__row\">\n        <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last submitted by' | rpxTranslate }}</th>\n        <td class=\"govuk-table__cell\">{{ query.lastSubmittedBy }}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n        <th scope=\"row\" class=\"govuk-table__header\">{{ 'Submission date' | rpxTranslate }}</th>\n        <td class=\"govuk-table__cell\">{{ query.createdOn | date: 'dd MMMM YYYY HH:mm' }}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n        <th scope=\"row\" class=\"govuk-table__header\">{{ 'Query subject' | rpxTranslate }}</th>\n        <td class=\"govuk-table__cell\">{{ query.subject }}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n        <th scope=\"row\" class=\"govuk-table__header\">{{ 'Query body' | rpxTranslate }}</th>\n        <td class=\"govuk-table__cell\">{{ query.body }}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n        <th scope=\"row\" class=\"govuk-table__header\" [class.govuk-table__header--no-border]=\"query.isHearingRelated\">\n          {{ 'Is the query hearing related?' | rpxTranslate }}\n        </th>\n        <td class=\"govuk-table__cell\" [class.govuk-table__cell--no-border]=\"query.isHearingRelated\">\n          {{ 'Is the query hearing related?' | rpxTranslate: null : (query.isHearingRelated) }}</td>\n      </tr>\n      <tr class=\"govuk-table__row govuk-table__row--isHearingRelated\" *ngIf=\"query.isHearingRelated === 'Yes'\">\n        <th scope=\"row\" class=\"govuk-table__header\">{{ 'What is the date of the hearing?' | rpxTranslate }}</th>\n        <td class=\"govuk-table__cell\">{{ query.hearingDate | date: 'dd MMM yyyy' }}</td>\n      </tr>\n      <tr class=\"govuk-table__row\" *ngIf=\"query.attachments.length > 0\">\n        <th scope=\"row\" class=\"govuk-table__header\">{{ 'Attachments' | rpxTranslate }}</th>\n        <td class=\"govuk-table__cell\">\n          <ccd-query-attachments-read\n            *ngIf=\"query.attachments\"\n            [attachments]=\"query.attachments\"\n          >\n          </ccd-query-attachments-read>\n        </td>\n      </tr>\n      </tbody>\n    </table>\n  </div>\n  <ng-container *ngIf=\"query.children?.length > 0\">\n    <ng-container *ngFor=\"let child of query.children; let i = index;\">\n      <ng-container *ngIf=\"(i % 2 === 0 && !child?.messageType) || (child && child?.messageType === respondToQuery); else followUpMessage\">\n        <table class=\"govuk-table query-details-table\" [attr.aria-describedby]=\"'Response of the query' | rpxTranslate\">\n          <caption class=\"govuk-table__caption govuk-table__caption--l\">\n            <div>{{ 'Response' | rpxTranslate }}</div>\n          </caption>\n          <tbody class=\"govuk-table__body\">\n          <tr class=\"govuk-table__row\">\n            <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last response date' | rpxTranslate }}</th>\n            <td class=\"govuk-table__cell\">{{ child.createdOn | date: 'dd MMMM YYYY HH:mm'  }}</td>\n          </tr>\n\n            <tr *ngIf=\"isInternalUser()\" class=\"govuk-table__row\">\n              <th scope=\"row\" class=\"govuk-table__header\">{{ 'Caseworker name' | rpxTranslate }}</th>\n              <td class=\"govuk-table__cell\">{{ child.name }}</td>\n            </tr>\n\n            <tr class=\"govuk-table__row\">\n              <th scope=\"row\" class=\"govuk-table__header\">{{ 'Response detail' | rpxTranslate }}</th>\n              <td class=\"govuk-table__cell\">{{ child.body }}</td>\n            </tr>\n\n          <tr class=\"govuk-table__row\" *ngIf=\"child.attachments.length > 0\">\n            <th scope=\"row\" class=\"govuk-table__header\">{{ 'Attachments' | rpxTranslate }}</th>\n            <td class=\"govuk-table__cell\">\n              <ccd-query-attachments-read\n                *ngIf=\"child.attachments\"\n                [attachments]=\"child.attachments\"\n              >\n              </ccd-query-attachments-read>\n            </td>\n          </tr>\n          </tbody>\n        </table>\n      </ng-container>\n\n      <ng-template #followUpMessage>\n        <!-- <div class=\"query_details_caption\">{{ 'Follow-up' | rpxTranslate }}</div> -->\n        <table class=\"govuk-table query-details-table\"\n               [attr.aria-describedby]=\"'Follow-up of the response' | rpxTranslate\">\n          <caption class=\"govuk-table__caption govuk-table__caption--l\">\n            <div>{{ 'Follow up query' | rpxTranslate }}</div>\n          </caption>\n          <tbody class=\"govuk-table__body\">\n          <tr class=\"govuk-table__row\">\n            <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last submission date' | rpxTranslate }}</th>\n            <td class=\"govuk-table__cell\">{{ child.createdOn | date: 'dd MMMM YYYY HH:mm'}}</td>\n          </tr>\n\n          <tr class=\"govuk-table__row\">\n            <th scope=\"row\" class=\"govuk-table__header\">{{ 'Last submitted by' | rpxTranslate }}</th>\n            <td class=\"govuk-table__cell\">{{ child.name }}</td>\n          </tr>\n\n            <tr class=\"govuk-table__row\">\n              <th scope=\"row\" class=\"govuk-table__header\">{{ 'Query detail' | rpxTranslate }}</th>\n              <td class=\"govuk-table__cell\">{{ child.body }}</td>\n            </tr>\n\n            <tr class=\"govuk-table__row\" *ngIf=\"child.attachments.length > 0\">\n              <th scope=\"row\" class=\"govuk-table__header\">{{ 'Attachments' | rpxTranslate }}</th>\n              <td class=\"govuk-table__cell\">\n                <ccd-query-attachments-read\n                  *ngIf=\"child.attachments\"\n                  [attachments]=\"child.attachments\"\n                >\n                </ccd-query-attachments-read>\n              </td>\n            </tr>\n          </tbody>\n        </table>\n      </ng-template>\n    </ng-container>\n  </ng-container>\n</ng-container>\n"]}