@mtna/web-form-angular 0.0.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 (170) hide show
  1. package/_index.scss +25 -0
  2. package/bundles/mtna-web-form-angular.umd.js +4982 -0
  3. package/bundles/mtna-web-form-angular.umd.js.map +1 -0
  4. package/esm2015/lib/core/animations.js +8 -0
  5. package/esm2015/lib/core/api-config.js +3 -0
  6. package/esm2015/lib/core/index.js +7 -0
  7. package/esm2015/lib/core/pipes/coerce-date-item.pipe.js +23 -0
  8. package/esm2015/lib/core/pipes/coerce-form-group.pipe.js +35 -0
  9. package/esm2015/lib/core/pipes/date-quarter.pipe.js +43 -0
  10. package/esm2015/lib/core/pipes/get-auto-complete.pipe.js +42 -0
  11. package/esm2015/lib/core/pipes/get-available-quarters.pipe.js +29 -0
  12. package/esm2015/lib/core/pipes/get-form-control-error.pipe.js +20 -0
  13. package/esm2015/lib/core/pipes/get-list-icon.pipe.js +53 -0
  14. package/esm2015/lib/core/pipes/get-object-type.pipe.js +17 -0
  15. package/esm2015/lib/core/pipes/get-selected-option.pipe.js +20 -0
  16. package/esm2015/lib/core/pipes/index.js +71 -0
  17. package/esm2015/lib/core/pipes/items-with-value.pipe.js +30 -0
  18. package/esm2015/lib/core/pipes/sanitize-html.pipe.js +23 -0
  19. package/esm2015/lib/core/services/api.service.js +67 -0
  20. package/esm2015/lib/core/services/form-manager.service.js +465 -0
  21. package/esm2015/lib/core/services/index.js +5 -0
  22. package/esm2015/lib/core/services/ng-form.service.js +150 -0
  23. package/esm2015/lib/core/services/ui.service.js +333 -0
  24. package/esm2015/lib/core/utilities/find-form-control.js +29 -0
  25. package/esm2015/lib/core/utilities/find-form-item.js +25 -0
  26. package/esm2015/lib/core/utilities/flatten-steps.js +10 -0
  27. package/esm2015/lib/core/utilities/generate-form-steps.js +25 -0
  28. package/esm2015/lib/core/utilities/index.js +9 -0
  29. package/esm2015/lib/core/utilities/is-form-group.js +6 -0
  30. package/esm2015/lib/core/utilities/serializer-util.js +358 -0
  31. package/esm2015/lib/core/utilities/update-step-status.js +38 -0
  32. package/esm2015/lib/core/validators/index.js +3 -0
  33. package/esm2015/lib/core/validators/instant-validation-result-error-state-matcher.js +23 -0
  34. package/esm2015/lib/core/validators/validation-result-validator.js +19 -0
  35. package/esm2015/lib/file-upload/file-upload.component.js +66 -0
  36. package/esm2015/lib/file-upload/index.js +2 -0
  37. package/esm2015/lib/form/base-form-item.model.js +2 -0
  38. package/esm2015/lib/form/form-disabler.component.js +38 -0
  39. package/esm2015/lib/form/form-item.directive.js +22 -0
  40. package/esm2015/lib/form/form.component.js +250 -0
  41. package/esm2015/lib/form/form.module.js +214 -0
  42. package/esm2015/lib/form/index.js +5 -0
  43. package/esm2015/lib/form/white-list.model.js +11 -0
  44. package/esm2015/lib/form-item-controls/base-form-item-control.directive.js +58 -0
  45. package/esm2015/lib/form-item-controls/base-parent-item-control.directive.js +42 -0
  46. package/esm2015/lib/form-item-controls/base-single-selection-parent.directive.js +53 -0
  47. package/esm2015/lib/form-item-controls/date-range.component.js +84 -0
  48. package/esm2015/lib/form-item-controls/date.component.js +134 -0
  49. package/esm2015/lib/form-item-controls/dropdown.component.js +109 -0
  50. package/esm2015/lib/form-item-controls/index.js +8 -0
  51. package/esm2015/lib/form-item-controls/input.component.js +149 -0
  52. package/esm2015/lib/form-item-controls/year-quarter-range.component.js +75 -0
  53. package/esm2015/lib/form-item-controls/year-quarter.component.js +228 -0
  54. package/esm2015/lib/form-stepper/form-step-group.component.js +95 -0
  55. package/esm2015/lib/form-stepper/form-step-group.pipe.js +20 -0
  56. package/esm2015/lib/form-stepper/form-step.component.js +110 -0
  57. package/esm2015/lib/form-stepper/form-step.util.js +28 -0
  58. package/esm2015/lib/form-stepper/form-stepper.component.js +115 -0
  59. package/esm2015/lib/form-stepper/form-stepper.module.js +53 -0
  60. package/esm2015/lib/form-stepper/index.js +8 -0
  61. package/esm2015/lib/form-stepper/models/base-form-step.model.js +6 -0
  62. package/esm2015/lib/form-stepper/models/form-step-group.model.js +13 -0
  63. package/esm2015/lib/form-stepper/models/form-step.model.js +12 -0
  64. package/esm2015/lib/form-stepper/models/index.js +4 -0
  65. package/esm2015/lib/groups/form-item-dialog-data.model.js +14 -0
  66. package/esm2015/lib/groups/group-components.js +646 -0
  67. package/esm2015/lib/groups/index.js +3 -0
  68. package/esm2015/lib/groups/repeatable-item.component.js +23 -0
  69. package/esm2015/lib/item-header/index.js +2 -0
  70. package/esm2015/lib/item-header/item-header.component.js +108 -0
  71. package/esm2015/lib/static-form-items/index.js +3 -0
  72. package/esm2015/lib/static-form-items/ordered-list-item.js +50 -0
  73. package/esm2015/lib/static-form-items/unordered-list-item.js +52 -0
  74. package/esm2015/lib/step-card/index.js +2 -0
  75. package/esm2015/lib/step-card/step-card.component.js +53 -0
  76. package/esm2015/mtna-web-form-angular.js +5 -0
  77. package/esm2015/public-api.js +10 -0
  78. package/fesm2015/mtna-web-form-angular.js +4614 -0
  79. package/fesm2015/mtna-web-form-angular.js.map +1 -0
  80. package/lib/_index.scss +25 -0
  81. package/lib/core/_all-color.scss +25 -0
  82. package/lib/core/_all-theme.scss +28 -0
  83. package/lib/core/_all-typography.scss +25 -0
  84. package/lib/core/_core-theme.scss +43 -0
  85. package/lib/core/animations.d.ts +2 -0
  86. package/lib/core/api-config.d.ts +5 -0
  87. package/lib/core/index.d.ts +6 -0
  88. package/lib/core/pipes/coerce-date-item.pipe.d.ts +11 -0
  89. package/lib/core/pipes/coerce-form-group.pipe.d.ts +23 -0
  90. package/lib/core/pipes/date-quarter.pipe.d.ts +7 -0
  91. package/lib/core/pipes/get-auto-complete.pipe.d.ts +7 -0
  92. package/lib/core/pipes/get-available-quarters.pipe.d.ts +8 -0
  93. package/lib/core/pipes/get-form-control-error.pipe.d.ts +14 -0
  94. package/lib/core/pipes/get-list-icon.pipe.d.ts +7 -0
  95. package/lib/core/pipes/get-object-type.pipe.d.ts +7 -0
  96. package/lib/core/pipes/get-selected-option.pipe.d.ts +8 -0
  97. package/lib/core/pipes/index.d.ts +28 -0
  98. package/lib/core/pipes/items-with-value.pipe.d.ts +13 -0
  99. package/lib/core/pipes/sanitize-html.pipe.d.ts +10 -0
  100. package/lib/core/services/api.service.d.ts +41 -0
  101. package/lib/core/services/form-manager.service.d.ts +184 -0
  102. package/lib/core/services/index.d.ts +4 -0
  103. package/lib/core/services/ng-form.service.d.ts +76 -0
  104. package/lib/core/services/ui.service.d.ts +123 -0
  105. package/lib/core/utilities/find-form-control.d.ts +11 -0
  106. package/lib/core/utilities/find-form-item.d.ts +10 -0
  107. package/lib/core/utilities/flatten-steps.d.ts +7 -0
  108. package/lib/core/utilities/generate-form-steps.d.ts +3 -0
  109. package/lib/core/utilities/index.d.ts +8 -0
  110. package/lib/core/utilities/is-form-group.d.ts +3 -0
  111. package/lib/core/utilities/serializer-util.d.ts +81 -0
  112. package/lib/core/utilities/update-step-status.d.ts +14 -0
  113. package/lib/core/validators/index.d.ts +2 -0
  114. package/lib/core/validators/instant-validation-result-error-state-matcher.d.ts +13 -0
  115. package/lib/core/validators/validation-result-validator.d.ts +12 -0
  116. package/lib/file-upload/file-upload.component.d.ts +23 -0
  117. package/lib/file-upload/index.d.ts +1 -0
  118. package/lib/form/base-form-item.model.d.ts +15 -0
  119. package/lib/form/form-disabler.component.d.ts +6 -0
  120. package/lib/form/form-item.directive.d.ts +13 -0
  121. package/lib/form/form.component.d.ts +89 -0
  122. package/lib/form/form.module.d.ts +52 -0
  123. package/lib/form/index.d.ts +4 -0
  124. package/lib/form/white-list.model.d.ts +6 -0
  125. package/lib/form-item-controls/_date-item-theme.scss +29 -0
  126. package/lib/form-item-controls/_form-control-theme.scss +28 -0
  127. package/lib/form-item-controls/_year-quarter-item-theme.scss +28 -0
  128. package/lib/form-item-controls/base-form-item-control.directive.d.ts +26 -0
  129. package/lib/form-item-controls/base-parent-item-control.directive.d.ts +19 -0
  130. package/lib/form-item-controls/base-single-selection-parent.directive.d.ts +26 -0
  131. package/lib/form-item-controls/date-range.component.d.ts +12 -0
  132. package/lib/form-item-controls/date.component.d.ts +24 -0
  133. package/lib/form-item-controls/dropdown.component.d.ts +9 -0
  134. package/lib/form-item-controls/index.d.ts +7 -0
  135. package/lib/form-item-controls/input.component.d.ts +14 -0
  136. package/lib/form-item-controls/year-quarter-range.component.d.ts +9 -0
  137. package/lib/form-item-controls/year-quarter.component.d.ts +33 -0
  138. package/lib/form-stepper/_form-step-group-theme.scss +43 -0
  139. package/lib/form-stepper/_form-stepper-theme.scss +72 -0
  140. package/lib/form-stepper/form-step-group.component.d.ts +23 -0
  141. package/lib/form-stepper/form-step-group.pipe.d.ts +11 -0
  142. package/lib/form-stepper/form-step.component.d.ts +27 -0
  143. package/lib/form-stepper/form-step.util.d.ts +27 -0
  144. package/lib/form-stepper/form-stepper.component.d.ts +35 -0
  145. package/lib/form-stepper/form-stepper.module.d.ts +18 -0
  146. package/lib/form-stepper/index.d.ts +7 -0
  147. package/lib/form-stepper/models/base-form-step.model.d.ts +4 -0
  148. package/lib/form-stepper/models/form-step-group.model.d.ts +8 -0
  149. package/lib/form-stepper/models/form-step.model.d.ts +11 -0
  150. package/lib/form-stepper/models/index.d.ts +3 -0
  151. package/lib/groups/_checkbox-theme.scss +62 -0
  152. package/lib/groups/_form-group-theme.scss +32 -0
  153. package/lib/groups/_multiple-choice-theme.scss +65 -0
  154. package/lib/groups/_repeatable-item-theme.scss +28 -0
  155. package/lib/groups/form-item-dialog-data.model.d.ts +13 -0
  156. package/lib/groups/group-components.d.ts +221 -0
  157. package/lib/groups/index.d.ts +2 -0
  158. package/lib/groups/repeatable-item.component.d.ts +5 -0
  159. package/lib/item-header/_item-header-theme.scss +28 -0
  160. package/lib/item-header/index.d.ts +1 -0
  161. package/lib/item-header/item-header.component.d.ts +35 -0
  162. package/lib/static-form-items/index.d.ts +2 -0
  163. package/lib/static-form-items/ordered-list-item.d.ts +11 -0
  164. package/lib/static-form-items/unordered-list-item.d.ts +11 -0
  165. package/lib/step-card/_step-card-theme.scss +42 -0
  166. package/lib/step-card/index.d.ts +1 -0
  167. package/lib/step-card/step-card.component.d.ts +21 -0
  168. package/mtna-web-form-angular.d.ts +5 -0
  169. package/package.json +43 -0
  170. package/public-api.d.ts +9 -0
