@hmcts/ccd-case-ui-toolkit 7.1.51-read-only-query-collection → 7.1.51
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/case-editor/case-edit-page/case-edit-page.component.mjs +154 -33
- package/esm2022/lib/shared/components/case-editor/case-edit-submit/case-edit-submit.component.mjs +103 -43
- package/esm2022/lib/shared/components/case-editor/case-editor.module.mjs +7 -4
- package/esm2022/lib/shared/components/case-editor/services/case-flag-state.service.mjs +7 -1
- package/esm2022/lib/shared/components/case-viewer/case-event-trigger/case-event-trigger.component.mjs +14 -4
- package/esm2022/lib/shared/components/case-viewer/case-full-access-view/case-full-access-view.component.mjs +15 -5
- package/esm2022/lib/shared/components/palette/base-field/abstract-field-write-journey.component.mjs +95 -0
- package/esm2022/lib/shared/components/palette/base-field/abstract-journey.component.mjs +81 -0
- package/esm2022/lib/shared/components/palette/base-field/index.mjs +3 -1
- package/esm2022/lib/shared/components/palette/case-flag/components/add-comments/add-comments.component.mjs +30 -21
- package/esm2022/lib/shared/components/palette/case-flag/components/case-flag-summary-list/case-flag-summary-list.component.mjs +3 -3
- package/esm2022/lib/shared/components/palette/case-flag/components/confirm-flag-status/confirm-flag-status.component.mjs +25 -22
- package/esm2022/lib/shared/components/palette/case-flag/components/manage-case-flags/manage-case-flags.component.mjs +154 -36
- package/esm2022/lib/shared/components/palette/case-flag/components/search-language-interpreter/search-language-interpreter.component.mjs +33 -29
- package/esm2022/lib/shared/components/palette/case-flag/components/select-flag-location/select-flag-location.component.mjs +33 -28
- package/esm2022/lib/shared/components/palette/case-flag/components/select-flag-type/select-flag-type.component.mjs +177 -71
- package/esm2022/lib/shared/components/palette/case-flag/components/update-flag/update-flag-add-translation-form/update-flag-add-translation-form.component.mjs +32 -28
- package/esm2022/lib/shared/components/palette/case-flag/components/update-flag/update-flag.component.mjs +123 -105
- package/esm2022/lib/shared/components/palette/case-flag/read-case-flag-field.component.mjs +31 -4
- package/esm2022/lib/shared/components/palette/case-flag/write-case-flag-field.component.mjs +147 -33
- package/esm2022/lib/shared/components/palette/linked-cases/components/before-you-start/before-you-start.component.mjs +44 -23
- package/esm2022/lib/shared/components/palette/linked-cases/components/check-your-answers/check-your-answers.component.mjs +29 -7
- package/esm2022/lib/shared/components/palette/linked-cases/components/link-cases/link-cases.component.mjs +84 -50
- package/esm2022/lib/shared/components/palette/linked-cases/components/no-linked-cases/no-linked-cases.component.mjs +13 -9
- package/esm2022/lib/shared/components/palette/linked-cases/components/unlink-cases/unlink-cases.component.mjs +84 -44
- package/esm2022/lib/shared/components/palette/linked-cases/services/linked-cases.service.mjs +25 -2
- package/esm2022/lib/shared/components/palette/linked-cases/write-linked-cases-field.component.mjs +110 -30
- package/esm2022/lib/shared/components/palette/palette.module.mjs +2 -2
- package/esm2022/lib/shared/components/palette/query-management/components/query-check-your-answers/query-check-your-answers.component.mjs +21 -8
- package/esm2022/lib/shared/domain/index.mjs +2 -1
- package/esm2022/lib/shared/domain/journey/index.mjs +3 -0
- package/esm2022/lib/shared/domain/journey/journey-instigator.model.mjs +2 -0
- package/esm2022/lib/shared/domain/journey/journey.model.mjs +2 -0
- package/esm2022/lib/shared/pipes/complex/ccd-page-fields.pipe.mjs +2 -2
- package/esm2022/lib/shared/services/index.mjs +2 -1
- package/esm2022/lib/shared/services/journey/index.mjs +2 -0
- package/esm2022/lib/shared/services/journey/multipage-component-state.service.mjs +117 -0
- package/fesm2022/hmcts-ccd-case-ui-toolkit.mjs +1873 -784
- package/fesm2022/hmcts-ccd-case-ui-toolkit.mjs.map +1 -1
- package/lib/shared/components/case-editor/case-edit-page/case-edit-page.component.d.ts +19 -3
- package/lib/shared/components/case-editor/case-edit-page/case-edit-page.component.d.ts.map +1 -1
- package/lib/shared/components/case-editor/case-edit-submit/case-edit-submit.component.d.ts +11 -2
- package/lib/shared/components/case-editor/case-edit-submit/case-edit-submit.component.d.ts.map +1 -1
- package/lib/shared/components/case-editor/case-editor.module.d.ts.map +1 -1
- package/lib/shared/components/case-editor/services/case-flag-state.service.d.ts +3 -0
- package/lib/shared/components/case-editor/services/case-flag-state.service.d.ts.map +1 -1
- package/lib/shared/components/case-viewer/case-event-trigger/case-event-trigger.component.d.ts +2 -1
- package/lib/shared/components/case-viewer/case-event-trigger/case-event-trigger.component.d.ts.map +1 -1
- package/lib/shared/components/case-viewer/case-full-access-view/case-full-access-view.component.d.ts +5 -1
- package/lib/shared/components/case-viewer/case-full-access-view/case-full-access-view.component.d.ts.map +1 -1
- package/lib/shared/components/palette/base-field/abstract-field-write-journey.component.d.ts +30 -0
- package/lib/shared/components/palette/base-field/abstract-field-write-journey.component.d.ts.map +1 -0
- package/lib/shared/components/palette/base-field/abstract-journey.component.d.ts +27 -0
- package/lib/shared/components/palette/base-field/abstract-journey.component.d.ts.map +1 -0
- package/lib/shared/components/palette/base-field/index.d.ts +2 -0
- package/lib/shared/components/palette/base-field/index.d.ts.map +1 -1
- package/lib/shared/components/palette/case-flag/components/add-comments/add-comments.component.d.ts +4 -2
- package/lib/shared/components/palette/case-flag/components/add-comments/add-comments.component.d.ts.map +1 -1
- package/lib/shared/components/palette/case-flag/components/confirm-flag-status/confirm-flag-status.component.d.ts +4 -2
- package/lib/shared/components/palette/case-flag/components/confirm-flag-status/confirm-flag-status.component.d.ts.map +1 -1
- package/lib/shared/components/palette/case-flag/components/manage-case-flags/manage-case-flags.component.d.ts +16 -4
- package/lib/shared/components/palette/case-flag/components/manage-case-flags/manage-case-flags.component.d.ts.map +1 -1
- package/lib/shared/components/palette/case-flag/components/search-language-interpreter/search-language-interpreter.component.d.ts +6 -3
- package/lib/shared/components/palette/case-flag/components/search-language-interpreter/search-language-interpreter.component.d.ts.map +1 -1
- package/lib/shared/components/palette/case-flag/components/select-flag-location/select-flag-location.component.d.ts +5 -2
- package/lib/shared/components/palette/case-flag/components/select-flag-location/select-flag-location.component.d.ts.map +1 -1
- package/lib/shared/components/palette/case-flag/components/select-flag-type/select-flag-type.component.d.ts +21 -6
- package/lib/shared/components/palette/case-flag/components/select-flag-type/select-flag-type.component.d.ts.map +1 -1
- package/lib/shared/components/palette/case-flag/components/update-flag/update-flag-add-translation-form/update-flag-add-translation-form.component.d.ts +5 -2
- package/lib/shared/components/palette/case-flag/components/update-flag/update-flag-add-translation-form/update-flag-add-translation-form.component.d.ts.map +1 -1
- package/lib/shared/components/palette/case-flag/components/update-flag/update-flag.component.d.ts +7 -3
- package/lib/shared/components/palette/case-flag/components/update-flag/update-flag.component.d.ts.map +1 -1
- package/lib/shared/components/palette/case-flag/read-case-flag-field.component.d.ts +1 -0
- package/lib/shared/components/palette/case-flag/read-case-flag-field.component.d.ts.map +1 -1
- package/lib/shared/components/palette/case-flag/write-case-flag-field.component.d.ts +18 -6
- package/lib/shared/components/palette/case-flag/write-case-flag-field.component.d.ts.map +1 -1
- package/lib/shared/components/palette/linked-cases/components/before-you-start/before-you-start.component.d.ts +6 -4
- package/lib/shared/components/palette/linked-cases/components/before-you-start/before-you-start.component.d.ts.map +1 -1
- package/lib/shared/components/palette/linked-cases/components/check-your-answers/check-your-answers.component.d.ts +8 -3
- package/lib/shared/components/palette/linked-cases/components/check-your-answers/check-your-answers.component.d.ts.map +1 -1
- package/lib/shared/components/palette/linked-cases/components/link-cases/link-cases.component.d.ts +8 -3
- package/lib/shared/components/palette/linked-cases/components/link-cases/link-cases.component.d.ts.map +1 -1
- package/lib/shared/components/palette/linked-cases/components/no-linked-cases/no-linked-cases.component.d.ts +5 -2
- package/lib/shared/components/palette/linked-cases/components/no-linked-cases/no-linked-cases.component.d.ts.map +1 -1
- package/lib/shared/components/palette/linked-cases/components/unlink-cases/unlink-cases.component.d.ts +9 -3
- package/lib/shared/components/palette/linked-cases/components/unlink-cases/unlink-cases.component.d.ts.map +1 -1
- package/lib/shared/components/palette/linked-cases/services/linked-cases.service.d.ts +8 -0
- package/lib/shared/components/palette/linked-cases/services/linked-cases.service.d.ts.map +1 -1
- package/lib/shared/components/palette/linked-cases/write-linked-cases-field.component.d.ts +10 -3
- package/lib/shared/components/palette/linked-cases/write-linked-cases-field.component.d.ts.map +1 -1
- package/lib/shared/components/palette/query-management/components/query-check-your-answers/query-check-your-answers.component.d.ts +3 -2
- package/lib/shared/components/palette/query-management/components/query-check-your-answers/query-check-your-answers.component.d.ts.map +1 -1
- package/lib/shared/domain/index.d.ts +1 -0
- package/lib/shared/domain/index.d.ts.map +1 -1
- package/lib/shared/domain/journey/index.d.ts +3 -0
- package/lib/shared/domain/journey/index.d.ts.map +1 -0
- package/lib/shared/domain/journey/journey-instigator.model.d.ts +5 -0
- package/lib/shared/domain/journey/journey-instigator.model.d.ts.map +1 -0
- package/lib/shared/domain/journey/journey.model.d.ts +19 -0
- package/lib/shared/domain/journey/journey.model.d.ts.map +1 -0
- package/lib/shared/services/index.d.ts +1 -0
- package/lib/shared/services/index.d.ts.map +1 -1
- package/lib/shared/services/journey/index.d.ts +2 -0
- package/lib/shared/services/journey/index.d.ts.map +1 -0
- package/lib/shared/services/journey/multipage-component-state.service.d.ts +26 -0
- package/lib/shared/services/journey/multipage-component-state.service.d.ts.map +1 -0
- package/package.json +1 -1
|
@@ -2,9 +2,10 @@ import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
|
2
2
|
import { FormControl, FormGroup } from '@angular/forms';
|
|
3
3
|
import { catchError, switchMap } from 'rxjs/operators';
|
|
4
4
|
import { FlagType } from '../../../../../domain/case-flag';
|
|
5
|
-
import { CaseFlagRefdataService } from '../../../../../services';
|
|
5
|
+
import { CaseFlagRefdataService, MultipageComponentStateService } from '../../../../../services';
|
|
6
6
|
import { RefdataCaseFlagType } from '../../../../../services/case-flag/refdata-case-flag-type.enum';
|
|
7
7
|
import { CaseFlagFieldState, CaseFlagFormFields, CaseFlagWizardStepTitle, SelectFlagTypeErrorMessage } from '../../enums';
|
|
8
|
+
import { AbstractJourneyComponent } from '../../../base-field/abstract-journey.component';
|
|
8
9
|
import { SearchLanguageInterpreterControlNames } from '../search-language-interpreter/search-language-interpreter-control-names.enum';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
import * as i1 from "../../../../../services";
|
|
@@ -29,7 +30,7 @@ function SelectFlagTypeComponent_ng_container_0_ng_template_6_Template(rf, ctx)
|
|
|
29
30
|
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind2(1, 1, ctx_r0.cachedFlagType, "name"), " ");
|
|
30
31
|
} }
|
|
31
32
|
function SelectFlagTypeComponent_ng_container_0_div_8_Template(rf, ctx) { if (rf & 1) {
|
|
32
|
-
i0.ɵɵelementStart(0, "div",
|
|
33
|
+
i0.ɵɵelementStart(0, "div", 12)(1, "span", 13);
|
|
33
34
|
i0.ɵɵtext(2);
|
|
34
35
|
i0.ɵɵpipe(3, "rpxTranslate");
|
|
35
36
|
i0.ɵɵelementEnd();
|
|
@@ -44,9 +45,9 @@ function SelectFlagTypeComponent_ng_container_0_div_8_Template(rf, ctx) { if (rf
|
|
|
44
45
|
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(5, 4, ctx_r0.flagTypeNotSelectedErrorMessage), " ");
|
|
45
46
|
} }
|
|
46
47
|
function SelectFlagTypeComponent_ng_container_0_div_10_Template(rf, ctx) { if (rf & 1) {
|
|
47
|
-
i0.ɵɵelementStart(0, "div",
|
|
48
|
-
i0.ɵɵelement(1, "input",
|
|
49
|
-
i0.ɵɵelementStart(2, "label",
|
|
48
|
+
i0.ɵɵelementStart(0, "div", 14);
|
|
49
|
+
i0.ɵɵelement(1, "input", 15);
|
|
50
|
+
i0.ɵɵelementStart(2, "label", 16);
|
|
50
51
|
i0.ɵɵtext(3);
|
|
51
52
|
i0.ɵɵpipe(4, "flagFieldDisplay");
|
|
52
53
|
i0.ɵɵelementEnd()();
|
|
@@ -63,7 +64,7 @@ function SelectFlagTypeComponent_ng_container_0_div_10_Template(rf, ctx) { if (r
|
|
|
63
64
|
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind2(4, 8, flagType_r2, "name"), " ");
|
|
64
65
|
} }
|
|
65
66
|
function SelectFlagTypeComponent_ng_container_0_div_11_div_6_Template(rf, ctx) { if (rf & 1) {
|
|
66
|
-
i0.ɵɵelementStart(0, "div",
|
|
67
|
+
i0.ɵɵelementStart(0, "div", 22)(1, "span", 13);
|
|
67
68
|
i0.ɵɵtext(2);
|
|
68
69
|
i0.ɵɵpipe(3, "rpxTranslate");
|
|
69
70
|
i0.ɵɵelementEnd();
|
|
@@ -78,9 +79,9 @@ function SelectFlagTypeComponent_ng_container_0_div_11_div_6_Template(rf, ctx) {
|
|
|
78
79
|
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(5, 4, ctx_r0.flagTypeErrorMessage), " ");
|
|
79
80
|
} }
|
|
80
81
|
function SelectFlagTypeComponent_ng_container_0_div_11_div_8_Template(rf, ctx) { if (rf & 1) {
|
|
81
|
-
i0.ɵɵelementStart(0, "div",
|
|
82
|
-
i0.ɵɵelement(1, "input",
|
|
83
|
-
i0.ɵɵelementStart(2, "label",
|
|
82
|
+
i0.ɵɵelementStart(0, "div", 23);
|
|
83
|
+
i0.ɵɵelement(1, "input", 24);
|
|
84
|
+
i0.ɵɵelementStart(2, "label", 25);
|
|
84
85
|
i0.ɵɵtext(3);
|
|
85
86
|
i0.ɵɵpipe(4, "rpxTranslate");
|
|
86
87
|
i0.ɵɵelementEnd()();
|
|
@@ -92,14 +93,14 @@ function SelectFlagTypeComponent_ng_container_0_div_11_div_8_Template(rf, ctx) {
|
|
|
92
93
|
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(4, 3, "This flag should only be visible to HMCTS Staff"), " ");
|
|
93
94
|
} }
|
|
94
95
|
function SelectFlagTypeComponent_ng_container_0_div_11_Template(rf, ctx) { if (rf & 1) {
|
|
95
|
-
i0.ɵɵelementStart(0, "div",
|
|
96
|
+
i0.ɵɵelementStart(0, "div", 17)(1, "div", 3)(2, "label", 18);
|
|
96
97
|
i0.ɵɵtext(3);
|
|
97
98
|
i0.ɵɵpipe(4, "rpxTranslate");
|
|
98
99
|
i0.ɵɵpipe(5, "rpxTranslate");
|
|
99
100
|
i0.ɵɵelementEnd();
|
|
100
|
-
i0.ɵɵtemplate(6, SelectFlagTypeComponent_ng_container_0_div_11_div_6_Template, 6, 6, "div",
|
|
101
|
-
i0.ɵɵelement(7, "input",
|
|
102
|
-
i0.ɵɵtemplate(8, SelectFlagTypeComponent_ng_container_0_div_11_div_8_Template, 5, 5, "div",
|
|
101
|
+
i0.ɵɵtemplate(6, SelectFlagTypeComponent_ng_container_0_div_11_div_6_Template, 6, 6, "div", 19);
|
|
102
|
+
i0.ɵɵelement(7, "input", 20);
|
|
103
|
+
i0.ɵɵtemplate(8, SelectFlagTypeComponent_ng_container_0_div_11_div_8_Template, 5, 5, "div", 21);
|
|
103
104
|
i0.ɵɵelementEnd()();
|
|
104
105
|
} if (rf & 2) {
|
|
105
106
|
const ctx_r0 = i0.ɵɵnextContext(2);
|
|
@@ -115,13 +116,13 @@ function SelectFlagTypeComponent_ng_container_0_div_11_Template(rf, ctx) { if (r
|
|
|
115
116
|
i0.ɵɵproperty("ngIf", !ctx_r0.isDisplayContextParameterExternal && !ctx_r0.isCaseLevelFlag && ctx_r0.isDisplayContextParameter2Point1Enabled);
|
|
116
117
|
} }
|
|
117
118
|
function SelectFlagTypeComponent_ng_container_0_Template(rf, ctx) { if (rf & 1) {
|
|
118
|
-
i0.ɵɵelementContainerStart(0,
|
|
119
|
-
i0.ɵɵelementStart(1, "div",
|
|
120
|
-
i0.ɵɵtemplate(5, SelectFlagTypeComponent_ng_container_0_ng_container_5_Template, 4, 5, "ng-container",
|
|
119
|
+
i0.ɵɵelementContainerStart(0, 2);
|
|
120
|
+
i0.ɵɵelementStart(1, "div", 3)(2, "fieldset", 4)(3, "legend", 5)(4, "h1", 6);
|
|
121
|
+
i0.ɵɵtemplate(5, SelectFlagTypeComponent_ng_container_0_ng_container_5_Template, 4, 5, "ng-container", 7)(6, SelectFlagTypeComponent_ng_container_0_ng_template_6_Template, 2, 4, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
|
|
121
122
|
i0.ɵɵelementEnd()();
|
|
122
|
-
i0.ɵɵtemplate(8, SelectFlagTypeComponent_ng_container_0_div_8_Template, 6, 6, "div",
|
|
123
|
-
i0.ɵɵelementStart(9, "div",
|
|
124
|
-
i0.ɵɵtemplate(10, SelectFlagTypeComponent_ng_container_0_div_10_Template, 5, 11, "div",
|
|
123
|
+
i0.ɵɵtemplate(8, SelectFlagTypeComponent_ng_container_0_div_8_Template, 6, 6, "div", 8);
|
|
124
|
+
i0.ɵɵelementStart(9, "div", 9);
|
|
125
|
+
i0.ɵɵtemplate(10, SelectFlagTypeComponent_ng_container_0_div_10_Template, 5, 11, "div", 10)(11, SelectFlagTypeComponent_ng_container_0_div_11_Template, 9, 15, "div", 11);
|
|
125
126
|
i0.ɵɵelementEnd()()();
|
|
126
127
|
i0.ɵɵelementContainerEnd();
|
|
127
128
|
} if (rf & 2) {
|
|
@@ -131,7 +132,7 @@ function SelectFlagTypeComponent_ng_container_0_Template(rf, ctx) { if (rf & 1)
|
|
|
131
132
|
i0.ɵɵadvance();
|
|
132
133
|
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(8, _c0, ctx_r0.flagTypeNotSelectedErrorMessage.length > 0));
|
|
133
134
|
i0.ɵɵadvance(4);
|
|
134
|
-
i0.ɵɵproperty("ngIf", !ctx_r0.cachedFlagType)("ngIfElse", priorFlagTypeSelected_r4);
|
|
135
|
+
i0.ɵɵproperty("ngIf", !ctx_r0.cachedFlagType || ctx_r0.subJourneyIndex == 0)("ngIfElse", priorFlagTypeSelected_r4);
|
|
135
136
|
i0.ɵɵadvance(3);
|
|
136
137
|
i0.ɵɵproperty("ngIf", ctx_r0.flagTypeNotSelectedErrorMessage.length > 0);
|
|
137
138
|
i0.ɵɵadvance(2);
|
|
@@ -139,18 +140,7 @@ function SelectFlagTypeComponent_ng_container_0_Template(rf, ctx) { if (rf & 1)
|
|
|
139
140
|
i0.ɵɵadvance();
|
|
140
141
|
i0.ɵɵproperty("ngIf", ctx_r0.otherFlagTypeSelected);
|
|
141
142
|
} }
|
|
142
|
-
|
|
143
|
-
const _r5 = i0.ɵɵgetCurrentView();
|
|
144
|
-
i0.ɵɵelementStart(0, "div", 27)(1, "button", 28);
|
|
145
|
-
i0.ɵɵlistener("click", function SelectFlagTypeComponent_div_1_Template_button_click_1_listener() { i0.ɵɵrestoreView(_r5); const ctx_r0 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r0.onNext()); });
|
|
146
|
-
i0.ɵɵtext(2);
|
|
147
|
-
i0.ɵɵpipe(3, "rpxTranslate");
|
|
148
|
-
i0.ɵɵelementEnd()();
|
|
149
|
-
} if (rf & 2) {
|
|
150
|
-
i0.ɵɵadvance(2);
|
|
151
|
-
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 1, "Next"));
|
|
152
|
-
} }
|
|
153
|
-
export class SelectFlagTypeComponent {
|
|
143
|
+
export class SelectFlagTypeComponent extends AbstractJourneyComponent {
|
|
154
144
|
caseFlagRefdataService;
|
|
155
145
|
formGroup;
|
|
156
146
|
jurisdiction;
|
|
@@ -161,6 +151,7 @@ export class SelectFlagTypeComponent {
|
|
|
161
151
|
selectedFlagsLocation;
|
|
162
152
|
caseFlagStateEmitter = new EventEmitter();
|
|
163
153
|
flagCommentsOptionalEmitter = new EventEmitter();
|
|
154
|
+
flagTypeSubJourneyEmitter = new EventEmitter();
|
|
164
155
|
flagTypes;
|
|
165
156
|
errorMessages;
|
|
166
157
|
flagTypeNotSelectedErrorMessage = '';
|
|
@@ -172,6 +163,8 @@ export class SelectFlagTypeComponent {
|
|
|
172
163
|
flagTypeControlChangesSubscription;
|
|
173
164
|
caseFlagFormField = CaseFlagFormFields;
|
|
174
165
|
isCaseLevelFlag = false;
|
|
166
|
+
cachedRDFlagTypes;
|
|
167
|
+
subJourneyIndex = 0;
|
|
175
168
|
maxCharactersForOtherFlagType = 80;
|
|
176
169
|
// Code for "Other" flag type as defined in Reference Data
|
|
177
170
|
otherFlagTypeCode = 'OT0001';
|
|
@@ -179,17 +172,21 @@ export class SelectFlagTypeComponent {
|
|
|
179
172
|
get caseFlagWizardStepTitle() {
|
|
180
173
|
return CaseFlagWizardStepTitle;
|
|
181
174
|
}
|
|
175
|
+
constructor(caseFlagRefdataService, pageStateService) {
|
|
176
|
+
super(pageStateService);
|
|
177
|
+
this.caseFlagRefdataService = caseFlagRefdataService;
|
|
178
|
+
this.handleBackButtonSubJourney = this.handleBackButtonSubJourney.bind(this);
|
|
179
|
+
}
|
|
182
180
|
get selectedFlagType() {
|
|
183
181
|
return this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.value;
|
|
184
182
|
}
|
|
185
183
|
get otherFlagTypeSelected() {
|
|
186
184
|
return this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.value?.flagCode === this.otherFlagTypeCode;
|
|
187
185
|
}
|
|
188
|
-
constructor(caseFlagRefdataService) {
|
|
189
|
-
this.caseFlagRefdataService = caseFlagRefdataService;
|
|
190
|
-
}
|
|
191
186
|
ngOnInit() {
|
|
192
187
|
this.isCaseLevelFlag = this.selectedFlagsLocation?.flags?.flagsCaseFieldId === this.caseLevelCaseFlagsFieldId;
|
|
188
|
+
this.flagTypeSubJourneyEmitter.emit(this.subJourneyIndex);
|
|
189
|
+
this.addState(this.subJourneyIndex);
|
|
193
190
|
this.flagTypes = [];
|
|
194
191
|
const flagType = this.isCaseLevelFlag ? RefdataCaseFlagType.CASE : RefdataCaseFlagType.PARTY;
|
|
195
192
|
this.formGroup.addControl(CaseFlagFormFields.FLAG_TYPE, new FormControl(''));
|
|
@@ -198,7 +195,7 @@ export class SelectFlagTypeComponent {
|
|
|
198
195
|
this.formGroup.addControl(CaseFlagFormFields.IS_VISIBLE_INTERNALLY_ONLY, new FormControl(false));
|
|
199
196
|
// Should clear descriptionControlName if flagTypeControlName is changed
|
|
200
197
|
this.flagTypeControlChangesSubscription = this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.valueChanges
|
|
201
|
-
.subscribe(_ => {
|
|
198
|
+
.subscribe((_) => {
|
|
202
199
|
this.formGroup.get(CaseFlagFormFields.OTHER_FLAG_DESCRIPTION)?.setValue('');
|
|
203
200
|
this.cachedPath = [];
|
|
204
201
|
// required to clear language interpreter
|
|
@@ -212,8 +209,8 @@ export class SelectFlagTypeComponent {
|
|
|
212
209
|
this.flagRefdata$ = this.caseFlagRefdataService
|
|
213
210
|
.getCaseFlagsRefdata(this.hmctsServiceId, flagType, true, this.isDisplayContextParameterExternal)
|
|
214
211
|
.subscribe({
|
|
215
|
-
next: flagTypes => this.processFlagTypes(flagTypes),
|
|
216
|
-
error: error => this.onRefdataError(error)
|
|
212
|
+
next: (flagTypes) => this.processFlagTypes(flagTypes),
|
|
213
|
+
error: (error) => this.onRefdataError(error)
|
|
217
214
|
});
|
|
218
215
|
}
|
|
219
216
|
else {
|
|
@@ -221,43 +218,122 @@ export class SelectFlagTypeComponent {
|
|
|
221
218
|
this.flagRefdata$ = this.caseFlagRefdataService.getHmctsServiceDetailsByCaseType(this.caseTypeId)
|
|
222
219
|
.pipe(
|
|
223
220
|
// If an error occurs retrieving HMCTS service details by case type ID, try by service name instead
|
|
224
|
-
catchError(_ => this.caseFlagRefdataService.getHmctsServiceDetailsByServiceName(this.jurisdiction)),
|
|
221
|
+
catchError((_) => this.caseFlagRefdataService.getHmctsServiceDetailsByServiceName(this.jurisdiction)),
|
|
225
222
|
// Use switchMap to return an inner Observable of the flag types data, having received the service details
|
|
226
223
|
// including service_code. This avoids having nested `subscribe`s, which is an anti-pattern!
|
|
227
|
-
switchMap(serviceDetails => this.caseFlagRefdataService.getCaseFlagsRefdata(serviceDetails[0].service_code, flagType, true, this.isDisplayContextParameterExternal)))
|
|
224
|
+
switchMap((serviceDetails) => this.caseFlagRefdataService.getCaseFlagsRefdata(serviceDetails[0].service_code, flagType, true, this.isDisplayContextParameterExternal)))
|
|
228
225
|
.subscribe({
|
|
229
|
-
next: flagTypes => this.processFlagTypes(flagTypes),
|
|
230
|
-
error: error => this.onRefdataError(error)
|
|
226
|
+
next: (flagTypes) => this.processFlagTypes(flagTypes),
|
|
227
|
+
error: (error) => this.onRefdataError(error)
|
|
231
228
|
});
|
|
232
229
|
}
|
|
230
|
+
this.addState(this.subJourneyIndex);
|
|
231
|
+
window.addEventListener('popstate', this.handleBackButtonSubJourney);
|
|
232
|
+
}
|
|
233
|
+
handleBackButtonSubJourney(event) {
|
|
234
|
+
event.preventDefault();
|
|
235
|
+
this.previous();
|
|
236
|
+
}
|
|
237
|
+
addState(data, url) {
|
|
238
|
+
history.pushState('1' + data, '', url);
|
|
233
239
|
}
|
|
234
240
|
ngOnDestroy() {
|
|
235
241
|
this.flagRefdata$?.unsubscribe();
|
|
236
242
|
this.flagTypeControlChangesSubscription?.unsubscribe();
|
|
243
|
+
// check if the user has an existing path when navigating away from the page
|
|
244
|
+
// if so we may need to ensure the values are set correctly.
|
|
245
|
+
this.checkForExistingPath();
|
|
246
|
+
window.removeEventListener('popstate', this.handleBackButtonSubJourney);
|
|
247
|
+
}
|
|
248
|
+
checkForExistingPath() {
|
|
249
|
+
// Restore values from cachedPath
|
|
250
|
+
if (this.subJourneyIndex <= 0) {
|
|
251
|
+
// check if the user is navigating to the previous page in the jounrey.
|
|
252
|
+
// in this situation we need to restore the full path for data retention across pages.
|
|
253
|
+
if (this.cachedPath && this.cachedPath.length > 0) {
|
|
254
|
+
this.cachedPath.forEach((flagType) => {
|
|
255
|
+
if (flagType) {
|
|
256
|
+
this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.setValue(flagType, { emitEvent: false });
|
|
257
|
+
}
|
|
258
|
+
});
|
|
259
|
+
}
|
|
260
|
+
}
|
|
237
261
|
}
|
|
238
262
|
onNext() {
|
|
239
|
-
// Validate form
|
|
240
263
|
this.validateForm();
|
|
241
|
-
|
|
242
|
-
|
|
264
|
+
this.emitCaseFlagState();
|
|
265
|
+
this.emitFlagCommentsOptional();
|
|
266
|
+
this.handleFlagTypeSelection();
|
|
267
|
+
this.flagTypeSubJourneyEmitter.emit(this.subJourneyIndex);
|
|
268
|
+
this.addState(this.subJourneyIndex);
|
|
269
|
+
}
|
|
270
|
+
emitCaseFlagState() {
|
|
243
271
|
this.caseFlagStateEmitter.emit({
|
|
244
272
|
currentCaseFlagFieldState: CaseFlagFieldState.FLAG_TYPE,
|
|
245
273
|
isParentFlagType: this.selectedFlagType ? this.selectedFlagType.isParent : null,
|
|
246
274
|
errorMessages: this.errorMessages
|
|
247
275
|
});
|
|
248
|
-
|
|
276
|
+
}
|
|
277
|
+
emitFlagCommentsOptional() {
|
|
249
278
|
if (this.selectedFlagType && !this.selectedFlagType.isParent && !this.selectedFlagType.flagComment) {
|
|
250
279
|
this.flagCommentsOptionalEmitter.emit(null);
|
|
251
280
|
}
|
|
252
|
-
|
|
281
|
+
}
|
|
282
|
+
handleFlagTypeSelection() {
|
|
253
283
|
if (this.selectedFlagType?.isParent) {
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
this.
|
|
284
|
+
this.loadChildFlagTypes();
|
|
285
|
+
}
|
|
286
|
+
else {
|
|
287
|
+
this.completeSubJourney();
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
loadChildFlagTypes() {
|
|
291
|
+
this.cachedFlagType = this.selectedFlagType;
|
|
292
|
+
this.flagTypes = this.selectedFlagType.childFlags;
|
|
293
|
+
if (this.cachedPath.length !== 0 && this.cachedPath[this.subJourneyIndex] === this.selectedFlagType) {
|
|
294
|
+
this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.setValue(this.cachedPath[this.subJourneyIndex + 1], { emitEvent: false });
|
|
295
|
+
}
|
|
296
|
+
else {
|
|
258
297
|
this.cachedPath?.shift();
|
|
259
|
-
this.
|
|
298
|
+
const value = this.cachedPath?.length ? this.cachedPath[0] : null;
|
|
299
|
+
this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.setValue(value, { emitEvent: false });
|
|
300
|
+
}
|
|
301
|
+
this.subJourneyIndex++;
|
|
302
|
+
}
|
|
303
|
+
completeSubJourney() {
|
|
304
|
+
const currentSelectedFlag = this.formGroup.controls.flagType;
|
|
305
|
+
const addedFlagValue = this.selectedFlagsLocation?.caseField?.value?.details;
|
|
306
|
+
if (addedFlagValue && (addedFlagValue[Object.keys(addedFlagValue).length]?.name !== currentSelectedFlag.value.name)) {
|
|
307
|
+
this.selectedFlagsLocation['caseField'].value.details.pop();
|
|
308
|
+
this.selectedFlagsLocation['caseField'].formatted_value?.details.pop();
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
// Simplified version of the onPrevious method with optimized code
|
|
312
|
+
onPrevious() {
|
|
313
|
+
if (this.cachedFlagType) {
|
|
314
|
+
if (this.cachedFlagType.Path?.length === 1) {
|
|
315
|
+
this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.setValue(this.cachedFlagType, { emitEvent: false });
|
|
316
|
+
this.flagTypes = this.cachedRDFlagTypes[0].childFlags;
|
|
317
|
+
}
|
|
318
|
+
else {
|
|
319
|
+
let currentPath = this.cachedRDFlagTypes[0];
|
|
320
|
+
const pathToSearch = this.cachedFlagType.Path.slice(1);
|
|
321
|
+
for (const pathElement of pathToSearch) {
|
|
322
|
+
const foundFlag = currentPath.childFlags.find((flag) => flag.name === pathElement);
|
|
323
|
+
if (foundFlag) {
|
|
324
|
+
currentPath = foundFlag;
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.setValue(this.cachedFlagType, { emitEvent: false });
|
|
328
|
+
this.flagTypes = currentPath.childFlags;
|
|
329
|
+
this.cachedFlagType = currentPath;
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
this.subJourneyIndex = Math.max(0, this.subJourneyIndex - 1);
|
|
333
|
+
if (this.subJourneyIndex === 0) {
|
|
334
|
+
this.flagTypes = this.flagTypes.filter((flag) => this.isDisplayContextParameterExternal ? flag.flagCode !== this.otherFlagTypeCode : true);
|
|
260
335
|
}
|
|
336
|
+
this.flagTypeSubJourneyEmitter.emit(this.subJourneyIndex);
|
|
261
337
|
}
|
|
262
338
|
// Identity function for trackBy use by *ngFor for flagTypes in HTML template
|
|
263
339
|
identifyFlagType(_, flagType) {
|
|
@@ -296,19 +372,36 @@ export class SelectFlagTypeComponent {
|
|
|
296
372
|
}
|
|
297
373
|
}
|
|
298
374
|
processFlagTypes(flagTypes) {
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
this.
|
|
375
|
+
const prevJourneyPage = this.multipageComponentStateService.getJourneyCollection()[0];
|
|
376
|
+
const { journeyPreviousPageNumber, journeyPageNumber } = prevJourneyPage;
|
|
377
|
+
this.cachedRDFlagTypes = flagTypes;
|
|
378
|
+
if (this.selectedFlagType && (journeyPreviousPageNumber > journeyPageNumber)) {
|
|
379
|
+
const selectedFlagType = this.selectedFlagType;
|
|
380
|
+
const pathToSearch = selectedFlagType.Path.slice(1);
|
|
381
|
+
let currentPath = flagTypes[0];
|
|
382
|
+
for (const pathElement of pathToSearch) {
|
|
383
|
+
const foundFlag = currentPath.childFlags.find((flag) => flag.name === pathElement);
|
|
384
|
+
if (foundFlag) {
|
|
385
|
+
currentPath = foundFlag;
|
|
386
|
+
}
|
|
387
|
+
}
|
|
388
|
+
this.flagTypes = currentPath.childFlags;
|
|
389
|
+
this.cachedFlagType = currentPath;
|
|
390
|
+
}
|
|
391
|
+
else {
|
|
392
|
+
this.flagTypes = flagTypes[0].childFlags.filter((flag) => this.isDisplayContextParameterExternal ? flag.flagCode !== this.otherFlagTypeCode : true);
|
|
393
|
+
}
|
|
302
394
|
const formControl = this.formGroup.get(CaseFlagFormFields.FLAG_TYPE);
|
|
303
395
|
if (formControl?.value) {
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
this.cachedPath
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
formControl.setValue(this.cachedPath[0], { emitEvent: false });
|
|
396
|
+
const [foundFlagType, path] = FlagType.searchPathByFlagTypeObject(formControl.value, this.cachedRDFlagTypes[0].childFlags);
|
|
397
|
+
this.cachedPath = [...path, foundFlagType];
|
|
398
|
+
formControl.setValue((this.selectedFlagType && (journeyPreviousPageNumber > journeyPageNumber)) ? this.cachedPath[this.cachedPath.length - 1] : this.cachedPath[0], { emitEvent: false });
|
|
399
|
+
if (this.cachedPath.length !== 0 && (journeyPreviousPageNumber > journeyPageNumber)) {
|
|
400
|
+
this.subJourneyIndex = this.cachedPath.length - 1;
|
|
401
|
+
}
|
|
311
402
|
}
|
|
403
|
+
this.flagTypeSubJourneyEmitter.emit(this.subJourneyIndex);
|
|
404
|
+
this.addState(this.subJourneyIndex);
|
|
312
405
|
}
|
|
313
406
|
onRefdataError(error) {
|
|
314
407
|
// Set error flag on component to remove the "Next" button (user cannot proceed with flag creation)
|
|
@@ -318,19 +411,30 @@ export class SelectFlagTypeComponent {
|
|
|
318
411
|
// Return case flag field state and error messages to the parent
|
|
319
412
|
this.caseFlagStateEmitter.emit({ currentCaseFlagFieldState: CaseFlagFieldState.FLAG_TYPE, errorMessages: this.errorMessages });
|
|
320
413
|
}
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
414
|
+
next() {
|
|
415
|
+
this.onNext();
|
|
416
|
+
this.addState(this.subJourneyIndex);
|
|
417
|
+
if (this.errorMessages.length === 0) {
|
|
418
|
+
super.next();
|
|
419
|
+
}
|
|
420
|
+
}
|
|
421
|
+
previous() {
|
|
422
|
+
this.onPrevious();
|
|
423
|
+
if (this.subJourneyIndex <= 0) {
|
|
424
|
+
super.previous();
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
static ɵfac = function SelectFlagTypeComponent_Factory(t) { return new (t || SelectFlagTypeComponent)(i0.ɵɵdirectiveInject(i1.CaseFlagRefdataService), i0.ɵɵdirectiveInject(i1.MultipageComponentStateService)); };
|
|
428
|
+
static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SelectFlagTypeComponent, selectors: [["ccd-select-flag-type"]], inputs: { formGroup: "formGroup", jurisdiction: "jurisdiction", caseTypeId: "caseTypeId", hmctsServiceId: "hmctsServiceId", isDisplayContextParameterExternal: "isDisplayContextParameterExternal", isDisplayContextParameter2Point1Enabled: "isDisplayContextParameter2Point1Enabled", selectedFlagsLocation: "selectedFlagsLocation" }, outputs: { caseFlagStateEmitter: "caseFlagStateEmitter", flagCommentsOptionalEmitter: "flagCommentsOptionalEmitter", flagTypeSubJourneyEmitter: "flagTypeSubJourneyEmitter" }, features: [i0.ɵɵInheritDefinitionFeature], decls: 1, vars: 1, consts: [["priorFlagTypeSelected", ""], [3, "formGroup", 4, "ngIf"], [3, "formGroup"], [1, "govuk-form-group", 3, "ngClass"], ["aria-describedby", "flag-type-heading", 1, "govuk-fieldset"], [1, "govuk-fieldset__legend", "govuk-fieldset__legend--m"], ["id", "flag-type-heading", 1, "govuk-fieldset__heading", "govuk-!-margin-bottom-1"], [4, "ngIf", "ngIfElse"], ["id", "flag-type-not-selected-error-message", "class", "govuk-error-message", 4, "ngIf"], ["data-module", "govuk-radios", "id", "conditional-radios-list", 1, "govuk-radios", "govuk-radios--conditional"], ["class", "govuk-radios__item", 4, "ngFor", "ngForOf", "ngForTrackBy"], ["class", "govuk-radios__conditional", "id", "conditional-flagType", 4, "ngIf"], ["id", "flag-type-not-selected-error-message", 1, "govuk-error-message"], [1, "govuk-visually-hidden"], [1, "govuk-radios__item"], ["type", "radio", 1, "govuk-radios__input", 3, "id", "name", "value", "formControlName"], [1, "govuk-label", "govuk-radios__label", 3, "for"], ["id", "conditional-flagType", 1, "govuk-radios__conditional"], ["for", "other-flag-type-description", 1, "govuk-label"], ["id", "flag-type-error-message", "class", "govuk-error-message", 4, "ngIf"], ["id", "other-flag-type-description", "type", "text", 1, "govuk-input", "govuk-!-width-one-half", 3, "ngClass", "name", "formControlName"], ["class", "govuk-checkboxes__item govuk-!-margin-top-4", 4, "ngIf"], ["id", "flag-type-error-message", 1, "govuk-error-message"], [1, "govuk-checkboxes__item", "govuk-!-margin-top-4"], ["id", "is-visible-externally", "type", "checkbox", 1, "govuk-checkboxes__input", 3, "name", "formControlName"], ["for", "is-visible-externally", 1, "govuk-label", "govuk-checkboxes__label"]], template: function SelectFlagTypeComponent_Template(rf, ctx) { if (rf & 1) {
|
|
429
|
+
i0.ɵɵtemplate(0, SelectFlagTypeComponent_ng_container_0_Template, 12, 10, "ng-container", 1);
|
|
324
430
|
} if (rf & 2) {
|
|
325
431
|
i0.ɵɵproperty("ngIf", ctx.flagTypes == null ? null : ctx.flagTypes.length);
|
|
326
|
-
i0.ɵɵadvance();
|
|
327
|
-
i0.ɵɵproperty("ngIf", !ctx.refdataError);
|
|
328
432
|
} }, styles: [".hidden[_ngcontent-%COMP%]{display:none}.validation-error[_ngcontent-%COMP%]{cursor:pointer;text-decoration:underline;color:#d4351c}"] });
|
|
329
433
|
}
|
|
330
434
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectFlagTypeComponent, [{
|
|
331
435
|
type: Component,
|
|
332
|
-
args: [{ selector: 'ccd-select-flag-type', template: "<ng-container *ngIf=\"flagTypes?.length\" [formGroup]=\"formGroup\">\n <div class=\"govuk-form-group\" [ngClass]=\"{'form-group-error': flagTypeNotSelectedErrorMessage.length > 0}\">\n <fieldset class=\"govuk-fieldset\" aria-describedby=\"flag-type-heading\">\n <legend class=\"govuk-fieldset__legend govuk-fieldset__legend--m\">\n <h1 id=\"flag-type-heading\" class=\"govuk-fieldset__heading govuk-!-margin-bottom-1\">\n <ng-container *ngIf=\"!cachedFlagType; else priorFlagTypeSelected\">\n {{\n
|
|
333
|
-
}], () => [{ type: i1.CaseFlagRefdataService }], { formGroup: [{
|
|
436
|
+
args: [{ selector: 'ccd-select-flag-type', template: "<ng-container *ngIf=\"flagTypes?.length\" [formGroup]=\"formGroup\">\n <div class=\"govuk-form-group\" [ngClass]=\"{'form-group-error': flagTypeNotSelectedErrorMessage.length > 0}\">\n <fieldset class=\"govuk-fieldset\" aria-describedby=\"flag-type-heading\">\n <legend class=\"govuk-fieldset__legend govuk-fieldset__legend--m\">\n <h1 id=\"flag-type-heading\" class=\"govuk-fieldset__heading govuk-!-margin-bottom-1\">\n <ng-container *ngIf=\"!cachedFlagType || subJourneyIndex == 0; else priorFlagTypeSelected\">\n {{\n isDisplayContextParameterExternal\n ? (caseFlagWizardStepTitle.SELECT_CASE_FLAG_EXTERNAL | rpxTranslate)\n : (caseFlagWizardStepTitle.SELECT_CASE_FLAG | rpxTranslate)\n }}\n </ng-container>\n <ng-template #priorFlagTypeSelected>\n {{cachedFlagType | flagFieldDisplay:'name'}}\n </ng-template>\n </h1>\n </legend>\n <div id=\"flag-type-not-selected-error-message\" class=\"govuk-error-message\"\n *ngIf=\"flagTypeNotSelectedErrorMessage.length > 0\">\n <span class=\"govuk-visually-hidden\">{{'Error:' | rpxTranslate}}</span> {{flagTypeNotSelectedErrorMessage |\n rpxTranslate}}\n </div>\n <div class=\"govuk-radios govuk-radios--conditional\" data-module=\"govuk-radios\" id=\"conditional-radios-list\">\n <div class=\"govuk-radios__item\" *ngFor=\"let flagType of flagTypes; index as i; trackBy: identifyFlagType\">\n <input class=\"govuk-radios__input\" id=\"flag-type-{{i}}\" [name]=\"caseFlagFormField.FLAG_TYPE\" type=\"radio\"\n [value]=\"flagType\" [formControlName]=\"caseFlagFormField.FLAG_TYPE\" />\n <label class=\"govuk-label govuk-radios__label\" for=\"flag-type-{{i}}\">\n {{flagType | flagFieldDisplay:'name'}}\n </label>\n </div>\n <div class=\"govuk-radios__conditional\" *ngIf=\"otherFlagTypeSelected\" id=\"conditional-flagType\">\n <div class=\"govuk-form-group\" [ngClass]=\"{'form-group-error': flagTypeErrorMessage.length > 0}\">\n <label class=\"govuk-label\" for=\"other-flag-type-description\">\n {{\n isDisplayContextParameterExternal\n ? (caseFlagWizardStepTitle.OTHER_FLAG_TYPE_DESCRIPTION_EXTERNAL | rpxTranslate)\n : (caseFlagWizardStepTitle.OTHER_FLAG_TYPE_DESCRIPTION | rpxTranslate)\n }}\n </label>\n <div id=\"flag-type-error-message\" class=\"govuk-error-message\" *ngIf=\"flagTypeErrorMessage.length > 0\">\n <span class=\"govuk-visually-hidden\">{{'Error:' | rpxTranslate}}</span> {{flagTypeErrorMessage |\n rpxTranslate}}\n </div>\n <input class=\"govuk-input govuk-!-width-one-half\"\n [ngClass]=\"{'govuk-input--error': flagTypeErrorMessage.length > 0}\" id=\"other-flag-type-description\"\n [name]=\"caseFlagFormField.OTHER_FLAG_DESCRIPTION\" type=\"text\"\n [formControlName]=\"caseFlagFormField.OTHER_FLAG_DESCRIPTION\" />\n <div class=\"govuk-checkboxes__item govuk-!-margin-top-4\"\n *ngIf=\"!isDisplayContextParameterExternal && !isCaseLevelFlag && isDisplayContextParameter2Point1Enabled\">\n <input class=\"govuk-checkboxes__input\" id=\"is-visible-externally\" type=\"checkbox\"\n [name]=\"caseFlagFormField.IS_VISIBLE_INTERNALLY_ONLY\"\n [formControlName]=\"caseFlagFormField.IS_VISIBLE_INTERNALLY_ONLY\">\n <label class=\"govuk-label govuk-checkboxes__label\" for=\"is-visible-externally\">\n {{'This flag should only be visible to HMCTS Staff' | rpxTranslate}}\n </label>\n </div>\n </div>\n </div>\n </div>\n </fieldset>\n </div>\n</ng-container>", styles: [".hidden{display:none}.validation-error{cursor:pointer;text-decoration:underline;color:#d4351c}\n"] }]
|
|
437
|
+
}], () => [{ type: i1.CaseFlagRefdataService }, { type: i1.MultipageComponentStateService }], { formGroup: [{
|
|
334
438
|
type: Input
|
|
335
439
|
}], jurisdiction: [{
|
|
336
440
|
type: Input
|
|
@@ -348,6 +452,8 @@ export class SelectFlagTypeComponent {
|
|
|
348
452
|
type: Output
|
|
349
453
|
}], flagCommentsOptionalEmitter: [{
|
|
350
454
|
type: Output
|
|
455
|
+
}], flagTypeSubJourneyEmitter: [{
|
|
456
|
+
type: Output
|
|
351
457
|
}] }); })();
|
|
352
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SelectFlagTypeComponent, { className: "SelectFlagTypeComponent", filePath: "lib/shared/components/palette/case-flag/components/select-flag-type/select-flag-type.component.ts", lineNumber:
|
|
353
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-flag-type.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/case-flag/components/select-flag-type/select-flag-type.component.ts","../../../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/case-flag/components/select-flag-type/select-flag-type.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAE,MAAM,eAAe,CAAC;AAC1F,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAExD,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEvD,OAAO,EAAE,QAAQ,EAAE,MAAM,iCAAiC,CAAC;AAC3D,OAAO,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,+DAA+D,CAAC;AAEpG,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,uBAAuB,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAC;AAC1H,OAAO,EAAE,qCAAqC,EAAE,MAAM,+EAA+E,CAAC;;;;;;ICL5H,6BAAkE;IAChE,YAKF;;;;;;IALE,cAKF;IALE,kOAKF;;;IAEE,YACF;;;;IADE,oFACF;;;IAKF,AAFF,+BACqD,eACf;IAAA,YAA2B;;IAAA,iBAAO;IAAC,YACzE;;IAAA,iBAAM;;;IADgC,eAA2B;IAA3B,oDAA2B;IAAQ,eACzE;IADyE,6FACzE;;;IAEE,+BAA0G;IACxG,4BAEmD;IACnD,iCAAqE;IACnE,YACF;;IACF,AADE,iBAAQ,EACJ;;;;;IAN+B,cAAoB;IAApB,uDAAoB;IAErD,AADa,AADyC,yDAAoC,sBAC3D,uDACgB;IACF,cAAqB;IAArB,wDAAqB;IAClE,cACF;IADE,0EACF;;;IAYI,AADF,+BAAsG,eAChE;IAAA,YAA2B;;IAAA,iBAAO;IAAC,YACzE;;IAAA,iBAAM;;;IADgC,eAA2B;IAA3B,oDAA2B;IAAQ,eACzE;IADyE,kFACzE;;;IAKA,+BAC4G;IAC1G,4BACyH;IACzH,iCAA+E;IAC7E,YACF;;IACF,AADE,iBAAQ,EACJ;;;IAJF,cAAqD;IAAC,AAAtD,0EAAqD,wEAAiE;IAEtH,eACF;IADE,wGACF;;;IApBF,AADF,AADF,+BAA+F,aACG,gBACjC;IAC3D,YAKF;;;IAAA,iBAAQ;IACR,+FAAsG;IAGtG,4BAGgE;IAChE,+FAC4G;IAQhH,AADE,iBAAM,EACF;;;IAxB0B,cAAiE;IAAjE,6FAAiE;IAE3F,eAKF;IALE,wPAKF;IAC+D,eAAqC;IAArC,6DAAqC;IAIlG,cAAmE;IAEnE,AADiC,AADjC,6FAAmE,yDACe,oEACtB;IAE3D,cAAuG;IAAvG,6IAAuG;;;IA/CtH,gCAAgE;IAIxD,AADF,AADF,AADF,8BAA2G,kBACnC,gBACH,YACoB;IAQjF,AAPA,yGAAkE,2HAO9B;IAIxC,AADE,iBAAK,EACE;IACT,uFACqD;IAGrD,+BAA4G;IAS1G,AARA,2FAA0G,8EAQX;IA4BrG,AADE,AADE,iBAAM,EACG,EACP;;;;;IA1DgC,4CAAuB;IAC/B,cAA4E;IAA5E,uGAA4E;IAInF,eAAuB;IAAA,AAAvB,6CAAuB,sCAA0B;IAajE,eAAgD;IAAhD,wEAAgD;IAII,eAAc;IAAY,AAA1B,0CAAc,yCAAqC;IAQhE,cAA2B;IAA3B,mDAA2B;;;;IAgCzE,AADF,+BAAsD,iBACmB;IAAnB,mLAAS,eAAQ,KAAC;IAAC,YAAyB;;IAClG,AADkG,iBAAS,EACrG;;IADmE,eAAyB;IAAzB,kDAAyB;;AD7ClG,MAAM,OAAO,uBAAuB;IAyDL;IAvDtB,SAAS,CAAY;IAGrB,YAAY,CAAS;IAGrB,UAAU,CAAS;IAGnB,cAAc,CAAS;IAGvB,iCAAiC,GAAG,KAAK,CAAC;IAG1C,uCAAuC,GAAG,KAAK,CAAC;IAGhD,qBAAqB,CAAyB;IAG9C,oBAAoB,GAAgC,IAAI,YAAY,EAAiB,CAAC;IAGtF,2BAA2B,GAAsB,IAAI,YAAY,EAAE,CAAC;IAEpE,SAAS,CAAa;IACtB,aAAa,CAAiB;IAC9B,+BAA+B,GAAG,EAAE,CAAC;IACrC,oBAAoB,GAAG,EAAE,CAAC;IAC1B,YAAY,CAAe;IAC3B,YAAY,GAAG,KAAK,CAAC;IACrB,UAAU,CAAuB;IACjC,cAAc,CAAW;IACzB,kCAAkC,CAAe;IACjD,iBAAiB,GAAG,kBAAkB,CAAC;IACvC,eAAe,GAAG,KAAK,CAAC;IAEd,6BAA6B,GAAG,EAAE,CAAC;IACpD,0DAA0D;IACzC,iBAAiB,GAAG,QAAQ,CAAC;IAC7B,yBAAyB,GAAG,WAAW,CAAC;IAEzD,IAAW,uBAAuB;QAChC,OAAO,uBAAuB,CAAC;IACjC,CAAC;IAED,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC,SAAS,CAAC,EAAE,KAAK,CAAC;IACjE,CAAC;IAED,IAAW,qBAAqB;QAC9B,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,QAAQ,KAAK,IAAI,CAAC,iBAAiB,CAAC;IACtG,CAAC;IAED,YAA6B,sBAA8C;QAA9C,2BAAsB,GAAtB,sBAAsB,CAAwB;IAAI,CAAC;IAEzE,QAAQ;QACb,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,qBAAqB,EAAE,KAAK,EAAE,gBAAgB,KAAK,IAAI,CAAC,yBAAyB,CAAC;QAC9G,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC,mBAAmB,CAAC,KAAK,CAAC;QAE7F,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,kBAAkB,CAAC,SAAS,EAAE,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;QAC7E,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,kBAAkB,CAAC,sBAAsB,EAAE,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1F,sFAAsF;QACtF,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,kBAAkB,CAAC,0BAA0B,EAAE,IAAI,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC;QAEjG,wEAAwE;QACxE,IAAI,CAAC,kCAAkC,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC,SAAS,CAAC,EAAE,YAAY;aACrG,SAAS,CAAC,CAAC,CAAC,EAAE;YACb,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC,sBAAsB,CAAC,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC;YAC5E,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;YAErB,yCAAyC;YACzC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;gBACxB,CAAC,qCAAqC,CAAC,oBAAoB,CAAC,EAAE,EAAE;gBAChE,CAAC,qCAAqC,CAAC,qBAAqB,CAAC,EAAE,EAAE;aAClE,CAAC,CAAC;QACL,CAAC,CACF,CAAC;QAEF,qFAAqF;QACrF,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,sBAAsB;iBAC5C,mBAAmB,CAAC,IAAI,CAAC,cAAc,EAAE,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,iCAAiC,CAAC;iBAChG,SAAS,CAAC;gBACT,IAAI,EAAE,SAAS,CAAC,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC;gBACnD,KAAK,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC;aAC3C,CAAC,CAAC;QACP,CAAC;aAAM,CAAC;YACN,+HAA+H;YAC/H,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,sBAAsB,CAAC,gCAAgC,CAAC,IAAI,CAAC,UAAU,CAAC;iBAC9F,IAAI;YACH,mGAAmG;YACnG,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,mCAAmC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACnG,0GAA0G;YAC1G,4FAA4F;YAC5F,SAAS,CAAC,cAAc,CAAC,EAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,mBAAmB,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,YAAY,EAAE,QAAQ,EAClH,IAAI,EAAE,IAAI,CAAC,iCAAiC,CAAC,CAAC,CACjD;iBACA,SAAS,CAAC;gBACT,IAAI,EAAE,SAAS,CAAC,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC;gBACnD,KAAK,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC;aAC3C,CAAC,CAAC;QACP,CAAC;IACH,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,YAAY,EAAE,WAAW,EAAE,CAAC;QACjC,IAAI,CAAC,kCAAkC,EAAE,WAAW,EAAE,CAAC;IACzD,CAAC;IAEM,MAAM;QACX,gBAAgB;QAChB,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,4GAA4G;QAC5G,iGAAiG;QACjG,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC;YAC7B,yBAAyB,EAAE,kBAAkB,CAAC,SAAS;YACvD,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI;YAC/E,aAAa,EAAE,IAAI,CAAC,aAAa;SAClC,CAAC,CAAC;QACH,6GAA6G;QAC7G,IAAI,IAAI,CAAC,gBAAgB,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC;YACnG,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9C,CAAC;QAED,2GAA2G;QAC3G,IAAI,IAAI,CAAC,gBAAgB,EAAE,QAAQ,EAAE,CAAC;YACpC,iHAAiH;YACjH,8CAA8C;YAC9C,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,gBAAgB,CAAC;YAC5C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC;YAClD,IAAI,CAAC,UAAU,EAAE,KAAK,EAAE,CAAC;YACzB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC,SAAS,CAAC,EAAE,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QACxI,CAAC;IACH,CAAC;IAED,6EAA6E;IACtE,gBAAgB,CAAC,CAAS,EAAE,QAAkB;QACnD,OAAO,GAAG,QAAQ,CAAC,QAAQ,IAAI,QAAQ,CAAC,IAAI,IAAI,QAAQ,CAAC,OAAO,EAAE,CAAC;IACrE,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,+BAA+B,GAAG,EAAE,CAAC;QAC1C,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QAExB,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC3B,yEAAyE;YACzE,IAAI,YAAY,GAAG,EAAE,CAAC;YACtB,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;gBACxB,YAAY,GAAG,0BAA0B,CAAC,6BAA6B,CAAC;YAC1E,CAAC;iBAAM,CAAC;gBACN,YAAY,GAAI,IAAI,CAAC,iCAAiC;oBACtD,CAAC,CAAC,0BAA0B,CAAC,+BAA+B;oBAC5D,CAAC,CAAC,0BAA0B,CAAC,sBAAsB,CAAC;YACtD,CAAC;YACD,IAAI,CAAC,+BAA+B,GAAG,YAAY,CAAC;YACpD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,YAAY,EAAE,OAAO,EAAE,yBAAyB,EAAE,CAAC,CAAC;QACxG,CAAC;QACD,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC/B,MAAM,wBAAwB,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC,sBAAsB,CAAC,EAAE,KAAK,CAAC;YACtG,IAAI,CAAC,wBAAwB,EAAE,CAAC;gBAC9B,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,iCAAiC;oBAChE,CAAC,CAAC,0BAA0B,CAAC,8BAA8B;oBAC3D,CAAC,CAAC,0BAA0B,CAAC,qBAAqB,CAAC;gBACrD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,oBAAoB,EAAE,EAAE,OAAO,EAAE,6BAA6B,EAAE,CAAC,CAAC;YAC9H,CAAC;YACD,IAAI,wBAAwB,CAAC,MAAM,GAAG,IAAI,CAAC,6BAA6B,EAAE,CAAC;gBACzE,IAAI,CAAC,oBAAoB,GAAG,0BAA0B,CAAC,wBAAwB,CAAC;gBAChF,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,GAAG,0BAA0B,CAAC,wBAAwB,EAAE,EAAE,OAAO,EAAE,6BAA6B,EAAE,CAAC,CAAC;YACxJ,CAAC;QACH,CAAC;IACH,CAAC;IAEO,gBAAgB,CAAC,SAAqB;QAC5C,0FAA0F;QAC1F,qFAAqF;QACrF,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CACvD,IAAI,CAAC,iCAAiC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAE5F,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QACrE,IAAI,WAAW,EAAE,KAAK,EAAE,CAAC;YACvB,qEAAqE;YACrE,MAAM,CAAC,aAAa,EAAE,IAAI,CAAC,GAAG,QAAQ,CAAC,0BAA0B,CAAC,WAAW,CAAC,KAAiB,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;YACjH,IAAI,CAAC,UAAU,GAAG;gBAChB,GAAG,IAAI;gBACP,aAAa;aACd,CAAC;YACF,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QACjE,CAAC;IACH,CAAC;IAEO,cAAc,CAAC,KAAU;QAC/B,mGAAmG;QACnG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QACxB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,yBAAyB,EAAE,CAAC,CAAC;QACvG,gEAAgE;QAChE,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,yBAAyB,EAAE,kBAAkB,CAAC,SAAS,EAAE,aAAa,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;IACjI,CAAC;iFA3MU,uBAAuB;6DAAvB,uBAAuB;YC4CpC,AA7DA,4FAAgE,2DA6DV;;YA7DvC,0EAAuB;YA6DL,cAAmB;YAAnB,wCAAmB;;;iFD5CvC,uBAAuB;cALnC,SAAS;2BACE,sBAAsB;uDAMzB,SAAS;kBADf,KAAK;YAIC,YAAY;kBADlB,KAAK;YAIC,UAAU;kBADhB,KAAK;YAIC,cAAc;kBADpB,KAAK;YAIC,iCAAiC;kBADvC,KAAK;YAIC,uCAAuC;kBAD7C,KAAK;YAIC,qBAAqB;kBAD3B,KAAK;YAIC,oBAAoB;kBAD1B,MAAM;YAIA,2BAA2B;kBADjC,MAAM;;kFAzBI,uBAAuB","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { catchError, switchMap } from 'rxjs/operators';\nimport { ErrorMessage } from '../../../../../domain';\nimport { FlagType } from '../../../../../domain/case-flag';\nimport { CaseFlagRefdataService } from '../../../../../services';\nimport { RefdataCaseFlagType } from '../../../../../services/case-flag/refdata-case-flag-type.enum';\nimport { CaseFlagState, FlagsWithFormGroupPath } from '../../domain';\nimport { CaseFlagFieldState, CaseFlagFormFields, CaseFlagWizardStepTitle, SelectFlagTypeErrorMessage } from '../../enums';\nimport { SearchLanguageInterpreterControlNames } from '../search-language-interpreter/search-language-interpreter-control-names.enum';\n\n@Component({\n  selector: 'ccd-select-flag-type',\n  templateUrl: './select-flag-type.component.html',\n  styleUrls: ['./select-flag-type.component.scss']\n})\nexport class SelectFlagTypeComponent implements OnInit, OnDestroy {\n  @Input()\n  public formGroup: FormGroup;\n\n  @Input()\n  public jurisdiction: string;\n\n  @Input()\n  public caseTypeId: string;\n\n  @Input()\n  public hmctsServiceId: string;\n\n  @Input()\n  public isDisplayContextParameterExternal = false;\n\n  @Input()\n  public isDisplayContextParameter2Point1Enabled = false;\n\n  @Input()\n  public selectedFlagsLocation: FlagsWithFormGroupPath;\n\n  @Output()\n  public caseFlagStateEmitter: EventEmitter<CaseFlagState> = new EventEmitter<CaseFlagState>();\n\n  @Output()\n  public flagCommentsOptionalEmitter: EventEmitter<any> = new EventEmitter();\n\n  public flagTypes: FlagType[];\n  public errorMessages: ErrorMessage[];\n  public flagTypeNotSelectedErrorMessage = '';\n  public flagTypeErrorMessage = '';\n  public flagRefdata$: Subscription;\n  public refdataError = false;\n  public cachedPath: (FlagType | false)[];\n  public cachedFlagType: FlagType;\n  public flagTypeControlChangesSubscription: Subscription;\n  public caseFlagFormField = CaseFlagFormFields;\n  public isCaseLevelFlag = false;\n\n  private readonly maxCharactersForOtherFlagType = 80;\n  // Code for \"Other\" flag type as defined in Reference Data\n  private readonly otherFlagTypeCode = 'OT0001';\n  private readonly caseLevelCaseFlagsFieldId = 'caseFlags';\n\n  public get caseFlagWizardStepTitle(): typeof CaseFlagWizardStepTitle {\n    return CaseFlagWizardStepTitle;\n  }\n\n  public get selectedFlagType(): FlagType | null {\n    return this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.value;\n  }\n\n  public get otherFlagTypeSelected(): boolean {\n    return this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.value?.flagCode === this.otherFlagTypeCode;\n  }\n\n  constructor(private readonly caseFlagRefdataService: CaseFlagRefdataService) { }\n\n  public ngOnInit(): void {\n    this.isCaseLevelFlag = this.selectedFlagsLocation?.flags?.flagsCaseFieldId === this.caseLevelCaseFlagsFieldId;\n    this.flagTypes = [];\n    const flagType = this.isCaseLevelFlag ? RefdataCaseFlagType.CASE : RefdataCaseFlagType.PARTY;\n\n    this.formGroup.addControl(CaseFlagFormFields.FLAG_TYPE, new FormControl(''));\n    this.formGroup.addControl(CaseFlagFormFields.OTHER_FLAG_DESCRIPTION, new FormControl(''));\n    // FormControl is linked to a checkbox input element, so initial value should be false\n    this.formGroup.addControl(CaseFlagFormFields.IS_VISIBLE_INTERNALLY_ONLY, new FormControl(false));\n\n    // Should clear descriptionControlName if flagTypeControlName is changed\n    this.flagTypeControlChangesSubscription = this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.valueChanges\n      .subscribe(_ => {\n        this.formGroup.get(CaseFlagFormFields.OTHER_FLAG_DESCRIPTION)?.setValue('');\n        this.cachedPath = [];\n\n        // required to clear language interpreter\n        this.formGroup.patchValue({\n          [SearchLanguageInterpreterControlNames.LANGUAGE_SEARCH_TERM]: '',\n          [SearchLanguageInterpreterControlNames.MANUAL_LANGUAGE_ENTRY]: ''\n        });\n      }\n    );\n\n    // If hmctsServiceId is present, use this to retrieve the relevant list of flag types\n    if (this.hmctsServiceId) {\n      this.flagRefdata$ = this.caseFlagRefdataService\n        .getCaseFlagsRefdata(this.hmctsServiceId, flagType, true, this.isDisplayContextParameterExternal)\n        .subscribe({\n          next: flagTypes => this.processFlagTypes(flagTypes),\n          error: error => this.onRefdataError(error)\n        });\n    } else {\n      // Else, HMCTS service code is required to retrieve the relevant list of flag types; attempt to obtain it by case type ID first\n      this.flagRefdata$ = this.caseFlagRefdataService.getHmctsServiceDetailsByCaseType(this.caseTypeId)\n        .pipe(\n          // If an error occurs retrieving HMCTS service details by case type ID, try by service name instead\n          catchError(_ => this.caseFlagRefdataService.getHmctsServiceDetailsByServiceName(this.jurisdiction)),\n          // Use switchMap to return an inner Observable of the flag types data, having received the service details\n          // including service_code. This avoids having nested `subscribe`s, which is an anti-pattern!\n          switchMap(serviceDetails => this.caseFlagRefdataService.getCaseFlagsRefdata(serviceDetails[0].service_code, flagType,\n            true, this.isDisplayContextParameterExternal))\n        )\n        .subscribe({\n          next: flagTypes => this.processFlagTypes(flagTypes),\n          error: error => this.onRefdataError(error)\n        });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.flagRefdata$?.unsubscribe();\n    this.flagTypeControlChangesSubscription?.unsubscribe();\n  }\n\n  public onNext(): void {\n    // Validate form\n    this.validateForm();\n    // Return case flag field state, whether the selected flag type (if any) is a parent or not, error messages,\n    // flag name, path, hearing relevant indicator, code, and \"list of values\" (if any) to the parent\n    this.caseFlagStateEmitter.emit({\n      currentCaseFlagFieldState: CaseFlagFieldState.FLAG_TYPE,\n      isParentFlagType: this.selectedFlagType ? this.selectedFlagType.isParent : null,\n      errorMessages: this.errorMessages\n    });\n    // Emit \"flag comments optional\" event if the user selects a child flag type where comments are not mandatory\n    if (this.selectedFlagType && !this.selectedFlagType.isParent && !this.selectedFlagType.flagComment) {\n      this.flagCommentsOptionalEmitter.emit(null);\n    }\n\n    // If the selected flag type is a parent, load the list of child flag types and reset the current selection\n    if (this.selectedFlagType?.isParent) {\n      // Cache the current flag type selection before it is reset - this is needed for displaying its name as the title\n      // when displaying the next set of child flags\n      this.cachedFlagType = this.selectedFlagType;\n      this.flagTypes = this.selectedFlagType.childFlags;\n      this.cachedPath?.shift();\n      this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.setValue(this.cachedPath?.length ? this.cachedPath[0] : null, { emitEvent: false });\n    }\n  }\n\n  // Identity function for trackBy use by *ngFor for flagTypes in HTML template\n  public identifyFlagType(_: number, flagType: FlagType): string {\n    return `${flagType.flagCode}_${flagType.name}_${flagType.name_cy}`;\n  }\n\n  private validateForm(): void {\n    this.flagTypeNotSelectedErrorMessage = '';\n    this.flagTypeErrorMessage = '';\n    this.errorMessages = [];\n\n    if (!this.selectedFlagType) {\n      // If there is any prior flag type selection then the message will differ\n      let errorMessage = '';\n      if (this.cachedFlagType) {\n        errorMessage = SelectFlagTypeErrorMessage.FLAG_TYPE_OPTION_NOT_SELECTED;\n      } else {\n        errorMessage  = this.isDisplayContextParameterExternal\n        ? SelectFlagTypeErrorMessage.FLAG_TYPE_NOT_SELECTED_EXTERNAL\n        : SelectFlagTypeErrorMessage.FLAG_TYPE_NOT_SELECTED;\n      }\n      this.flagTypeNotSelectedErrorMessage = errorMessage;\n      this.errorMessages.push({ title: '', description: errorMessage, fieldId: 'conditional-radios-list' });\n    }\n    if (this.otherFlagTypeSelected) {\n      const otherFlagTypeDescription = this.formGroup.get(CaseFlagFormFields.OTHER_FLAG_DESCRIPTION)?.value;\n      if (!otherFlagTypeDescription) {\n        this.flagTypeErrorMessage = this.isDisplayContextParameterExternal\n          ? SelectFlagTypeErrorMessage.FLAG_TYPE_NOT_ENTERED_EXTERNAL\n          : SelectFlagTypeErrorMessage.FLAG_TYPE_NOT_ENTERED;\n        this.errorMessages.push({ title: '', description: `${this.flagTypeErrorMessage}`, fieldId: 'other-flag-type-description' });\n      }\n      if (otherFlagTypeDescription.length > this.maxCharactersForOtherFlagType) {\n        this.flagTypeErrorMessage = SelectFlagTypeErrorMessage.FLAG_TYPE_LIMIT_EXCEEDED;\n        this.errorMessages.push({ title: '', description: `${SelectFlagTypeErrorMessage.FLAG_TYPE_LIMIT_EXCEEDED}`, fieldId: 'other-flag-type-description' });\n      }\n    }\n  }\n\n  private processFlagTypes(flagTypes: FlagType[]): void {\n    // First (and only) object in the returned array should be the top-level \"Party\" flag type\n    // The \"Other\" flag type should be removed from the top level if the user is external\n    this.flagTypes = flagTypes[0].childFlags.filter((flag) =>\n      this.isDisplayContextParameterExternal ? flag.flagCode !== this.otherFlagTypeCode : true);\n\n    const formControl = this.formGroup.get(CaseFlagFormFields.FLAG_TYPE);\n    if (formControl?.value) {\n      // Cache Path based on existing flagCode -- needed for nested choices\n      const [foundFlagType, path] = FlagType.searchPathByFlagTypeObject(formControl.value as FlagType, this.flagTypes);\n      this.cachedPath = [\n        ...path,\n        foundFlagType\n      ];\n      formControl.setValue(this.cachedPath[0], { emitEvent: false });\n    }\n  }\n\n  private onRefdataError(error: any): void {\n    // Set error flag on component to remove the \"Next\" button (user cannot proceed with flag creation)\n    this.refdataError = true;\n    this.errorMessages = [];\n    this.errorMessages.push({ title: '', description: error.message, fieldId: 'conditional-radios-list' });\n    // Return case flag field state and error messages to the parent\n    this.caseFlagStateEmitter.emit({ currentCaseFlagFieldState: CaseFlagFieldState.FLAG_TYPE, errorMessages: this.errorMessages });\n  }\n}\n","<ng-container *ngIf=\"flagTypes?.length\" [formGroup]=\"formGroup\">\n  <div class=\"govuk-form-group\" [ngClass]=\"{'form-group-error': flagTypeNotSelectedErrorMessage.length > 0}\">\n    <fieldset class=\"govuk-fieldset\" aria-describedby=\"flag-type-heading\">\n      <legend class=\"govuk-fieldset__legend govuk-fieldset__legend--m\">\n        <h1 id=\"flag-type-heading\" class=\"govuk-fieldset__heading govuk-!-margin-bottom-1\">\n          <ng-container *ngIf=\"!cachedFlagType; else priorFlagTypeSelected\">\n            {{\n              isDisplayContextParameterExternal\n                ? (caseFlagWizardStepTitle.SELECT_CASE_FLAG_EXTERNAL | rpxTranslate)\n                : (caseFlagWizardStepTitle.SELECT_CASE_FLAG | rpxTranslate)\n            }}\n          </ng-container>\n          <ng-template #priorFlagTypeSelected>\n            {{cachedFlagType | flagFieldDisplay:'name'}}\n          </ng-template>\n        </h1>\n      </legend>\n      <div id=\"flag-type-not-selected-error-message\" class=\"govuk-error-message\"\n        *ngIf=\"flagTypeNotSelectedErrorMessage.length > 0\">\n        <span class=\"govuk-visually-hidden\">{{'Error:' | rpxTranslate}}</span> {{flagTypeNotSelectedErrorMessage | rpxTranslate}}\n      </div>\n      <div class=\"govuk-radios govuk-radios--conditional\" data-module=\"govuk-radios\" id=\"conditional-radios-list\">\n        <div class=\"govuk-radios__item\" *ngFor=\"let flagType of flagTypes; index as i; trackBy: identifyFlagType\">\n          <input class=\"govuk-radios__input\" id=\"flag-type-{{i}}\" [name]=\"caseFlagFormField.FLAG_TYPE\"\n            type=\"radio\" [value]=\"flagType\"\n            [formControlName]=\"caseFlagFormField.FLAG_TYPE\"/>\n          <label class=\"govuk-label govuk-radios__label\" for=\"flag-type-{{i}}\">\n            {{flagType | flagFieldDisplay:'name'}}\n          </label>\n        </div>\n        <div class=\"govuk-radios__conditional\" *ngIf=\"otherFlagTypeSelected\" id=\"conditional-flagType\">\n          <div class=\"govuk-form-group\" [ngClass]=\"{'form-group-error': flagTypeErrorMessage.length > 0}\">\n            <label class=\"govuk-label\" for=\"other-flag-type-description\">\n              {{\n                isDisplayContextParameterExternal\n                  ? (caseFlagWizardStepTitle.OTHER_FLAG_TYPE_DESCRIPTION_EXTERNAL | rpxTranslate)\n                  : (caseFlagWizardStepTitle.OTHER_FLAG_TYPE_DESCRIPTION | rpxTranslate)\n              }}\n            </label>\n            <div id=\"flag-type-error-message\" class=\"govuk-error-message\" *ngIf=\"flagTypeErrorMessage.length > 0\">\n              <span class=\"govuk-visually-hidden\">{{'Error:' | rpxTranslate}}</span> {{flagTypeErrorMessage | rpxTranslate}}\n            </div>\n            <input class=\"govuk-input govuk-!-width-one-half\"\n              [ngClass]=\"{'govuk-input--error': flagTypeErrorMessage.length > 0}\"\n              id=\"other-flag-type-description\" [name]=\"caseFlagFormField.OTHER_FLAG_DESCRIPTION\" type=\"text\"\n              [formControlName]=\"caseFlagFormField.OTHER_FLAG_DESCRIPTION\"/>\n            <div class=\"govuk-checkboxes__item govuk-!-margin-top-4\"\n              *ngIf=\"!isDisplayContextParameterExternal && !isCaseLevelFlag && isDisplayContextParameter2Point1Enabled\">\n              <input class=\"govuk-checkboxes__input\" id=\"is-visible-externally\" type=\"checkbox\"\n                [name]=\"caseFlagFormField.IS_VISIBLE_INTERNALLY_ONLY\" [formControlName]=\"caseFlagFormField.IS_VISIBLE_INTERNALLY_ONLY\">\n              <label class=\"govuk-label govuk-checkboxes__label\" for=\"is-visible-externally\">\n                {{'This flag should only be visible to HMCTS Staff' | rpxTranslate}}\n              </label>\n            </div>\n          </div>\n        </div>\n      </div>\n    </fieldset>\n  </div>\n</ng-container>\n\n<div class=\"govuk-button-group\" *ngIf=\"!refdataError\">\n  <button class=\"button button-primary\" type=\"button\" (click)=\"onNext()\">{{'Next' | rpxTranslate}}</button>\n</div>\n"]}
|
|
458
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SelectFlagTypeComponent, { className: "SelectFlagTypeComponent", filePath: "lib/shared/components/palette/case-flag/components/select-flag-type/select-flag-type.component.ts", lineNumber: 19 }); })();
|
|
459
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-flag-type.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/case-flag/components/select-flag-type/select-flag-type.component.ts","../../../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/case-flag/components/select-flag-type/select-flag-type.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { catchError, switchMap } from 'rxjs/operators';\nimport { ErrorMessage, Journey } from '../../../../../domain';\nimport { FlagType } from '../../../../../domain/case-flag';\nimport { CaseFlagRefdataService, MultipageComponentStateService } from '../../../../../services';\nimport { RefdataCaseFlagType } from '../../../../../services/case-flag/refdata-case-flag-type.enum';\nimport { CaseFlagState, FlagsWithFormGroupPath } from '../../domain';\nimport { CaseFlagFieldState, CaseFlagFormFields, CaseFlagWizardStepTitle, SelectFlagTypeErrorMessage } from '../../enums';\nimport { AbstractJourneyComponent } from '../../../base-field/abstract-journey.component';\nimport { SearchLanguageInterpreterControlNames } from '../search-language-interpreter/search-language-interpreter-control-names.enum';\n\n@Component({\n  selector: 'ccd-select-flag-type',\n  templateUrl: './select-flag-type.component.html',\n  styleUrls: ['./select-flag-type.component.scss']\n})\nexport class SelectFlagTypeComponent extends AbstractJourneyComponent implements OnInit, OnDestroy, Journey {\n  @Input()\n  public formGroup: FormGroup;\n\n  @Input()\n  public jurisdiction: string;\n\n  @Input()\n  public caseTypeId: string;\n\n  @Input()\n  public hmctsServiceId: string;\n\n  @Input()\n  public isDisplayContextParameterExternal = false;\n\n  @Input()\n  public isDisplayContextParameter2Point1Enabled = false;\n\n  @Input()\n  public selectedFlagsLocation: FlagsWithFormGroupPath;\n\n  @Output()\n  public caseFlagStateEmitter: EventEmitter<CaseFlagState> = new EventEmitter<CaseFlagState>();\n\n  @Output()\n  public flagCommentsOptionalEmitter: EventEmitter<any> = new EventEmitter();\n\n  @Output()\n  public flagTypeSubJourneyEmitter: EventEmitter<any> = new EventEmitter();\n\n  public flagTypes: FlagType[];\n  public errorMessages: ErrorMessage[];\n  public flagTypeNotSelectedErrorMessage = '';\n  public flagTypeErrorMessage = '';\n  public flagRefdata$: Subscription;\n  public refdataError = false;\n  public cachedPath: (FlagType | false)[];\n  public cachedFlagType: FlagType;\n  public flagTypeControlChangesSubscription: Subscription;\n  public caseFlagFormField = CaseFlagFormFields;\n  public isCaseLevelFlag = false;\n  public cachedRDFlagTypes: FlagType[];\n  public subJourneyIndex: number = 0;\n\n  private readonly maxCharactersForOtherFlagType = 80;\n  // Code for \"Other\" flag type as defined in Reference Data\n  private readonly otherFlagTypeCode = 'OT0001';\n  private readonly caseLevelCaseFlagsFieldId = 'caseFlags';\n\n  public get caseFlagWizardStepTitle(): typeof CaseFlagWizardStepTitle {\n    return CaseFlagWizardStepTitle;\n  }\n\n  public constructor(private readonly caseFlagRefdataService: CaseFlagRefdataService, pageStateService: MultipageComponentStateService) {\n    super(pageStateService);\n    this.handleBackButtonSubJourney = this.handleBackButtonSubJourney.bind(this);\n  }\n\n  public get selectedFlagType(): FlagType | null {\n    return this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.value;\n  }\n\n  public get otherFlagTypeSelected(): boolean {\n    return this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.value?.flagCode === this.otherFlagTypeCode;\n  }\n\n  public ngOnInit(): void {\n    this.isCaseLevelFlag = this.selectedFlagsLocation?.flags?.flagsCaseFieldId === this.caseLevelCaseFlagsFieldId;\n    this.flagTypeSubJourneyEmitter.emit(this.subJourneyIndex);\n    this.addState(this.subJourneyIndex);\n    this.flagTypes = [];\n    const flagType = this.isCaseLevelFlag ? RefdataCaseFlagType.CASE : RefdataCaseFlagType.PARTY;\n    this.formGroup.addControl(CaseFlagFormFields.FLAG_TYPE, new FormControl(''));\n    this.formGroup.addControl(CaseFlagFormFields.OTHER_FLAG_DESCRIPTION, new FormControl(''));\n    // FormControl is linked to a checkbox input element, so initial value should be false\n    this.formGroup.addControl(CaseFlagFormFields.IS_VISIBLE_INTERNALLY_ONLY, new FormControl(false));\n\n    // Should clear descriptionControlName if flagTypeControlName is changed\n    this.flagTypeControlChangesSubscription = this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.valueChanges\n      .subscribe((_) => {\n        this.formGroup.get(CaseFlagFormFields.OTHER_FLAG_DESCRIPTION)?.setValue('');\n        this.cachedPath = [];\n\n        // required to clear language interpreter\n        this.formGroup.patchValue({\n          [SearchLanguageInterpreterControlNames.LANGUAGE_SEARCH_TERM]: '',\n          [SearchLanguageInterpreterControlNames.MANUAL_LANGUAGE_ENTRY]: ''\n        });\n      }\n      );\n\n    // If hmctsServiceId is present, use this to retrieve the relevant list of flag types\n    if (this.hmctsServiceId) {\n      this.flagRefdata$ = this.caseFlagRefdataService\n        .getCaseFlagsRefdata(this.hmctsServiceId, flagType, true, this.isDisplayContextParameterExternal)\n        .subscribe({\n          next: (flagTypes) => this.processFlagTypes(flagTypes),\n          error: (error) => this.onRefdataError(error)\n        });\n    } else {\n      // Else, HMCTS service code is required to retrieve the relevant list of flag types; attempt to obtain it by case type ID first\n      this.flagRefdata$ = this.caseFlagRefdataService.getHmctsServiceDetailsByCaseType(this.caseTypeId)\n        .pipe(\n          // If an error occurs retrieving HMCTS service details by case type ID, try by service name instead\n          catchError((_) => this.caseFlagRefdataService.getHmctsServiceDetailsByServiceName(this.jurisdiction)),\n          // Use switchMap to return an inner Observable of the flag types data, having received the service details\n          // including service_code. This avoids having nested `subscribe`s, which is an anti-pattern!\n          switchMap((serviceDetails) => this.caseFlagRefdataService.getCaseFlagsRefdata(serviceDetails[0].service_code, flagType,\n            true, this.isDisplayContextParameterExternal))\n        )\n        .subscribe({\n          next: (flagTypes) => this.processFlagTypes(flagTypes),\n          error: (error) => this.onRefdataError(error)\n        });\n    }\n    this.addState(this.subJourneyIndex);\n    window.addEventListener('popstate', this.handleBackButtonSubJourney);\n  }\n\n  public handleBackButtonSubJourney(event: Event): void {\n    event.preventDefault();\n    this.previous();\n  }\n\n  public addState(data: number, url?: string): void {\n    history.pushState('1'+data, '', url);\n  }\n\n  public ngOnDestroy(): void {\n    this.flagRefdata$?.unsubscribe();\n    this.flagTypeControlChangesSubscription?.unsubscribe();\n    // check if the user has an existing path when navigating away from the page\n    // if so we may need to ensure the values are set correctly.\n    this.checkForExistingPath();\n    window.removeEventListener('popstate', this.handleBackButtonSubJourney);\n  }\n\n  public checkForExistingPath(): void {\n    // Restore values from cachedPath\n    if (this.subJourneyIndex <= 0) {\n      // check if the user is navigating to the previous page in the jounrey.\n      // in this situation we need to restore the full path for data retention across pages.\n      if (this.cachedPath && this.cachedPath.length > 0) {\n        this.cachedPath.forEach((flagType) => {\n          if (flagType) {\n            this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.setValue(flagType, { emitEvent: false });\n          }\n        });\n      }\n    }\n  }\n\n  public onNext(): void {\n    this.validateForm();\n    this.emitCaseFlagState();\n    this.emitFlagCommentsOptional();\n    this.handleFlagTypeSelection();\n    this.flagTypeSubJourneyEmitter.emit(this.subJourneyIndex);\n    this.addState(this.subJourneyIndex);\n  }\n\n  private emitCaseFlagState(): void {\n    this.caseFlagStateEmitter.emit({\n      currentCaseFlagFieldState: CaseFlagFieldState.FLAG_TYPE,\n      isParentFlagType: this.selectedFlagType ? this.selectedFlagType.isParent : null,\n      errorMessages: this.errorMessages\n    });\n  }\n\n  private emitFlagCommentsOptional(): void {\n    if (this.selectedFlagType && !this.selectedFlagType.isParent && !this.selectedFlagType.flagComment) {\n      this.flagCommentsOptionalEmitter.emit(null);\n    }\n  }\n\n  private handleFlagTypeSelection(): void {\n    if (this.selectedFlagType?.isParent) {\n      this.loadChildFlagTypes();\n    } else {\n      this.completeSubJourney();\n    }\n  }\n\n  private loadChildFlagTypes(): void {\n    this.cachedFlagType = this.selectedFlagType;\n    this.flagTypes = this.selectedFlagType.childFlags;\n    if (this.cachedPath.length !== 0 && this.cachedPath[this.subJourneyIndex] === this.selectedFlagType) {\n      this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.setValue(this.cachedPath[this.subJourneyIndex + 1], { emitEvent: false });\n    } else {\n      this.cachedPath?.shift();\n      const value = this.cachedPath?.length ? this.cachedPath[0] : null;\n      this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.setValue(value, { emitEvent: false });\n    }\n    this.subJourneyIndex++;\n  }\n\n  private completeSubJourney(): void {\n    const currentSelectedFlag = this.formGroup.controls.flagType;\n    const addedFlagValue = this.selectedFlagsLocation?.caseField?.value?.details;\n    if (addedFlagValue && (addedFlagValue[Object.keys(addedFlagValue).length]?.name !== currentSelectedFlag.value.name)) {\n      this.selectedFlagsLocation['caseField'].value.details.pop();\n      this.selectedFlagsLocation['caseField'].formatted_value?.details.pop();\n    }\n  }\n\n  // Simplified version of the onPrevious method with optimized code\n  public onPrevious(): void {\n    if (this.cachedFlagType) {\n      if (this.cachedFlagType.Path?.length === 1) {\n        this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.setValue(this.cachedFlagType, { emitEvent: false });\n        this.flagTypes = this.cachedRDFlagTypes[0].childFlags;\n      } else {\n        let currentPath = this.cachedRDFlagTypes[0];\n        const pathToSearch = this.cachedFlagType.Path.slice(1);\n        for (const pathElement of pathToSearch) {\n          const foundFlag = currentPath.childFlags.find((flag) => flag.name === pathElement);\n          if (foundFlag) {\n            currentPath = foundFlag;\n          }\n        }\n        this.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.setValue(this.cachedFlagType, { emitEvent: false });\n        this.flagTypes = currentPath.childFlags;\n        this.cachedFlagType = currentPath;\n      }\n    }\n    this.subJourneyIndex = Math.max(0, this.subJourneyIndex - 1);\n    if (this.subJourneyIndex === 0) {\n      this.flagTypes = this.flagTypes.filter((flag) =>\n        this.isDisplayContextParameterExternal ? flag.flagCode !== this.otherFlagTypeCode : true);\n    }\n    this.flagTypeSubJourneyEmitter.emit(this.subJourneyIndex);\n  }\n\n  // Identity function for trackBy use by *ngFor for flagTypes in HTML template\n  public identifyFlagType(_: number, flagType: FlagType): string {\n    return `${flagType.flagCode}_${flagType.name}_${flagType.name_cy}`;\n  }\n\n  private validateForm(): void {\n    this.flagTypeNotSelectedErrorMessage = '';\n    this.flagTypeErrorMessage = '';\n    this.errorMessages = [];\n\n    if (!this.selectedFlagType) {\n      // If there is any prior flag type selection then the message will differ\n      let errorMessage = '';\n      if (this.cachedFlagType) {\n        errorMessage = SelectFlagTypeErrorMessage.FLAG_TYPE_OPTION_NOT_SELECTED;\n      } else {\n        errorMessage = this.isDisplayContextParameterExternal\n          ? SelectFlagTypeErrorMessage.FLAG_TYPE_NOT_SELECTED_EXTERNAL\n          : SelectFlagTypeErrorMessage.FLAG_TYPE_NOT_SELECTED;\n      }\n      this.flagTypeNotSelectedErrorMessage = errorMessage;\n      this.errorMessages.push({ title: '', description: errorMessage, fieldId: 'conditional-radios-list' });\n    }\n    if (this.otherFlagTypeSelected) {\n      const otherFlagTypeDescription = this.formGroup.get(CaseFlagFormFields.OTHER_FLAG_DESCRIPTION)?.value;\n      if (!otherFlagTypeDescription) {\n        this.flagTypeErrorMessage = this.isDisplayContextParameterExternal\n          ? SelectFlagTypeErrorMessage.FLAG_TYPE_NOT_ENTERED_EXTERNAL\n          : SelectFlagTypeErrorMessage.FLAG_TYPE_NOT_ENTERED;\n        this.errorMessages.push({ title: '', description: `${this.flagTypeErrorMessage}`, fieldId: 'other-flag-type-description' });\n      }\n      if (otherFlagTypeDescription.length > this.maxCharactersForOtherFlagType) {\n        this.flagTypeErrorMessage = SelectFlagTypeErrorMessage.FLAG_TYPE_LIMIT_EXCEEDED;\n        this.errorMessages.push({ title: '', description: `${SelectFlagTypeErrorMessage.FLAG_TYPE_LIMIT_EXCEEDED}`, fieldId: 'other-flag-type-description' });\n      }\n    }\n  }\n\n  public processFlagTypes(flagTypes: FlagType[]): void {\n    const prevJourneyPage = this.multipageComponentStateService.getJourneyCollection()[0];\n    const { journeyPreviousPageNumber, journeyPageNumber } = prevJourneyPage;\n    this.cachedRDFlagTypes = flagTypes;\n    if (this.selectedFlagType && (journeyPreviousPageNumber > journeyPageNumber)) {\n      const selectedFlagType = this.selectedFlagType;\n      const pathToSearch = selectedFlagType.Path.slice(1);\n      let currentPath = flagTypes[0];\n      for (const pathElement of pathToSearch) {\n        const foundFlag = currentPath.childFlags.find((flag) => flag.name === pathElement);\n        if (foundFlag) {\n          currentPath = foundFlag;\n        }\n      }\n      this.flagTypes = currentPath.childFlags;\n      this.cachedFlagType = currentPath;\n    } else {\n      this.flagTypes = flagTypes[0].childFlags.filter((flag) =>\n        this.isDisplayContextParameterExternal ? flag.flagCode !== this.otherFlagTypeCode : true);\n    }\n    const formControl = this.formGroup.get(CaseFlagFormFields.FLAG_TYPE);\n    if (formControl?.value) {\n      const [foundFlagType, path] = FlagType.searchPathByFlagTypeObject(formControl.value as FlagType, this.cachedRDFlagTypes[0].childFlags);\n      this.cachedPath = [...path, foundFlagType];\n      formControl.setValue((this.selectedFlagType && (journeyPreviousPageNumber > journeyPageNumber)) ? this.cachedPath[this.cachedPath.length - 1] : this.cachedPath[0], { emitEvent: false });\n      if (this.cachedPath.length !== 0 && (journeyPreviousPageNumber > journeyPageNumber)) {\n        this.subJourneyIndex = this.cachedPath.length-1;\n      }\n    }\n    this.flagTypeSubJourneyEmitter.emit(this.subJourneyIndex);\n    this.addState(this.subJourneyIndex);\n  }\n\n  private onRefdataError(error: any): void {\n    // Set error flag on component to remove the \"Next\" button (user cannot proceed with flag creation)\n    this.refdataError = true;\n    this.errorMessages = [];\n    this.errorMessages.push({ title: '', description: error.message, fieldId: 'conditional-radios-list' });\n    // Return case flag field state and error messages to the parent\n    this.caseFlagStateEmitter.emit({ currentCaseFlagFieldState: CaseFlagFieldState.FLAG_TYPE, errorMessages: this.errorMessages });\n  }\n\n  public next(): void {\n    this.onNext();\n    this.addState(this.subJourneyIndex);\n    if (this.errorMessages.length === 0) {\n      super.next();\n    }\n  }\n\n  public previous(): void {\n    this.onPrevious();\n\n    if (this.subJourneyIndex <= 0) {\n      super.previous();\n    }\n  }\n}\n","<ng-container *ngIf=\"flagTypes?.length\" [formGroup]=\"formGroup\">\n  <div class=\"govuk-form-group\" [ngClass]=\"{'form-group-error': flagTypeNotSelectedErrorMessage.length > 0}\">\n    <fieldset class=\"govuk-fieldset\" aria-describedby=\"flag-type-heading\">\n      <legend class=\"govuk-fieldset__legend govuk-fieldset__legend--m\">\n        <h1 id=\"flag-type-heading\" class=\"govuk-fieldset__heading govuk-!-margin-bottom-1\">\n          <ng-container *ngIf=\"!cachedFlagType || subJourneyIndex == 0; else priorFlagTypeSelected\">\n            {{\n            isDisplayContextParameterExternal\n            ? (caseFlagWizardStepTitle.SELECT_CASE_FLAG_EXTERNAL | rpxTranslate)\n            : (caseFlagWizardStepTitle.SELECT_CASE_FLAG | rpxTranslate)\n            }}\n          </ng-container>\n          <ng-template #priorFlagTypeSelected>\n            {{cachedFlagType | flagFieldDisplay:'name'}}\n          </ng-template>\n        </h1>\n      </legend>\n      <div id=\"flag-type-not-selected-error-message\" class=\"govuk-error-message\"\n        *ngIf=\"flagTypeNotSelectedErrorMessage.length > 0\">\n        <span class=\"govuk-visually-hidden\">{{'Error:' | rpxTranslate}}</span> {{flagTypeNotSelectedErrorMessage |\n        rpxTranslate}}\n      </div>\n      <div class=\"govuk-radios govuk-radios--conditional\" data-module=\"govuk-radios\" id=\"conditional-radios-list\">\n        <div class=\"govuk-radios__item\" *ngFor=\"let flagType of flagTypes; index as i; trackBy: identifyFlagType\">\n          <input class=\"govuk-radios__input\" id=\"flag-type-{{i}}\" [name]=\"caseFlagFormField.FLAG_TYPE\" type=\"radio\"\n            [value]=\"flagType\" [formControlName]=\"caseFlagFormField.FLAG_TYPE\" />\n          <label class=\"govuk-label govuk-radios__label\" for=\"flag-type-{{i}}\">\n            {{flagType | flagFieldDisplay:'name'}}\n          </label>\n        </div>\n        <div class=\"govuk-radios__conditional\" *ngIf=\"otherFlagTypeSelected\" id=\"conditional-flagType\">\n          <div class=\"govuk-form-group\" [ngClass]=\"{'form-group-error': flagTypeErrorMessage.length > 0}\">\n            <label class=\"govuk-label\" for=\"other-flag-type-description\">\n              {{\n              isDisplayContextParameterExternal\n              ? (caseFlagWizardStepTitle.OTHER_FLAG_TYPE_DESCRIPTION_EXTERNAL | rpxTranslate)\n              : (caseFlagWizardStepTitle.OTHER_FLAG_TYPE_DESCRIPTION | rpxTranslate)\n              }}\n            </label>\n            <div id=\"flag-type-error-message\" class=\"govuk-error-message\" *ngIf=\"flagTypeErrorMessage.length > 0\">\n              <span class=\"govuk-visually-hidden\">{{'Error:' | rpxTranslate}}</span> {{flagTypeErrorMessage |\n              rpxTranslate}}\n            </div>\n            <input class=\"govuk-input govuk-!-width-one-half\"\n              [ngClass]=\"{'govuk-input--error': flagTypeErrorMessage.length > 0}\" id=\"other-flag-type-description\"\n              [name]=\"caseFlagFormField.OTHER_FLAG_DESCRIPTION\" type=\"text\"\n              [formControlName]=\"caseFlagFormField.OTHER_FLAG_DESCRIPTION\" />\n            <div class=\"govuk-checkboxes__item govuk-!-margin-top-4\"\n              *ngIf=\"!isDisplayContextParameterExternal && !isCaseLevelFlag && isDisplayContextParameter2Point1Enabled\">\n              <input class=\"govuk-checkboxes__input\" id=\"is-visible-externally\" type=\"checkbox\"\n                [name]=\"caseFlagFormField.IS_VISIBLE_INTERNALLY_ONLY\"\n                [formControlName]=\"caseFlagFormField.IS_VISIBLE_INTERNALLY_ONLY\">\n              <label class=\"govuk-label govuk-checkboxes__label\" for=\"is-visible-externally\">\n                {{'This flag should only be visible to HMCTS Staff' | rpxTranslate}}\n              </label>\n            </div>\n          </div>\n        </div>\n      </div>\n    </fieldset>\n  </div>\n</ng-container>"]}
|