@hmcts/ccd-case-ui-toolkit 7.1.72 → 7.1.73-follow-up
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.
- package/esm2022/lib/shared/components/palette/query-management/components/query-details/query-details.component.mjs +15 -7
- package/esm2022/lib/shared/components/palette/query-management/components/query-write/query-write-respond-to-query/query-write-respond-to-query.component.mjs +14 -9
- package/fesm2022/hmcts-ccd-case-ui-toolkit.mjs +27 -14
- package/fesm2022/hmcts-ccd-case-ui-toolkit.mjs.map +1 -1
- package/lib/shared/components/palette/query-management/components/query-details/query-details.component.d.ts +1 -0
- package/lib/shared/components/palette/query-management/components/query-details/query-details.component.d.ts.map +1 -1
- package/lib/shared/components/palette/query-management/components/query-write/query-write-respond-to-query/query-write-respond-to-query.component.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -346,6 +346,7 @@ export class QueryDetailsComponent {
|
|
|
346
346
|
showItem = true;
|
|
347
347
|
message;
|
|
348
348
|
static QUERY_ITEM_RESPOND = '3';
|
|
349
|
+
static QUERY_ITEM_FOLLOW_UP = '4';
|
|
349
350
|
queryItemId;
|
|
350
351
|
constructor(sessionStorageService, route, router) {
|
|
351
352
|
this.sessionStorageService = sessionStorageService;
|
|
@@ -364,18 +365,25 @@ export class QueryDetailsComponent {
|
|
|
364
365
|
}
|
|
365
366
|
toggleLinkVisibility() {
|
|
366
367
|
this.queryItemId = this.route.snapshot.params.qid;
|
|
367
|
-
this.
|
|
368
|
+
if (this.queryItemId === QueryDetailsComponent.QUERY_ITEM_RESPOND || this.queryItemId === QueryDetailsComponent.QUERY_ITEM_FOLLOW_UP) {
|
|
369
|
+
this.showItem = false;
|
|
370
|
+
}
|
|
368
371
|
}
|
|
369
372
|
hasRespondedToQuery() {
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
373
|
+
const isAwaiting = this.queryResponseStatus === undefined || this.queryResponseStatus === QueryItemResponseStatus.AWAITING;
|
|
374
|
+
if (this.isInternalUser()) {
|
|
375
|
+
if (isAwaiting) {
|
|
376
|
+
this.hasResponded.emit(false);
|
|
377
|
+
return false;
|
|
378
|
+
}
|
|
375
379
|
this.message = Constants.TASK_COMPLETION_ERROR;
|
|
376
380
|
this.hasResponded.emit(true);
|
|
377
381
|
return true;
|
|
378
382
|
}
|
|
383
|
+
if (isAwaiting) {
|
|
384
|
+
this.hasResponded.emit(true);
|
|
385
|
+
return false; // Don't show message
|
|
386
|
+
}
|
|
379
387
|
this.hasResponded.emit(false);
|
|
380
388
|
return false;
|
|
381
389
|
}
|
|
@@ -401,4 +409,4 @@ export class QueryDetailsComponent {
|
|
|
401
409
|
type: Output
|
|
402
410
|
}] }); })();
|
|
403
411
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(QueryDetailsComponent, { className: "QueryDetailsComponent", filePath: "lib/shared/components/palette/query-management/components/query-details/query-details.component.ts", lineNumber: 15 }); })();
|
|
404
|
-
//# 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 { Constants } from '../../../../../commons/constants';\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  public message: string;\n\n  private static readonly QUERY_ITEM_RESPOND = '3';\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;\n    this.showItem = this.queryItemId !== QueryDetailsComponent.QUERY_ITEM_RESPOND;\n  }\n\n  public hasRespondedToQuery(): boolean {\n    if (this.queryResponseStatus === undefined || this.queryResponseStatus === QueryItemResponseStatus.AWAITING) {\n      this.hasResponded.emit(false);\n      return false;\n    }\n\n    if (this.isInternalUser() && this.queryResponseStatus !== QueryItemResponseStatus.AWAITING) {\n      this.message = Constants.TASK_COMPLETION_ERROR;\n      this.hasResponded.emit(true);\n      return true;\n    }\n\n    this.hasResponded.emit(false);\n    return false;\n  }\n}\n","<ng-container *ngIf=\"query\">\n  <cut-alert type=\"error\" *ngIf=\"hasRespondedToQuery() && !showItem\">\n    <ng-container>{{message}}</ng-container>\n  </cut-alert>\n\n  <br/>\n  <p *ngIf=\"showItem\">\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 MMM yyyy' }}</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 MMM yyyy' }}</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 MMM yyyy' }}</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"]}
|
|
412
|
+
//# 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 { Constants } from '../../../../../commons/constants';\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  public message: string;\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\n    if (this.isInternalUser()) {\n      if (isAwaiting) {\n        this.hasResponded.emit(false);\n        return false;\n      }\n\n      this.message = Constants.TASK_COMPLETION_ERROR;\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  <cut-alert type=\"error\" *ngIf=\"hasRespondedToQuery() && !showItem\">\n    <ng-container>{{message}}</ng-container>\n  </cut-alert>\n\n  <br/>\n  <p *ngIf=\"showItem\">\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 MMM yyyy' }}</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 MMM yyyy' }}</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 MMM yyyy' }}</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"]}
|
|
@@ -101,8 +101,7 @@ export class QueryWriteRespondToQueryComponent {
|
|
|
101
101
|
});
|
|
102
102
|
}
|
|
103
103
|
ngOnChanges() {
|
|
104
|
-
if (this.
|
|
105
|
-
&& this.caseQueriesCollections?.length > 0) {
|
|
104
|
+
if (this.caseQueriesCollections?.length > 0) {
|
|
106
105
|
if (!this.caseQueriesCollections[0]) {
|
|
107
106
|
console.error('caseQueriesCollections[0] is undefined!', this.caseQueriesCollections);
|
|
108
107
|
return;
|
|
@@ -119,13 +118,19 @@ export class QueryWriteRespondToQueryComponent {
|
|
|
119
118
|
.filter((message) => message?.value?.id === messageId); // Safe access
|
|
120
119
|
if (filteredMessages.length > 0) {
|
|
121
120
|
const matchingMessage = filteredMessages[0]?.value;
|
|
122
|
-
|
|
123
|
-
this.
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
121
|
+
let filteredQuery = [];
|
|
122
|
+
if (this.queryItemId === QueryWriteRespondToQueryComponent.QUERY_ITEM_RESPOND) {
|
|
123
|
+
filteredQuery = queryWithChildren?.queries.filter((message) => filteredMessages[0]?.value?.parentId === message?.id);
|
|
124
|
+
if (matchingMessage) {
|
|
125
|
+
this.queryItemDisplay = new QueryListItem();
|
|
126
|
+
Object.assign(this.queryItemDisplay, matchingMessage);
|
|
127
|
+
this.queryItem = this.queryItemDisplay;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
filteredQuery = queryWithChildren?.queries.filter((message) => filteredMessages[0]?.value?.id === message?.id);
|
|
128
132
|
}
|
|
133
|
+
this.queryResponseStatus = filteredQuery[0]?.responseStatus;
|
|
129
134
|
}
|
|
130
135
|
}
|
|
131
136
|
}
|
|
@@ -182,4 +187,4 @@ export class QueryWriteRespondToQueryComponent {
|
|
|
182
187
|
type: Output
|
|
183
188
|
}] }); })();
|
|
184
189
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(QueryWriteRespondToQueryComponent, { className: "QueryWriteRespondToQueryComponent", filePath: "lib/shared/components/palette/query-management/components/query-write/query-write-respond-to-query/query-write-respond-to-query.component.ts", lineNumber: 14 }); })();
|
|
185
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-write-respond-to-query.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/query-management/components/query-write/query-write-respond-to-query/query-write-respond-to-query.component.ts","../../../../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/query-management/components/query-write/query-write-respond-to-query/query-write-respond-to-query.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAE,MAAM,eAAe,CAAC;AAC1F,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AACnE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAyB,kBAAkB,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;;;;;IC0BhG,AAFF,6BACoE,eAC9B;IAAA,YAA8B;;IAAA,iBAAO;IAAA,YAC3E;;IAAA,iBAAI;;;IADkC,eAA8B;IAA9B,8DAA8B;IAAO,eAC3E;IAD2E,yNAC3E;;;IAfJ,AADF,2BAAkC,YACJ;IAC1B,YACF;;IAAA,iBAAK;IAMC,AADF,AAFF,AADF,+BAA6B,cAEqE,cAC7D,gBAC+C;IAC5E,YACF;;IACF,AADE,iBAAQ,EACJ;IACN,8FACoE;IAGpE,qCAEuE;IACzE,uBAAA;IAGJ,AADE,AADE,AADA,iBAAW,EACL,EACF,EACF;;;;;;IArBF,eACF;IADE,8KACF;IAEK,eAAuB;IAAvB,4CAAuB;IAErB,cAA0F;IAA1F,uJAA0F;IAGzF,eACF;IADE,8JACF;IAGE,eAA8D;IAA9D,mIAA8D;IAIxD,cAAwF;IAAxF,qJAAwF;IADxF,wCAA0B;;;IAlB5C,8BAA4C;IAC1C,2FAAkC;IAwBpC,iBAAM;;;IAxBE,cAA0B;IAA1B,kDAA0B;;ADJlC,MAAM,OAAO,iCAAiC;IAsBf;IACV;IAtBH,SAAS,CAAgB;IACzB,SAAS,CAAY;IACrB,kBAAkB,CAAqB;IACvC,SAAS,GAAG,KAAK,CAAC;IAClB,sBAAsB,CAA0B;IAChD,QAAQ,CAAC;IACR,uBAAuB,GAA0B,IAAI,YAAY,EAAE,CAAC;IAErE,sBAAsB,GAAG,kBAAkB,CAAC;IAC5C,uBAAuB,GAAG,sBAAsB,CAAC;IAC1D,MAAM,CAAS;IACf,WAAW,CAAS;IACpB,WAAW,CAAC;IACZ,mBAAmB,CAAS;IAC5B,gBAAgB,CAAgB;IAEhC,mBAAmB,GAAY,KAAK,CAAC;IAEpC,MAAM,CAAU,kBAAkB,GAAG,GAAG,CAAC;IACzC,MAAM,CAAU,mBAAmB,GAAG,GAAG,CAAC;IAElD,YAA6B,YAA0B,EACpC,KAAqB;QADX,iBAAY,GAAZ,YAAY,CAAc;QACpC,UAAK,GAAL,KAAK,CAAgB;IAAG,CAAC;IAErC,QAAQ;QACb,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC;QAClD,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;YACjD,IAAI,EAAE,CAAC,WAAW,EAAE,EAAE;gBACpB,IAAI,CAAC,MAAM,GAAG,WAAW,EAAE,OAAO,IAAI,EAAE,CAAC;gBACzC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;YACjC,CAAC;YACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE;gBACb,OAAO,CAAC,KAAK,CAAC,gCAAgC,EAAE,GAAG,CAAC,CAAC;YACvD,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAEM,WAAW;QAChB,IAAI,IAAI,CAAC,WAAW,KAAK,iCAAiC,CAAC,kBAAkB;eACxE,IAAI,CAAC,sBAAsB,EAAE,MAAM,GAAG,CAAC,EAC1C,CAAC;YACD,IAAI,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAAE,CAAC;gBACpC,OAAO,CAAC,KAAK,CAAC,yCAAyC,EAAE,IAAI,CAAC,sBAAsB,CAAC,CAAC;gBACtF,OAAO;YACT,CAAC;YAED,MAAM,iBAAiB,GAAG,IAAI,aAAa,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,CAAC;YAE5E,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC;YACpD,IAAI,CAAC,SAAS,EAAE,CAAC;gBACf,OAAO,CAAC,IAAI,CAAC,qCAAqC,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;gBAChF,OAAO;YACT,CAAC;YAED,MAAM,gBAAgB,GAAG,IAAI,CAAC,sBAAsB;iBACjD,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,EAAE,YAAY,IAAI,EAAE,CAAC,CAAC,yCAAyC;iBACzF,IAAI,EAAE,CAAC,0CAA0C;iBACjD,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,KAAK,SAAS,CAAC,CAAC,CAAC,cAAc;YAExE,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAChC,MAAM,eAAe,GAAG,gBAAgB,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC;gBAEnD,MAAM,aAAa,GAAG,iBAAiB,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,QAAQ,KAAK,OAAO,EAAE,EAAE,CAAC,CAAC;gBAC3H,IAAI,CAAC,mBAAmB,GAAG,aAAa,CAAC,CAAC,CAAC,EAAE,cAAc,CAAC;gBAE5D,IAAI,eAAe,EAAE,CAAC;oBACpB,IAAI,CAAC,gBAAgB,GAAG,IAAI,aAAa,EAAE,CAAC;oBAC5C,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE,eAAe,CAAC,CAAC;oBACtD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC;gBACzC,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAEM,YAAY,CAAC,KAAc;QAChC,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;QACjC,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3C,CAAC;2FA9EU,iCAAiC;6DAAjC,iCAAiC;YCX1C,AADF,AADF,8BAAqC,aACE,aACN;YAAA,YAAyC;;YAAA,iBAAM;YAC5E,6BAAoD;YAAA,YAAoC;;YAC1F,AAD0F,iBAAK,EACzF;YAEN,8BAAqC;YACnC,mDAA2F;YAC7F,iBAAM;YAGJ,AADF,4BAAK,4BAGqC;YAAtC,8IAAgB,wBAAoB,IAAC;YAE3C,AADE,AAD0C,iBAAoB,EACxD,EACF;YACN,oFAA4C;;YAdX,eAAyC;YAAzC,gEAAyC;YAClB,eAAoC;YAApC,2DAAoC;YAIzD,eAA2B;YAA3B,6CAA2B;YAIvC,eAAmB;YACpC,AADiB,qCAAmB,gDACO;YAIrB,cAAc;YAAd,mCAAc;;;iFDH7B,iCAAiC;cAN7C,SAAS;2BACE,kCAAkC;0EAM5B,SAAS;kBAAxB,KAAK;YACU,SAAS;kBAAxB,KAAK;YACU,kBAAkB;kBAAjC,KAAK;YACU,SAAS;kBAAxB,KAAK;YACU,sBAAsB;kBAArC,KAAK;YACU,QAAQ;kBAAvB,KAAK;YACW,uBAAuB;kBAAvC,MAAM;;kFAPI,iCAAiC","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { FormGroup } from '@angular/forms';\nimport { take } from 'rxjs/operators';\nimport { CaseNotifier } from '../../../../../case-editor/services';\nimport { RaiseQueryErrorMessage } from '../../../enums';\nimport { CaseQueriesCollection, QueryCreateContext, QueryListData, QueryListItem } from '../../../models';\n@Component({\n  selector: 'ccd-query-write-respond-to-query',\n  templateUrl: './query-write-respond-to-query.component.html',\n  styleUrls: ['./query-write-respond-to-query.component.scss']\n})\n\nexport class QueryWriteRespondToQueryComponent implements OnInit, OnChanges {\n  @Input() public queryItem: QueryListItem;\n  @Input() public formGroup: FormGroup;\n  @Input() public queryCreateContext: QueryCreateContext;\n  @Input() public submitted = false;\n  @Input() public caseQueriesCollections: CaseQueriesCollection[];\n  @Input() public showForm;\n  @Output() public hasRespondedToQueryTask: EventEmitter<boolean> = new EventEmitter();\n\n  public readonly queryCreateContextEnum = QueryCreateContext;\n  public readonly raiseQueryErrorMessages = RaiseQueryErrorMessage;\n  public caseId: string;\n  public queryItemId: string;\n  public caseDetails;\n  public queryResponseStatus: string;\n  public queryItemDisplay: QueryListItem;\n\n  public hasRespondedToQuery: boolean = false;\n\n  private static readonly QUERY_ITEM_RESPOND = '3';\n  private static readonly QUERY_ITEM_FOLLOWUP = '4';\n\n  constructor(private readonly caseNotifier: CaseNotifier,\n    private readonly route: ActivatedRoute) {}\n\n  public ngOnInit(): void {\n    this.queryItemId = this.route.snapshot.params.qid;\n    this.caseNotifier.caseView.pipe(take(1)).subscribe({\n      next: (caseDetails) => {\n        this.caseId = caseDetails?.case_id ?? '';\n        this.caseDetails = caseDetails;\n      },\n      error: (err) => {\n        console.error('Error retrieving case details:', err);\n      }\n    });\n  }\n\n  public ngOnChanges(): void {\n    if (this.queryItemId === QueryWriteRespondToQueryComponent.QUERY_ITEM_RESPOND\n      && this.caseQueriesCollections?.length > 0\n    ) {\n      if (!this.caseQueriesCollections[0]) {\n        console.error('caseQueriesCollections[0] is undefined!', this.caseQueriesCollections);\n        return;\n      }\n\n      const queryWithChildren = new QueryListData(this.caseQueriesCollections[0]);\n\n      const messageId = this.route.snapshot.params.dataid;\n      if (!messageId) {\n        console.warn('No messageId found in route params:', this.route.snapshot.params);\n        return;\n      }\n\n      const filteredMessages = this.caseQueriesCollections\n        .map((caseData) => caseData?.caseMessages || []) // Ensure caseMessages is always an array\n        .flat() // Flatten into a single array of messages\n        .filter((message) => message?.value?.id === messageId); // Safe access\n\n      if (filteredMessages.length > 0) {\n        const matchingMessage = filteredMessages[0]?.value;\n\n        const filteredQuery = queryWithChildren?.queries.filter((message) => filteredMessages[0]?.value?.parentId === message?.id);\n        this.queryResponseStatus = filteredQuery[0]?.responseStatus;\n\n        if (matchingMessage) {\n          this.queryItemDisplay = new QueryListItem();\n          Object.assign(this.queryItemDisplay, matchingMessage);\n          this.queryItem = this.queryItemDisplay;\n        }\n      }\n    }\n  }\n\n  public hasResponded(value: boolean): void {\n    this.hasRespondedToQuery = value;\n    this.hasRespondedToQueryTask.emit(value);\n  }\n}\n","<div class=\"govuk-!-margin-bottom-6\">\n  <div class=\"govuk-!-margin-bottom-6\">\n    <div class=\"govuk-caption-l\">{{ 'Respond to a query' | rpxTranslate }}</div>\n    <h1 class=\"govuk-heading-l govuk-!-margin-bottom-0\">{{ 'Query details' | rpxTranslate }}</h1>\n  </div>\n\n  <div class=\"govuk-!-margin-bottom-4\">\n    <ccd-query-case-details-header [caseDetails]=\"caseDetails\"></ccd-query-case-details-header>\n  </div>\n\n  <div>\n    <ccd-query-details [query]=\"queryItem\"\n      [queryResponseStatus]=\"queryResponseStatus\"\n      (hasResponded)=\"hasResponded($event)\"></ccd-query-details>\n  </div>\n</div>\n<div class=\"query-respond\" *ngIf=\"showForm\">\n  <div *ngIf=\"!hasRespondedToQuery\">\n    <h1 class=\"govuk-heading-m\">\n      {{ queryCreateContext === queryCreateContextEnum.RESPOND ? 'Respond to a query' : 'Ask a follow-up question' | rpxTranslate }}\n    </h1>\n\n    <div [formGroup]=\"formGroup\">\n      <div class=\"govuk-form-group body-textarea\"\n           [class.govuk-form-group--error]=\"submitted && formGroup.get('body')?.hasError('required')\">\n        <div class=\"govuk-label-wrapper\">\n          <label class=\"govuk-label govuk-label--m govuk-!-font-weight-bold\" for=\"body\">\n            {{ queryCreateContext === queryCreateContextEnum.RESPOND ? 'Response detail' : 'Query Body' | rpxTranslate }}\n          </label>\n        </div>\n        <p id=\"body-error\" class=\"govuk-error-message\"\n           *ngIf=\"submitted && formGroup.get('body')?.hasError('required')\">\n          <span class=\"govuk-visually-hidden\">{{ 'Error:' | rpxTranslate }} </span>{{ queryCreateContext === queryCreateContextEnum.RESPOND ? raiseQueryErrorMessages.RESPOND_QUERY_BODY : raiseQueryErrorMessages.QUERY_BODY | rpxTranslate }}\n        </p>\n        <textarea [formControlName]=\"'body'\" class=\"govuk-textarea\"\n                  [class.govuk-textarea--error]=\"submitted && formGroup.get('body')?.hasError('required')\" id=\"body\"\n                  name=\"body\" rows=\"5\" aria-describedby=\"body-hint body-error\">\n      </textarea>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
190
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-write-respond-to-query.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/query-management/components/query-write/query-write-respond-to-query/query-write-respond-to-query.component.ts","../../../../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/query-management/components/query-write/query-write-respond-to-query/query-write-respond-to-query.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { FormGroup } from '@angular/forms';\nimport { take } from 'rxjs/operators';\nimport { CaseNotifier } from '../../../../../case-editor/services';\nimport { RaiseQueryErrorMessage } from '../../../enums';\nimport { CaseQueriesCollection, QueryCreateContext, QueryListData, QueryListItem } from '../../../models';\n@Component({\n  selector: 'ccd-query-write-respond-to-query',\n  templateUrl: './query-write-respond-to-query.component.html',\n  styleUrls: ['./query-write-respond-to-query.component.scss']\n})\n\nexport class QueryWriteRespondToQueryComponent implements OnInit, OnChanges {\n  @Input() public queryItem: QueryListItem;\n  @Input() public formGroup: FormGroup;\n  @Input() public queryCreateContext: QueryCreateContext;\n  @Input() public submitted = false;\n  @Input() public caseQueriesCollections: CaseQueriesCollection[];\n  @Input() public showForm;\n  @Output() public hasRespondedToQueryTask: EventEmitter<boolean> = new EventEmitter();\n\n  public readonly queryCreateContextEnum = QueryCreateContext;\n  public readonly raiseQueryErrorMessages = RaiseQueryErrorMessage;\n  public caseId: string;\n  public queryItemId: string;\n  public caseDetails;\n  public queryResponseStatus: string;\n  public queryItemDisplay: QueryListItem;\n\n  public hasRespondedToQuery: boolean = false;\n\n  private static readonly QUERY_ITEM_RESPOND = '3';\n  private static readonly QUERY_ITEM_FOLLOWUP = '4';\n\n  constructor(private readonly caseNotifier: CaseNotifier,\n    private readonly route: ActivatedRoute) {}\n\n  public ngOnInit(): void {\n    this.queryItemId = this.route.snapshot.params.qid;\n    this.caseNotifier.caseView.pipe(take(1)).subscribe({\n      next: (caseDetails) => {\n        this.caseId = caseDetails?.case_id ?? '';\n        this.caseDetails = caseDetails;\n      },\n      error: (err) => {\n        console.error('Error retrieving case details:', err);\n      }\n    });\n  }\n\n  public ngOnChanges(): void {\n    if (this.caseQueriesCollections?.length > 0\n    ) {\n      if (!this.caseQueriesCollections[0]) {\n        console.error('caseQueriesCollections[0] is undefined!', this.caseQueriesCollections);\n        return;\n      }\n\n      const queryWithChildren = new QueryListData(this.caseQueriesCollections[0]);\n\n      const messageId = this.route.snapshot.params.dataid;\n      if (!messageId) {\n        console.warn('No messageId found in route params:', this.route.snapshot.params);\n        return;\n      }\n\n      const filteredMessages = this.caseQueriesCollections\n        .map((caseData) => caseData?.caseMessages || []) // Ensure caseMessages is always an array\n        .flat() // Flatten into a single array of messages\n        .filter((message) => message?.value?.id === messageId); // Safe access\n\n      if (filteredMessages.length > 0) {\n        const matchingMessage = filteredMessages[0]?.value;\n        let filteredQuery = [];\n        if (this.queryItemId === QueryWriteRespondToQueryComponent.QUERY_ITEM_RESPOND) {\n          filteredQuery = queryWithChildren?.queries.filter((message) => filteredMessages[0]?.value?.parentId === message?.id);\n          if (matchingMessage) {\n            this.queryItemDisplay = new QueryListItem();\n            Object.assign(this.queryItemDisplay, matchingMessage);\n            this.queryItem = this.queryItemDisplay;\n          }\n        } else {\n          filteredQuery = queryWithChildren?.queries.filter((message) => filteredMessages[0]?.value?.id === message?.id);\n        }\n\n        this.queryResponseStatus = filteredQuery[0]?.responseStatus;\n      }\n    }\n  }\n\n  public hasResponded(value: boolean): void {\n    this.hasRespondedToQuery = value;\n    this.hasRespondedToQueryTask.emit(value);\n  }\n}\n","<div class=\"govuk-!-margin-bottom-6\">\n  <div class=\"govuk-!-margin-bottom-6\">\n    <div class=\"govuk-caption-l\">{{ 'Respond to a query' | rpxTranslate }}</div>\n    <h1 class=\"govuk-heading-l govuk-!-margin-bottom-0\">{{ 'Query details' | rpxTranslate }}</h1>\n  </div>\n\n  <div class=\"govuk-!-margin-bottom-4\">\n    <ccd-query-case-details-header [caseDetails]=\"caseDetails\"></ccd-query-case-details-header>\n  </div>\n\n  <div>\n    <ccd-query-details [query]=\"queryItem\"\n      [queryResponseStatus]=\"queryResponseStatus\"\n      (hasResponded)=\"hasResponded($event)\"></ccd-query-details>\n  </div>\n</div>\n<div class=\"query-respond\" *ngIf=\"showForm\">\n  <div *ngIf=\"!hasRespondedToQuery\">\n    <h1 class=\"govuk-heading-m\">\n      {{ queryCreateContext === queryCreateContextEnum.RESPOND ? 'Respond to a query' : 'Ask a follow-up question' | rpxTranslate }}\n    </h1>\n\n    <div [formGroup]=\"formGroup\">\n      <div class=\"govuk-form-group body-textarea\"\n           [class.govuk-form-group--error]=\"submitted && formGroup.get('body')?.hasError('required')\">\n        <div class=\"govuk-label-wrapper\">\n          <label class=\"govuk-label govuk-label--m govuk-!-font-weight-bold\" for=\"body\">\n            {{ queryCreateContext === queryCreateContextEnum.RESPOND ? 'Response detail' : 'Query Body' | rpxTranslate }}\n          </label>\n        </div>\n        <p id=\"body-error\" class=\"govuk-error-message\"\n           *ngIf=\"submitted && formGroup.get('body')?.hasError('required')\">\n          <span class=\"govuk-visually-hidden\">{{ 'Error:' | rpxTranslate }} </span>{{ queryCreateContext === queryCreateContextEnum.RESPOND ? raiseQueryErrorMessages.RESPOND_QUERY_BODY : raiseQueryErrorMessages.QUERY_BODY | rpxTranslate }}\n        </p>\n        <textarea [formControlName]=\"'body'\" class=\"govuk-textarea\"\n                  [class.govuk-textarea--error]=\"submitted && formGroup.get('body')?.hasError('required')\" id=\"body\"\n                  name=\"body\" rows=\"5\" aria-describedby=\"body-hint body-error\">\n      </textarea>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -21851,6 +21851,7 @@ class QueryDetailsComponent {
|
|
|
21851
21851
|
showItem = true;
|
|
21852
21852
|
message;
|
|
21853
21853
|
static QUERY_ITEM_RESPOND = '3';
|
|
21854
|
+
static QUERY_ITEM_FOLLOW_UP = '4';
|
|
21854
21855
|
queryItemId;
|
|
21855
21856
|
constructor(sessionStorageService, route, router) {
|
|
21856
21857
|
this.sessionStorageService = sessionStorageService;
|
|
@@ -21869,18 +21870,25 @@ class QueryDetailsComponent {
|
|
|
21869
21870
|
}
|
|
21870
21871
|
toggleLinkVisibility() {
|
|
21871
21872
|
this.queryItemId = this.route.snapshot.params.qid;
|
|
21872
|
-
this.
|
|
21873
|
+
if (this.queryItemId === QueryDetailsComponent.QUERY_ITEM_RESPOND || this.queryItemId === QueryDetailsComponent.QUERY_ITEM_FOLLOW_UP) {
|
|
21874
|
+
this.showItem = false;
|
|
21875
|
+
}
|
|
21873
21876
|
}
|
|
21874
21877
|
hasRespondedToQuery() {
|
|
21875
|
-
|
|
21876
|
-
|
|
21877
|
-
|
|
21878
|
-
|
|
21879
|
-
|
|
21878
|
+
const isAwaiting = this.queryResponseStatus === undefined || this.queryResponseStatus === QueryItemResponseStatus.AWAITING;
|
|
21879
|
+
if (this.isInternalUser()) {
|
|
21880
|
+
if (isAwaiting) {
|
|
21881
|
+
this.hasResponded.emit(false);
|
|
21882
|
+
return false;
|
|
21883
|
+
}
|
|
21880
21884
|
this.message = Constants.TASK_COMPLETION_ERROR;
|
|
21881
21885
|
this.hasResponded.emit(true);
|
|
21882
21886
|
return true;
|
|
21883
21887
|
}
|
|
21888
|
+
if (isAwaiting) {
|
|
21889
|
+
this.hasResponded.emit(true);
|
|
21890
|
+
return false; // Don't show message
|
|
21891
|
+
}
|
|
21884
21892
|
this.hasResponded.emit(false);
|
|
21885
21893
|
return false;
|
|
21886
21894
|
}
|
|
@@ -22619,8 +22627,7 @@ class QueryWriteRespondToQueryComponent {
|
|
|
22619
22627
|
});
|
|
22620
22628
|
}
|
|
22621
22629
|
ngOnChanges() {
|
|
22622
|
-
if (this.
|
|
22623
|
-
&& this.caseQueriesCollections?.length > 0) {
|
|
22630
|
+
if (this.caseQueriesCollections?.length > 0) {
|
|
22624
22631
|
if (!this.caseQueriesCollections[0]) {
|
|
22625
22632
|
console.error('caseQueriesCollections[0] is undefined!', this.caseQueriesCollections);
|
|
22626
22633
|
return;
|
|
@@ -22637,13 +22644,19 @@ class QueryWriteRespondToQueryComponent {
|
|
|
22637
22644
|
.filter((message) => message?.value?.id === messageId); // Safe access
|
|
22638
22645
|
if (filteredMessages.length > 0) {
|
|
22639
22646
|
const matchingMessage = filteredMessages[0]?.value;
|
|
22640
|
-
|
|
22641
|
-
this.
|
|
22642
|
-
|
|
22643
|
-
|
|
22644
|
-
|
|
22645
|
-
|
|
22647
|
+
let filteredQuery = [];
|
|
22648
|
+
if (this.queryItemId === QueryWriteRespondToQueryComponent.QUERY_ITEM_RESPOND) {
|
|
22649
|
+
filteredQuery = queryWithChildren?.queries.filter((message) => filteredMessages[0]?.value?.parentId === message?.id);
|
|
22650
|
+
if (matchingMessage) {
|
|
22651
|
+
this.queryItemDisplay = new QueryListItem();
|
|
22652
|
+
Object.assign(this.queryItemDisplay, matchingMessage);
|
|
22653
|
+
this.queryItem = this.queryItemDisplay;
|
|
22654
|
+
}
|
|
22646
22655
|
}
|
|
22656
|
+
else {
|
|
22657
|
+
filteredQuery = queryWithChildren?.queries.filter((message) => filteredMessages[0]?.value?.id === message?.id);
|
|
22658
|
+
}
|
|
22659
|
+
this.queryResponseStatus = filteredQuery[0]?.responseStatus;
|
|
22647
22660
|
}
|
|
22648
22661
|
}
|
|
22649
22662
|
}
|