@@ -0,0 +1,646 @@
1
+ import { animate, state, style, transition, trigger } from '@angular/animations';
2
+ import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Inject, Injectable, Input, Optional, Output, ViewChild, ViewEncapsulation, } from '@angular/core';
3
+ import { MAT_DIALOG_DATA } from '@angular/material/dialog';
4
+ import { isKey } from '@mtna/core-ts';
5
+ import { DROPDOWN_ITEM_ID, FORM_ITEM_GROUP_IMPL_ID, isConditionalItem, MtnaWfFormItemChange, PARAGRAPH_ANSWER_ITEM_ID, SECTION_ID, SHORT_ANSWER_ITEM_ID, TEXT_ITEM_ID, TITLE_ITEM_ID, } from '@mtna/web-form-ts';
6
+ import { Subject } from 'rxjs';
7
+ import { takeUntil } from 'rxjs/operators';
8
+ import { COMPLEX_STANDARD, MTNA_WF_EXPAND_COLLAPSE } from '../core/animations';
9
+ import { BaseParentItemControl } from '../form-item-controls/base-parent-item-control.directive';
10
+ import { BaseSingleSelectionParent } from '../form-item-controls/base-single-selection-parent.directive';
11
+ import { MtnaWfFormItemDirective } from '../form/form-item.directive';
12
+ import { MTNA_WF_ITEM_WHITELIST } from '../form/white-list.model';
13
+ import { MtnaWfFormItemDialogData } from './form-item-dialog-data.model';
14
+ import * as i0 from "@angular/core";
15
+ import * as i1 from "@angular/material/dialog";
16
+ import * as i2 from "@angular/material/button";
17
+ import * as i3 from "@angular/common";
18
+ import * as i4 from "./form-item-dialog-data.model";
19
+ import * as i5 from "../core/services/ui.service";
20
+ import * as i6 from "@mtna/pojo-social-angular";
21
+ import * as i7 from "@mtna/core-angular";
22
+ import * as i8 from "../core/pipes/get-object-type.pipe";
23
+ import * as i9 from "../step-card/step-card.component";
24
+ import * as i10 from "@angular/material/divider";
25
+ import * as i11 from "../item-header/item-header.component";
26
+ import * as i12 from "@angular/material/list";
27
+ import * as i13 from "@angular/forms";
28
+ import * as i14 from "@angular/flex-layout/extended";
29
+ import * as i15 from "../core/pipes/items-with-value.pipe";
30
+ import * as i16 from "../core/services/form-manager.service";
31
+ import * as i17 from "./repeatable-item.component";
32
+ import * as i18 from "@angular/material/icon";
33
+ import * as i19 from "@angular/material/tooltip";
34
+ import * as i20 from "@angular/material/table";
35
+ import * as i21 from "../form-item-controls/date.component";
36
+ import * as i22 from "../form-item-controls/date-range.component";
37
+ import * as i23 from "../form-item-controls/year-quarter-range.component";
38
+ import * as i24 from "../form-item-controls/dropdown.component";
39
+ import * as i25 from "../file-upload/file-upload.component";
40
+ import * as i26 from "../static-form-items/unordered-list-item";
41
+ import * as i27 from "../static-form-items/ordered-list-item";
42
+ import * as i28 from "../form-item-controls/input.component";
43
+ import * as i29 from "../form/form-item.directive";
44
+ import * as i30 from "../core/pipes/sanitize-html.pipe";
45
+ import * as i31 from "../core/pipes/coerce-date-item.pipe";
46
+ import * as i32 from "@angular/material/radio";
47
+ import * as i33 from "@angular/material/form-field";
48
+ import * as i34 from "../core/pipes/get-form-control-error.pipe";
49
+ import * as i35 from "@angular/material/slide-toggle";
50
+ import * as i36 from "@angular/material/checkbox";
51
+ export class MtnaWfDialogService {
52
+ constructor(dialog) {
53
+ this.dialog = dialog;
54
+ }
55
+ /**
56
+ * Display the acknowledgement the user agreed to for a given option.
57
+ * @param acknowledgementItem The {@link Section} that represents the acknowledgement text to display to the user.
58
+ */
59
+ showAcknowledgement(acknowledgementItem) {
60
+ this.dialog.open(MtnaWfFormItemDialogComponent, {
61
+ closeOnNavigation: true,
62
+ data: new MtnaWfFormItemDialogData(acknowledgementItem.items, acknowledgementItem.title.value || 'Acknowledgement'),
63
+ disableClose: false,
64
+ hasBackdrop: true,
65
+ maxWidth: '500px',
66
+ });
67
+ }
68
+ /**
69
+ * Show some text in a dialog that the user needs to "acknowledge" before they can make a certain selection.
70
+ * @param acknowledgementItem The {@link Section} that represents the text displayed to the user for acknowledgement.
71
+ * @returns Whether the user acknowledges (agrees).
72
+ */
73
+ verifyAcknowledgement(acknowledgementItem) {
74
+ return this.dialog
75
+ .open(MtnaWfAcknowledgeDialogComponent, {
76
+ closeOnNavigation: true,
77
+ data: new MtnaWfFormItemDialogData(acknowledgementItem.items, acknowledgementItem.title.value || 'Acknowledgement'),
78
+ disableClose: true,
79
+ hasBackdrop: true,
80
+ maxWidth: '500px',
81
+ })
82
+ .afterClosed();
83
+ }
84
+ }
85
+ MtnaWfDialogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfDialogService, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Injectable });
86
+ MtnaWfDialogService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfDialogService, providedIn: 'root' });
87
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfDialogService, decorators: [{
88
+ type: Injectable,
89
+ args: [{ providedIn: 'root' }]
90
+ }], ctorParameters: function () { return [{ type: i1.MatDialog }]; } });
91
+ /*
92
+ * Due to the recursive nature of these form components, we had to combine all the TS into a single file.
93
+ * Perhaps when we refactor this in the future to use dynamic components, this can be avoided.
94
+ * Read more about the errors if they are not in the same file here: https://angular.io/errors/NG3003
95
+ */
96
+ // TODO: refactor, reduce code in here. mixins
97
+ /**
98
+ * A dialog that renders a form item that represents something the user needs to acknowledge.
99
+ */
100
+ export class MtnaWfAcknowledgeDialogComponent {
101
+ constructor(data, dialogRef) {
102
+ this.data = data;
103
+ this.dialogRef = dialogRef;
104
+ }
105
+ }
106
+ MtnaWfAcknowledgeDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfAcknowledgeDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }], target: i0.ɵɵFactoryTarget.Component });
107
+ MtnaWfAcknowledgeDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfAcknowledgeDialogComponent, selector: "mtna-wf-acknowledge-dialog", ngImport: i0, template: "<h2 *ngIf=\"data.title as title\" mat-dialog-title>{{ title }}</h2>\n<mat-dialog-content>\n <mtna-wf-item *ngFor=\"let item of data.formItems\" [item]=\"item\" [readonly]=\"true\"></mtna-wf-item>\n</mat-dialog-content>\n<mat-dialog-actions align=\"end\">\n <button [mat-dialog-close]=\"false\" mat-button>CANCEL</button>\n <button [mat-dialog-close]=\"true\" color=\"accent\" mat-raised-button>ACKNOWLEDGE</button>\n</mat-dialog-actions>\n", components: [{ type: i0.forwardRef(function () { return MtnaWfFormItemComponent; }), selector: "mtna-wf-item", inputs: ["item", "readonly", "control", "parentIds", "step"], outputs: ["focusedSection"] }, { type: i0.forwardRef(function () { return i2.MatButton; }), selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i0.forwardRef(function () { return i3.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i0.forwardRef(function () { return i1.MatDialogTitle; }), selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i0.forwardRef(function () { return i1.MatDialogContent; }), selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i0.forwardRef(function () { return i3.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i0.forwardRef(function () { return i1.MatDialogActions; }), selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i0.forwardRef(function () { return i1.MatDialogClose; }), selector: "[mat-dialog-close], [matDialogClose]", inputs: ["type", "mat-dialog-close", "aria-label", "matDialogClose"], exportAs: ["matDialogClose"] }] });
108
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfAcknowledgeDialogComponent, decorators: [{
109
+ type: Component,
110
+ args: [{
111
+ selector: 'mtna-wf-acknowledge-dialog',
112
+ templateUrl: 'acknowledge-dialog.component.html',
113
+ }]
114
+ }], ctorParameters: function () { return [{ type: i4.MtnaWfFormItemDialogData, decorators: [{
115
+ type: Inject,
116
+ args: [MAT_DIALOG_DATA]
117
+ }] }, { type: i1.MatDialogRef }]; } });
118
+ /**
119
+ * Component that wraps an MtnaForm item.
120
+ *
121
+ * ChangeDetectionStrategy.OnPush was not working as of 9/19/2018.
122
+ * Dynamic components in the ValueItemComponent were not being initialized (ngOnInit was never called).
123
+ *
124
+ * @export
125
+ */
126
+ export class MtnaWfFormItemComponent {
127
+ constructor(_elementRef, uiService) {
128
+ this._elementRef = _elementRef;
129
+ this.uiService = uiService;
130
+ this.visible = true;
131
+ this.readonly = false;
132
+ this.parentIds = new Array();
133
+ this.focusedSection = new EventEmitter();
134
+ this.indicatorStatus = 'INACTIVE';
135
+ }
136
+ get elementId() {
137
+ return this.item ? this.item.instanceId : '';
138
+ }
139
+ ngOnInit() {
140
+ if (isConditionalItem(this.item)) {
141
+ this.visible = !this.item.hideOnDisable || !this.item.disabled;
142
+ }
143
+ this.uiService.registerSelf(this);
144
+ this._elementRef.nativeElement.classList.add(`mtna-wf-${getItemClassSuffix(this.item.itemId)}`);
145
+ }
146
+ }
147
+ MtnaWfFormItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormItemComponent, deps: [{ token: i0.ElementRef }, { token: i5.MtnaWfUIService }], target: i0.ɵɵFactoryTarget.Component });
148
+ MtnaWfFormItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfFormItemComponent, selector: "mtna-wf-item", inputs: { item: "item", readonly: "readonly", control: "control", parentIds: "parentIds", step: "step" }, outputs: { focusedSection: "focusedSection" }, host: { properties: { "@mtnaWfExpandCollapse": "this.visible", "attr.id": "this.elementId" } }, ngImport: i0, template: "<mtna-annotations-indicator\n *ngIf=\"item.annotationEnabled\"\n [annotatableId]=\"item.annotatableId\"\n color=\"primary\"\n [count]=\"annotations$ | async\"\n (status)=\"indicatorStatus = $event\"\n></mtna-annotations-indicator>\n\n<ng-container [ngSwitch]=\"item.itemId | getObjectType\">\n <mtna-wf-section\n *ngSwitchCase=\"'sectionimpl'\"\n [control]=\"$any(control)\"\n [item]=\"$any(item)\"\n [mtnaHighlight]=\"indicatorStatus === 'ACTIVE'\"\n [parentIds]=\"parentIds.concat(item.instanceId)\"\n [readonly]=\"readonly\"\n [step]=\"step\"\n (focused)=\"focusedSection.emit($event)\"\n ></mtna-wf-section>\n\n <mtna-wf-group\n *ngSwitchCase=\"'formitemgroupimpl'\"\n [indicatorStatus]=\"indicatorStatus\"\n [item]=\"$any(item)\"\n [control]=\"$any(control)\"\n [mtnaHighlight]=\"indicatorStatus === 'ACTIVE' && (!!item.descriptiveText || !!item.questionText)\"\n [parentIds]=\"parentIds.concat(item.instanceId)\"\n [readonly]=\"readonly\"\n ></mtna-wf-group>\n\n <mtna-wf-repeatable-item-container\n *ngSwitchCase=\"'repeatableitem'\"\n [indicatorStatus]=\"indicatorStatus\"\n [item]=\"$any(item)\"\n [control]=\"$any(control)\"\n [mtnaHighlight]=\"indicatorStatus === 'ACTIVE' && (!!item.descriptiveText || !!item.questionText)\"\n [parentIds]=\"parentIds.concat(item.instanceId)\"\n [readonly]=\"readonly\"\n ></mtna-wf-repeatable-item-container>\n\n <mtna-wf-value-item\n *ngSwitchDefault\n [indicatorStatus]=\"indicatorStatus\"\n [item]=\"$any(item)\"\n [control]=\"control\"\n [mtnaHighlight]=\"indicatorStatus === 'ACTIVE' && (!!item.descriptiveText || !!item.questionText)\"\n [parentIds]=\"parentIds.concat(item.instanceId)\"\n [readonly]=\"readonly\"\n ></mtna-wf-value-item>\n</ng-container>\n", styles: ["mtna-wf-item{display:block;position:relative}mtna-wf-item mtna-annotations-indicator{position:absolute;top:0;right:0;z-index:2}\n"], components: [{ type: i0.forwardRef(function () { return i6.MtnaAnnotationsIndicatorComponent; }), selector: "mtna-annotations-indicator", inputs: ["color", "annotatableId", "annotatableItemName", "count"], outputs: ["status"] }, { type: i0.forwardRef(function () { return MtnaWfFormSectionComponent; }), selector: "mtna-wf-section", inputs: ["indicatorStatus", "item", "readonly", "step", "control", "parentIds"], outputs: ["focused"] }, { type: i0.forwardRef(function () { return MtnaWfFormGroupComponent; }), selector: "mtna-wf-group", inputs: ["control", "indicatorStatus", "item", "parentIds", "readonly"] }, { type: i0.forwardRef(function () { return RepeatableItemContainerComponent; }), selector: "mtna-wf-repeatable-item-container", inputs: ["indicatorStatus", "item", "control", "parentIds", "readonly"] }, { type: i0.forwardRef(function () { return ValueItemComponent; }), selector: "mtna-wf-value-item", inputs: ["control", "inList", "indicatorStatus", "item", "parentIds", "readonly"] }], directives: [{ type: i0.forwardRef(function () { return i3.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i0.forwardRef(function () { return i3.NgSwitch; }), selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i0.forwardRef(function () { return i3.NgSwitchCase; }), selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i0.forwardRef(function () { return i7.MtnaHighlightDirective; }), selector: "[mtnaHighlight]", inputs: ["mtnaHighlight", "mtnaHighlightColor"], exportAs: ["mtnaHighlight"] }, { type: i0.forwardRef(function () { return i3.NgSwitchDefault; }), selector: "[ngSwitchDefault]" }], pipes: { "async": i0.forwardRef(function () { return i3.AsyncPipe; }), "getObjectType": i0.forwardRef(function () { return i8.GetObjectTypePipe; }) }, animations: [MTNA_WF_EXPAND_COLLAPSE], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
149
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormItemComponent, decorators: [{
150
+ type: Component,
151
+ args: [{
152
+ selector: 'mtna-wf-item',
153
+ templateUrl: './form-item.component.html',
154
+ styleUrls: ['./form-item.component.scss'],
155
+ changeDetection: ChangeDetectionStrategy.OnPush,
156
+ encapsulation: ViewEncapsulation.None,
157
+ animations: [MTNA_WF_EXPAND_COLLAPSE],
158
+ }]
159
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i5.MtnaWfUIService }]; }, propDecorators: { visible: [{
160
+ type: HostBinding,
161
+ args: ['@mtnaWfExpandCollapse']
162
+ }], elementId: [{
163
+ type: HostBinding,
164
+ args: ['attr.id']
165
+ }], item: [{
166
+ type: Input
167
+ }], readonly: [{
168
+ type: Input
169
+ }], control: [{
170
+ type: Input
171
+ }], parentIds: [{
172
+ type: Input
173
+ }], step: [{
174
+ type: Input
175
+ }], focusedSection: [{
176
+ type: Output
177
+ }] } });
178
+ function getItemClassSuffix(itemId) {
179
+ // FIXME: surely there is a stronger/better way
180
+ switch (itemId) {
181
+ case FORM_ITEM_GROUP_IMPL_ID:
182
+ return 'group';
183
+ case SECTION_ID:
184
+ return 'section';
185
+ case TEXT_ITEM_ID:
186
+ return 'text';
187
+ case TITLE_ITEM_ID:
188
+ return 'title';
189
+ default:
190
+ return 'item';
191
+ }
192
+ }
193
+ /**
194
+ * A dialog that renders a form item.
195
+ */
196
+ export class MtnaWfFormItemDialogComponent {
197
+ constructor(data, dialogRef) {
198
+ this.data = data;
199
+ this.dialogRef = dialogRef;
200
+ }
201
+ }
202
+ MtnaWfFormItemDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormItemDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }], target: i0.ɵɵFactoryTarget.Component });
203
+ MtnaWfFormItemDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfFormItemDialogComponent, selector: "mtna-wf-form-item-dialog", ngImport: i0, template: "<h2 *ngIf=\"data.title as title\" mat-dialog-title>{{ title }}</h2>\n<mat-dialog-content>\n <mtna-wf-item *ngFor=\"let item of data.formItems\" [item]=\"item\" [readonly]=\"true\"></mtna-wf-item>\n</mat-dialog-content>\n<mat-dialog-actions align=\"end\">\n <button mat-button mat-dialog-close>Close</button>\n</mat-dialog-actions>\n", components: [{ type: MtnaWfFormItemComponent, selector: "mtna-wf-item", inputs: ["item", "readonly", "control", "parentIds", "step"], outputs: ["focusedSection"] }, { type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["type", "mat-dialog-close", "aria-label", "matDialogClose"], exportAs: ["matDialogClose"] }] });
204
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormItemDialogComponent, decorators: [{
205
+ type: Component,
206
+ args: [{
207
+ selector: 'mtna-wf-form-item-dialog',
208
+ templateUrl: 'form-item-dialog.component.html',
209
+ }]
210
+ }], ctorParameters: function () { return [{ type: i4.MtnaWfFormItemDialogData, decorators: [{
211
+ type: Inject,
212
+ args: [MAT_DIALOG_DATA]
213
+ }] }, { type: i1.MatDialogRef }]; } });
214
+ export class MtnaWfFormSectionComponent {
215
+ constructor() {
216
+ this.indicatorStatus = 'INACTIVE';
217
+ this.readonly = false;
218
+ this.parentIds = new Array();
219
+ this.focused = new EventEmitter();
220
+ }
221
+ _trackByInstanceId(index, item) {
222
+ return item.instanceId;
223
+ }
224
+ }
225
+ MtnaWfFormSectionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormSectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
226
+ MtnaWfFormSectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfFormSectionComponent, selector: "mtna-wf-section", inputs: { indicatorStatus: "indicatorStatus", item: "item", readonly: "readonly", step: "step", control: "control", parentIds: "parentIds" }, outputs: { focused: "focused" }, ngImport: i0, template: "<mtna-wf-step-card [step]=\"step\" [subtitle]=\"item.descriptiveText\" (focused)=\"focused.emit($event)\">\n <div cardContent>\n <ng-container *ngFor=\"let subItem of item.items; trackBy: _trackByInstanceId\">\n <mat-divider\n *ngIf=\"(subItem.itemId | getObjectType) === 'formitemgroupimpl' && item.items.indexOf(subItem) !== 0\"\n class=\"section-item-divider\"\n [inset]=\"true\"\n ></mat-divider>\n\n <mtna-wf-item\n [item]=\"subItem\"\n [readonly]=\"readonly\"\n [parentIds]=\"parentIds\"\n [control]=\"!!control && !!control.controls ? control.controls[subItem.instanceId] : undefined\"\n (focusedSection)=\"focused.emit($event)\"\n ></mtna-wf-item>\n </ng-container>\n </div>\n</mtna-wf-step-card>\n", styles: [":host{display:block}mat-divider.mat-divider-horizontal.mat-divider-inset.section-item-divider{margin-top:8px;margin-bottom:8px}\n"], components: [{ type: i9.MtnaWfStepCardComponent, selector: "mtna-wf-step-card", inputs: ["color", "step", "subtitle"], outputs: ["focused"] }, { type: i10.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { type: MtnaWfFormItemComponent, selector: "mtna-wf-item", inputs: ["item", "readonly", "control", "parentIds", "step"], outputs: ["focusedSection"] }], directives: [{ type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "getObjectType": i8.GetObjectTypePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
227
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormSectionComponent, decorators: [{
228
+ type: Component,
229
+ args: [{
230
+ selector: 'mtna-wf-section',
231
+ templateUrl: './form-section.component.html',
232
+ styleUrls: ['./form-section.component.scss'],
233
+ changeDetection: ChangeDetectionStrategy.OnPush,
234
+ }]
235
+ }], propDecorators: { indicatorStatus: [{
236
+ type: Input
237
+ }], item: [{
238
+ type: Input
239
+ }], readonly: [{
240
+ type: Input
241
+ }], step: [{
242
+ type: Input
243
+ }], control: [{
244
+ type: Input
245
+ }], parentIds: [{
246
+ type: Input
247
+ }], focused: [{
248
+ type: Output
249
+ }] } });
250
+ export class MtnaWfFormGroupComponent {
251
+ constructor() {
252
+ this.indicatorStatus = 'INACTIVE';
253
+ this.parentIds = [];
254
+ this.readonly = false;
255
+ this.fullWidth = {
256
+ [PARAGRAPH_ANSWER_ITEM_ID]: true,
257
+ [FORM_ITEM_GROUP_IMPL_ID]: true,
258
+ [TEXT_ITEM_ID]: true,
259
+ [TITLE_ITEM_ID]: true,
260
+ };
261
+ /**
262
+ * If form is readonly & all child items are one of the specified types below,
263
+ * we want to display this group's child items in a mat-list
264
+ */
265
+ this.inList = false;
266
+ }
267
+ get item() {
268
+ return this._item;
269
+ }
270
+ set item(item) {
271
+ this._item = item;
272
+ if (this.item) {
273
+ // A list item can only display a heading line & a small text line
274
+ // Compatible items should be items with short labels/headers & values
275
+ // Items with multiple options, or potential nested items should not be included
276
+ this.inList = this.item.items.every((i) => i.itemId === SHORT_ANSWER_ITEM_ID || i.itemId === DROPDOWN_ITEM_ID);
277
+ }
278
+ }
279
+ _trackByInstanceId(index, section) {
280
+ return section.instanceId;
281
+ }
282
+ }
283
+ MtnaWfFormGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
284
+ MtnaWfFormGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfFormGroupComponent, selector: "mtna-wf-group", inputs: { control: "control", indicatorStatus: "indicatorStatus", item: "item", parentIds: "parentIds", readonly: "readonly" }, ngImport: i0, template: "<ng-container *ngIf=\"item && control\">\n <mtna-wf-item-header\n *ngIf=\"!!item.questionText || !!item.descriptiveText\"\n [descriptiveText]=\"item.descriptiveText\"\n [disabled]=\"control.disabled\"\n [questionText]=\"item.questionText\"\n [required]=\"item.required\"\n ></mtna-wf-item-header>\n <ng-template #fullLayout>\n <div\n class=\"item-group-container\"\n [mtnaHighlight]=\"indicatorStatus === 'ACTIVE' && !item.questionText && !item.descriptiveText\"\n [formGroup]=\"control\"\n [ngClass]=\"item.layout\"\n >\n <mtna-wf-item\n *ngFor=\"let subItem of item.items; trackBy: _trackByInstanceId\"\n [class.row-item]=\"item.layout === 'ROW' && !fullWidth[subItem.itemId]\"\n [ngClass.lt-md]=\"'width-100'\"\n [item]=\"subItem\"\n [control]=\"control.controls[subItem.instanceId]\"\n [parentIds]=\"parentIds\"\n [readonly]=\"readonly\"\n ></mtna-wf-item>\n </div>\n </ng-template>\n\n <!-- When readonly, && all child items should be displayed in a mat-list-->\n <mat-list *ngIf=\"readonly && inList; else fullLayout\" [ngClass]=\"item.layout\">\n <mtna-wf-value-item\n *ngFor=\"let subItem of item.items | mtnaWfItemsWithValue; trackBy: _trackByInstanceId\"\n [class.row-item]=\"item.layout === 'ROW'\"\n [ngClass.lt-md]=\"'width-100'\"\n [item]=\"subItem\"\n [inList]=\"true\"\n [parentIds]=\"parentIds\"\n [readonly]=\"true\"\n ></mtna-wf-value-item>\n </mat-list>\n</ng-container>\n", styles: ["mtna-annotations-indicator+mtna-wf-group .item-group-container{padding-top:24px}mtna-wf-group .mtna-wf-group-header{margin-top:1rem}mtna-wf-group .mtna-wf-group-description{margin-bottom:1rem}mtna-wf-group mat-list mat-list-item [mat-line]{letter-spacing:.5px}mtna-wf-group mtna-wf-multiple-choice-item{display:block}mtna-wf-group .item-group-container>.mtna-wf-group{margin-top:1rem}mtna-wf-group .item-group-container>mtna-wf-item.mtna-wf-title~mtna-wf-item:not(.mtna-wf-title):not(.row-item){padding-left:16px}mtna-wf-group .item-group-container>mtna-wf-item.mtna-wf-title~mtna-wf-item:not(.mtna-wf-title):not(.row-item).width-100{width:calc(100% - 16px)}mtna-wf-group .item-group-container>mtna-wf-item:first-of-type{margin-top:0}mtna-wf-group .item-group-container.ROW>mtna-wf-item{margin-top:0}mtna-wf-group .item-group-container.ROW>*{display:block}mtna-wf-group .item-group-container .row-item{width:calc(50% - 16px);display:inline-block;margin:0 8px}mtna-wf-group .item-group-container .width-100{width:100%}mtna-wf-group .item-group-container .width-100.row-item{width:calc(100% - 16px)}mtna-wf-group mtna-wf-item-header+.item-group-container{padding:.35em .75em .625em}mtna-wf-group mtna-wf-item-header+.item-group-container>mtna-wf-item{margin-top:0}\n"], components: [{ type: i0.forwardRef(function () { return i11.ItemHeaderComponent; }), selector: "mtna-wf-item-header", inputs: ["descriptiveText", "disabled", "hideRequiredMarker", "invalid", "questionText", "required"] }, { type: i0.forwardRef(function () { return MtnaWfFormItemComponent; }), selector: "mtna-wf-item", inputs: ["item", "readonly", "control", "parentIds", "step"], outputs: ["focusedSection"] }, { type: i0.forwardRef(function () { return i12.MatList; }), selector: "mat-list, mat-action-list", inputs: ["disableRipple", "disabled"], exportAs: ["matList"] }, { type: i0.forwardRef(function () { return ValueItemComponent; }), selector: "mtna-wf-value-item", inputs: ["control", "inList", "indicatorStatus", "item", "parentIds", "readonly"] }], directives: [{ type: i0.forwardRef(function () { return i3.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i0.forwardRef(function () { return i7.MtnaHighlightDirective; }), selector: "[mtnaHighlight]", inputs: ["mtnaHighlight", "mtnaHighlightColor"], exportAs: ["mtnaHighlight"] }, { type: i0.forwardRef(function () { return i13.NgControlStatusGroup; }), selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i0.forwardRef(function () { return i13.FormGroupDirective; }), selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i0.forwardRef(function () { return i3.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i0.forwardRef(function () { return i14.DefaultClassDirective; }), selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { type: i0.forwardRef(function () { return i3.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "mtnaWfItemsWithValue": i0.forwardRef(function () { return i15.MtnaWfItemsWithValuePipe; }) }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
285
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormGroupComponent, decorators: [{
286
+ type: Component,
287
+ args: [{
288
+ selector: 'mtna-wf-group',
289
+ templateUrl: './form-group.component.html',
290
+ styleUrls: ['./form-group.component.scss'],
291
+ changeDetection: ChangeDetectionStrategy.OnPush,
292
+ encapsulation: ViewEncapsulation.None,
293
+ }]
294
+ }], propDecorators: { control: [{
295
+ type: Input
296
+ }], indicatorStatus: [{
297
+ type: Input
298
+ }], item: [{
299
+ type: Input
300
+ }], parentIds: [{
301
+ type: Input
302
+ }], readonly: [{
303
+ type: Input
304
+ }] } });
305
+ export class RepeatableItemContainerComponent {
306
+ constructor(manager) {
307
+ this.manager = manager;
308
+ this.indicatorStatus = 'INACTIVE';
309
+ this.parentIds = new Array();
310
+ this.readonly = false;
311
+ }
312
+ addItem() {
313
+ this.manager.changeMtnaFormItem(new MtnaWfFormItemChange(this.item.repeatableTemplateId, this.parentIds, 'ADD'));
314
+ }
315
+ removeItem(item) {
316
+ const conditionChanges = this.manager.generateConditionChangeArray(item, 'REMOVE');
317
+ this.manager.changeMtnaFormItem(new MtnaWfFormItemChange(item.instanceId, this.parentIds, 'REMOVE', conditionChanges));
318
+ }
319
+ }
320
+ RepeatableItemContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: RepeatableItemContainerComponent, deps: [{ token: i16.MtnaWfManagerService }], target: i0.ɵɵFactoryTarget.Component });
321
+ RepeatableItemContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: RepeatableItemContainerComponent, selector: "mtna-wf-repeatable-item-container", inputs: { indicatorStatus: "indicatorStatus", item: "item", control: "control", parentIds: "parentIds", readonly: "readonly" }, ngImport: i0, template: "<mtna-wf-item-header\n *ngIf=\"!!item.questionText || !!item.descriptiveText\"\n [descriptiveText]=\"item.descriptiveText\"\n [disabled]=\"control?.disabled || false\"\n [questionText]=\"item.questionText\"\n [required]=\"item.required\"\n></mtna-wf-item-header>\n<section [mtnaHighlight]=\"indicatorStatus === 'ACTIVE' && !item.questionText && !item.descriptiveText\">\n <mtna-wf-repeatable-item\n @repeatItemExpandCollapse\n *ngFor=\"let subitem of item.items; let first = first; trackBy: 'instanceId' | mtnaTrackByProperty\"\n >\n <button\n *ngIf=\"!readonly && item.items.length > item.minOccurrences\"\n mat-icon-button\n class=\"item-remove-button\"\n color=\"warn\"\n (click)=\"removeItem(subitem)\"\n matTooltip=\"Remove Item\"\n >\n <mat-icon>remove_circle</mat-icon>\n </button>\n <mtna-wf-item\n [item]=\"subitem\"\n [control]=\"!!control && !!control.controls ? control.controls[subitem.instanceId] : undefined\"\n [readonly]=\"readonly\"\n [parentIds]=\"parentIds\"\n ></mtna-wf-item>\n </mtna-wf-repeatable-item>\n</section>\n<button *ngIf=\"!readonly\" mat-raised-button (click)=\"addItem()\" class=\"new-item-button\" color=\"primary\">\n {{ item.additionalText || 'ADD' | uppercase }}\n</button>\n", styles: ["mtna-wf-repeatable-item-container{display:block}mtna-wf-repeatable-item-container>section>mtna-wf-repeatable-item{position:relative;padding:16px;border-style:dashed;border-width:4px;border-radius:4px;display:inline-block;margin:8px;max-width:100%}mtna-wf-repeatable-item-container>section>mtna-wf-repeatable-item .item-remove-button{position:absolute;top:-22px;left:-22px}mtna-wf-repeatable-item-container>section>mtna-wf-repeatable-item>mtna-wf-item:first-child{margin-top:0}mtna-wf-repeatable-item-container .new-item-button{margin-left:.75em}mtna-wf-repeatable-item-container>section{padding-left:.75em}mtna-wf-repeatable-item-container>section,mtna-wf-repeatable-item-container .new-item-button{margin-top:16px}\n"], components: [{ type: i11.ItemHeaderComponent, selector: "mtna-wf-item-header", inputs: ["descriptiveText", "disabled", "hideRequiredMarker", "invalid", "questionText", "required"] }, { type: i17.RepeatableItemComponent, selector: "mtna-wf-repeatable-item" }, { type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i18.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: MtnaWfFormItemComponent, selector: "mtna-wf-item", inputs: ["item", "readonly", "control", "parentIds", "step"], outputs: ["focusedSection"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.MtnaHighlightDirective, selector: "[mtnaHighlight]", inputs: ["mtnaHighlight", "mtnaHighlightColor"], exportAs: ["mtnaHighlight"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i19.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }], pipes: { "mtnaTrackByProperty": i7.MtnaTrackByPropertyPipe, "uppercase": i3.UpperCasePipe }, animations: [
322
+ trigger('repeatItemExpandCollapse', [
323
+ state('in', style({ height: '*', margin: '*', opacity: 1 })),
324
+ state('void', style({ height: 0, margin: 0, opacity: 0, visibility: 'hidden' })),
325
+ transition(':enter', [animate(COMPLEX_STANDARD, style({ height: '*', margin: '*', opacity: 1 }))]),
326
+ transition(':leave', animate(COMPLEX_STANDARD)),
327
+ ]),
328
+ ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
329
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: RepeatableItemContainerComponent, decorators: [{
330
+ type: Component,
331
+ args: [{
332
+ selector: 'mtna-wf-repeatable-item-container',
333
+ templateUrl: 'repeatable-item-container.component.html',
334
+ styleUrls: [`repeatable-item-container.component.scss`],
335
+ animations: [
336
+ trigger('repeatItemExpandCollapse', [
337
+ state('in', style({ height: '*', margin: '*', opacity: 1 })),
338
+ state('void', style({ height: 0, margin: 0, opacity: 0, visibility: 'hidden' })),
339
+ transition(':enter', [animate(COMPLEX_STANDARD, style({ height: '*', margin: '*', opacity: 1 }))]),
340
+ transition(':leave', animate(COMPLEX_STANDARD)),
341
+ ]),
342
+ ],
343
+ changeDetection: ChangeDetectionStrategy.OnPush,
344
+ encapsulation: ViewEncapsulation.None,
345
+ }]
346
+ }], ctorParameters: function () { return [{ type: i16.MtnaWfManagerService }]; }, propDecorators: { indicatorStatus: [{
347
+ type: Input
348
+ }], item: [{
349
+ type: Input
350
+ }], control: [{
351
+ type: Input
352
+ }], parentIds: [{
353
+ type: Input
354
+ }], readonly: [{
355
+ type: Input
356
+ }] } });
357
+ export class MtnaWfTableFormItemComponent {
358
+ constructor() {
359
+ this.indicatorStatus = 'INACTIVE';
360
+ this.readonly = false;
361
+ this.parentIds = new Array();
362
+ }
363
+ _trackByTableRow(index, row) {
364
+ return row.items
365
+ .filter((i) => !!i)
366
+ .map((item) => item.instanceId)
367
+ .join('');
368
+ }
369
+ }
370
+ MtnaWfTableFormItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfTableFormItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
371
+ MtnaWfTableFormItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfTableFormItemComponent, selector: "mtna-wf-table-item", inputs: { indicatorStatus: "indicatorStatus", item: "item", control: "control", readonly: "readonly", parentIds: "parentIds" }, ngImport: i0, template: "<table mat-table [dataSource]=\"item.tableRows\" [trackBy]=\"_trackByTableRow\">\n <ng-container *ngFor=\"let header of item.headers; let index = index\" [matColumnDef]=\"header\">\n <th mat-header-cell *matHeaderCellDef>{{ header }}</th>\n\n <td mat-cell *matCellDef=\"let rowItem\">\n <mtna-wf-item\n *ngIf=\"!!rowItem.items[index]\"\n [control]=\"!!control && !!control.controls ? control.controls[rowItem.items[index].instanceId] : undefined\"\n [item]=\"rowItem.items[index]\"\n [readonly]=\"readonly\"\n [parentIds]=\"parentIds\"\n ></mtna-wf-item>\n </td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"item.headers\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: item.headers\"></tr>\n</table>\n", styles: ["mtna-wf-table-item .mat-table{width:100%}mtna-wf-table-item .mat-table tbody tr td.mat-cell{padding:8px;vertical-align:top}mtna-wf-table-item .mat-table tbody tr td mtna-wf-group>.group{flex-direction:column;place-content:start start;align-items:start;justify-content:start}mtna-wf-table-item .mat-table tbody tr td mtna-wf-group>.group *{margin-top:0;margin-bottom:0}mtna-wf-table-item .mat-table tbody tr td mtna-wf-boolean-item>.mat-slide-toggle{margin-bottom:8px;margin-top:8px}mtna-wf-table-item .mat-table tbody tr td mtna-wf-repeatable-item-container .repeat-item-container:not(:first-of-type){margin-top:8px}mtna-wf-table-item .mat-table tbody tr td mtna-wf-repeatable-item-container .new-item-button{margin:8px 0}\n"], components: [{ type: i20.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { type: MtnaWfFormItemComponent, selector: "mtna-wf-item", inputs: ["item", "readonly", "control", "parentIds", "step"], outputs: ["focusedSection"] }, { type: i20.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { type: i20.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }], directives: [{ type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i20.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { type: i20.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { type: i20.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { type: i20.MatCellDef, selector: "[matCellDef]" }, { type: i20.MatCell, selector: "mat-cell, td[mat-cell]" }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i20.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { type: i20.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
372
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfTableFormItemComponent, decorators: [{
373
+ type: Component,
374
+ args: [{
375
+ selector: 'mtna-wf-table-item',
376
+ templateUrl: 'table-item.component.html',
377
+ styleUrls: ['table-item.component.scss'],
378
+ encapsulation: ViewEncapsulation.None,
379
+ changeDetection: ChangeDetectionStrategy.OnPush,
380
+ }]
381
+ }], propDecorators: { indicatorStatus: [{
382
+ type: Input
383
+ }], item: [{
384
+ type: Input
385
+ }], control: [{
386
+ type: Input
387
+ }], readonly: [{
388
+ type: Input
389
+ }], parentIds: [{
390
+ type: Input
391
+ }] } });
392
+ export class ValueItemComponent {
393
+ constructor(cdf, cfResolver, formManager, logger, whiteList) {
394
+ this.cdf = cdf;
395
+ this.cfResolver = cfResolver;
396
+ this.formManager = formManager;
397
+ this.logger = logger;
398
+ this.whiteList = whiteList;
399
+ this.inList = false;
400
+ this.indicatorStatus = 'INACTIVE';
401
+ this.parentIds = new Array();
402
+ this.readonly = false;
403
+ /** The list of pre-existing(non-dynamic) item types
404
+ * If this item's itemId does not match one of the following, then
405
+ * this item is a dynamic component registered by the client application
406
+ * & requires the ComponentFactory to create the component.
407
+ */
408
+ this.fixedItemTypes = [
409
+ 'booleanitem',
410
+ 'bulletedlistitem',
411
+ 'checkboxitem',
412
+ 'dateitem',
413
+ 'daterangeitem',
414
+ 'decimalansweritem',
415
+ 'documentationitem',
416
+ 'dropdownitem',
417
+ 'fileuploaditem',
418
+ 'multiplechoiceitem',
419
+ 'numberedlistitem',
420
+ 'offsetdaterangeitem',
421
+ 'paragraphansweritem',
422
+ 'shortansweritem',
423
+ 'tableitem',
424
+ 'textitem',
425
+ 'titleitem',
426
+ 'wholenumberansweritem',
427
+ 'yearquarterrangeitem',
428
+ ];
429
+ }
430
+ /**
431
+ * Sets a value on the control for any components that only emit a value &
432
+ * do not directly manipulate their control themselves, i.e. a FileUploadItem
433
+ *
434
+ * @param item the value to be set on the control
435
+ */
436
+ setValue(item) {
437
+ var _a, _b;
438
+ (_a = this.control) === null || _a === void 0 ? void 0 : _a.markAsDirty();
439
+ (_b = this.control) === null || _b === void 0 ? void 0 : _b.setValue(item);
440
+ }
441
+ /**
442
+ * Renders a dynamic component from a relevant type in the FormService (registered)components;
443
+ * ONLY if the item type(using itemId) does not match one of the existing fixedItemTypes
444
+ *
445
+ */
446
+ ngAfterViewInit() {
447
+ var _a, _b;
448
+ // Trim the itemId down to the relevant type
449
+ const newId = this.item.itemId.toLowerCase().split('.');
450
+ const type = newId[newId.length - 1];
451
+ // Check if type is not one of the fixedItemTypes
452
+ if (!this.fixedItemTypes.some((i) => i === type)) {
453
+ // Retrieve a relevant component type
454
+ const component = this.formManager.getDynamicComponent(type);
455
+ // if a type is returned, instantiate the component and set the input values, then mark
456
+ // the value item for changeDetection check
457
+ if (component) {
458
+ const componentFactory = this.cfResolver.resolveComponentFactory(component);
459
+ this.componentRef = (_a = this.itemHost) === null || _a === void 0 ? void 0 : _a.viewContainerRef.createComponent(componentFactory);
460
+ const instance = (_b = this.componentRef) === null || _b === void 0 ? void 0 : _b.instance;
461
+ if (instance) {
462
+ for (const input of componentFactory.inputs) {
463
+ const propName = input.propName;
464
+ // Forcefully assign every input from this to instance
465
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
466
+ instance[propName] = this[propName];
467
+ }
468
+ }
469
+ // Dynamic Component won't fire ngOnInit unless we detectChanges
470
+ this.cdf.detectChanges();
471
+ }
472
+ else if (!this.whiteList || !this.whiteList.itemTypes || !this.whiteList.itemTypes.some((t) => t === type)) {
473
+ this.logger.error(`No Component Found for ${type} - Ensure any dynamic components were registered in the service, or use the MtnaWfItemWhiteList to ignore this item.`);
474
+ }
475
+ }
476
+ }
477
+ ngOnChanges(changes) {
478
+ if (this.componentRef) {
479
+ for (const prop in changes) {
480
+ if (Object.prototype.hasOwnProperty.call(changes, prop)) {
481
+ const change = changes[prop];
482
+ if (!change.firstChange && isKey(this.componentRef.instance, prop)) {
483
+ this.componentRef.instance[prop] = change.currentValue;
484
+ }
485
+ }
486
+ }
487
+ }
488
+ }
489
+ /**
490
+ * Used to destroy the componentRef to a dynamic component, if it was rendered.
491
+ *
492
+ */
493
+ ngOnDestroy() {
494
+ if (this.componentRef) {
495
+ this.componentRef.destroy();
496
+ }
497
+ }
498
+ }
499
+ ValueItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ValueItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ComponentFactoryResolver }, { token: i16.MtnaWfManagerService }, { token: i7.MtnaLogger }, { token: MTNA_WF_ITEM_WHITELIST, optional: true }], target: i0.ɵɵFactoryTarget.Component });
500
+ ValueItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: ValueItemComponent, selector: "mtna-wf-value-item", inputs: { control: "control", inList: "inList", indicatorStatus: "indicatorStatus", item: "item", parentIds: "parentIds", readonly: "readonly" }, viewQueries: [{ propertyName: "itemHost", first: true, predicate: MtnaWfFormItemDirective, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container [ngSwitch]=\"item.itemId | getObjectType\">\n <h3 *ngSwitchCase=\"'titleitem'\" class=\"mtna-wf-title-item\" [mtnaHighlight]=\"indicatorStatus === 'ACTIVE'\">{{ item.value }}</h3>\n <p\n *ngSwitchCase=\"'textitem'\"\n [innerHTML]=\"$any(item.value) | mtnaWfSanitizeHtml\"\n class=\"mtna-wf-text-item\"\n [mtnaHighlight]=\"indicatorStatus === 'ACTIVE'\"\n ></p>\n\n <mtna-wf-boolean-item\n *ngSwitchCase=\"'booleanitem'\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [item]=\"$any(item)\"\n [control]=\"$any(control)\"\n [mtnaHighlight]=\"indicatorStatus === 'ACTIVE'\"\n [parentIds]=\"parentIds\"\n [readonly]=\"readonly\"\n ></mtna-wf-boolean-item>\n\n <mtna-wf-checkbox-item\n *ngSwitchCase=\"'checkboxitem'\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [item]=\"$any(item)\"\n [control]=\"$any(control)\"\n [parentIds]=\"parentIds\"\n [readonly]=\"readonly\"\n ></mtna-wf-checkbox-item>\n\n <ng-container *ngSwitchCase=\"'dateitem'\">\n <mtna-wf-date-item\n *ngIf=\"item | coerceDateItem as dateItem\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [format]=\"dateItem.format\"\n [item]=\"dateItem\"\n [control]=\"$any(control)\"\n [readonly]=\"readonly\"\n ></mtna-wf-date-item>\n </ng-container>\n\n <mtna-wf-date-range\n *ngSwitchCase=\"'offsetdaterangeitem'\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [item]=\"$any(item)\"\n [control]=\"$any(control)\"\n [readonly]=\"readonly\"\n ></mtna-wf-date-range>\n\n <mtna-wf-year-quarter-range-item\n *ngSwitchCase=\"'yearquarterrangeitem'\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [item]=\"$any(item)\"\n [control]=\"$any(control)\"\n [readonly]=\"readonly\"\n ></mtna-wf-year-quarter-range-item>\n\n <mtna-wf-dropdown-item\n *ngSwitchCase=\"'dropdownitem'\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [item]=\"$any(item)\"\n [inList]=\"inList\"\n [control]=\"$any(control)\"\n [readonly]=\"readonly\"\n ></mtna-wf-dropdown-item>\n\n <mtna-wf-file-upload-item\n *ngSwitchCase=\"'fileuploaditem'\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [item]=\"$any(item)\"\n [readonly]=\"readonly\"\n (file)=\"setValue($event)\"\n ></mtna-wf-file-upload-item>\n\n <mtna-wf-unordered-list-item\n *ngSwitchCase=\"'bulletedlistitem'\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [item]=\"$any(item)\"\n ></mtna-wf-unordered-list-item>\n\n <mtna-wf-ordered-list-item\n *ngSwitchCase=\"'numberedlistitem'\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [item]=\"$any(item)\"\n ></mtna-wf-ordered-list-item>\n\n <mtna-wf-multiple-choice-item\n *ngSwitchCase=\"'multiplechoiceitem'\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [item]=\"$any(item)\"\n [control]=\"$any(control)\"\n [parentIds]=\"parentIds\"\n [readonly]=\"readonly\"\n ></mtna-wf-multiple-choice-item>\n\n <mtna-wf-input-item\n *ngSwitchCase=\"'shortansweritem'\"\n mtnaWfShortAnswerItem\n [control]=\"$any(control)\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [inList]=\"inList\"\n [item]=\"$any(item)\"\n [readonly]=\"readonly\"\n ></mtna-wf-input-item>\n\n <mtna-wf-input-item\n *ngSwitchCase=\"'paragraphansweritem'\"\n mtnaWfParagraphItem\n [control]=\"$any(control)\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [inList]=\"inList\"\n [item]=\"$any(item)\"\n [readonly]=\"readonly\"\n ></mtna-wf-input-item>\n\n <mtna-wf-table-item\n *ngSwitchCase=\"'tableitem'\"\n [control]=\"$any(control)\"\n [indicatorStatus]=\"indicatorStatus\"\n [item]=\"$any(item)\"\n [readonly]=\"readonly\"\n [parentIds]=\"parentIds\"\n ></mtna-wf-table-item>\n\n <mtna-wf-input-item\n *ngSwitchCase=\"'decimalansweritem'\"\n mtnaWfDecimalItem\n [control]=\"$any(control)\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [inList]=\"inList\"\n [item]=\"$any(item)\"\n [readonly]=\"readonly\"\n ></mtna-wf-input-item>\n\n <mtna-wf-input-item\n *ngSwitchCase=\"'wholenumberansweritem'\"\n mtnaWfWholeNumberItem\n [control]=\"$any(control)\"\n [header]=\"itemHeader\"\n [indicatorStatus]=\"indicatorStatus\"\n [inList]=\"inList\"\n [item]=\"$any(item)\"\n [readonly]=\"readonly\"\n ></mtna-wf-input-item>\n\n <!-- DYNAMIC COMPONENT CONTAINER -->\n <ng-template *ngSwitchDefault formItemHost></ng-template>\n</ng-container>\n\n<ng-template #itemHeader let-hideRequiredMarker>\n <mtna-wf-item-header\n *ngIf=\"!!item.questionText || !!item.descriptiveText\"\n [descriptiveText]=\"item.descriptiveText\"\n [disabled]=\"control?.disabled\"\n [hideRequiredMarker]=\"hideRequiredMarker\"\n [invalid]=\"control?.invalid && (control?.dirty || control?.touched)\"\n [questionText]=\"item.questionText\"\n [required]=\"item.required\"\n ></mtna-wf-item-header>\n</ng-template>\n", components: [{ type: i0.forwardRef(function () { return MtnaWfBooleanComponent; }), selector: "mtna-wf-boolean-item" }, { type: i0.forwardRef(function () { return MtnaWfCheckboxComponent; }), selector: "mtna-wf-checkbox-item", inputs: ["color"] }, { type: i0.forwardRef(function () { return i21.MtnaWfDateComponent; }), selector: "mtna-wf-date-item", inputs: ["format", "rangeLimits"] }, { type: i0.forwardRef(function () { return i22.MtnaWfDateRangeComponent; }), selector: "mtna-wf-date-range" }, { type: i0.forwardRef(function () { return i23.MtnaWfYearQuarterRangeComponent; }), selector: "mtna-wf-year-quarter-range-item" }, { type: i0.forwardRef(function () { return i24.MtnaWfDropdownComponent; }), selector: "mtna-wf-dropdown-item" }, { type: i0.forwardRef(function () { return i25.MtnaWfFileUploadComponent; }), selector: "mtna-wf-file-upload-item", inputs: ["header", "indicatorStatus", "item", "readonly"], outputs: ["file"] }, { type: i0.forwardRef(function () { return i26.MtnaWfUnorderedListItemComponent; }), selector: "mtna-wf-unordered-list-item", inputs: ["header", "indicatorStatus", "item"] }, { type: i0.forwardRef(function () { return i27.MtnaWfOrderedListItemComponent; }), selector: "mtna-wf-ordered-list-item", inputs: ["header", "indicatorStatus", "item"] }, { type: i0.forwardRef(function () { return MtnaWfMultipleChoiceComponent; }), selector: "mtna-wf-multiple-choice-item" }, { type: i0.forwardRef(function () { return i28.MtnaWfInputComponent; }), selector: "mtna-wf-input-item[mtnaWfDecimalItem],\n mtna-wf-input-item[mtnaWfParagraphItem],\n mtna-wf-input-item[mtnaWfShortAnswerItem],\n mtna-wf-input-item[mtnaWfWholeNumberItem]," }, { type: i0.forwardRef(function () { return MtnaWfTableFormItemComponent; }), selector: "mtna-wf-table-item", inputs: ["indicatorStatus", "item", "control", "readonly", "parentIds"] }, { type: i0.forwardRef(function () { return i11.ItemHeaderComponent; }), selector: "mtna-wf-item-header", inputs: ["descriptiveText", "disabled", "hideRequiredMarker", "invalid", "questionText", "required"] }], directives: [{ type: i0.forwardRef(function () { return i3.NgSwitch; }), selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i0.forwardRef(function () { return i3.NgSwitchCase; }), selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i0.forwardRef(function () { return i7.MtnaHighlightDirective; }), selector: "[mtnaHighlight]", inputs: ["mtnaHighlight", "mtnaHighlightColor"], exportAs: ["mtnaHighlight"] }, { type: i0.forwardRef(function () { return i3.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i0.forwardRef(function () { return i3.NgSwitchDefault; }), selector: "[ngSwitchDefault]" }, { type: i0.forwardRef(function () { return i29.MtnaWfFormItemDirective; }), selector: "[formItemHost]" }], pipes: { "getObjectType": i0.forwardRef(function () { return i8.GetObjectTypePipe; }), "mtnaWfSanitizeHtml": i0.forwardRef(function () { return i30.MtnaWfSanitizeHtmlPipe; }), "coerceDateItem": i0.forwardRef(function () { return i31.CoerceDateItemPipe; }) }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
501
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ValueItemComponent, decorators: [{
502
+ type: Component,
503
+ args: [{
504
+ selector: 'mtna-wf-value-item',
505
+ templateUrl: './value-item.component.html',
506
+ changeDetection: ChangeDetectionStrategy.OnPush,
507
+ }]
508
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ComponentFactoryResolver }, { type: i16.MtnaWfManagerService }, { type: i7.MtnaLogger }, { type: undefined, decorators: [{
509
+ type: Optional
510
+ }, {
511
+ type: Inject,
512
+ args: [MTNA_WF_ITEM_WHITELIST]
513
+ }] }]; }, propDecorators: { itemHost: [{
514
+ type: ViewChild,
515
+ args: [MtnaWfFormItemDirective]
516
+ }], control: [{
517
+ type: Input
518
+ }], inList: [{
519
+ type: Input
520
+ }], indicatorStatus: [{
521
+ type: Input
522
+ }], item: [{
523
+ type: Input
524
+ }], parentIds: [{
525
+ type: Input
526
+ }], readonly: [{
527
+ type: Input
528
+ }] } });
529
+ export class MtnaWfMultipleChoiceComponent extends BaseSingleSelectionParent {
530
+ constructor(uiService) {
531
+ super(uiService);
532
+ }
533
+ }
534
+ MtnaWfMultipleChoiceComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfMultipleChoiceComponent, deps: [{ token: i5.MtnaWfUIService }], target: i0.ɵɵFactoryTarget.Component });
535
+ MtnaWfMultipleChoiceComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfMultipleChoiceComponent, selector: "mtna-wf-multiple-choice-item", usesInheritance: true, ngImport: i0, template: "<ng-container *ngTemplateOutlet=\"header\"></ng-container>\n<ng-container *ngIf=\"control\">\n <div class=\"mtna-wf-error-container\">\n <ng-container *ngIf=\"control.invalid && (control.dirty || control.touched)\">\n <mat-error *ngFor=\"let error of control.errors | keyvalue\">\n {{ error | mtnaWfGetControlError : item }}\n </mat-error>\n </ng-container>\n </div>\n <mat-radio-group class=\"control-item-content\" [formControl]=\"control\" (change)=\"selectionChange($event)\">\n <ng-container *ngFor=\"let opt of item.options; trackBy: _trackByOptionId\">\n <mat-radio-button [disableRipple]=\"readonly\" [value]=\"opt.option.id\">{{ opt.option.name }}</mat-radio-button>\n <mtna-wf-item\n *ngIf=\"item.optionItemMap[opt.option.id] as subItem\"\n [item]=\"subItem\"\n [control]=\"!!controlWrapper && !!controlWrapper.controls ? controlWrapper.controls[subItem.instanceId] : undefined\"\n [parentIds]=\"parentIds.concat(opt.option.id)\"\n [readonly]=\"readonly\"\n ></mtna-wf-item>\n </ng-container>\n </mat-radio-group>\n</ng-container>\n", styles: [".mtna-wf-control-item .mat-form-field{width:100%}.mtna-wf-control-item .mtna-wf-error-container{font-size:75%;line-height:1;min-height:1em;margin-top:-.75rem}.mtna-wf-control-item .control-item-content{padding:.35em .75em .625em}.mtna-wf-control-item .mtna-wf-item-header~:not(.mtna-wf-error-container):not(.mat-list){padding-left:.75em}.mtna-wf-control-item .mtna-wf-item-header~:not(.mtna-wf-error-container):not(.mat-list).mat-form-field{width:calc(100% - .75em)}\n", "mtna-wf-multiple-choice-item .mat-radio-group{display:inline-block;max-width:100%;width:100%}mtna-wf-multiple-choice-item .mat-radio-button{display:block;max-width:100%}mtna-wf-multiple-choice-item .mat-radio-button:not(:last-of-type){margin-bottom:4px}mtna-wf-multiple-choice-item .mat-radio-button .mat-radio-label{white-space:normal}mtna-wf-multiple-choice-item .mat-radio-button+mtna-wf-item{padding-left:28px;margin-top:0}mtna-wf-multiple-choice-item.read-only .mat-radio-button .mat-radio-label{cursor:default}\n"], components: [{ type: i32.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }, { type: MtnaWfFormItemComponent, selector: "mtna-wf-item", inputs: ["item", "readonly", "control", "parentIds", "step"], outputs: ["focusedSection"] }], directives: [{ type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i33.MatError, selector: "mat-error", inputs: ["id"] }, { type: i32.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { type: i13.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i13.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], pipes: { "keyvalue": i3.KeyValuePipe, "mtnaWfGetControlError": i34.MtnaGetFormControlErrorPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
536
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfMultipleChoiceComponent, decorators: [{
537
+ type: Component,
538
+ args: [{
539
+ selector: 'mtna-wf-multiple-choice-item',
540
+ templateUrl: 'multiple-choice.component.html',
541
+ styleUrls: [
542
+ `../form-item-controls/form-control.scss`,
543
+ 'multiple-choice.component.scss',
544
+ ],
545
+ encapsulation: ViewEncapsulation.None,
546
+ changeDetection: ChangeDetectionStrategy.OnPush,
547
+ }]
548
+ }], ctorParameters: function () { return [{ type: i5.MtnaWfUIService }]; } });
549
+ export class MtnaWfBooleanComponent extends BaseParentItemControl {
550
+ constructor(uiService) {
551
+ super();
552
+ this.uiService = uiService;
553
+ }
554
+ toggleChange(change) {
555
+ this.uiService.toggleFormItems(this.item.option.enabledItems, this.item.option.disabledItems, change.checked, this.item.instanceId);
556
+ }
557
+ _trackByInstanceId(index, item) {
558
+ return item.value.instanceId;
559
+ }
560
+ }
561
+ MtnaWfBooleanComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfBooleanComponent, deps: [{ token: i5.MtnaWfUIService }], target: i0.ɵɵFactoryTarget.Component });
562
+ MtnaWfBooleanComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfBooleanComponent, selector: "mtna-wf-boolean-item", usesInheritance: true, ngImport: i0, template: "<ng-container *ngTemplateOutlet=\"header\"></ng-container>\n<mat-slide-toggle *ngIf=\"control\" [formControl]=\"control\" (change)=\"toggleChange($event)\">{{ item.option.option.name }}</mat-slide-toggle>\n<ng-container *ngIf=\"!!item.optionItemMap\">\n <mtna-wf-item\n *ngFor=\"let f of item.optionItemMap | keyvalue; trackBy: _trackByInstanceId\"\n [item]=\"f.value\"\n [control]=\"!!controlWrapper && controlWrapper.controls ? controlWrapper.controls[f.value.instanceId] : undefined\"\n [parentIds]=\"parentIds\"\n [readonly]=\"readonly\"\n ></mtna-wf-item>\n <ng-container> </ng-container\n></ng-container>\n", styles: [".mtna-wf-control-item .mat-form-field{width:100%}.mtna-wf-control-item .mtna-wf-error-container{font-size:75%;line-height:1;min-height:1em;margin-top:-.75rem}.mtna-wf-control-item .control-item-content{padding:.35em .75em .625em}.mtna-wf-control-item .mtna-wf-item-header~:not(.mtna-wf-error-container):not(.mat-list){padding-left:.75em}.mtna-wf-control-item .mtna-wf-item-header~:not(.mtna-wf-error-container):not(.mat-list).mat-form-field{width:calc(100% - .75em)}\n", "mtna-annotations-indicator+mtna-wf-value-item>mtna-wf-boolean-item{padding-right:24px}mtna-wf-boolean-item{display:block}mtna-wf-boolean-item .mat-slide-toggle{margin:4px 0}mtna-wf-boolean-item .mat-slide-toggle+mtna-wf-item{margin-top:0}mtna-wf-boolean-item .mat-slide-toggle~mtna-wf-item{padding-left:18px}mtna-wf-boolean-item.read-only .mat-slide-toggle.mat-disabled{opacity:.8}mtna-wf-boolean-item.read-only .mat-slide-toggle .mat-slide-toggle-label,mtna-wf-boolean-item.read-only .mat-slide-toggle .mat-slide-toggle-label .mat-slide-toggle-bar .mat-slide-toggle-thumb-container{cursor:default}mtna-wf-boolean-item .mat-slide-toggle{height:auto;min-height:24px}mtna-wf-boolean-item .mat-slide-toggle>.mat-slide-toggle-label>.mat-slide-toggle-content{white-space:normal}\n"], components: [{ type: i35.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["disabled", "disableRipple", "color", "tabIndex", "name", "id", "labelPosition", "aria-label", "aria-labelledby", "required", "checked", "aria-describedby"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { type: MtnaWfFormItemComponent, selector: "mtna-wf-item", inputs: ["item", "readonly", "control", "parentIds", "step"], outputs: ["focusedSection"] }], directives: [{ type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i13.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i13.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "keyvalue": i3.KeyValuePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
563
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfBooleanComponent, decorators: [{
564
+ type: Component,
565
+ args: [{
566
+ selector: 'mtna-wf-boolean-item',
567
+ templateUrl: 'boolean.component.html',
568
+ styleUrls: [
569
+ `../form-item-controls/form-control.scss`,
570
+ 'boolean.component.scss',
571
+ ],
572
+ encapsulation: ViewEncapsulation.None,
573
+ changeDetection: ChangeDetectionStrategy.OnPush,
574
+ }]
575
+ }], ctorParameters: function () { return [{ type: i5.MtnaWfUIService }]; } });
576
+ export class MtnaWfCheckboxComponent extends BaseParentItemControl {
577
+ constructor(dialogService, uiService) {
578
+ super();
579
+ this.dialogService = dialogService;
580
+ this.uiService = uiService;
581
+ this.destroyed$ = new Subject();
582
+ }
583
+ handleChange(change, index) {
584
+ var _a;
585
+ const option = this.item.options[index];
586
+ const formControl = (_a = this.control) === null || _a === void 0 ? void 0 : _a.controls[index];
587
+ // If the user is trying to make a selection with something that has an acknowledgement,
588
+ // show the acknowledge dialog first to get their consent.
589
+ // Note: we don't need to show the acknowledgement if the user is unchecking the box.
590
+ if (option.acknowledgement && (formControl === null || formControl === void 0 ? void 0 : formControl.value)) {
591
+ // Revert the checkbox to an unchecked state until they agree to the acknowledgement
592
+ formControl === null || formControl === void 0 ? void 0 : formControl.setValue(false);
593
+ this.dialogService
594
+ .verifyAcknowledgement(option.acknowledgement)
595
+ .pipe(takeUntil(this.destroyed$))
596
+ .subscribe((acknowledged) => {
597
+ if (acknowledged) {
598
+ formControl === null || formControl === void 0 ? void 0 : formControl.setValue(true);
599
+ this.uiService.toggleFormItems(option.enabledItems, option.disabledItems, change.checked, this.item.instanceId);
600
+ }
601
+ });
602
+ }
603
+ else {
604
+ this.uiService.toggleFormItems(option.enabledItems, option.disabledItems, change.checked, this.item.instanceId);
605
+ }
606
+ }
607
+ ngOnDestroy() {
608
+ this.destroyed$.next();
609
+ this.destroyed$.complete();
610
+ }
611
+ /**
612
+ * Display what the user already acknowledged for a given option.
613
+ * @param event the browser event when the button was invoked
614
+ * @param acknowledgementItem The form item that represents the acknowledgement text to display to the user.
615
+ * */
616
+ showAcknowledgement(event, acknowledgementItem) {
617
+ event.stopPropagation();
618
+ event.preventDefault();
619
+ this.dialogService.showAcknowledgement(acknowledgementItem);
620
+ }
621
+ /**
622
+ * Stop a browser event from propagating
623
+ * @param event the event to stop
624
+ */
625
+ stopEventPropagation(event) {
626
+ event.stopPropagation();
627
+ }
628
+ }
629
+ MtnaWfCheckboxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfCheckboxComponent, deps: [{ token: MtnaWfDialogService }, { token: i5.MtnaWfUIService }], target: i0.ɵɵFactoryTarget.Component });
630
+ MtnaWfCheckboxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfCheckboxComponent, selector: "mtna-wf-checkbox-item", inputs: { color: "color" }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngTemplateOutlet=\"header\"></ng-container>\n<div *ngIf=\"hasItemHeader\" class=\"mtna-wf-error-container\">\n <ng-container *ngIf=\"control?.invalid && (control?.dirty || control?.touched)\">\n <mat-error *ngFor=\"let error of control?.errors | keyvalue\">\n {{ error | mtnaWfGetControlError : item }}\n </mat-error>\n </ng-container>\n</div>\n<fieldset\n class=\"control-item-content\"\n [class.single-option]=\"item.options?.length === 1\"\n [mtnaHighlight]=\"indicatorStatus === 'ACTIVE' && !hasItemHeader\"\n>\n <ng-container *ngFor=\"let opt of item.options; let i = index; trackBy: _trackByOptionId\">\n <mat-checkbox\n *ngIf=\"!!control && !!control.controls && !!control.controls[i]\"\n [disableRipple]=\"readonly\"\n [formControl]=\"$any(control.controls[i])\"\n [color]=\"color\"\n (change)=\"handleChange($event, i)\"\n >{{ opt.option.name }}\n <button\n *ngIf=\"opt.acknowledgement && control.controls[i].value\"\n aria-label=\"Acknowledged. Click to view the agreement.\"\n class=\"acknowledge-verification-button\"\n mat-icon-button\n matTooltip=\"Acknowledged. Click to view the agreement.\"\n matTooltipShowDelay=\"800\"\n (click)=\"showAcknowledgement($event, opt.acknowledgement)\"\n (mousedown)=\"stopEventPropagation($event)\"\n (touchstart)=\"stopEventPropagation($event)\"\n >\n <mat-icon>verified</mat-icon>\n </button>\n </mat-checkbox>\n <ng-container *ngIf=\"item.optionItemMap[opt.option.id]\">\n <mtna-wf-item\n *ngIf=\"item.optionItemMap[opt.option.id] as subItem\"\n [item]=\"subItem\"\n [control]=\"!!controlWrapper && controlWrapper.controls ? controlWrapper.controls[subItem.instanceId] : undefined\"\n [readonly]=\"readonly\"\n [parentIds]=\"parentIds.concat(opt.option.id)\"\n ></mtna-wf-item>\n </ng-container>\n </ng-container>\n</fieldset>\n", styles: [".mtna-wf-control-item .mat-form-field{width:100%}.mtna-wf-control-item .mtna-wf-error-container{font-size:75%;line-height:1;min-height:1em;margin-top:-.75rem}.mtna-wf-control-item .control-item-content{padding:.35em .75em .625em}.mtna-wf-control-item .mtna-wf-item-header~:not(.mtna-wf-error-container):not(.mat-list){padding-left:.75em}.mtna-wf-control-item .mtna-wf-item-header~:not(.mtna-wf-error-container):not(.mat-list).mat-form-field{width:calc(100% - .75em)}\n", "mtna-wf-checkbox-item{display:flex;flex-direction:column;position:relative}mtna-wf-checkbox-item .mat-checkbox{display:block}mtna-wf-checkbox-item .mat-checkbox>.mat-checkbox-layout{display:block}mtna-wf-checkbox-item .mat-checkbox>.mat-checkbox-layout>.mat-checkbox-label{white-space:normal}mtna-wf-checkbox-item .mat-checkbox .acknowledge-verification-button{vertical-align:top;width:18px;height:18px;line-height:18px;margin-left:4px}mtna-wf-checkbox-item .mat-checkbox .acknowledge-verification-button .mat-icon{width:18px;height:18px;line-height:18px;font-size:18px}mtna-wf-checkbox-item fieldset{border:none;margin:0}mtna-wf-checkbox-item fieldset.control-item-content.single-option{padding:0}mtna-wf-checkbox-item .mat-checkbox+mtna-wf-item{margin-top:0;padding-left:24px}mtna-wf-checkbox-item.read-only .mat-checkbox{cursor:default}\n"], components: [{ type: i36.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "id", "labelPosition", "name", "required", "checked", "disabled", "indeterminate", "aria-describedby", "value"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i18.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: MtnaWfFormItemComponent, selector: "mtna-wf-item", inputs: ["item", "readonly", "control", "parentIds", "step"], outputs: ["focusedSection"] }], directives: [{ type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i33.MatError, selector: "mat-error", inputs: ["id"] }, { type: i7.MtnaHighlightDirective, selector: "[mtnaHighlight]", inputs: ["mtnaHighlight", "mtnaHighlightColor"], exportAs: ["mtnaHighlight"] }, { type: i13.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i13.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i19.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }], pipes: { "keyvalue": i3.KeyValuePipe, "mtnaWfGetControlError": i34.MtnaGetFormControlErrorPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
631
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfCheckboxComponent, decorators: [{
632
+ type: Component,
633
+ args: [{
634
+ selector: 'mtna-wf-checkbox-item',
635
+ templateUrl: 'checkbox.component.html',
636
+ styleUrls: [
637
+ `../form-item-controls/form-control.scss`,
638
+ 'checkbox.component.scss',
639
+ ],
640
+ encapsulation: ViewEncapsulation.None,
641
+ changeDetection: ChangeDetectionStrategy.OnPush,
642
+ }]
643
+ }], ctorParameters: function () { return [{ type: MtnaWfDialogService }, { type: i5.MtnaWfUIService }]; }, propDecorators: { color: [{
644
+ type: Input
645
+ }] } });
646
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-components.js","sourceRoot":"","sources":["../../../../../../projects/web-form-angular/src/lib/groups/group-components.ts","../../../../../../projects/web-form-angular/src/lib/groups/acknowledge-dialog.component.html","../../../../../../projects/web-form-angular/src/lib/groups/form-item.component.html","../../../../../../projects/web-form-angular/src/lib/groups/form-item-dialog.component.html","../../../../../../projects/web-form-angular/src/lib/groups/form-section.component.html","../../../../../../projects/web-form-angular/src/lib/groups/form-group.component.html","../../../../../../projects/web-form-angular/src/lib/groups/repeatable-item-container.component.html","../../../../../../projects/web-form-angular/src/lib/groups/table-item.component.html","../../../../../../projects/web-form-angular/src/lib/groups/value-item.component.html","../../../../../../projects/web-form-angular/src/lib/groups/multiple-choice.component.html","../../../../../../projects/web-form-angular/src/lib/groups/boolean.component.html","../../../../../../projects/web-form-angular/src/lib/groups/checkbox.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACjF,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EAIT,YAAY,EACZ,WAAW,EACX,MAAM,EACN,UAAU,EACV,KAAK,EAIL,QAAQ,EACR,MAAM,EAEN,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AAIvB,OAAO,EAAE,eAAe,EAA2B,MAAM,0BAA0B,CAAC;AAGpF,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAGtC,OAAO,EAGL,gBAAgB,EAChB,uBAAuB,EAGvB,iBAAiB,EACjB,oBAAoB,EAEpB,wBAAwB,EAGxB,UAAU,EACV,oBAAoB,EAGpB,YAAY,EACZ,aAAa,GAEd,MAAM,mBAAmB,CAAC;AAE3B,OAAO,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,gBAAgB,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAC;AAG/E,OAAO,EAAE,qBAAqB,EAAE,MAAM,0DAA0D,CAAC;AACjG,OAAO,EAAE,yBAAyB,EAAE,MAAM,8DAA8D,CAAC;AACzG,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAEtE,OAAO,EAAE,sBAAsB,EAAuB,MAAM,0BAA0B,CAAC;AACvF,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGzE,MAAM,OAAO,mBAAmB;IAC9B,YAAoB,MAAiB;QAAjB,WAAM,GAAN,MAAM,CAAW;IAAG,CAAC;IAEzC;;;OAGG;IACH,mBAAmB,CAAC,mBAA4B;QAC9C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,6BAA6B,EAAE;YAC9C,iBAAiB,EAAE,IAAI;YACvB,IAAI,EAAE,IAAI,wBAAwB,CAAC,mBAAmB,CAAC,KAAK,EAAE,mBAAmB,CAAC,KAAK,CAAC,KAAK,IAAI,iBAAiB,CAAC;YACnH,YAAY,EAAE,KAAK;YACnB,WAAW,EAAE,IAAI;YACjB,QAAQ,EAAE,OAAO;SAClB,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACH,qBAAqB,CAAC,mBAA4B;QAChD,OAAO,IAAI,CAAC,MAAM;aACf,IAAI,CAAC,gCAAgC,EAAE;YACtC,iBAAiB,EAAE,IAAI;YACvB,IAAI,EAAE,IAAI,wBAAwB,CAAC,mBAAmB,CAAC,KAAK,EAAE,mBAAmB,CAAC,KAAK,CAAC,KAAK,IAAI,iBAAiB,CAAC;YACnH,YAAY,EAAE,IAAI;YAClB,WAAW,EAAE,IAAI;YACjB,QAAQ,EAAE,OAAO;SAClB,CAAC;aACD,WAAW,EAAE,CAAC;IACnB,CAAC;;iHAhCU,mBAAmB;qHAAnB,mBAAmB,cADN,MAAM;4FACnB,mBAAmB;kBAD/B,UAAU;mBAAC,EAAE,UAAU,EAAE,MAAM,EAAE;;AAoClC;;;;GAIG;AAEH,8CAA8C;AAE9C;;GAEG;AAKH,MAAM,OAAO,gCAAgC;IAC3C,YACkC,IAA8B,EACvD,SAAkE;QADzC,SAAI,GAAJ,IAAI,CAA0B;QACvD,cAAS,GAAT,SAAS,CAAyD;IACxE,CAAC;;8HAJO,gCAAgC,kBAEjC,eAAe;kHAFd,gCAAgC,kECtH7C,4bAQA,0DDqIa,uBAAuB;4FAvBvB,gCAAgC;kBAJ5C,SAAS;mBAAC;oBACT,QAAQ,EAAE,4BAA4B;oBACtC,WAAW,EAAE,mCAAmC;iBACjD;;0BAGI,MAAM;2BAAC,eAAe;;AAK3B;;;;;;;GAOG;AASH,MAAM,OAAO,uBAAuB;IAmBlC,YAAoB,WAAuB,EAAU,SAA0B;QAA3D,gBAAW,GAAX,WAAW,CAAY;QAAU,cAAS,GAAT,SAAS,CAAiB;QAlBzC,YAAO,GAAG,IAAI,CAAC;QAQ5C,aAAQ,GAAG,KAAK,CAAC;QAEjB,cAAS,GAAG,IAAI,KAAK,EAAU,CAAC;QAG/B,mBAAc,GAAG,IAAI,YAAY,EAAY,CAAC;QAGxD,oBAAe,GAA8B,UAAU,CAAC;IAE0B,CAAC;IAhBnF,IACI,SAAS;QACX,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;IAC/C,CAAC;IAeD,QAAQ;QACN,IAAI,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;YAChC,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;SAChE;QACD,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;QAElC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,WAAW,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAClG,CAAC;;qHA5BU,uBAAuB;yGAAvB,uBAAuB,6SE7IpC,mxDAkDA,iaF8Ja,0BAA0B,uLAsB1B,wBAAwB,uJA0DxB,gCAAgC,2KAgDhC,kBAAkB,o6BArMjB,CAAC,uBAAuB,CAAC;4FAE1B,uBAAuB;kBARnC,SAAS;mBAAC;oBACT,QAAQ,EAAE,cAAc;oBACxB,WAAW,EAAE,4BAA4B;oBACzC,SAAS,EAAE,CAAC,4BAA4B,CAAC;oBACzC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,UAAU,EAAE,CAAC,uBAAuB,CAAC;iBACtC;+HAEuC,OAAO;sBAA5C,WAAW;uBAAC,uBAAuB;gBAGhC,SAAS;sBADZ,WAAW;uBAAC,SAAS;gBAKb,IAAI;sBAAZ,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAEI,cAAc;sBAAvB,MAAM;;AAiBT,SAAS,kBAAkB,CAAC,MAAc;IACxC,+CAA+C;IAC/C,QAAQ,MAAM,EAAE;QACd,KAAK,uBAAuB;YAC1B,OAAO,OAAO,CAAC;QACjB,KAAK,UAAU;YACb,OAAO,SAAS,CAAC;QACnB,KAAK,YAAY;YACf,OAAO,MAAM,CAAC;QAChB,KAAK,aAAa;YAChB,OAAO,OAAO,CAAC;QACjB;YACE,OAAO,MAAM,CAAC;KACjB;AACH,CAAC;AAED;;GAEG;AAKH,MAAM,OAAO,6BAA6B;IACxC,YACkC,IAA8B,EACvD,SAAsD;QAD7B,SAAI,GAAJ,IAAI,CAA0B;QACvD,cAAS,GAAT,SAAS,CAA6C;IAC5D,CAAC;;2HAJO,6BAA6B,kBAE9B,eAAe;+GAFd,6BAA6B,gEGnM1C,gVAOA,uBHsIa,uBAAuB;4FAsDvB,6BAA6B;kBAJzC,SAAS;mBAAC;oBACT,QAAQ,EAAE,0BAA0B;oBACpC,WAAW,EAAE,iCAAiC;iBAC/C;;0BAGI,MAAM;2BAAC,eAAe;;AAW3B,MAAM,OAAO,0BAA0B;IANvC;QAOW,oBAAe,GAA8B,UAAU,CAAC;QAExD,aAAQ,GAAG,KAAK,CAAC;QAGjB,cAAS,GAAG,IAAI,KAAK,EAAU,CAAC;QAE/B,YAAO,GAAG,IAAI,YAAY,EAAY,CAAC;KAKlD;IAHC,kBAAkB,CAAC,KAAa,EAAE,IAAc;QAC9C,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;;wHAZU,0BAA0B;4GAA1B,0BAA0B,sOIhNvC,wxBAmBA,0XJ0Ha,uBAAuB;4FAmEvB,0BAA0B;kBANtC,SAAS;mBAAC;oBACT,QAAQ,EAAE,iBAAiB;oBAC3B,WAAW,EAAE,+BAA+B;oBAC5C,SAAS,EAAE,CAAC,+BAA+B,CAAC;oBAC5C,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;8BAEU,eAAe;sBAAvB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAEI,OAAO;sBAAhB,MAAM;;AAcT,MAAM,OAAO,wBAAwB;IAPrC;QASW,oBAAe,GAA8B,UAAU,CAAC;QAoBxD,cAAS,GAAkB,EAAE,CAAC;QAC9B,aAAQ,GAAG,KAAK,CAAC;QAE1B,cAAS,GAA8B;YACrC,CAAC,wBAAwB,CAAC,EAAE,IAAI;YAChC,CAAC,uBAAuB,CAAC,EAAE,IAAI;YAC/B,CAAC,YAAY,CAAC,EAAE,IAAI;YACpB,CAAC,aAAa,CAAC,EAAE,IAAI;SACtB,CAAC;QAEF;;;WAGG;QACH,WAAM,GAAG,KAAK,CAAC;KAKhB;IArCC,IACI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IAAI,IAAI,CAAC,IAA0C;QACjD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAElB,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,kEAAkE;YAClE,sEAAsE;YACtE,gFAAgF;YAChF,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,oBAAoB,IAAI,CAAC,CAAC,MAAM,KAAK,gBAAgB,CAAC,CAAC;SAChH;IACH,CAAC;IAoBD,kBAAkB,CAAC,KAAa,EAAE,OAAiB;QACjD,OAAO,OAAO,CAAC,UAAU,CAAC;IAC5B,CAAC;;sHAxCU,wBAAwB;0GAAxB,wBAAwB,qLKtOrC,ygDAwCA,ygDLqGa,uBAAuB,2UAmMvB,kBAAkB;4FA1GlB,wBAAwB;kBAPpC,SAAS;mBAAC;oBACT,QAAQ,EAAE,eAAe;oBACzB,WAAW,EAAE,6BAA6B;oBAC1C,SAAS,EAAE,CAAC,6BAA6B,CAAC;oBAC1C,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;iBACtC;8BAEU,OAAO;sBAAf,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBAGF,IAAI;sBADP,KAAK;gBAkBG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;;AAmCR,MAAM,OAAO,gCAAgC;IAO3C,YAAoB,OAA6B;QAA7B,YAAO,GAAP,OAAO,CAAsB;QANxC,oBAAe,GAA8B,UAAU,CAAC;QAGxD,cAAS,GAAG,IAAI,KAAK,EAAU,CAAC;QAChC,aAAQ,GAAG,KAAK,CAAC;IAE0B,CAAC;IAErD,OAAO;QACL,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,IAAI,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC;IACnH,CAAC;IAED,UAAU,CAAC,IAAc;QACvB,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,4BAA4B,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QACnF,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,IAAI,oBAAoB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,QAAQ,EAAE,gBAAgB,CAAC,CAAC,CAAC;IACzH,CAAC;;8HAhBU,gCAAgC;kHAAhC,gCAAgC,yMMhS7C,qxCAiCA,o5CN4Ga,uBAAuB,0oBAwItB;QACV,OAAO,CAAC,0BAA0B,EAAE;YAClC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;YAC5D,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC,CAAC;YAChF,UAAU,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,gBAAgB,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAClG,UAAU,CAAC,QAAQ,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC;SAChD,CAAC;KACH;4FAIU,gCAAgC;kBAf5C,SAAS;mBAAC;oBACT,QAAQ,EAAE,mCAAmC;oBAC7C,WAAW,EAAE,0CAA0C;oBACvD,SAAS,EAAE,CAAC,0CAA0C,CAAC;oBACvD,UAAU,EAAE;wBACV,OAAO,CAAC,0BAA0B,EAAE;4BAClC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;4BAC5D,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC,CAAC;4BAChF,UAAU,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,gBAAgB,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;4BAClG,UAAU,CAAC,QAAQ,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC;yBAChD,CAAC;qBACH;oBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;iBACtC;4GAEU,eAAe;sBAAvB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;;AAqBR,MAAM,OAAO,4BAA4B;IAPzC;QAQW,oBAAe,GAA8B,UAAU,CAAC;QAGxD,aAAQ,GAAG,KAAK,CAAC;QACjB,cAAS,GAAG,IAAI,KAAK,EAAU,CAAC;KAQ1C;IANC,gBAAgB,CAAC,KAAa,EAAE,GAAiB;QAC/C,OAAO,GAAG,CAAC,KAAK;aACb,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;aAClB,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC;aAC9B,IAAI,CAAC,EAAE,CAAC,CAAC;IACd,CAAC;;0HAZU,4BAA4B;8GAA5B,4BAA4B,0LO1TzC,6wBAkBA,k1BP2Ha,uBAAuB;4FA6KvB,4BAA4B;kBAPxC,SAAS;mBAAC;oBACT,QAAQ,EAAE,oBAAoB;oBAC9B,WAAW,EAAE,2BAA2B;oBACxC,SAAS,EAAE,CAAC,2BAA2B,CAAC;oBACxC,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;8BAEU,eAAe;sBAAvB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;;AAiBR,MAAM,OAAO,kBAAkB;IAyC7B,YACU,GAAsB,EACtB,UAAoC,EACpC,WAAiC,EACjC,MAAkB,EAGlB,SAA8B;QAN9B,QAAG,GAAH,GAAG,CAAmB;QACtB,eAAU,GAAV,UAAU,CAA0B;QACpC,gBAAW,GAAX,WAAW,CAAsB;QACjC,WAAM,GAAN,MAAM,CAAY;QAGlB,cAAS,GAAT,SAAS,CAAqB;QA3C/B,WAAM,GAAG,KAAK,CAAC;QACf,oBAAe,GAA8B,UAAU,CAAC;QAExD,cAAS,GAAG,IAAI,KAAK,EAAU,CAAC;QAChC,aAAQ,GAAG,KAAK,CAAC;QAK1B;;;;WAIG;QACH,mBAAc,GAAG;YACf,aAAa;YACb,kBAAkB;YAClB,cAAc;YACd,UAAU;YACV,eAAe;YACf,mBAAmB;YACnB,mBAAmB;YACnB,cAAc;YACd,gBAAgB;YAChB,oBAAoB;YACpB,kBAAkB;YAClB,qBAAqB;YACrB,qBAAqB;YACrB,iBAAiB;YACjB,WAAW;YACX,UAAU;YACV,WAAW;YACX,uBAAuB;YACvB,sBAAsB;SACvB,CAAC;IAUC,CAAC;IAEJ;;;;;OAKG;IACH,QAAQ,CAAC,IAAa;;QACpB,MAAA,IAAI,CAAC,OAAO,0CAAE,WAAW,EAAE,CAAC;QAC5B,MAAA,IAAI,CAAC,OAAO,0CAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED;;;;OAIG;IACH,eAAe;;QACb,4CAA4C;QAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACxD,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACrC,iDAAiD;QACjD,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,EAAE;YAChD,qCAAqC;YACrC,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;YAC7D,uFAAuF;YACvF,2CAA2C;YAC3C,IAAI,SAAS,EAAE;gBACb,MAAM,gBAAgB,GAAG,IAAI,CAAC,UAAU,CAAC,uBAAuB,CAAe,SAAS,CAAC,CAAC;gBAE1F,IAAI,CAAC,YAAY,GAAG,MAAA,IAAI,CAAC,QAAQ,0CAAE,gBAAgB,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;gBACtF,MAAM,QAAQ,GAAG,MAAA,IAAI,CAAC,YAAY,0CAAE,QAAQ,CAAC;gBAC7C,IAAI,QAAQ,EAAE;oBACZ,KAAK,MAAM,KAAK,IAAI,gBAAgB,CAAC,MAAM,EAAE;wBAC3C,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;wBAChC,sDAAsD;wBACtD,8DAA8D;wBAC9D,QAAQ,CAAC,QAA8B,CAAC,GAAG,IAAI,CAAC,QAAoC,CAAQ,CAAC;qBAC9F;iBACF;gBAED,gEAAgE;gBAChE,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;aAC1B;iBAAM,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,EAAE;gBAC5G,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,0BAA0B,IAAI,sHAAsH,CACrJ,CAAC;aACH;SACF;IACH,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,KAAK,MAAM,IAAI,IAAI,OAAO,EAAE;gBAC1B,IAAI,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE;oBACvD,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;oBAC7B,IAAI,CAAC,MAAM,CAAC,WAAW,IAAI,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE;wBAClE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,YAAY,CAAC;qBACxD;iBACF;aACF;SACF;IACH,CAAC;IAED;;;OAGG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;SAC7B;IACH,CAAC;;gHA1HU,kBAAkB,0JA+CnB,sBAAsB;oGA/CrB,kBAAkB,sPAElB,uBAAuB,qEQlVpC,gpKA2KA,0DR4Ta,sBAAsB,qFAwBtB,uBAAuB,snCAxCvB,6BAA6B,qYA7J7B,4BAA4B;4FAsB5B,kBAAkB;kBAL9B,SAAS;mBAAC;oBACT,QAAQ,EAAE,oBAAoB;oBAC9B,WAAW,EAAE,6BAA6B;oBAC1C,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;;0BA+CI,QAAQ;;0BACR,MAAM;2BAAC,sBAAsB;4CA7CI,QAAQ;sBAA3C,SAAS;uBAAC,uBAAuB;gBAEzB,OAAO;sBAAf,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;;AA8HR,MAAM,OAAO,6BAA8B,SAAQ,yBAA6C;IAC9F,YAAY,SAA0B;QACpC,KAAK,CAAC,SAAS,CAAC,CAAC;IACnB,CAAC;;2HAHU,6BAA6B;+GAA7B,6BAA6B,2FSvd1C,umCAsBA,ooCTuHa,uBAAuB;4FA0UvB,6BAA6B;kBAVzC,SAAS;mBAAC;oBACT,QAAQ,EAAE,8BAA8B;oBACxC,WAAW,EAAE,gCAAgC;oBAC7C,SAAS,EAAE;wBACT,yCAAyC;wBACzC,gCAAgC;qBACjC;oBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;;AAiBD,MAAM,OAAO,sBAAuB,SAAQ,qBAA+C;IACzF,YAAoB,SAA0B;QAC5C,KAAK,EAAE,CAAC;QADU,cAAS,GAAT,SAAS,CAAiB;IAE9C,CAAC;IAED,YAAY,CAAC,MAA4B;QACvC,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACtI,CAAC;IAED,kBAAkB,CAAC,KAAa,EAAE,IAAsC;QACtE,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC;IAC/B,CAAC;;oHAXU,sBAAsB;wGAAtB,sBAAsB,mFUvenC,wnBAYA,0iDViIa,uBAAuB;4FA0VvB,sBAAsB;kBAVlC,SAAS;mBAAC;oBACT,QAAQ,EAAE,sBAAsB;oBAChC,WAAW,EAAE,wBAAwB;oBACrC,SAAS,EAAE;wBACT,yCAAyC;wBACzC,wBAAwB;qBACzB;oBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;;AAyBD,MAAM,OAAO,uBAAwB,SAAQ,qBAA8C;IAKzF,YAAoB,aAAkC,EAAU,SAA0B;QACxF,KAAK,EAAE,CAAC;QADU,kBAAa,GAAb,aAAa,CAAqB;QAAU,cAAS,GAAT,SAAS,CAAiB;QAF1F,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;IAIjC,CAAC;IAED,YAAY,CAAC,MAAyB,EAAE,KAAa;;QACnD,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACxC,MAAM,WAAW,GAAG,MAAA,IAAI,CAAC,OAAO,0CAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;QAElD,wFAAwF;QACxF,0DAA0D;QAC1D,qFAAqF;QACrF,IAAI,MAAM,CAAC,eAAe,KAAI,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,KAAK,CAAA,EAAE;YAChD,oFAAoF;YACpF,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;YAC7B,IAAI,CAAC,aAAa;iBACf,qBAAqB,CAAC,MAAM,CAAC,eAAe,CAAC;iBAC7C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBAChC,SAAS,CAAC,CAAC,YAAY,EAAE,EAAE;gBAC1B,IAAI,YAAY,EAAE;oBAChB,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;oBAC5B,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,aAAa,EAAE,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBACjH;YACH,CAAC,CAAC,CAAC;SACN;aAAM;YACL,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,aAAa,EAAE,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACjH;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;IAC7B,CAAC;IAED;;;;SAIK;IACL,mBAAmB,CAAC,KAAY,EAAE,mBAA4B;QAC5D,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,mBAAmB,CAAC,CAAC;IAC9D,CAAC;IAED;;;OAGG;IACH,oBAAoB,CAAC,KAAY;QAC/B,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;;qHAvDU,uBAAuB,kBAKC,mBAAmB;yGAL3C,uBAAuB,gHW/fpC,m8DA8CA,+iEX+Fa,uBAAuB;4FAkXvB,uBAAuB;kBAVnC,SAAS;mBAAC;oBACT,QAAQ,EAAE,uBAAuB;oBACjC,WAAW,EAAE,yBAAyB;oBACtC,SAAS,EAAE;wBACT,yCAAyC;wBACzC,yBAAyB;qBAC1B;oBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;0DAMoC,mBAAmB,wDAJ7C,KAAK;sBAAb,KAAK","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Injectable,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { AbstractControl, FormArray, FormControl, FormGroup } from '@angular/forms';\nimport { MatCheckboxChange } from '@angular/material/checkbox';\nimport { ThemePalette } from '@angular/material/core';\nimport { MAT_DIALOG_DATA, MatDialog, MatDialogRef } from '@angular/material/dialog';\nimport { MatSlideToggleChange } from '@angular/material/slide-toggle';\n\nimport { isKey } from '@mtna/core-ts';\nimport { CanDestroyNotify, MtnaLogger } from '@mtna/core-angular';\nimport { AnnotationIndicatorStatus, IndicatorStatusRepeater } from '@mtna/pojo-social-angular';\nimport {\n  BooleanItem,\n  CheckboxItem,\n  DROPDOWN_ITEM_ID,\n  FORM_ITEM_GROUP_IMPL_ID,\n  FormItem,\n  FormItemGroupImpl,\n  isConditionalItem,\n  MtnaWfFormItemChange,\n  MultipleChoiceItem,\n  PARAGRAPH_ANSWER_ITEM_ID,\n  RepeatableItem,\n  Section,\n  SECTION_ID,\n  SHORT_ANSWER_ITEM_ID,\n  TableItem,\n  TableRowItem,\n  TEXT_ITEM_ID,\n  TITLE_ITEM_ID,\n  ValueItem,\n} from '@mtna/web-form-ts';\n\nimport { Observable, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { COMPLEX_STANDARD, MTNA_WF_EXPAND_COLLAPSE } from '../core/animations';\nimport { MtnaWfManagerService } from '../core/services/form-manager.service';\nimport { MtnaWfUIService } from '../core/services/ui.service';\nimport { BaseParentItemControl } from '../form-item-controls/base-parent-item-control.directive';\nimport { BaseSingleSelectionParent } from '../form-item-controls/base-single-selection-parent.directive';\nimport { MtnaWfFormItemDirective } from '../form/form-item.directive';\nimport { FormStep } from '../form-stepper/models/form-step.model';\nimport { MTNA_WF_ITEM_WHITELIST, MtnaWfItemWhiteList } from '../form/white-list.model';\nimport { MtnaWfFormItemDialogData } from './form-item-dialog-data.model';\n\n@Injectable({ providedIn: 'root' })\nexport class MtnaWfDialogService {\n  constructor(private dialog: MatDialog) {}\n\n  /**\n   * Display the acknowledgement the user agreed to for a given option.\n   * @param acknowledgementItem The {@link Section} that represents the acknowledgement text to display to the user.\n   */\n  showAcknowledgement(acknowledgementItem: Section) {\n    this.dialog.open(MtnaWfFormItemDialogComponent, {\n      closeOnNavigation: true,\n      data: new MtnaWfFormItemDialogData(acknowledgementItem.items, acknowledgementItem.title.value || 'Acknowledgement'),\n      disableClose: false,\n      hasBackdrop: true,\n      maxWidth: '500px',\n    });\n  }\n\n  /**\n   * Show some text in a dialog that the user needs to \"acknowledge\" before they can make a certain selection.\n   * @param acknowledgementItem The {@link Section} that represents the text displayed to the user for acknowledgement.\n   * @returns Whether the user acknowledges (agrees).\n   */\n  verifyAcknowledgement(acknowledgementItem: Section): Observable<boolean> {\n    return this.dialog\n      .open(MtnaWfAcknowledgeDialogComponent, {\n        closeOnNavigation: true,\n        data: new MtnaWfFormItemDialogData(acknowledgementItem.items, acknowledgementItem.title.value || 'Acknowledgement'),\n        disableClose: true,\n        hasBackdrop: true,\n        maxWidth: '500px',\n      })\n      .afterClosed();\n  }\n}\n\n/*\n * Due to the recursive nature of these form components, we had to combine all the TS into a single file.\n * Perhaps when we refactor this in the future to use dynamic components, this can be avoided.\n * Read more about the errors if they are not in the same file here: https://angular.io/errors/NG3003\n */\n\n// TODO: refactor, reduce code in here. mixins\n\n/**\n * A dialog that renders a form item that represents something the user needs to acknowledge.\n */\n@Component({\n  selector: 'mtna-wf-acknowledge-dialog',\n  templateUrl: 'acknowledge-dialog.component.html',\n})\nexport class MtnaWfAcknowledgeDialogComponent {\n  constructor(\n    @Inject(MAT_DIALOG_DATA) public data: MtnaWfFormItemDialogData,\n    public dialogRef: MatDialogRef<MtnaWfAcknowledgeDialogComponent, boolean>\n  ) {}\n}\n\n/**\n * Component that wraps an MtnaForm item.\n *\n * ChangeDetectionStrategy.OnPush was not working as of 9/19/2018.\n * Dynamic components in the ValueItemComponent were not being initialized (ngOnInit was never called).\n *\n * @export\n */\n@Component({\n  selector: 'mtna-wf-item',\n  templateUrl: './form-item.component.html',\n  styleUrls: ['./form-item.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  animations: [MTNA_WF_EXPAND_COLLAPSE],\n})\nexport class MtnaWfFormItemComponent implements OnInit {\n  @HostBinding('@mtnaWfExpandCollapse') visible = true;\n\n  @HostBinding('attr.id')\n  get elementId(): string {\n    return this.item ? this.item.instanceId : '';\n  }\n\n  @Input() item!: FormItem;\n  @Input() readonly = false;\n  @Input() control: AbstractControl | null | undefined;\n  @Input() parentIds = new Array<string>();\n  @Input() step: FormStep | null | undefined;\n\n  @Output() focusedSection = new EventEmitter<FormStep>();\n\n  annotations$?: Observable<number | null>;\n  indicatorStatus: AnnotationIndicatorStatus = 'INACTIVE';\n\n  constructor(private _elementRef: ElementRef, private uiService: MtnaWfUIService) {}\n\n  ngOnInit() {\n    if (isConditionalItem(this.item)) {\n      this.visible = !this.item.hideOnDisable || !this.item.disabled;\n    }\n    this.uiService.registerSelf(this);\n\n    this._elementRef.nativeElement.classList.add(`mtna-wf-${getItemClassSuffix(this.item.itemId)}`);\n  }\n}\n\nfunction getItemClassSuffix(itemId: string): string {\n  // FIXME: surely there is a stronger/better way\n  switch (itemId) {\n    case FORM_ITEM_GROUP_IMPL_ID:\n      return 'group';\n    case SECTION_ID:\n      return 'section';\n    case TEXT_ITEM_ID:\n      return 'text';\n    case TITLE_ITEM_ID:\n      return 'title';\n    default:\n      return 'item';\n  }\n}\n\n/**\n * A dialog that renders a form item.\n */\n@Component({\n  selector: 'mtna-wf-form-item-dialog',\n  templateUrl: 'form-item-dialog.component.html',\n})\nexport class MtnaWfFormItemDialogComponent {\n  constructor(\n    @Inject(MAT_DIALOG_DATA) public data: MtnaWfFormItemDialogData,\n    public dialogRef: MatDialogRef<MtnaWfFormItemDialogComponent>\n  ) {}\n}\n\n@Component({\n  selector: 'mtna-wf-section',\n  templateUrl: './form-section.component.html',\n  styleUrls: ['./form-section.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class MtnaWfFormSectionComponent implements IndicatorStatusRepeater {\n  @Input() indicatorStatus: AnnotationIndicatorStatus = 'INACTIVE';\n  @Input() item!: Section;\n  @Input() readonly = false;\n  @Input() step: FormStep | undefined | null;\n  @Input() control: FormGroup | null | undefined;\n  @Input() parentIds = new Array<string>();\n\n  @Output() focused = new EventEmitter<FormStep>();\n\n  _trackByInstanceId(index: number, item: FormItem) {\n    return item.instanceId;\n  }\n}\n\n@Component({\n  selector: 'mtna-wf-group',\n  templateUrl: './form-group.component.html',\n  styleUrls: ['./form-group.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MtnaWfFormGroupComponent implements IndicatorStatusRepeater {\n  @Input() control: FormGroup | null | undefined;\n  @Input() indicatorStatus: AnnotationIndicatorStatus = 'INACTIVE';\n\n  @Input()\n  get item(): FormItemGroupImpl | null | undefined {\n    return this._item;\n  }\n\n  set item(item: FormItemGroupImpl | null | undefined) {\n    this._item = item;\n\n    if (this.item) {\n      // A list item can only display a heading line & a small text line\n      // Compatible items should be items with short labels/headers & values\n      // Items with multiple options, or potential nested items should not be included\n      this.inList = this.item.items.every((i) => i.itemId === SHORT_ANSWER_ITEM_ID || i.itemId === DROPDOWN_ITEM_ID);\n    }\n  }\n\n  private _item: FormItemGroupImpl | null | undefined;\n\n  @Input() parentIds: Array<string> = [];\n  @Input() readonly = false;\n\n  fullWidth: { [id: string]: boolean } = {\n    [PARAGRAPH_ANSWER_ITEM_ID]: true,\n    [FORM_ITEM_GROUP_IMPL_ID]: true,\n    [TEXT_ITEM_ID]: true,\n    [TITLE_ITEM_ID]: true,\n  };\n\n  /**\n   * If form is readonly & all child items are one of the specified types below,\n   * we want to display this group's child items in a mat-list\n   */\n  inList = false;\n\n  _trackByInstanceId(index: number, section: FormItem) {\n    return section.instanceId;\n  }\n}\n\n@Component({\n  selector: 'mtna-wf-repeatable-item-container',\n  templateUrl: 'repeatable-item-container.component.html',\n  styleUrls: [`repeatable-item-container.component.scss`],\n  animations: [\n    trigger('repeatItemExpandCollapse', [\n      state('in', style({ height: '*', margin: '*', opacity: 1 })),\n      state('void', style({ height: 0, margin: 0, opacity: 0, visibility: 'hidden' })),\n      transition(':enter', [animate(COMPLEX_STANDARD, style({ height: '*', margin: '*', opacity: 1 }))]),\n      transition(':leave', animate(COMPLEX_STANDARD)),\n    ]),\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class RepeatableItemContainerComponent implements IndicatorStatusRepeater {\n  @Input() indicatorStatus: AnnotationIndicatorStatus = 'INACTIVE';\n  @Input() item!: RepeatableItem;\n  @Input() control: FormGroup | null | undefined;\n  @Input() parentIds = new Array<string>();\n  @Input() readonly = false;\n\n  constructor(private manager: MtnaWfManagerService) {}\n\n  addItem() {\n    this.manager.changeMtnaFormItem(new MtnaWfFormItemChange(this.item.repeatableTemplateId, this.parentIds, 'ADD'));\n  }\n\n  removeItem(item: FormItem) {\n    const conditionChanges = this.manager.generateConditionChangeArray(item, 'REMOVE');\n    this.manager.changeMtnaFormItem(new MtnaWfFormItemChange(item.instanceId, this.parentIds, 'REMOVE', conditionChanges));\n  }\n}\n\n@Component({\n  selector: 'mtna-wf-table-item',\n  templateUrl: 'table-item.component.html',\n  styleUrls: ['table-item.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class MtnaWfTableFormItemComponent implements IndicatorStatusRepeater {\n  @Input() indicatorStatus: AnnotationIndicatorStatus = 'INACTIVE';\n  @Input() item!: TableItem;\n  @Input() control: FormGroup | null | undefined;\n  @Input() readonly = false;\n  @Input() parentIds = new Array<string>();\n\n  _trackByTableRow(index: number, row: TableRowItem) {\n    return row.items\n      .filter((i) => !!i)\n      .map((item) => item.instanceId)\n      .join('');\n  }\n}\n\nimport type { BaseFormItem } from '../form/base-form-item.model';\n\n@Component({\n  selector: 'mtna-wf-value-item',\n  templateUrl: './value-item.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ValueItemComponent implements AfterViewInit, IndicatorStatusRepeater, OnChanges, OnDestroy {\n  /** the container for adding dynamic form items */\n  @ViewChild(MtnaWfFormItemDirective) itemHost: MtnaWfFormItemDirective | null | undefined;\n\n  @Input() control: AbstractControl | null | undefined;\n  @Input() inList = false;\n  @Input() indicatorStatus: AnnotationIndicatorStatus = 'INACTIVE';\n  @Input() item!: ValueItem<unknown>;\n  @Input() parentIds = new Array<string>();\n  @Input() readonly = false;\n\n  /** the reference to a dynamically rendered component */\n  componentRef: ComponentRef<BaseFormItem> | null | undefined;\n\n  /** The list of pre-existing(non-dynamic) item types\n   * If this item's itemId does not match one of the following, then\n   * this item is a dynamic component registered by the client application\n   * & requires the ComponentFactory to create the component.\n   */\n  fixedItemTypes = [\n    'booleanitem',\n    'bulletedlistitem',\n    'checkboxitem',\n    'dateitem',\n    'daterangeitem',\n    'decimalansweritem',\n    'documentationitem',\n    'dropdownitem',\n    'fileuploaditem',\n    'multiplechoiceitem',\n    'numberedlistitem',\n    'offsetdaterangeitem',\n    'paragraphansweritem',\n    'shortansweritem',\n    'tableitem',\n    'textitem',\n    'titleitem',\n    'wholenumberansweritem',\n    'yearquarterrangeitem',\n  ];\n\n  constructor(\n    private cdf: ChangeDetectorRef,\n    private cfResolver: ComponentFactoryResolver,\n    private formManager: MtnaWfManagerService,\n    private logger: MtnaLogger,\n    @Optional()\n    @Inject(MTNA_WF_ITEM_WHITELIST)\n    private whiteList: MtnaWfItemWhiteList\n  ) {}\n\n  /**\n   * Sets a value on the control for any components that only emit a value &\n   * do not directly manipulate their control themselves, i.e. a FileUploadItem\n   *\n   * @param item the value to be set on the control\n   */\n  setValue(item: unknown) {\n    this.control?.markAsDirty();\n    this.control?.setValue(item);\n  }\n\n  /**\n   * Renders a dynamic component from a relevant type in the FormService (registered)components;\n   * ONLY if the item type(using itemId) does not match one of the existing fixedItemTypes\n   *\n   */\n  ngAfterViewInit() {\n    // Trim the itemId down to the relevant type\n    const newId = this.item.itemId.toLowerCase().split('.');\n    const type = newId[newId.length - 1];\n    // Check if type is not one of the fixedItemTypes\n    if (!this.fixedItemTypes.some((i) => i === type)) {\n      // Retrieve a relevant component type\n      const component = this.formManager.getDynamicComponent(type);\n      // if a type is returned, instantiate the component and set the input values, then mark\n      // the value item for changeDetection check\n      if (component) {\n        const componentFactory = this.cfResolver.resolveComponentFactory<BaseFormItem>(component);\n\n        this.componentRef = this.itemHost?.viewContainerRef.createComponent(componentFactory);\n        const instance = this.componentRef?.instance;\n        if (instance) {\n          for (const input of componentFactory.inputs) {\n            const propName = input.propName;\n            // Forcefully assign every input from this to instance\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any\n            instance[propName as keyof BaseFormItem] = this[propName as keyof ValueItemComponent] as any;\n          }\n        }\n\n        // Dynamic Component won't fire ngOnInit unless we detectChanges\n        this.cdf.detectChanges();\n      } else if (!this.whiteList || !this.whiteList.itemTypes || !this.whiteList.itemTypes.some((t) => t === type)) {\n        this.logger.error(\n          `No Component Found for ${type} - Ensure any dynamic components were registered in the service, or use the MtnaWfItemWhiteList to ignore this item.`\n        );\n      }\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.componentRef) {\n      for (const prop in changes) {\n        if (Object.prototype.hasOwnProperty.call(changes, prop)) {\n          const change = changes[prop];\n          if (!change.firstChange && isKey(this.componentRef.instance, prop)) {\n            this.componentRef.instance[prop] = change.currentValue;\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * Used to destroy the componentRef to a dynamic component, if it was rendered.\n   *\n   */\n  ngOnDestroy() {\n    if (this.componentRef) {\n      this.componentRef.destroy();\n    }\n  }\n}\n\n@Component({\n  selector: 'mtna-wf-multiple-choice-item',\n  templateUrl: 'multiple-choice.component.html',\n  styleUrls: [\n    `../form-item-controls/form-control.scss`, // FIXME: these styles are getting duplicated like this\n    'multiple-choice.component.scss',\n  ],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class MtnaWfMultipleChoiceComponent extends BaseSingleSelectionParent<MultipleChoiceItem> {\n  constructor(uiService: MtnaWfUIService) {\n    super(uiService);\n  }\n}\n\n@Component({\n  selector: 'mtna-wf-boolean-item',\n  templateUrl: 'boolean.component.html',\n  styleUrls: [\n    `../form-item-controls/form-control.scss`, // FIXME: these styles are getting duplicated like this\n    'boolean.component.scss',\n  ],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class MtnaWfBooleanComponent extends BaseParentItemControl<BooleanItem, FormControl> {\n  constructor(private uiService: MtnaWfUIService) {\n    super();\n  }\n\n  toggleChange(change: MatSlideToggleChange) {\n    this.uiService.toggleFormItems(this.item.option.enabledItems, this.item.option.disabledItems, change.checked, this.item.instanceId);\n  }\n\n  _trackByInstanceId(index: number, item: { key: string; value: FormItem }) {\n    return item.value.instanceId;\n  }\n}\n\n@Component({\n  selector: 'mtna-wf-checkbox-item',\n  templateUrl: 'checkbox.component.html',\n  styleUrls: [\n    `../form-item-controls/form-control.scss`, // FIXME: these styles are getting duplicated like this\n    'checkbox.component.scss',\n  ],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class MtnaWfCheckboxComponent extends BaseParentItemControl<CheckboxItem, FormArray> implements CanDestroyNotify, OnDestroy {\n  @Input() color: ThemePalette;\n\n  destroyed$ = new Subject<void>();\n\n  constructor(private dialogService: MtnaWfDialogService, private uiService: MtnaWfUIService) {\n    super();\n  }\n\n  handleChange(change: MatCheckboxChange, index: number) {\n    const option = this.item.options[index];\n    const formControl = this.control?.controls[index];\n\n    // If the user is trying to make a selection with something that has an acknowledgement,\n    // show the acknowledge dialog first to get their consent.\n    // Note: we don't need to show the acknowledgement if the user is unchecking the box.\n    if (option.acknowledgement && formControl?.value) {\n      // Revert the checkbox to an unchecked state until they agree to the acknowledgement\n      formControl?.setValue(false);\n      this.dialogService\n        .verifyAcknowledgement(option.acknowledgement)\n        .pipe(takeUntil(this.destroyed$))\n        .subscribe((acknowledged) => {\n          if (acknowledged) {\n            formControl?.setValue(true);\n            this.uiService.toggleFormItems(option.enabledItems, option.disabledItems, change.checked, this.item.instanceId);\n          }\n        });\n    } else {\n      this.uiService.toggleFormItems(option.enabledItems, option.disabledItems, change.checked, this.item.instanceId);\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n    this.destroyed$.complete();\n  }\n\n  /**\n   * Display what the user already acknowledged for a given option.\n   * @param event the browser event when the button was invoked\n   * @param acknowledgementItem The form item that represents the acknowledgement text to display to the user.\n   * */\n  showAcknowledgement(event: Event, acknowledgementItem: Section) {\n    event.stopPropagation();\n    event.preventDefault();\n    this.dialogService.showAcknowledgement(acknowledgementItem);\n  }\n\n  /**\n   * Stop a browser event from propagating\n   * @param event the event to stop\n   */\n  stopEventPropagation(event: Event) {\n    event.stopPropagation();\n  }\n}\n","<h2 *ngIf=\"data.title as title\" mat-dialog-title>{{ title }}</h2>\n<mat-dialog-content>\n  <mtna-wf-item *ngFor=\"let item of data.formItems\" [item]=\"item\" [readonly]=\"true\"></mtna-wf-item>\n</mat-dialog-content>\n<mat-dialog-actions align=\"end\">\n  <button [mat-dialog-close]=\"false\" mat-button>CANCEL</button>\n  <button [mat-dialog-close]=\"true\" color=\"accent\" mat-raised-button>ACKNOWLEDGE</button>\n</mat-dialog-actions>\n","<mtna-annotations-indicator\n  *ngIf=\"item.annotationEnabled\"\n  [annotatableId]=\"item.annotatableId\"\n  color=\"primary\"\n  [count]=\"annotations$ | async\"\n  (status)=\"indicatorStatus = $event\"\n></mtna-annotations-indicator>\n\n<ng-container [ngSwitch]=\"item.itemId | getObjectType\">\n  <mtna-wf-section\n    *ngSwitchCase=\"'sectionimpl'\"\n    [control]=\"$any(control)\"\n    [item]=\"$any(item)\"\n    [mtnaHighlight]=\"indicatorStatus === 'ACTIVE'\"\n    [parentIds]=\"parentIds.concat(item.instanceId)\"\n    [readonly]=\"readonly\"\n    [step]=\"step\"\n    (focused)=\"focusedSection.emit($event)\"\n  ></mtna-wf-section>\n\n  <mtna-wf-group\n    *ngSwitchCase=\"'formitemgroupimpl'\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [item]=\"$any(item)\"\n    [control]=\"$any(control)\"\n    [mtnaHighlight]=\"indicatorStatus === 'ACTIVE' && (!!item.descriptiveText || !!item.questionText)\"\n    [parentIds]=\"parentIds.concat(item.instanceId)\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-group>\n\n  <mtna-wf-repeatable-item-container\n    *ngSwitchCase=\"'repeatableitem'\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [item]=\"$any(item)\"\n    [control]=\"$any(control)\"\n    [mtnaHighlight]=\"indicatorStatus === 'ACTIVE' && (!!item.descriptiveText || !!item.questionText)\"\n    [parentIds]=\"parentIds.concat(item.instanceId)\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-repeatable-item-container>\n\n  <mtna-wf-value-item\n    *ngSwitchDefault\n    [indicatorStatus]=\"indicatorStatus\"\n    [item]=\"$any(item)\"\n    [control]=\"control\"\n    [mtnaHighlight]=\"indicatorStatus === 'ACTIVE' && (!!item.descriptiveText || !!item.questionText)\"\n    [parentIds]=\"parentIds.concat(item.instanceId)\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-value-item>\n</ng-container>\n","<h2 *ngIf=\"data.title as title\" mat-dialog-title>{{ title }}</h2>\n<mat-dialog-content>\n  <mtna-wf-item *ngFor=\"let item of data.formItems\" [item]=\"item\" [readonly]=\"true\"></mtna-wf-item>\n</mat-dialog-content>\n<mat-dialog-actions align=\"end\">\n  <button mat-button mat-dialog-close>Close</button>\n</mat-dialog-actions>\n","<mtna-wf-step-card [step]=\"step\" [subtitle]=\"item.descriptiveText\" (focused)=\"focused.emit($event)\">\n  <div cardContent>\n    <ng-container *ngFor=\"let subItem of item.items; trackBy: _trackByInstanceId\">\n      <mat-divider\n        *ngIf=\"(subItem.itemId | getObjectType) === 'formitemgroupimpl' && item.items.indexOf(subItem) !== 0\"\n        class=\"section-item-divider\"\n        [inset]=\"true\"\n      ></mat-divider>\n\n      <mtna-wf-item\n        [item]=\"subItem\"\n        [readonly]=\"readonly\"\n        [parentIds]=\"parentIds\"\n        [control]=\"!!control && !!control.controls ? control.controls[subItem.instanceId] : undefined\"\n        (focusedSection)=\"focused.emit($event)\"\n      ></mtna-wf-item>\n    </ng-container>\n  </div>\n</mtna-wf-step-card>\n","<ng-container *ngIf=\"item && control\">\n  <mtna-wf-item-header\n    *ngIf=\"!!item.questionText || !!item.descriptiveText\"\n    [descriptiveText]=\"item.descriptiveText\"\n    [disabled]=\"control.disabled\"\n    [questionText]=\"item.questionText\"\n    [required]=\"item.required\"\n  ></mtna-wf-item-header>\n  <ng-template #fullLayout>\n    <div\n      class=\"item-group-container\"\n      [mtnaHighlight]=\"indicatorStatus === 'ACTIVE' && !item.questionText && !item.descriptiveText\"\n      [formGroup]=\"control\"\n      [ngClass]=\"item.layout\"\n    >\n      <mtna-wf-item\n        *ngFor=\"let subItem of item.items; trackBy: _trackByInstanceId\"\n        [class.row-item]=\"item.layout === 'ROW' && !fullWidth[subItem.itemId]\"\n        [ngClass.lt-md]=\"'width-100'\"\n        [item]=\"subItem\"\n        [control]=\"control.controls[subItem.instanceId]\"\n        [parentIds]=\"parentIds\"\n        [readonly]=\"readonly\"\n      ></mtna-wf-item>\n    </div>\n  </ng-template>\n\n  <!-- When readonly, && all child items should be displayed in a mat-list-->\n  <mat-list *ngIf=\"readonly && inList; else fullLayout\" [ngClass]=\"item.layout\">\n    <mtna-wf-value-item\n      *ngFor=\"let subItem of item.items | mtnaWfItemsWithValue; trackBy: _trackByInstanceId\"\n      [class.row-item]=\"item.layout === 'ROW'\"\n      [ngClass.lt-md]=\"'width-100'\"\n      [item]=\"subItem\"\n      [inList]=\"true\"\n      [parentIds]=\"parentIds\"\n      [readonly]=\"true\"\n    ></mtna-wf-value-item>\n  </mat-list>\n</ng-container>\n","<mtna-wf-item-header\n  *ngIf=\"!!item.questionText || !!item.descriptiveText\"\n  [descriptiveText]=\"item.descriptiveText\"\n  [disabled]=\"control?.disabled || false\"\n  [questionText]=\"item.questionText\"\n  [required]=\"item.required\"\n></mtna-wf-item-header>\n<section [mtnaHighlight]=\"indicatorStatus === 'ACTIVE' && !item.questionText && !item.descriptiveText\">\n  <mtna-wf-repeatable-item\n    @repeatItemExpandCollapse\n    *ngFor=\"let subitem of item.items; let first = first; trackBy: 'instanceId' | mtnaTrackByProperty\"\n  >\n    <button\n      *ngIf=\"!readonly && item.items.length > item.minOccurrences\"\n      mat-icon-button\n      class=\"item-remove-button\"\n      color=\"warn\"\n      (click)=\"removeItem(subitem)\"\n      matTooltip=\"Remove Item\"\n    >\n      <mat-icon>remove_circle</mat-icon>\n    </button>\n    <mtna-wf-item\n      [item]=\"subitem\"\n      [control]=\"!!control && !!control.controls ? control.controls[subitem.instanceId] : undefined\"\n      [readonly]=\"readonly\"\n      [parentIds]=\"parentIds\"\n    ></mtna-wf-item>\n  </mtna-wf-repeatable-item>\n</section>\n<button *ngIf=\"!readonly\" mat-raised-button (click)=\"addItem()\" class=\"new-item-button\" color=\"primary\">\n  {{ item.additionalText || 'ADD' | uppercase }}\n</button>\n","<table mat-table [dataSource]=\"item.tableRows\" [trackBy]=\"_trackByTableRow\">\n  <ng-container *ngFor=\"let header of item.headers; let index = index\" [matColumnDef]=\"header\">\n    <th mat-header-cell *matHeaderCellDef>{{ header }}</th>\n\n    <td mat-cell *matCellDef=\"let rowItem\">\n      <mtna-wf-item\n        *ngIf=\"!!rowItem.items[index]\"\n        [control]=\"!!control && !!control.controls ? control.controls[rowItem.items[index].instanceId] : undefined\"\n        [item]=\"rowItem.items[index]\"\n        [readonly]=\"readonly\"\n        [parentIds]=\"parentIds\"\n      ></mtna-wf-item>\n    </td>\n  </ng-container>\n\n  <tr mat-header-row *matHeaderRowDef=\"item.headers\"></tr>\n  <tr mat-row *matRowDef=\"let row; columns: item.headers\"></tr>\n</table>\n","<ng-container [ngSwitch]=\"item.itemId | getObjectType\">\n  <h3 *ngSwitchCase=\"'titleitem'\" class=\"mtna-wf-title-item\" [mtnaHighlight]=\"indicatorStatus === 'ACTIVE'\">{{ item.value }}</h3>\n  <p\n    *ngSwitchCase=\"'textitem'\"\n    [innerHTML]=\"$any(item.value) | mtnaWfSanitizeHtml\"\n    class=\"mtna-wf-text-item\"\n    [mtnaHighlight]=\"indicatorStatus === 'ACTIVE'\"\n  ></p>\n\n  <mtna-wf-boolean-item\n    *ngSwitchCase=\"'booleanitem'\"\n    [header]=\"itemHeader\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [item]=\"$any(item)\"\n    [control]=\"$any(control)\"\n    [mtnaHighlight]=\"indicatorStatus === 'ACTIVE'\"\n    [parentIds]=\"parentIds\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-boolean-item>\n\n  <mtna-wf-checkbox-item\n    *ngSwitchCase=\"'checkboxitem'\"\n    [header]=\"itemHeader\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [item]=\"$any(item)\"\n    [control]=\"$any(control)\"\n    [parentIds]=\"parentIds\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-checkbox-item>\n\n  <ng-container *ngSwitchCase=\"'dateitem'\">\n    <mtna-wf-date-item\n      *ngIf=\"item | coerceDateItem as dateItem\"\n      [header]=\"itemHeader\"\n      [indicatorStatus]=\"indicatorStatus\"\n      [format]=\"dateItem.format\"\n      [item]=\"dateItem\"\n      [control]=\"$any(control)\"\n      [readonly]=\"readonly\"\n    ></mtna-wf-date-item>\n  </ng-container>\n\n  <mtna-wf-date-range\n    *ngSwitchCase=\"'offsetdaterangeitem'\"\n    [header]=\"itemHeader\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [item]=\"$any(item)\"\n    [control]=\"$any(control)\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-date-range>\n\n  <mtna-wf-year-quarter-range-item\n    *ngSwitchCase=\"'yearquarterrangeitem'\"\n    [header]=\"itemHeader\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [item]=\"$any(item)\"\n    [control]=\"$any(control)\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-year-quarter-range-item>\n\n  <mtna-wf-dropdown-item\n    *ngSwitchCase=\"'dropdownitem'\"\n    [header]=\"itemHeader\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [item]=\"$any(item)\"\n    [inList]=\"inList\"\n    [control]=\"$any(control)\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-dropdown-item>\n\n  <mtna-wf-file-upload-item\n    *ngSwitchCase=\"'fileuploaditem'\"\n    [header]=\"itemHeader\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [item]=\"$any(item)\"\n    [readonly]=\"readonly\"\n    (file)=\"setValue($event)\"\n  ></mtna-wf-file-upload-item>\n\n  <mtna-wf-unordered-list-item\n    *ngSwitchCase=\"'bulletedlistitem'\"\n    [header]=\"itemHeader\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [item]=\"$any(item)\"\n  ></mtna-wf-unordered-list-item>\n\n  <mtna-wf-ordered-list-item\n    *ngSwitchCase=\"'numberedlistitem'\"\n    [header]=\"itemHeader\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [item]=\"$any(item)\"\n  ></mtna-wf-ordered-list-item>\n\n  <mtna-wf-multiple-choice-item\n    *ngSwitchCase=\"'multiplechoiceitem'\"\n    [header]=\"itemHeader\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [item]=\"$any(item)\"\n    [control]=\"$any(control)\"\n    [parentIds]=\"parentIds\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-multiple-choice-item>\n\n  <mtna-wf-input-item\n    *ngSwitchCase=\"'shortansweritem'\"\n    mtnaWfShortAnswerItem\n    [control]=\"$any(control)\"\n    [header]=\"itemHeader\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [inList]=\"inList\"\n    [item]=\"$any(item)\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-input-item>\n\n  <mtna-wf-input-item\n    *ngSwitchCase=\"'paragraphansweritem'\"\n    mtnaWfParagraphItem\n    [control]=\"$any(control)\"\n    [header]=\"itemHeader\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [inList]=\"inList\"\n    [item]=\"$any(item)\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-input-item>\n\n  <mtna-wf-table-item\n    *ngSwitchCase=\"'tableitem'\"\n    [control]=\"$any(control)\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [item]=\"$any(item)\"\n    [readonly]=\"readonly\"\n    [parentIds]=\"parentIds\"\n  ></mtna-wf-table-item>\n\n  <mtna-wf-input-item\n    *ngSwitchCase=\"'decimalansweritem'\"\n    mtnaWfDecimalItem\n    [control]=\"$any(control)\"\n    [header]=\"itemHeader\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [inList]=\"inList\"\n    [item]=\"$any(item)\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-input-item>\n\n  <mtna-wf-input-item\n    *ngSwitchCase=\"'wholenumberansweritem'\"\n    mtnaWfWholeNumberItem\n    [control]=\"$any(control)\"\n    [header]=\"itemHeader\"\n    [indicatorStatus]=\"indicatorStatus\"\n    [inList]=\"inList\"\n    [item]=\"$any(item)\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-input-item>\n\n  <!-- DYNAMIC COMPONENT CONTAINER -->\n  <ng-template *ngSwitchDefault formItemHost></ng-template>\n</ng-container>\n\n<ng-template #itemHeader let-hideRequiredMarker>\n  <mtna-wf-item-header\n    *ngIf=\"!!item.questionText || !!item.descriptiveText\"\n    [descriptiveText]=\"item.descriptiveText\"\n    [disabled]=\"control?.disabled\"\n    [hideRequiredMarker]=\"hideRequiredMarker\"\n    [invalid]=\"control?.invalid && (control?.dirty || control?.touched)\"\n    [questionText]=\"item.questionText\"\n    [required]=\"item.required\"\n  ></mtna-wf-item-header>\n</ng-template>\n","<ng-container *ngTemplateOutlet=\"header\"></ng-container>\n<ng-container *ngIf=\"control\">\n  <div class=\"mtna-wf-error-container\">\n    <ng-container *ngIf=\"control.invalid && (control.dirty || control.touched)\">\n      <mat-error *ngFor=\"let error of control.errors | keyvalue\">\n        {{ error | mtnaWfGetControlError : item }}\n      </mat-error>\n    </ng-container>\n  </div>\n  <mat-radio-group class=\"control-item-content\" [formControl]=\"control\" (change)=\"selectionChange($event)\">\n    <ng-container *ngFor=\"let opt of item.options; trackBy: _trackByOptionId\">\n      <mat-radio-button [disableRipple]=\"readonly\" [value]=\"opt.option.id\">{{ opt.option.name }}</mat-radio-button>\n      <mtna-wf-item\n        *ngIf=\"item.optionItemMap[opt.option.id] as subItem\"\n        [item]=\"subItem\"\n        [control]=\"!!controlWrapper && !!controlWrapper.controls ? controlWrapper.controls[subItem.instanceId] : undefined\"\n        [parentIds]=\"parentIds.concat(opt.option.id)\"\n        [readonly]=\"readonly\"\n      ></mtna-wf-item>\n    </ng-container>\n  </mat-radio-group>\n</ng-container>\n","<ng-container *ngTemplateOutlet=\"header\"></ng-container>\n<mat-slide-toggle *ngIf=\"control\" [formControl]=\"control\" (change)=\"toggleChange($event)\">{{ item.option.option.name }}</mat-slide-toggle>\n<ng-container *ngIf=\"!!item.optionItemMap\">\n  <mtna-wf-item\n    *ngFor=\"let f of item.optionItemMap | keyvalue; trackBy: _trackByInstanceId\"\n    [item]=\"f.value\"\n    [control]=\"!!controlWrapper && controlWrapper.controls ? controlWrapper.controls[f.value.instanceId] : undefined\"\n    [parentIds]=\"parentIds\"\n    [readonly]=\"readonly\"\n  ></mtna-wf-item>\n  <ng-container> </ng-container\n></ng-container>\n","<ng-container *ngTemplateOutlet=\"header\"></ng-container>\n<div *ngIf=\"hasItemHeader\" class=\"mtna-wf-error-container\">\n  <ng-container *ngIf=\"control?.invalid && (control?.dirty || control?.touched)\">\n    <mat-error *ngFor=\"let error of control?.errors | keyvalue\">\n      {{ error | mtnaWfGetControlError : item }}\n    </mat-error>\n  </ng-container>\n</div>\n<fieldset\n  class=\"control-item-content\"\n  [class.single-option]=\"item.options?.length === 1\"\n  [mtnaHighlight]=\"indicatorStatus === 'ACTIVE' && !hasItemHeader\"\n>\n  <ng-container *ngFor=\"let opt of item.options; let i = index; trackBy: _trackByOptionId\">\n    <mat-checkbox\n      *ngIf=\"!!control && !!control.controls && !!control.controls[i]\"\n      [disableRipple]=\"readonly\"\n      [formControl]=\"$any(control.controls[i])\"\n      [color]=\"color\"\n      (change)=\"handleChange($event, i)\"\n      >{{ opt.option.name }}\n      <button\n        *ngIf=\"opt.acknowledgement && control.controls[i].value\"\n        aria-label=\"Acknowledged. Click to view the agreement.\"\n        class=\"acknowledge-verification-button\"\n        mat-icon-button\n        matTooltip=\"Acknowledged. Click to view the agreement.\"\n        matTooltipShowDelay=\"800\"\n        (click)=\"showAcknowledgement($event, opt.acknowledgement)\"\n        (mousedown)=\"stopEventPropagation($event)\"\n        (touchstart)=\"stopEventPropagation($event)\"\n      >\n        <mat-icon>verified</mat-icon>\n      </button>\n    </mat-checkbox>\n    <ng-container *ngIf=\"item.optionItemMap[opt.option.id]\">\n      <mtna-wf-item\n        *ngIf=\"item.optionItemMap[opt.option.id] as subItem\"\n        [item]=\"subItem\"\n        [control]=\"!!controlWrapper && controlWrapper.controls ? controlWrapper.controls[subItem.instanceId] : undefined\"\n        [readonly]=\"readonly\"\n        [parentIds]=\"parentIds.concat(opt.option.id)\"\n      ></mtna-wf-item>\n    </ng-container>\n  </ng-container>\n</fieldset>\n"]}