@hmcts/ccd-case-ui-toolkit 7.1.51-ongoing-accessibility → 7.1.51-ongoing-accessibility-v1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (106) hide show
  1. package/esm2022/lib/shared/components/case-editor/case-edit-page/case-edit-page.component.mjs +154 -33
  2. package/esm2022/lib/shared/components/case-editor/case-edit-submit/case-edit-submit.component.mjs +103 -43
  3. package/esm2022/lib/shared/components/case-editor/case-editor.module.mjs +7 -4
  4. package/esm2022/lib/shared/components/case-editor/services/case-flag-state.service.mjs +7 -1
  5. package/esm2022/lib/shared/components/case-list/case-list.component.mjs +6 -6
  6. package/esm2022/lib/shared/components/case-viewer/case-event-trigger/case-event-trigger.component.mjs +14 -4
  7. package/esm2022/lib/shared/components/case-viewer/case-full-access-view/case-full-access-view.component.mjs +15 -5
  8. package/esm2022/lib/shared/components/palette/base-field/abstract-field-write-journey.component.mjs +95 -0
  9. package/esm2022/lib/shared/components/palette/base-field/abstract-journey.component.mjs +81 -0
  10. package/esm2022/lib/shared/components/palette/base-field/index.mjs +3 -1
  11. package/esm2022/lib/shared/components/palette/case-file-view/components/case-file-view-folder-selector/case-file-view-folder-selector.component.mjs +6 -6
  12. package/esm2022/lib/shared/components/palette/case-flag/components/add-comments/add-comments.component.mjs +30 -21
  13. package/esm2022/lib/shared/components/palette/case-flag/components/case-flag-summary-list/case-flag-summary-list.component.mjs +3 -3
  14. package/esm2022/lib/shared/components/palette/case-flag/components/confirm-flag-status/confirm-flag-status.component.mjs +25 -22
  15. package/esm2022/lib/shared/components/palette/case-flag/components/manage-case-flags/manage-case-flags.component.mjs +154 -36
  16. package/esm2022/lib/shared/components/palette/case-flag/components/search-language-interpreter/search-language-interpreter.component.mjs +33 -29
  17. package/esm2022/lib/shared/components/palette/case-flag/components/select-flag-location/select-flag-location.component.mjs +33 -28
  18. package/esm2022/lib/shared/components/palette/case-flag/components/select-flag-type/select-flag-type.component.mjs +177 -71
  19. 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
  20. package/esm2022/lib/shared/components/palette/case-flag/components/update-flag/update-flag.component.mjs +123 -105
  21. package/esm2022/lib/shared/components/palette/case-flag/read-case-flag-field.component.mjs +31 -4
  22. package/esm2022/lib/shared/components/palette/case-flag/write-case-flag-field.component.mjs +147 -33
  23. package/esm2022/lib/shared/components/palette/linked-cases/components/before-you-start/before-you-start.component.mjs +44 -23
  24. package/esm2022/lib/shared/components/palette/linked-cases/components/check-your-answers/check-your-answers.component.mjs +31 -9
  25. package/esm2022/lib/shared/components/palette/linked-cases/components/link-cases/link-cases.component.mjs +84 -50
  26. package/esm2022/lib/shared/components/palette/linked-cases/components/no-linked-cases/no-linked-cases.component.mjs +13 -9
  27. package/esm2022/lib/shared/components/palette/linked-cases/components/unlink-cases/unlink-cases.component.mjs +84 -44
  28. package/esm2022/lib/shared/components/palette/linked-cases/services/linked-cases.service.mjs +25 -2
  29. package/esm2022/lib/shared/components/palette/linked-cases/write-linked-cases-field.component.mjs +110 -30
  30. package/esm2022/lib/shared/components/palette/palette.module.mjs +2 -2
  31. package/esm2022/lib/shared/domain/index.mjs +2 -1
  32. package/esm2022/lib/shared/domain/journey/index.mjs +3 -0
  33. package/esm2022/lib/shared/domain/journey/journey-instigator.model.mjs +2 -0
  34. package/esm2022/lib/shared/domain/journey/journey.model.mjs +2 -0
  35. package/esm2022/lib/shared/pipes/complex/ccd-page-fields.pipe.mjs +2 -2
  36. package/esm2022/lib/shared/services/index.mjs +2 -1
  37. package/esm2022/lib/shared/services/journey/index.mjs +2 -0
  38. package/esm2022/lib/shared/services/journey/multipage-component-state.service.mjs +117 -0
  39. package/fesm2022/hmcts-ccd-case-ui-toolkit.mjs +1865 -789
  40. package/fesm2022/hmcts-ccd-case-ui-toolkit.mjs.map +1 -1
  41. package/lib/shared/components/case-editor/case-edit-page/case-edit-page.component.d.ts +19 -3
  42. package/lib/shared/components/case-editor/case-edit-page/case-edit-page.component.d.ts.map +1 -1
  43. package/lib/shared/components/case-editor/case-edit-submit/case-edit-submit.component.d.ts +11 -2
  44. package/lib/shared/components/case-editor/case-edit-submit/case-edit-submit.component.d.ts.map +1 -1
  45. package/lib/shared/components/case-editor/case-editor.module.d.ts.map +1 -1
  46. package/lib/shared/components/case-editor/services/case-flag-state.service.d.ts +3 -0
  47. package/lib/shared/components/case-editor/services/case-flag-state.service.d.ts.map +1 -1
  48. package/lib/shared/components/case-viewer/case-event-trigger/case-event-trigger.component.d.ts +2 -1
  49. package/lib/shared/components/case-viewer/case-event-trigger/case-event-trigger.component.d.ts.map +1 -1
  50. package/lib/shared/components/case-viewer/case-full-access-view/case-full-access-view.component.d.ts +5 -1
  51. package/lib/shared/components/case-viewer/case-full-access-view/case-full-access-view.component.d.ts.map +1 -1
  52. package/lib/shared/components/palette/base-field/abstract-field-write-journey.component.d.ts +30 -0
  53. package/lib/shared/components/palette/base-field/abstract-field-write-journey.component.d.ts.map +1 -0
  54. package/lib/shared/components/palette/base-field/abstract-journey.component.d.ts +27 -0
  55. package/lib/shared/components/palette/base-field/abstract-journey.component.d.ts.map +1 -0
  56. package/lib/shared/components/palette/base-field/index.d.ts +2 -0
  57. package/lib/shared/components/palette/base-field/index.d.ts.map +1 -1
  58. package/lib/shared/components/palette/case-flag/components/add-comments/add-comments.component.d.ts +4 -2
  59. package/lib/shared/components/palette/case-flag/components/add-comments/add-comments.component.d.ts.map +1 -1
  60. package/lib/shared/components/palette/case-flag/components/confirm-flag-status/confirm-flag-status.component.d.ts +4 -2
  61. package/lib/shared/components/palette/case-flag/components/confirm-flag-status/confirm-flag-status.component.d.ts.map +1 -1
  62. package/lib/shared/components/palette/case-flag/components/manage-case-flags/manage-case-flags.component.d.ts +16 -4
  63. package/lib/shared/components/palette/case-flag/components/manage-case-flags/manage-case-flags.component.d.ts.map +1 -1
  64. package/lib/shared/components/palette/case-flag/components/search-language-interpreter/search-language-interpreter.component.d.ts +6 -3
  65. package/lib/shared/components/palette/case-flag/components/search-language-interpreter/search-language-interpreter.component.d.ts.map +1 -1
  66. package/lib/shared/components/palette/case-flag/components/select-flag-location/select-flag-location.component.d.ts +5 -2
  67. package/lib/shared/components/palette/case-flag/components/select-flag-location/select-flag-location.component.d.ts.map +1 -1
  68. package/lib/shared/components/palette/case-flag/components/select-flag-type/select-flag-type.component.d.ts +21 -6
  69. package/lib/shared/components/palette/case-flag/components/select-flag-type/select-flag-type.component.d.ts.map +1 -1
  70. 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
  71. 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
  72. package/lib/shared/components/palette/case-flag/components/update-flag/update-flag.component.d.ts +7 -3
  73. package/lib/shared/components/palette/case-flag/components/update-flag/update-flag.component.d.ts.map +1 -1
  74. package/lib/shared/components/palette/case-flag/read-case-flag-field.component.d.ts +1 -0
  75. package/lib/shared/components/palette/case-flag/read-case-flag-field.component.d.ts.map +1 -1
  76. package/lib/shared/components/palette/case-flag/write-case-flag-field.component.d.ts +18 -6
  77. package/lib/shared/components/palette/case-flag/write-case-flag-field.component.d.ts.map +1 -1
  78. package/lib/shared/components/palette/linked-cases/components/before-you-start/before-you-start.component.d.ts +6 -4
  79. package/lib/shared/components/palette/linked-cases/components/before-you-start/before-you-start.component.d.ts.map +1 -1
  80. package/lib/shared/components/palette/linked-cases/components/check-your-answers/check-your-answers.component.d.ts +8 -3
  81. package/lib/shared/components/palette/linked-cases/components/check-your-answers/check-your-answers.component.d.ts.map +1 -1
  82. package/lib/shared/components/palette/linked-cases/components/link-cases/link-cases.component.d.ts +8 -3
  83. package/lib/shared/components/palette/linked-cases/components/link-cases/link-cases.component.d.ts.map +1 -1
  84. package/lib/shared/components/palette/linked-cases/components/no-linked-cases/no-linked-cases.component.d.ts +5 -2
  85. package/lib/shared/components/palette/linked-cases/components/no-linked-cases/no-linked-cases.component.d.ts.map +1 -1
  86. package/lib/shared/components/palette/linked-cases/components/unlink-cases/unlink-cases.component.d.ts +9 -3
  87. package/lib/shared/components/palette/linked-cases/components/unlink-cases/unlink-cases.component.d.ts.map +1 -1
  88. package/lib/shared/components/palette/linked-cases/services/linked-cases.service.d.ts +8 -0
  89. package/lib/shared/components/palette/linked-cases/services/linked-cases.service.d.ts.map +1 -1
  90. package/lib/shared/components/palette/linked-cases/write-linked-cases-field.component.d.ts +10 -3
  91. package/lib/shared/components/palette/linked-cases/write-linked-cases-field.component.d.ts.map +1 -1
  92. package/lib/shared/domain/index.d.ts +1 -0
  93. package/lib/shared/domain/index.d.ts.map +1 -1
  94. package/lib/shared/domain/journey/index.d.ts +3 -0
  95. package/lib/shared/domain/journey/index.d.ts.map +1 -0
  96. package/lib/shared/domain/journey/journey-instigator.model.d.ts +5 -0
  97. package/lib/shared/domain/journey/journey-instigator.model.d.ts.map +1 -0
  98. package/lib/shared/domain/journey/journey.model.d.ts +19 -0
  99. package/lib/shared/domain/journey/journey.model.d.ts.map +1 -0
  100. package/lib/shared/services/index.d.ts +1 -0
  101. package/lib/shared/services/index.d.ts.map +1 -1
  102. package/lib/shared/services/journey/index.d.ts +2 -0
  103. package/lib/shared/services/journey/index.d.ts.map +1 -0
  104. package/lib/shared/services/journey/multipage-component-state.service.d.ts +26 -0
  105. package/lib/shared/services/journey/multipage-component-state.service.d.ts.map +1 -0
  106. 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", 13)(1, "span", 14);
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", 15);
48
- i0.ɵɵelement(1, "input", 16);
49
- i0.ɵɵelementStart(2, "label", 17);
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", 23)(1, "span", 14);
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", 24);
82
- i0.ɵɵelement(1, "input", 25);
83
- i0.ɵɵelementStart(2, "label", 26);
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", 18)(1, "div", 4)(2, "label", 19);
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", 20);
101
- i0.ɵɵelement(7, "input", 21);
102
- i0.ɵɵtemplate(8, SelectFlagTypeComponent_ng_container_0_div_11_div_8_Template, 5, 5, "div", 22);
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, 3);
119
- i0.ɵɵelementStart(1, "div", 4)(2, "fieldset", 5)(3, "legend", 6)(4, "h1", 7);
120
- i0.ɵɵtemplate(5, SelectFlagTypeComponent_ng_container_0_ng_container_5_Template, 4, 5, "ng-container", 8)(6, SelectFlagTypeComponent_ng_container_0_ng_template_6_Template, 2, 4, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
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", 9);
123
- i0.ɵɵelementStart(9, "div", 10);
124
- i0.ɵɵtemplate(10, SelectFlagTypeComponent_ng_container_0_div_10_Template, 5, 11, "div", 11)(11, SelectFlagTypeComponent_ng_container_0_div_11_Template, 9, 15, "div", 12);
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
- function SelectFlagTypeComponent_div_1_Template(rf, ctx) { if (rf & 1) {
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
- // Return case flag field state, whether the selected flag type (if any) is a parent or not, error messages,
242
- // flag name, path, hearing relevant indicator, code, and "list of values" (if any) to the parent
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
- // Emit "flag comments optional" event if the user selects a child flag type where comments are not mandatory
276
+ }
277
+ emitFlagCommentsOptional() {
249
278
  if (this.selectedFlagType && !this.selectedFlagType.isParent && !this.selectedFlagType.flagComment) {
250
279
  this.flagCommentsOptionalEmitter.emit(null);
251
280
  }
252
- // If the selected flag type is a parent, load the list of child flag types and reset the current selection
281
+ }
282
+ handleFlagTypeSelection() {
253
283
  if (this.selectedFlagType?.isParent) {
254
- // Cache the current flag type selection before it is reset - this is needed for displaying its name as the title
255
- // when displaying the next set of child flags
256
- this.cachedFlagType = this.selectedFlagType;
257
- this.flagTypes = this.selectedFlagType.childFlags;
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.formGroup.get(CaseFlagFormFields.FLAG_TYPE)?.setValue(this.cachedPath?.length ? this.cachedPath[0] : null, { emitEvent: false });
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
- // First (and only) object in the returned array should be the top-level "Party" flag type
300
- // The "Other" flag type should be removed from the top level if the user is external
301
- this.flagTypes = flagTypes[0].childFlags.filter((flag) => this.isDisplayContextParameterExternal ? flag.flagCode !== this.otherFlagTypeCode : true);
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
- // Cache Path based on existing flagCode -- needed for nested choices
305
- const [foundFlagType, path] = FlagType.searchPathByFlagTypeObject(formControl.value, this.flagTypes);
306
- this.cachedPath = [
307
- ...path,
308
- foundFlagType
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
- static ɵfac = function SelectFlagTypeComponent_Factory(t) { return new (t || SelectFlagTypeComponent)(i0.ɵɵdirectiveInject(i1.CaseFlagRefdataService)); };
322
- 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" }, decls: 2, vars: 2, consts: [["priorFlagTypeSelected", ""], [3, "formGroup", 4, "ngIf"], ["class", "govuk-button-group", 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"], [1, "govuk-button-group"], ["type", "button", 1, "button", "button-primary", 3, "click"]], template: function SelectFlagTypeComponent_Template(rf, ctx) { if (rf & 1) {
323
- i0.ɵɵtemplate(0, SelectFlagTypeComponent_ng_container_0_Template, 12, 10, "ng-container", 1)(1, SelectFlagTypeComponent_div_1_Template, 4, 3, "div", 2);
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 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", styles: [".hidden{display:none}.validation-error{cursor:pointer;text-decoration:underline;color:#d4351c}\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: 18 }); })();
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":"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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 } 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>"]}