@mtna/web-form-angular 1.0.2-SNAPSHOT.2 → 1.0.2

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 (135) hide show
  1. package/_index.scss +1 -2
  2. package/bundles/mtna-web-form-angular.umd.js +1219 -539
  3. package/bundles/mtna-web-form-angular.umd.js.map +1 -1
  4. package/esm2015/lib/components/acknowledge-dialog/acknowledge-dialog.component.js +2 -2
  5. package/esm2015/lib/components/base-form/base-form.component.js +243 -0
  6. package/esm2015/lib/components/base-form/index.js +2 -0
  7. package/esm2015/lib/components/base-items/base-group-item.component.js +5 -5
  8. package/esm2015/lib/components/base-items/base-parent-value-item.component.js +3 -2
  9. package/esm2015/lib/components/base-items/base-section-item.component.js +6 -5
  10. package/esm2015/lib/components/form/form.component.js +13 -239
  11. package/esm2015/lib/components/form-item/form-item.component.js +2 -2
  12. package/esm2015/lib/components/form-item-component-provider/form-item-injected-components.js +7 -1
  13. package/esm2015/lib/components/form-item-dialog/form-item-dialog.component.js +6 -5
  14. package/esm2015/lib/components/form-item-dialog/form-item-dialog.module.js +5 -4
  15. package/esm2015/lib/components/form-item-impl/boolean/boolean.component.js +2 -2
  16. package/esm2015/lib/components/form-item-impl/checkbox/checkbox.component.js +7 -5
  17. package/esm2015/lib/components/form-item-impl/checkbox/checkbox.module.js +5 -1
  18. package/esm2015/lib/components/form-item-impl/date/date.component.js +3 -2
  19. package/esm2015/lib/components/form-item-impl/date-range/date-range.component.js +6 -2
  20. package/esm2015/lib/components/form-item-impl/dropdown/dropdown.component.js +2 -2
  21. package/esm2015/lib/components/form-item-impl/file-upload/file-upload.component.js +3 -2
  22. package/esm2015/lib/components/form-item-impl/form-group/form-group.component.js +2 -2
  23. package/esm2015/lib/components/form-item-impl/i18n-input/i18n-input.component.js +3 -2
  24. package/esm2015/lib/components/form-item-impl/input/input.component.js +3 -2
  25. package/esm2015/lib/components/form-item-impl/multiple-choice/multiple-choice.component.js +2 -2
  26. package/esm2015/lib/components/form-item-impl/repeatable-item-container/repeatable-item-container.component.js +3 -2
  27. package/esm2015/lib/components/form-item-impl/search/resource-search.component.js +2 -2
  28. package/esm2015/lib/components/form-item-impl/year-quarter/year-quarter.component.js +2 -3
  29. package/esm2015/lib/components/form-stepper/form-step/form-step.component.js +10 -3
  30. package/esm2015/lib/components/form-stepper/form-step-group/form-step-group.component.js +4 -2
  31. package/esm2015/lib/components/form-stepper/form-stepper/form-stepper.component.js +52 -10
  32. package/esm2015/lib/components/form-stepper/form-stepper.module.js +17 -5
  33. package/esm2015/lib/components/index.js +2 -1
  34. package/esm2015/lib/components/progressive-form/index.js +3 -0
  35. package/esm2015/lib/components/progressive-form/progressive-form/index.js +3 -0
  36. package/esm2015/lib/components/progressive-form/progressive-form/progressive-form.component.js +287 -0
  37. package/esm2015/lib/components/progressive-form/progressive-form/progressive-form.module.js +68 -0
  38. package/esm2015/lib/components/progressive-form/progressive-form-section/index.js +3 -0
  39. package/esm2015/lib/components/progressive-form/progressive-form-section/progressive-form-section.component.js +27 -0
  40. package/esm2015/lib/components/progressive-form/progressive-form-section/progressive-form-section.module.js +54 -0
  41. package/esm2015/lib/components/step-card/step-card.component.js +10 -2
  42. package/esm2015/lib/components/step-card/step-card.module.js +27 -4
  43. package/esm2015/lib/models/form-stepper/form-step-group.model.js +8 -2
  44. package/esm2015/lib/models/form-stepper/form-step.model.js +7 -1
  45. package/esm2015/lib/models/index.js +2 -1
  46. package/esm2015/lib/models/progressive-form/index.js +4 -0
  47. package/esm2015/lib/models/progressive-form/outline-step.model.js +2 -0
  48. package/esm2015/lib/models/progressive-form/progressive-form-section.model.js +6 -0
  49. package/esm2015/lib/models/progressive-form/progressive-form.model.js +6 -0
  50. package/esm2015/lib/pipes/child-step-active.pipe.js +28 -0
  51. package/esm2015/lib/pipes/coerce-form-step-group.pipe.js +29 -0
  52. package/esm2015/lib/pipes/coerce-form-step.pipe.js +29 -0
  53. package/esm2015/lib/pipes/date-quarter.pipe.js +13 -13
  54. package/esm2015/lib/pipes/get-active-form-step-item.pipe.js +33 -0
  55. package/esm2015/lib/pipes/get-progressive-form-item.pipe.js +40 -0
  56. package/esm2015/lib/pipes/get-selected-option.pipe.js +4 -3
  57. package/esm2015/lib/pipes/get-step-aria-label.pipe.js +55 -0
  58. package/esm2015/lib/pipes/index.js +7 -1
  59. package/esm2015/lib/pipes/items-with-value.pipe.js +5 -10
  60. package/esm2015/lib/services/dialog.service.js +4 -3
  61. package/esm2015/lib/services/form-manager.service.js +19 -7
  62. package/esm2015/lib/services/ng-form.service.js +7 -1
  63. package/esm2015/lib/services/ui.service.js +15 -15
  64. package/esm2015/lib/utilities/generate-form-steps.js +20 -5
  65. package/esm2015/lib/utilities/serializer-util.js +12 -5
  66. package/esm2015/lib/utilities/update-step-status.js +1 -1
  67. package/esm2015/public-api.js +1 -2
  68. package/fesm2015/mtna-web-form-angular.js +962 -364
  69. package/fesm2015/mtna-web-form-angular.js.map +1 -1
  70. package/lib/components/base-form/base-form.component.d.ts +89 -0
  71. package/lib/components/base-form/index.d.ts +1 -0
  72. package/lib/components/base-items/base-group-item.component.d.ts +2 -0
  73. package/lib/components/base-items/base-section-item.component.d.ts +2 -1
  74. package/lib/components/form/form.component.d.ts +4 -86
  75. package/lib/components/form-item-dialog/form-item-dialog.module.d.ts +2 -1
  76. package/lib/components/form-item-impl/checkbox/_checkbox-theme.scss +11 -2
  77. package/lib/components/form-item-impl/checkbox/checkbox.component.d.ts +1 -0
  78. package/lib/components/form-item-impl/checkbox/checkbox.module.d.ts +11 -10
  79. package/lib/components/form-item-impl/date/date.component.d.ts +1 -0
  80. package/lib/components/form-item-impl/date-range/date-range.component.d.ts +1 -0
  81. package/lib/components/form-item-impl/dropdown/_dropdown-theme.scss +35 -0
  82. package/lib/components/form-item-impl/file-upload/file-upload.component.d.ts +1 -0
  83. package/lib/components/form-item-impl/i18n-input/i18n-input.component.d.ts +1 -0
  84. package/lib/components/form-item-impl/input/input.component.d.ts +1 -0
  85. package/lib/components/form-item-impl/repeatable-item-container/repeatable-item-container.component.d.ts +1 -0
  86. package/lib/components/form-stepper/form-step/form-step.component.d.ts +7 -0
  87. package/lib/components/form-stepper/form-step-group/form-step-group.component.d.ts +2 -0
  88. package/lib/components/form-stepper/form-stepper/_form-stepper-theme.scss +30 -15
  89. package/lib/components/form-stepper/form-stepper/form-stepper.component.d.ts +15 -1
  90. package/lib/components/form-stepper/form-stepper.module.d.ts +5 -1
  91. package/lib/components/index.d.ts +1 -0
  92. package/lib/components/progressive-form/index.d.ts +2 -0
  93. package/lib/components/progressive-form/progressive-form/index.d.ts +2 -0
  94. package/lib/components/progressive-form/progressive-form/progressive-form.component.d.ts +101 -0
  95. package/lib/components/progressive-form/progressive-form/progressive-form.module.d.ts +19 -0
  96. package/lib/components/progressive-form/progressive-form-section/index.d.ts +2 -0
  97. package/lib/components/progressive-form/progressive-form-section/progressive-form-section.component.d.ts +9 -0
  98. package/lib/components/progressive-form/progressive-form-section/progressive-form-section.module.d.ts +16 -0
  99. package/lib/components/step-card/step-card.component.d.ts +3 -1
  100. package/lib/components/step-card/step-card.module.d.ts +2 -1
  101. package/lib/core/_all-color.scss +2 -2
  102. package/lib/core/_all-theme.scss +2 -2
  103. package/lib/core/_all-typography.scss +2 -2
  104. package/lib/models/form-stepper/form-step-group.model.d.ts +5 -1
  105. package/lib/models/form-stepper/form-step.model.d.ts +3 -0
  106. package/lib/models/index.d.ts +1 -0
  107. package/lib/models/progressive-form/index.d.ts +3 -0
  108. package/lib/models/progressive-form/outline-step.model.d.ts +7 -0
  109. package/lib/models/progressive-form/progressive-form-section.model.d.ts +4 -0
  110. package/lib/models/progressive-form/progressive-form.model.d.ts +7 -0
  111. package/lib/pipes/child-step-active.pipe.d.ts +13 -0
  112. package/lib/pipes/coerce-form-step-group.pipe.d.ts +13 -0
  113. package/lib/pipes/coerce-form-step.pipe.d.ts +13 -0
  114. package/lib/pipes/get-active-form-step-item.pipe.d.ts +13 -0
  115. package/lib/pipes/get-progressive-form-item.pipe.d.ts +14 -0
  116. package/lib/pipes/get-step-aria-label.pipe.d.ts +17 -0
  117. package/lib/pipes/index.d.ts +6 -0
  118. package/lib/pipes/items-with-value.pipe.d.ts +0 -1
  119. package/lib/services/dialog.service.d.ts +1 -0
  120. package/lib/services/form-manager.service.d.ts +13 -4
  121. package/lib/services/ng-form.service.d.ts +6 -0
  122. package/lib/utilities/generate-form-steps.d.ts +5 -1
  123. package/lib/utilities/update-step-status.d.ts +2 -2
  124. package/package.json +1 -1
  125. package/public-api.d.ts +0 -1
  126. package/esm2015/lib/directives/base-form-item-control.directive.js +0 -58
  127. package/esm2015/lib/directives/base-parent-item-control.directive.js +0 -42
  128. package/esm2015/lib/directives/base-single-selection-parent.directive.js +0 -53
  129. package/esm2015/lib/directives/form-item.directive.js +0 -22
  130. package/esm2015/lib/directives/index.js +0 -5
  131. package/lib/directives/base-form-item-control.directive.d.ts +0 -26
  132. package/lib/directives/base-parent-item-control.directive.d.ts +0 -19
  133. package/lib/directives/base-single-selection-parent.directive.d.ts +0 -26
  134. package/lib/directives/form-item.directive.d.ts +0 -13
  135. package/lib/directives/index.d.ts +0 -4
@@ -0,0 +1,287 @@
1
+ import { coerceBooleanProperty } from '@angular/cdk/coercion';
2
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
3
+ import { BehaviorSubject } from 'rxjs';
4
+ import { flattenSteps, generateFormStepsFromOutline } from '../../../utilities';
5
+ import { MtnaWfBaseFormComponent } from '../../base-form';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../../../services";
8
+ import * as i2 from "@mtna/core-angular";
9
+ import * as i3 from "../../form-stepper/form-stepper/form-stepper.component";
10
+ import * as i4 from "../../form-disabler/form-disabler.component";
11
+ import * as i5 from "../../form-item/form-item.component";
12
+ import * as i6 from "@angular/material/button";
13
+ import * as i7 from "@angular/flex-layout/flex";
14
+ import * as i8 from "@angular/common";
15
+ import * as i9 from "@angular/forms";
16
+ /* eslint-disable @angular-eslint/no-outputs-metadata-property */
17
+ export class MtnaWfProgressiveFormComponent extends MtnaWfBaseFormComponent {
18
+ constructor(mtnaFormManager, ngFormService, uiService, cdr, scrollService) {
19
+ super(mtnaFormManager, ngFormService, uiService);
20
+ this.cdr = cdr;
21
+ this.scrollService = scrollService;
22
+ this._loading = false;
23
+ /** Emits the updated ProgressiveForm value */
24
+ this.nextStepSelected = new EventEmitter();
25
+ /**
26
+ * Emits the previous steps instanceId.
27
+ * Since this component is always on the last step and the last item, we can always count on having the instanceId of the previous step.
28
+ */
29
+ this.previousStepSelected = new EventEmitter();
30
+ /**
31
+ * Emits the instanceId of the selected step.
32
+ * If the currently active step is the step that is selected, this will not emit.
33
+ */
34
+ this.showSelectedStepId = new EventEmitter();
35
+ this.activeStepId$ = new BehaviorSubject(undefined);
36
+ this.formItems = [];
37
+ this.formStatusValid$ = new BehaviorSubject(false);
38
+ this.lastStepActive = false;
39
+ this.scrollDirection$ = this.scrollService.getScrollDirection();
40
+ this.showPreviousButton = false;
41
+ this.stepArray$ = new BehaviorSubject([]);
42
+ /**
43
+ * Checks if the last step in the form is active.
44
+ * @returns true if the last step in the form is active, otherwise false
45
+ */
46
+ this.checkLastStepActive = () => {
47
+ if (this.stepArray$.value.length > 0) {
48
+ return this.stepArray$.value[this.stepArray$.value.length - 1].active;
49
+ }
50
+ else if (this.stepArray$.value.length === 0) {
51
+ return this.stepArray$.value[0].active;
52
+ }
53
+ else {
54
+ return false;
55
+ }
56
+ };
57
+ }
58
+ get mtnaForm() {
59
+ return super.mtnaForm;
60
+ }
61
+ set mtnaForm(form) {
62
+ if (form) {
63
+ this.formItems = form.items;
64
+ this.resetValues();
65
+ this.generateFormSteps(form.outline);
66
+ this.checkAllStepsIds(form.items);
67
+ super.steps = this.determineStepsToPassToSuper(form.items);
68
+ super.mtnaForm = form;
69
+ this.setStepStatus();
70
+ this.setFormStatusSubscription();
71
+ this.showPreviousButton = this.showPreviousButtonFn();
72
+ this.lastStepActive = this.checkLastStepActive();
73
+ this.cdr.markForCheck();
74
+ }
75
+ }
76
+ get loading() {
77
+ return this._loading;
78
+ }
79
+ set loading(value) {
80
+ this._loading = coerceBooleanProperty(value);
81
+ }
82
+ ngOnDestroy() {
83
+ super.ngOnDestroy();
84
+ if (this.formStatusSubscriber) {
85
+ this.formStatusSubscriber.unsubscribe();
86
+ }
87
+ }
88
+ /**
89
+ * Checks if the previous button should be shown.
90
+ * @returns true if the previous button should be shown, otherwise false
91
+ */
92
+ showPreviousButtonFn() {
93
+ if (this.activeStepId$.value) {
94
+ const indexOfActiveStep = this.stepArray$.value.findIndex((step) => step.instanceId === this.activeStepId$.value);
95
+ return indexOfActiveStep > 0;
96
+ }
97
+ else {
98
+ return false;
99
+ }
100
+ }
101
+ /**
102
+ * Subscribes to the form status changes and updates the formStatusValid$ BehaviorSubject with the validity of the active step.
103
+ */
104
+ setFormStatusSubscription() {
105
+ var _a;
106
+ if (this.ngForm) {
107
+ // Used to set the initial validity of the active step, otherwise it will always default to false
108
+ if (this.activeStepId$.value) {
109
+ const initialValidity = (_a = this.ngForm.controls[this.activeStepId$.value]) === null || _a === void 0 ? void 0 : _a.valid;
110
+ this.formStatusValid$.next(initialValidity);
111
+ }
112
+ if (!this.formStatusSubscriber) {
113
+ this.formStatusSubscriber = this.ngForm.statusChanges.subscribe(() => {
114
+ if (this.activeStepId$.value) {
115
+ if (this.ngForm) {
116
+ const activeControlExists = Object.keys(this.ngForm.controls).includes(this.activeStepId$.value);
117
+ if (activeControlExists) {
118
+ const activeControl = this.ngForm.controls[this.activeStepId$.value];
119
+ if (activeControl) {
120
+ this.formStatusValid$.next(activeControl.valid);
121
+ }
122
+ }
123
+ }
124
+ }
125
+ });
126
+ }
127
+ }
128
+ }
129
+ /**
130
+ * Resets all necessary values to build to form each iteration.
131
+ */
132
+ resetValues() {
133
+ var _a;
134
+ (_a = this.formStatusSubscriber) === null || _a === void 0 ? void 0 : _a.unsubscribe();
135
+ this.ngForm = undefined;
136
+ this._steps = undefined;
137
+ this.ngFormService.disposeForm();
138
+ this.stepArray$.next([]);
139
+ this.activeStepId$.next(undefined);
140
+ }
141
+ /**
142
+ * Generates the steps for the form based on the outline property of the form.
143
+ * @param outline the outline of the form that is the basis for the steps
144
+ */
145
+ generateFormSteps(outline) {
146
+ if (this.stepArray$.value.length === 0) {
147
+ const generatedFormSteps = generateFormStepsFromOutline(outline);
148
+ const flattenedFormSteps = flattenSteps(generatedFormSteps);
149
+ this.stepArray$.next(flattenedFormSteps);
150
+ // Set the active step to the first step in the array for the first load
151
+ const lastItemIndex = this.formItems.length - 1;
152
+ const updatedSteps = [];
153
+ this.stepArray$.value.forEach((step) => {
154
+ if (step.instanceId === this.formItems[lastItemIndex].instanceId || step.instanceId === this.formItems[lastItemIndex].templateId) {
155
+ updatedSteps.push(Object.assign(Object.assign({}, step), { active: true, status: 'INVALID' }));
156
+ }
157
+ else {
158
+ updatedSteps.push(step);
159
+ }
160
+ });
161
+ this.stepArray$.next(updatedSteps);
162
+ }
163
+ }
164
+ /**
165
+ * Checks all of the steps to ensure that each steps instanceId property matches the instanceId of the FormItem and updates the property if needed.
166
+ * This finds the step based on the templateId. When the stepArray is first built, the templateId of the FormItem gets set as the steps instanceId.
167
+ * Here, we just need to find the steps that match the templateId and update the instanceId.
168
+ * Matching is based off of templateId reduces the number of steps that need to be checked/manipulated.
169
+ *
170
+ * @param formItems the FormItems to check against the steps
171
+ */
172
+ checkAllStepsIds(formItems) {
173
+ formItems.forEach((item) => {
174
+ const stepMatchedOnTemplateId = this.stepArray$.value.find((s) => s.instanceId === item.templateId);
175
+ if (stepMatchedOnTemplateId) {
176
+ stepMatchedOnTemplateId.instanceId = item.instanceId;
177
+ if (stepMatchedOnTemplateId.active) {
178
+ this.activeStepId$.next(item.instanceId);
179
+ this.cdr.markForCheck();
180
+ }
181
+ }
182
+ });
183
+ }
184
+ /**
185
+ * Because the super class has no knowledge of the stepArray that have been generated for the form,
186
+ * this function determines which steps need to be passed to the super class and the inherited _steps
187
+ * property. The super class "should" obtain each step as it is passed in. This means that when the
188
+ * call to either grab the form again or to get the next FormItem, should also continue to pass the
189
+ * steps that have been generated.
190
+ * @returns
191
+ */
192
+ determineStepsToPassToSuper(items) {
193
+ const availableItemInstanceIds = [];
194
+ items.forEach((item) => {
195
+ availableItemInstanceIds.push(item.instanceId);
196
+ });
197
+ const stepsToPass = [];
198
+ this.stepArray$.value.forEach((step) => {
199
+ if (availableItemInstanceIds.includes(step.instanceId)) {
200
+ stepsToPass.push(step);
201
+ }
202
+ });
203
+ return stepsToPass;
204
+ }
205
+ /**
206
+ * Sets the status of each step in the form based on the validity of the form control.
207
+ * If the form control key is not found in the controls of the form, the status is set to 'PLACEHOLDER'.
208
+ */
209
+ setStepStatus() {
210
+ const updatedSteps = [];
211
+ this.stepArray$.value.forEach((step) => {
212
+ if (this.ngForm) {
213
+ const controlKeyExists = Object.keys(this.ngForm.controls).includes(step.instanceId);
214
+ if (controlKeyExists) {
215
+ updatedSteps.push(Object.assign(Object.assign({}, step), { status: this.ngForm.controls[step.instanceId].valid ? 'VALID' : 'INVALID' }));
216
+ }
217
+ else {
218
+ updatedSteps.push(Object.assign(Object.assign({}, step), { status: 'PLACEHOLDER' }));
219
+ }
220
+ }
221
+ });
222
+ this.stepArray$.next(updatedSteps);
223
+ }
224
+ /**
225
+ * Emits the next or previous step templateId based on the direction provided.
226
+ * @param stepDirection the direction of the step to emit
227
+ */
228
+ showDirectionalStep(stepDirection) {
229
+ // const stepTemplateId = this.getDirectionalStepTemplateId(stepDirection);
230
+ // if (stepTemplateId) {
231
+ if (this.mtnaForm) {
232
+ const formValue = this.ngFormService.getFormValue();
233
+ const updatedForm = this.mtnaFormManager.insertNewValues(this.mtnaForm, formValue);
234
+ if (stepDirection === 'next') {
235
+ this.nextStepSelected.emit(updatedForm);
236
+ this.scrollService.scrollTop();
237
+ }
238
+ else {
239
+ const previousStepIndex = this.stepArray$.value.findIndex((step) => step.instanceId === this.activeStepId$.value) - 1;
240
+ if (previousStepIndex >= 0) {
241
+ const previousStep = this.stepArray$.value[previousStepIndex];
242
+ if (previousStep) {
243
+ this.previousStepSelected.emit(previousStep.instanceId);
244
+ this.scrollService.scrollTop();
245
+ }
246
+ }
247
+ }
248
+ }
249
+ }
250
+ /**
251
+ * Shows the selected step as the active step in the form.
252
+ * To be used on the mtna-wf-form-stepper components "selected" output.
253
+ * @param step the step to show as the active step
254
+ */
255
+ showSelectedStep(step) {
256
+ if (this.activeStepId$.value !== step.instanceId) {
257
+ this.showSelectedStepId.emit(step.instanceId);
258
+ this.activeStepId$.next(step.instanceId);
259
+ this.scrollService.scrollTop();
260
+ }
261
+ }
262
+ _trackByStepInstanceId(index, formStep) {
263
+ return formStep.instanceId;
264
+ }
265
+ }
266
+ MtnaWfProgressiveFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfProgressiveFormComponent, deps: [{ token: i1.MtnaWfManagerService }, { token: i1.MtnaWfNgFormService }, { token: i1.MtnaWfUIService }, { token: i0.ChangeDetectorRef }, { token: i2.MtnaScrollService }], target: i0.ɵɵFactoryTarget.Component });
267
+ MtnaWfProgressiveFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfProgressiveFormComponent, selector: "mtna-wf-progressive-form", inputs: { loading: "loading" }, outputs: { status: "status", focusedSection: "focusedSection", mtnaFormChange: "mtnaFormChange", nextStepSelected: "nextStepSelected", previousStepSelected: "previousStepSelected", showSelectedStepId: "showSelectedStepId" }, usesInheritance: true, ngImport: i0, template: "<div fxLayout=\"row\" class=\"mtna-wf-progressive-form__container\">\n <mtna-wf-stepper\n *ngIf=\"stepArray$ | async as steps\"\n fxFlex=\"200px\"\n [steps]=\"steps\"\n (selected)=\"showSelectedStep($event)\"\n ></mtna-wf-stepper>\n <div fxFlex class=\"mtna-wf-progressive-form__form-container\">\n <form *ngIf=\"ngForm\" [formGroup]=\"ngForm\" [formDisabled]=\"readonly\">\n <ng-container *ngFor=\"let item of mtnaForm?.items\">\n <ng-container *ngIf=\"activeStepId$ | async as activeStepId\">\n <mtna-wf-item\n *ngIf=\"item.instanceId === activeStepId\"\n [item]=\"item\"\n [control]=\"ngForm.controls[item.instanceId]\"\n [readonly]=\"readonly\"\n [parentIds]=\"componentIds\"\n [step]=\"_steps?.[item.instanceId]\"\n (focusedSection)=\"focusedSection.emit($event)\"\n ></mtna-wf-item>\n </ng-container>\n </ng-container>\n </form>\n <div *ngIf=\"!loading\" class=\"mtna-wf-progressive-form__stepper-actions\" fxLayout=\"row\" fxLayoutAlign=\"center center\" fxLayoutGap=\"26px\">\n <button *ngIf=\"showPreviousButton\" mat-stroked-button color=\"primary\" (click)=\"showDirectionalStep('previous')\" i18n>\n Previous Step\n </button>\n <ng-container *ngIf=\"!lastStepActive; else parentActions\">\n <button mat-raised-button color=\"primary\" (click)=\"showDirectionalStep('next')\" i18n>Next Step</button>\n </ng-container>\n </div>\n </div>\n</div>\n\n<ng-template #parentActions>\n <ng-content></ng-content>\n</ng-template>\n", styles: ["mtna-wf-progressive-form{display:flex;flex:1}mtna-wf-progressive-form .mtna-wf-progressive-form__container{width:100%}mtna-wf-progressive-form mtna-wf-progressive-form-section mtna-wf-step-card{margin:24px}mtna-wf-progressive-form .mtna-wf-progressive-form__stepper-actions{margin:0 24px 24px}mtna-wf-progressive-form .mtna-wf-progressive-form__stepper-actions .mtna-wf-progressive-form__next-button{margin-left:auto}\n"], components: [{ type: i3.MtnaWfFormStepperComponent, selector: "mtna-wf-stepper", inputs: ["color", "incompleteIcon", "steps"], outputs: ["selected"] }, { type: i4.MtnaWfFormDisablerComponent, selector: "[formDisabled]", inputs: ["formDisabled"] }, { type: i5.MtnaWfFormItemComponent, selector: "mtna-wf-item", inputs: ["color", "control", "header", "inList", "item", "parentIds", "readonly", "step"], outputs: ["focusedSection"] }, { type: i6.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: i7.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { type: i9.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i9.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i9.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { type: i7.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }], pipes: { "async": i8.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
268
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfProgressiveFormComponent, decorators: [{
269
+ type: Component,
270
+ args: [{
271
+ selector: 'mtna-wf-progressive-form',
272
+ templateUrl: './progressive-form.component.html',
273
+ styleUrls: ['./progressive-form.component.scss'],
274
+ changeDetection: ChangeDetectionStrategy.OnPush,
275
+ encapsulation: ViewEncapsulation.None,
276
+ outputs: ['status', 'focusedSection', 'mtnaFormChange'],
277
+ }]
278
+ }], ctorParameters: function () { return [{ type: i1.MtnaWfManagerService }, { type: i1.MtnaWfNgFormService }, { type: i1.MtnaWfUIService }, { type: i0.ChangeDetectorRef }, { type: i2.MtnaScrollService }]; }, propDecorators: { loading: [{
279
+ type: Input
280
+ }], nextStepSelected: [{
281
+ type: Output
282
+ }], previousStepSelected: [{
283
+ type: Output
284
+ }], showSelectedStepId: [{
285
+ type: Output
286
+ }] } });
287
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progressive-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/web-form-angular/src/lib/components/progressive-form/progressive-form/progressive-form.component.ts","../../../../../../../../projects/web-form-angular/src/lib/components/progressive-form/progressive-form/progressive-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';\nimport { MtnaScrollDirection, MtnaScrollService } from '@mtna/core-angular';\nimport { FormItem } from '@mtna/web-form-ts';\nimport { BehaviorSubject, Observable, Subscription } from 'rxjs';\n\nimport { FormStep, OutlineStep, ProgressiveForm } from '../../../models';\nimport { MtnaWfManagerService, MtnaWfNgFormService, MtnaWfUIService } from '../../../services';\nimport { flattenSteps, generateFormStepsFromOutline } from '../../../utilities';\nimport { MtnaWfBaseFormComponent } from '../../base-form';\n\n/* eslint-disable @angular-eslint/no-outputs-metadata-property */\n@Component({\n  selector: 'mtna-wf-progressive-form',\n  templateUrl: './progressive-form.component.html',\n  styleUrls: ['./progressive-form.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  outputs: ['status', 'focusedSection', 'mtnaFormChange'],\n})\nexport class MtnaWfProgressiveFormComponent extends MtnaWfBaseFormComponent<ProgressiveForm> {\n  static ngAcceptInputType_loading: BooleanInput;\n\n  override get mtnaForm(): ProgressiveForm | null | undefined {\n    return super.mtnaForm as ProgressiveForm | null | undefined;\n  }\n  override set mtnaForm(form: ProgressiveForm | null | undefined) {\n    if (form) {\n      this.formItems = form.items;\n      this.resetValues();\n      this.generateFormSteps(form.outline);\n      this.checkAllStepsIds(form.items);\n      super.steps = this.determineStepsToPassToSuper(form.items);\n      super.mtnaForm = form;\n\n      this.setStepStatus();\n      this.setFormStatusSubscription();\n      this.showPreviousButton = this.showPreviousButtonFn();\n      this.lastStepActive = this.checkLastStepActive();\n      this.cdr.markForCheck();\n    }\n  }\n\n  @Input()\n  get loading(): boolean {\n    return this._loading;\n  }\n  set loading(value: boolean) {\n    this._loading = coerceBooleanProperty(value);\n  }\n  private _loading = false;\n\n  /** Emits the updated ProgressiveForm value */\n  @Output() nextStepSelected = new EventEmitter<ProgressiveForm>();\n  /**\n   * Emits the previous steps instanceId.\n   * Since this component is always on the last step and the last item, we can always count on having the instanceId of the previous step.\n   */\n  @Output() previousStepSelected = new EventEmitter<string>();\n  /**\n   * Emits the instanceId of the selected step.\n   * If the currently active step is the step that is selected, this will not emit.\n   */\n  @Output() showSelectedStepId = new EventEmitter<string>();\n\n  activeStepId$ = new BehaviorSubject<string | undefined>(undefined);\n  formItems: FormItem[] = [];\n  formStatusSubscriber: Subscription | undefined;\n  formStatusValid$ = new BehaviorSubject<boolean>(false);\n  lastStepActive = false;\n  scrollDirection$: Observable<MtnaScrollDirection> = this.scrollService.getScrollDirection();\n  showPreviousButton = false;\n  stepArray$ = new BehaviorSubject<FormStep[]>([]);\n\n  constructor(\n    mtnaFormManager: MtnaWfManagerService,\n    ngFormService: MtnaWfNgFormService,\n    uiService: MtnaWfUIService,\n    private cdr: ChangeDetectorRef,\n    private scrollService: MtnaScrollService\n  ) {\n    super(mtnaFormManager, ngFormService, uiService);\n  }\n\n  ngOnDestroy(): void {\n    super.ngOnDestroy();\n    if (this.formStatusSubscriber) {\n      this.formStatusSubscriber.unsubscribe();\n    }\n  }\n\n  /**\n   * Checks if the last step in the form is active.\n   * @returns true if the last step in the form is active, otherwise false\n   */\n  checkLastStepActive = () => {\n    if (this.stepArray$.value.length > 0) {\n      return this.stepArray$.value[this.stepArray$.value.length - 1].active;\n    } else if (this.stepArray$.value.length === 0) {\n      return this.stepArray$.value[0].active;\n    } else {\n      return false;\n    }\n  };\n\n  /**\n   * Checks if the previous button should be shown.\n   * @returns true if the previous button should be shown, otherwise false\n   */\n  showPreviousButtonFn(): boolean {\n    if (this.activeStepId$.value) {\n      const indexOfActiveStep = this.stepArray$.value.findIndex((step) => step.instanceId === this.activeStepId$.value);\n      return indexOfActiveStep > 0;\n    } else {\n      return false;\n    }\n  }\n\n  /**\n   * Subscribes to the form status changes and updates the formStatusValid$ BehaviorSubject with the validity of the active step.\n   */\n  private setFormStatusSubscription(): void {\n    if (this.ngForm) {\n      // Used to set the initial validity of the active step, otherwise it will always default to false\n      if (this.activeStepId$.value) {\n        const initialValidity = this.ngForm.controls[this.activeStepId$.value]?.valid;\n        this.formStatusValid$.next(initialValidity);\n      }\n\n      if (!this.formStatusSubscriber) {\n        this.formStatusSubscriber = this.ngForm.statusChanges.subscribe(() => {\n          if (this.activeStepId$.value) {\n            if (this.ngForm) {\n              const activeControlExists = Object.keys(this.ngForm.controls).includes(this.activeStepId$.value);\n              if (activeControlExists) {\n                const activeControl = this.ngForm.controls[this.activeStepId$.value];\n                if (activeControl) {\n                  this.formStatusValid$.next(activeControl.valid);\n                }\n              }\n            }\n          }\n        });\n      }\n    }\n  }\n\n  /**\n   * Resets all necessary values to build to form each iteration.\n   */\n  private resetValues() {\n    this.formStatusSubscriber?.unsubscribe();\n    this.ngForm = undefined;\n    this._steps = undefined;\n    this.ngFormService.disposeForm();\n    this.stepArray$.next([]);\n    this.activeStepId$.next(undefined);\n  }\n\n  /**\n   * Generates the steps for the form based on the outline property of the form.\n   * @param outline the outline of the form that is the basis for the steps\n   */\n  private generateFormSteps(outline: OutlineStep[]) {\n    if (this.stepArray$.value.length === 0) {\n      const generatedFormSteps = generateFormStepsFromOutline(outline);\n      const flattenedFormSteps = flattenSteps(generatedFormSteps);\n      this.stepArray$.next(flattenedFormSteps);\n      // Set the active step to the first step in the array for the first load\n      const lastItemIndex = this.formItems.length - 1;\n      const updatedSteps: FormStep[] = [];\n      this.stepArray$.value.forEach((step) => {\n        if (step.instanceId === this.formItems[lastItemIndex].instanceId || step.instanceId === this.formItems[lastItemIndex].templateId) {\n          updatedSteps.push({ ...step, active: true, status: 'INVALID' });\n        } else {\n          updatedSteps.push(step);\n        }\n      });\n      this.stepArray$.next(updatedSteps);\n    }\n  }\n\n  /**\n   * Checks all of the steps to ensure that each steps instanceId property matches the instanceId of the FormItem and updates the property if needed.\n   * This finds the step based on the templateId. When the stepArray is first built, the templateId of the FormItem gets set as the steps instanceId.\n   * Here, we just need to find the steps that match the templateId and update the instanceId.\n   * Matching is based off of templateId reduces the number of steps that need to be checked/manipulated.\n   *\n   * @param formItems the FormItems to check against the steps\n   */\n  private checkAllStepsIds(formItems: FormItem[]) {\n    formItems.forEach((item) => {\n      const stepMatchedOnTemplateId = this.stepArray$.value.find((s) => s.instanceId === item.templateId);\n      if (stepMatchedOnTemplateId) {\n        stepMatchedOnTemplateId.instanceId = item.instanceId;\n        if (stepMatchedOnTemplateId.active) {\n          this.activeStepId$.next(item.instanceId);\n          this.cdr.markForCheck();\n        }\n      }\n    });\n  }\n\n  /**\n   * Because the super class has no knowledge of the stepArray that have been generated for the form,\n   * this function determines which steps need to be passed to the super class and the inherited _steps\n   * property. The super class \"should\" obtain each step as it is passed in. This means that when the\n   * call to either grab the form again or to get the next FormItem, should also continue to pass the\n   * steps that have been generated.\n   * @returns\n   */\n  private determineStepsToPassToSuper(items: FormItem[]): FormStep[] {\n    const availableItemInstanceIds: string[] = [];\n    items.forEach((item) => {\n      availableItemInstanceIds.push(item.instanceId);\n    });\n\n    const stepsToPass: FormStep[] = [];\n    this.stepArray$.value.forEach((step) => {\n      if (availableItemInstanceIds.includes(step.instanceId)) {\n        stepsToPass.push(step);\n      }\n    });\n\n    return stepsToPass;\n  }\n\n  /**\n   * Sets the status of each step in the form based on the validity of the form control.\n   * If the form control key is not found in the controls of the form, the status is set to 'PLACEHOLDER'.\n   */\n  private setStepStatus() {\n    const updatedSteps: FormStep[] = [];\n    this.stepArray$.value.forEach((step) => {\n      if (this.ngForm) {\n        const controlKeyExists = Object.keys(this.ngForm.controls).includes(step.instanceId);\n        if (controlKeyExists) {\n          updatedSteps.push({ ...step, status: this.ngForm.controls[step.instanceId].valid ? 'VALID' : 'INVALID' });\n        } else {\n          updatedSteps.push({ ...step, status: 'PLACEHOLDER' });\n        }\n      }\n    });\n    this.stepArray$.next(updatedSteps);\n  }\n\n  /**\n   * Emits the next or previous step templateId based on the direction provided.\n   * @param stepDirection the direction of the step to emit\n   */\n  showDirectionalStep(stepDirection: 'previous' | 'next') {\n    // const stepTemplateId = this.getDirectionalStepTemplateId(stepDirection);\n    // if (stepTemplateId) {\n    if (this.mtnaForm) {\n      const formValue = this.ngFormService.getFormValue();\n      const updatedForm = this.mtnaFormManager.insertNewValues(this.mtnaForm, formValue) as ProgressiveForm;\n      if (stepDirection === 'next') {\n        this.nextStepSelected.emit(updatedForm);\n        this.scrollService.scrollTop();\n      } else {\n        const previousStepIndex = this.stepArray$.value.findIndex((step) => step.instanceId === this.activeStepId$.value) - 1;\n        if (previousStepIndex >= 0) {\n          const previousStep = this.stepArray$.value[previousStepIndex];\n          if (previousStep) {\n            this.previousStepSelected.emit(previousStep.instanceId);\n            this.scrollService.scrollTop();\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * Shows the selected step as the active step in the form.\n   * To be used on the mtna-wf-form-stepper components \"selected\" output.\n   * @param step the step to show as the active step\n   */\n  showSelectedStep(step: FormStep) {\n    if (this.activeStepId$.value !== step.instanceId) {\n      this.showSelectedStepId.emit(step.instanceId);\n      this.activeStepId$.next(step.instanceId);\n      this.scrollService.scrollTop();\n    }\n  }\n\n  _trackByStepInstanceId(index: number, formStep: FormStep) {\n    return formStep.instanceId;\n  }\n}\n","<div fxLayout=\"row\" class=\"mtna-wf-progressive-form__container\">\n  <mtna-wf-stepper\n    *ngIf=\"stepArray$ | async as steps\"\n    fxFlex=\"200px\"\n    [steps]=\"steps\"\n    (selected)=\"showSelectedStep($event)\"\n  ></mtna-wf-stepper>\n  <div fxFlex class=\"mtna-wf-progressive-form__form-container\">\n    <form *ngIf=\"ngForm\" [formGroup]=\"ngForm\" [formDisabled]=\"readonly\">\n      <ng-container *ngFor=\"let item of mtnaForm?.items\">\n        <ng-container *ngIf=\"activeStepId$ | async as activeStepId\">\n          <mtna-wf-item\n            *ngIf=\"item.instanceId === activeStepId\"\n            [item]=\"item\"\n            [control]=\"ngForm.controls[item.instanceId]\"\n            [readonly]=\"readonly\"\n            [parentIds]=\"componentIds\"\n            [step]=\"_steps?.[item.instanceId]\"\n            (focusedSection)=\"focusedSection.emit($event)\"\n          ></mtna-wf-item>\n        </ng-container>\n      </ng-container>\n    </form>\n    <div *ngIf=\"!loading\" class=\"mtna-wf-progressive-form__stepper-actions\" fxLayout=\"row\" fxLayoutAlign=\"center center\" fxLayoutGap=\"26px\">\n      <button *ngIf=\"showPreviousButton\" mat-stroked-button color=\"primary\" (click)=\"showDirectionalStep('previous')\" i18n>\n        Previous Step\n      </button>\n      <ng-container *ngIf=\"!lastStepActive; else parentActions\">\n        <button mat-raised-button color=\"primary\" (click)=\"showDirectionalStep('next')\" i18n>Next Step</button>\n      </ng-container>\n    </div>\n  </div>\n</div>\n\n<ng-template #parentActions>\n  <ng-content></ng-content>\n</ng-template>\n"]}
@@ -0,0 +1,68 @@
1
+ import { A11yModule } from '@angular/cdk/a11y';
2
+ import { CommonModule } from '@angular/common';
3
+ import { NgModule } from '@angular/core';
4
+ import { FlexLayoutModule } from '@angular/flex-layout';
5
+ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
6
+ import { MatButtonModule } from '@angular/material/button';
7
+ import { MatIconModule } from '@angular/material/icon';
8
+ import { GetActiveFormStepItemPipeModule, GetProgressiveFormItemPipeModule } from '../../../pipes';
9
+ import { MtnaWfFormDisablerModule } from '../../form-disabler/form-disabler.module';
10
+ import { MtnaWfFormItemModule } from '../../form-item/form-item.module';
11
+ import { MtnaWfFormStepperModule } from '../../form-stepper/form-stepper.module';
12
+ import { MtnaWfProgressiveFormSectionModule } from '../progressive-form-section/progressive-form-section.module';
13
+ import { MtnaWfProgressiveFormComponent } from './progressive-form.component';
14
+ import * as i0 from "@angular/core";
15
+ export class MtnaWfProgressiveFormModule {
16
+ }
17
+ MtnaWfProgressiveFormModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfProgressiveFormModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
18
+ MtnaWfProgressiveFormModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfProgressiveFormModule, declarations: [MtnaWfProgressiveFormComponent], imports: [A11yModule,
19
+ CommonModule,
20
+ FlexLayoutModule,
21
+ FormsModule,
22
+ MatButtonModule,
23
+ MatIconModule,
24
+ MtnaWfFormDisablerModule,
25
+ MtnaWfFormItemModule,
26
+ MtnaWfProgressiveFormSectionModule,
27
+ ReactiveFormsModule,
28
+ MtnaWfFormStepperModule,
29
+ GetProgressiveFormItemPipeModule,
30
+ GetActiveFormStepItemPipeModule], exports: [MtnaWfProgressiveFormComponent] });
31
+ MtnaWfProgressiveFormModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfProgressiveFormModule, imports: [[
32
+ A11yModule,
33
+ CommonModule,
34
+ FlexLayoutModule,
35
+ FormsModule,
36
+ MatButtonModule,
37
+ MatIconModule,
38
+ MtnaWfFormDisablerModule,
39
+ MtnaWfFormItemModule,
40
+ MtnaWfProgressiveFormSectionModule,
41
+ ReactiveFormsModule,
42
+ MtnaWfFormStepperModule,
43
+ GetProgressiveFormItemPipeModule,
44
+ GetActiveFormStepItemPipeModule,
45
+ ]] });
46
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfProgressiveFormModule, decorators: [{
47
+ type: NgModule,
48
+ args: [{
49
+ imports: [
50
+ A11yModule,
51
+ CommonModule,
52
+ FlexLayoutModule,
53
+ FormsModule,
54
+ MatButtonModule,
55
+ MatIconModule,
56
+ MtnaWfFormDisablerModule,
57
+ MtnaWfFormItemModule,
58
+ MtnaWfProgressiveFormSectionModule,
59
+ ReactiveFormsModule,
60
+ MtnaWfFormStepperModule,
61
+ GetProgressiveFormItemPipeModule,
62
+ GetActiveFormStepItemPipeModule,
63
+ ],
64
+ declarations: [MtnaWfProgressiveFormComponent],
65
+ exports: [MtnaWfProgressiveFormComponent],
66
+ }]
67
+ }] });
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3NpdmUtZm9ybS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy93ZWItZm9ybS1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9wcm9ncmVzc2l2ZS1mb3JtL3Byb2dyZXNzaXZlLWZvcm0vcHJvZ3Jlc3NpdmUtZm9ybS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRXZELE9BQU8sRUFBRSwrQkFBK0IsRUFBRSxnQ0FBZ0MsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ25HLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLDZEQUE2RCxDQUFDO0FBQ2pILE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLDhCQUE4QixDQUFDOztBQXFCOUUsTUFBTSxPQUFPLDJCQUEyQjs7eUhBQTNCLDJCQUEyQjswSEFBM0IsMkJBQTJCLGlCQUh2Qiw4QkFBOEIsYUFkM0MsVUFBVTtRQUNWLFlBQVk7UUFDWixnQkFBZ0I7UUFDaEIsV0FBVztRQUNYLGVBQWU7UUFDZixhQUFhO1FBQ2Isd0JBQXdCO1FBQ3hCLG9CQUFvQjtRQUNwQixrQ0FBa0M7UUFDbEMsbUJBQW1CO1FBQ25CLHVCQUF1QjtRQUN2QixnQ0FBZ0M7UUFDaEMsK0JBQStCLGFBR3ZCLDhCQUE4QjswSEFFN0IsMkJBQTJCLFlBbEI3QjtZQUNQLFVBQVU7WUFDVixZQUFZO1lBQ1osZ0JBQWdCO1lBQ2hCLFdBQVc7WUFDWCxlQUFlO1lBQ2YsYUFBYTtZQUNiLHdCQUF3QjtZQUN4QixvQkFBb0I7WUFDcEIsa0NBQWtDO1lBQ2xDLG1CQUFtQjtZQUNuQix1QkFBdUI7WUFDdkIsZ0NBQWdDO1lBQ2hDLCtCQUErQjtTQUNoQzs0RkFJVSwyQkFBMkI7a0JBbkJ2QyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxVQUFVO3dCQUNWLFlBQVk7d0JBQ1osZ0JBQWdCO3dCQUNoQixXQUFXO3dCQUNYLGVBQWU7d0JBQ2YsYUFBYTt3QkFDYix3QkFBd0I7d0JBQ3hCLG9CQUFvQjt3QkFDcEIsa0NBQWtDO3dCQUNsQyxtQkFBbUI7d0JBQ25CLHVCQUF1Qjt3QkFDdkIsZ0NBQWdDO3dCQUNoQywrQkFBK0I7cUJBQ2hDO29CQUNELFlBQVksRUFBRSxDQUFDLDhCQUE4QixDQUFDO29CQUM5QyxPQUFPLEVBQUUsQ0FBQyw4QkFBOEIsQ0FBQztpQkFDMUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBMTF5TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2ExMXknO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGbGV4TGF5b3V0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZmxleC1sYXlvdXQnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuXG5pbXBvcnQgeyBHZXRBY3RpdmVGb3JtU3RlcEl0ZW1QaXBlTW9kdWxlLCBHZXRQcm9ncmVzc2l2ZUZvcm1JdGVtUGlwZU1vZHVsZSB9IGZyb20gJy4uLy4uLy4uL3BpcGVzJztcbmltcG9ydCB7IE10bmFXZkZvcm1EaXNhYmxlck1vZHVsZSB9IGZyb20gJy4uLy4uL2Zvcm0tZGlzYWJsZXIvZm9ybS1kaXNhYmxlci5tb2R1bGUnO1xuaW1wb3J0IHsgTXRuYVdmRm9ybUl0ZW1Nb2R1bGUgfSBmcm9tICcuLi8uLi9mb3JtLWl0ZW0vZm9ybS1pdGVtLm1vZHVsZSc7XG5pbXBvcnQgeyBNdG5hV2ZGb3JtU3RlcHBlck1vZHVsZSB9IGZyb20gJy4uLy4uL2Zvcm0tc3RlcHBlci9mb3JtLXN0ZXBwZXIubW9kdWxlJztcbmltcG9ydCB7IE10bmFXZlByb2dyZXNzaXZlRm9ybVNlY3Rpb25Nb2R1bGUgfSBmcm9tICcuLi9wcm9ncmVzc2l2ZS1mb3JtLXNlY3Rpb24vcHJvZ3Jlc3NpdmUtZm9ybS1zZWN0aW9uLm1vZHVsZSc7XG5pbXBvcnQgeyBNdG5hV2ZQcm9ncmVzc2l2ZUZvcm1Db21wb25lbnQgfSBmcm9tICcuL3Byb2dyZXNzaXZlLWZvcm0uY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIEExMXlNb2R1bGUsXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZsZXhMYXlvdXRNb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxuICAgIE1hdEljb25Nb2R1bGUsXG4gICAgTXRuYVdmRm9ybURpc2FibGVyTW9kdWxlLFxuICAgIE10bmFXZkZvcm1JdGVtTW9kdWxlLFxuICAgIE10bmFXZlByb2dyZXNzaXZlRm9ybVNlY3Rpb25Nb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICBNdG5hV2ZGb3JtU3RlcHBlck1vZHVsZSxcbiAgICBHZXRQcm9ncmVzc2l2ZUZvcm1JdGVtUGlwZU1vZHVsZSxcbiAgICBHZXRBY3RpdmVGb3JtU3RlcEl0ZW1QaXBlTW9kdWxlLFxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFtNdG5hV2ZQcm9ncmVzc2l2ZUZvcm1Db21wb25lbnRdLFxuICBleHBvcnRzOiBbTXRuYVdmUHJvZ3Jlc3NpdmVGb3JtQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTXRuYVdmUHJvZ3Jlc3NpdmVGb3JtTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,3 @@
1
+ export * from './progressive-form-section.component';
2
+ export * from './progressive-form-section.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy93ZWItZm9ybS1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9wcm9ncmVzc2l2ZS1mb3JtL3Byb2dyZXNzaXZlLWZvcm0tc2VjdGlvbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsbUNBQW1DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3Byb2dyZXNzaXZlLWZvcm0tc2VjdGlvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9wcm9ncmVzc2l2ZS1mb3JtLXNlY3Rpb24ubW9kdWxlJztcbiJdfQ==
@@ -0,0 +1,27 @@
1
+ import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
2
+ import { MtnaWfBaseSectionItem } from '../../base-items/base-section-item.component';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../../step-card/step-card.component";
5
+ import * as i2 from "@angular/material/divider";
6
+ import * as i3 from "../../form-item/form-item.component";
7
+ import * as i4 from "@mtna/core-angular";
8
+ import * as i5 from "@angular/common";
9
+ import * as i6 from "../../../pipes/get-object-type.pipe";
10
+ export class MtnaWfProgressiveFormSectionComponent extends MtnaWfBaseSectionItem {
11
+ constructor(cdr) {
12
+ super(cdr);
13
+ }
14
+ }
15
+ MtnaWfProgressiveFormSectionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfProgressiveFormSectionComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
16
+ MtnaWfProgressiveFormSectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfProgressiveFormSectionComponent, selector: "mtna-wf-progressive-form-section", usesInheritance: true, ngImport: i0, template: "<mtna-wf-step-card [step]=\"step\" [subtitle]=\"item.descriptiveText\" [mtnaHighlight]=\"indicatorStatus === 'ACTIVE'\">\n <div cardContent>\n <ng-container *ngFor=\"let subItem of item.items; trackBy: _trackByInstanceId\">\n <mat-divider\n *ngIf=\"(subItem.itemId | mtnaWfGetObjectType) === '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: ["mtna-wf-progressive-form-section mat-divider.mat-divider-horizontal.progressive-form-section-actions-divider{position:relative;left:unset;padding-bottom:8px}mtna-wf-progressive-form-section .progressive-form-section-actions-wrapper .mat-raised-button{margin:0}\n"], components: [{ type: i1.MtnaWfStepCardComponent, selector: "mtna-wf-step-card", inputs: ["color", "step", "subtitle"], outputs: ["focused"] }, { type: i2.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { type: i3.MtnaWfFormItemComponent, selector: "mtna-wf-item", inputs: ["color", "control", "header", "inList", "item", "parentIds", "readonly", "step"], outputs: ["focusedSection"] }], directives: [{ type: i4.MtnaHighlightDirective, selector: "[mtnaHighlight]", inputs: ["mtnaHighlight", "mtnaHighlightColor"], exportAs: ["mtnaHighlight"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "mtnaWfGetObjectType": i6.MtnaWfGetObjectTypePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfProgressiveFormSectionComponent, decorators: [{
18
+ type: Component,
19
+ args: [{
20
+ selector: 'mtna-wf-progressive-form-section',
21
+ templateUrl: './progressive-form-section.component.html',
22
+ styleUrls: ['./progressive-form-section.component.scss'],
23
+ changeDetection: ChangeDetectionStrategy.OnPush,
24
+ encapsulation: ViewEncapsulation.None,
25
+ }]
26
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; } });
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3NpdmUtZm9ybS1zZWN0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dlYi1mb3JtLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL3Byb2dyZXNzaXZlLWZvcm0vcHJvZ3Jlc3NpdmUtZm9ybS1zZWN0aW9uL3Byb2dyZXNzaXZlLWZvcm0tc2VjdGlvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy93ZWItZm9ybS1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9wcm9ncmVzc2l2ZS1mb3JtL3Byb2dyZXNzaXZlLWZvcm0tc2VjdGlvbi9wcm9ncmVzc2l2ZS1mb3JtLXNlY3Rpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFxQixTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHekcsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sOENBQThDLENBQUM7Ozs7Ozs7O0FBU3JGLE1BQU0sT0FBTyxxQ0FBc0MsU0FBUSxxQkFBNkM7SUFDdEcsWUFBWSxHQUFzQjtRQUNoQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDYixDQUFDOzttSUFIVSxxQ0FBcUM7dUhBQXJDLHFDQUFxQywrRkNabEQsNHlCQW1CQTs0RkRQYSxxQ0FBcUM7a0JBUGpELFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGtDQUFrQztvQkFDNUMsV0FBVyxFQUFFLDJDQUEyQztvQkFDeEQsU0FBUyxFQUFFLENBQUMsMkNBQTJDLENBQUM7b0JBQ3hELGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO29CQUMvQyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTtpQkFDdEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgUHJvZ3Jlc3NpdmVGb3JtU2VjdGlvbiB9IGZyb20gJy4uLy4uLy4uL21vZGVscy9wcm9ncmVzc2l2ZS1mb3JtL3Byb2dyZXNzaXZlLWZvcm0tc2VjdGlvbi5tb2RlbCc7XG5pbXBvcnQgeyBNdG5hV2ZCYXNlU2VjdGlvbkl0ZW0gfSBmcm9tICcuLi8uLi9iYXNlLWl0ZW1zL2Jhc2Utc2VjdGlvbi1pdGVtLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ210bmEtd2YtcHJvZ3Jlc3NpdmUtZm9ybS1zZWN0aW9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3Byb2dyZXNzaXZlLWZvcm0tc2VjdGlvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3Byb2dyZXNzaXZlLWZvcm0tc2VjdGlvbi5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbn0pXG5leHBvcnQgY2xhc3MgTXRuYVdmUHJvZ3Jlc3NpdmVGb3JtU2VjdGlvbkNvbXBvbmVudCBleHRlbmRzIE10bmFXZkJhc2VTZWN0aW9uSXRlbTxQcm9ncmVzc2l2ZUZvcm1TZWN0aW9uPiB7XG4gIGNvbnN0cnVjdG9yKGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcbiAgICBzdXBlcihjZHIpO1xuICB9XG59XG4iLCI8bXRuYS13Zi1zdGVwLWNhcmQgW3N0ZXBdPVwic3RlcFwiIFtzdWJ0aXRsZV09XCJpdGVtLmRlc2NyaXB0aXZlVGV4dFwiIFttdG5hSGlnaGxpZ2h0XT1cImluZGljYXRvclN0YXR1cyA9PT0gJ0FDVElWRSdcIj5cbiAgPGRpdiBjYXJkQ29udGVudD5cbiAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBzdWJJdGVtIG9mIGl0ZW0uaXRlbXM7IHRyYWNrQnk6IF90cmFja0J5SW5zdGFuY2VJZFwiPlxuICAgICAgPG1hdC1kaXZpZGVyXG4gICAgICAgICpuZ0lmPVwiKHN1Ykl0ZW0uaXRlbUlkIHwgbXRuYVdmR2V0T2JqZWN0VHlwZSkgPT09ICdmb3JtaXRlbWdyb3VwaW1wbCcgJiYgaXRlbS5pdGVtcy5pbmRleE9mKHN1Ykl0ZW0pICE9PSAwXCJcbiAgICAgICAgY2xhc3M9XCJzZWN0aW9uLWl0ZW0tZGl2aWRlclwiXG4gICAgICAgIFtpbnNldF09XCJ0cnVlXCJcbiAgICAgID48L21hdC1kaXZpZGVyPlxuXG4gICAgICA8bXRuYS13Zi1pdGVtXG4gICAgICAgIFtpdGVtXT1cInN1Ykl0ZW1cIlxuICAgICAgICBbcmVhZG9ubHldPVwicmVhZG9ubHlcIlxuICAgICAgICBbcGFyZW50SWRzXT1cInBhcmVudElkc1wiXG4gICAgICAgIFtjb250cm9sXT1cIiEhY29udHJvbCAmJiAhIWNvbnRyb2wuY29udHJvbHMgPyBjb250cm9sLmNvbnRyb2xzW3N1Ykl0ZW0uaW5zdGFuY2VJZF0gOiB1bmRlZmluZWRcIlxuICAgICAgICAoZm9jdXNlZFNlY3Rpb24pPVwiZm9jdXNlZC5lbWl0KCRldmVudClcIlxuICAgICAgPjwvbXRuYS13Zi1pdGVtPlxuICAgIDwvbmctY29udGFpbmVyPlxuICA8L2Rpdj5cbjwvbXRuYS13Zi1zdGVwLWNhcmQ+XG4iXX0=
@@ -0,0 +1,54 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { FlexLayoutModule } from '@angular/flex-layout';
4
+ import { MatButtonModule } from '@angular/material/button';
5
+ import { MatDividerModule } from '@angular/material/divider';
6
+ import { MatIconModule } from '@angular/material/icon';
7
+ import { MtnaHighlightModule } from '@mtna/core-angular';
8
+ import { MtnaWfGetObjectTypePipeModule } from '../../../pipes/get-object-type.pipe';
9
+ import { MtnaWfFormItemModule } from '../../form-item/form-item.module';
10
+ import { MtnaWfStepCardModule } from '../../step-card/step-card.module';
11
+ import { MtnaWfProgressiveFormSectionComponent } from './progressive-form-section.component';
12
+ import * as i0 from "@angular/core";
13
+ export class MtnaWfProgressiveFormSectionModule {
14
+ }
15
+ MtnaWfProgressiveFormSectionModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfProgressiveFormSectionModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
16
+ MtnaWfProgressiveFormSectionModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfProgressiveFormSectionModule, declarations: [MtnaWfProgressiveFormSectionComponent], imports: [CommonModule,
17
+ FlexLayoutModule,
18
+ MtnaWfStepCardModule,
19
+ MtnaHighlightModule,
20
+ MatDividerModule,
21
+ MtnaWfGetObjectTypePipeModule,
22
+ MtnaWfFormItemModule,
23
+ MatButtonModule,
24
+ MatIconModule], exports: [MtnaWfProgressiveFormSectionComponent] });
25
+ MtnaWfProgressiveFormSectionModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfProgressiveFormSectionModule, imports: [[
26
+ CommonModule,
27
+ FlexLayoutModule,
28
+ MtnaWfStepCardModule,
29
+ MtnaHighlightModule,
30
+ MatDividerModule,
31
+ MtnaWfGetObjectTypePipeModule,
32
+ MtnaWfFormItemModule,
33
+ MatButtonModule,
34
+ MatIconModule,
35
+ ]] });
36
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfProgressiveFormSectionModule, decorators: [{
37
+ type: NgModule,
38
+ args: [{
39
+ imports: [
40
+ CommonModule,
41
+ FlexLayoutModule,
42
+ MtnaWfStepCardModule,
43
+ MtnaHighlightModule,
44
+ MatDividerModule,
45
+ MtnaWfGetObjectTypePipeModule,
46
+ MtnaWfFormItemModule,
47
+ MatButtonModule,
48
+ MatIconModule,
49
+ ],
50
+ declarations: [MtnaWfProgressiveFormSectionComponent],
51
+ exports: [MtnaWfProgressiveFormSectionComponent],
52
+ }]
53
+ }] });
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3NpdmUtZm9ybS1zZWN0aW9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dlYi1mb3JtLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL3Byb2dyZXNzaXZlLWZvcm0vcHJvZ3Jlc3NpdmUtZm9ybS1zZWN0aW9uL3Byb2dyZXNzaXZlLWZvcm0tc2VjdGlvbi5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDeEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUV6RCxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUNwRixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN4RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN4RSxPQUFPLEVBQUUscUNBQXFDLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQzs7QUFpQjdGLE1BQU0sT0FBTyxrQ0FBa0M7O2dJQUFsQyxrQ0FBa0M7aUlBQWxDLGtDQUFrQyxpQkFIOUIscUNBQXFDLGFBVmxELFlBQVk7UUFDWixnQkFBZ0I7UUFDaEIsb0JBQW9CO1FBQ3BCLG1CQUFtQjtRQUNuQixnQkFBZ0I7UUFDaEIsNkJBQTZCO1FBQzdCLG9CQUFvQjtRQUNwQixlQUFlO1FBQ2YsYUFBYSxhQUdMLHFDQUFxQztpSUFFcEMsa0NBQWtDLFlBZHBDO1lBQ1AsWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixvQkFBb0I7WUFDcEIsbUJBQW1CO1lBQ25CLGdCQUFnQjtZQUNoQiw2QkFBNkI7WUFDN0Isb0JBQW9CO1lBQ3BCLGVBQWU7WUFDZixhQUFhO1NBQ2Q7NEZBSVUsa0NBQWtDO2tCQWY5QyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGdCQUFnQjt3QkFDaEIsb0JBQW9CO3dCQUNwQixtQkFBbUI7d0JBQ25CLGdCQUFnQjt3QkFDaEIsNkJBQTZCO3dCQUM3QixvQkFBb0I7d0JBQ3BCLGVBQWU7d0JBQ2YsYUFBYTtxQkFDZDtvQkFDRCxZQUFZLEVBQUUsQ0FBQyxxQ0FBcUMsQ0FBQztvQkFDckQsT0FBTyxFQUFFLENBQUMscUNBQXFDLENBQUM7aUJBQ2pEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGbGV4TGF5b3V0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZmxleC1sYXlvdXQnO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IE1hdERpdmlkZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaXZpZGVyJztcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IE10bmFIaWdobGlnaHRNb2R1bGUgfSBmcm9tICdAbXRuYS9jb3JlLWFuZ3VsYXInO1xuXG5pbXBvcnQgeyBNdG5hV2ZHZXRPYmplY3RUeXBlUGlwZU1vZHVsZSB9IGZyb20gJy4uLy4uLy4uL3BpcGVzL2dldC1vYmplY3QtdHlwZS5waXBlJztcbmltcG9ydCB7IE10bmFXZkZvcm1JdGVtTW9kdWxlIH0gZnJvbSAnLi4vLi4vZm9ybS1pdGVtL2Zvcm0taXRlbS5tb2R1bGUnO1xuaW1wb3J0IHsgTXRuYVdmU3RlcENhcmRNb2R1bGUgfSBmcm9tICcuLi8uLi9zdGVwLWNhcmQvc3RlcC1jYXJkLm1vZHVsZSc7XG5pbXBvcnQgeyBNdG5hV2ZQcm9ncmVzc2l2ZUZvcm1TZWN0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi9wcm9ncmVzc2l2ZS1mb3JtLXNlY3Rpb24uY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGbGV4TGF5b3V0TW9kdWxlLFxuICAgIE10bmFXZlN0ZXBDYXJkTW9kdWxlLFxuICAgIE10bmFIaWdobGlnaHRNb2R1bGUsXG4gICAgTWF0RGl2aWRlck1vZHVsZSxcbiAgICBNdG5hV2ZHZXRPYmplY3RUeXBlUGlwZU1vZHVsZSxcbiAgICBNdG5hV2ZGb3JtSXRlbU1vZHVsZSxcbiAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbTXRuYVdmUHJvZ3Jlc3NpdmVGb3JtU2VjdGlvbkNvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtNdG5hV2ZQcm9ncmVzc2l2ZUZvcm1TZWN0aW9uQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTXRuYVdmUHJvZ3Jlc3NpdmVGb3JtU2VjdGlvbk1vZHVsZSB7fVxuIl19
@@ -22,6 +22,14 @@ export class MtnaWfStepCardComponent extends _StepCardMixinBase {
22
22
  var _a;
23
23
  return !!((_a = this.step) === null || _a === void 0 ? void 0 : _a.active);
24
24
  }
25
+ // @Input() step: FormStep | null | undefined;
26
+ get step() {
27
+ return this._step;
28
+ }
29
+ set step(step) {
30
+ this._step = step;
31
+ console.warn({ stepInsideStepCard: step });
32
+ }
25
33
  handleFocusChange(event) {
26
34
  if (!!this.step && !!event && !this.step.active) {
27
35
  this.focused.emit(this.step);
@@ -29,7 +37,7 @@ export class MtnaWfStepCardComponent extends _StepCardMixinBase {
29
37
  }
30
38
  }
31
39
  MtnaWfStepCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfStepCardComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
32
- MtnaWfStepCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfStepCardComponent, selector: "mtna-wf-step-card", inputs: { color: "color", step: "step", subtitle: "subtitle" }, outputs: { focused: "focused" }, host: { properties: { "class.active": "this.active" } }, usesInheritance: true, ngImport: i0, template: "<mat-card cdkMonitorSubtreeFocus (cdkFocusChange)=\"handleFocusChange($event)\">\n <mat-card-header>\n <mtna-status-circle mat-card-avatar [circleNumber]=\"step?.num\" [optional]=\"step?.optional\" [status]=\"step?.status\"></mtna-status-circle>\n <mat-card-title>{{ step?.label }}</mat-card-title>\n <mat-card-subtitle [innerHTML]=\"subtitle | mtnaWfSanitizeHtml\"></mat-card-subtitle>\n <p *ngIf=\"step?.optional\" class=\"optional mat-caption\">Optional</p>\n </mat-card-header>\n\n <mat-divider [inset]=\"true\"></mat-divider>\n\n <mat-card-content>\n <ng-content select=\"[cardContent]\"></ng-content>\n </mat-card-content>\n\n <mat-card-actions>\n <ng-content select=\"[cardActions]\"></ng-content>\n </mat-card-actions>\n</mat-card>\n", styles: ["mtna-wf-step-card{display:block;position:relative}mtna-wf-step-card.active:before{transform-origin:top;transform:scaleY(1)}mtna-wf-step-card:before{content:\"\";display:block;position:absolute;top:0;left:0;bottom:0;width:5px;transition:transform .4s cubic-bezier(.25,.8,.25,1);transform-origin:bottom;transform:scaleY(0);z-index:1;border-top-left-radius:2px;border-bottom-left-radius:2px}mtna-wf-step-card mat-card-header{position:relative}mtna-wf-step-card mat-card-header mat-card-title{line-height:24px;margin-right:100px}mtna-wf-step-card mat-card-header mtna-status-circle[mat-card-avatar]{width:24px;height:24px}mtna-wf-step-card mat-card-header>.optional:not(.mtna-status-circle){position:absolute;right:16px;top:0;margin:0;line-height:24px}mtna-wf-step-card mat-card-actions{padding:0;margin:0}mtna-wf-step-card mat-card-content{margin-top:16px}mtna-wf-step-card mat-card-content [cardcontent]>:first-child{margin-top:0}\n"], components: [{ type: i1.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { type: i1.MatCardHeader, selector: "mat-card-header" }, { type: i2.MtnaStatusCircleComponent, selector: "mtna-status-circle", inputs: ["color", "circleNumber", "incompleteIcon", "status", "validIcon", "optional"] }, { type: i3.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }], directives: [{ type: i4.CdkMonitorFocus, selector: "[cdkMonitorElementFocus], [cdkMonitorSubtreeFocus]", outputs: ["cdkFocusChange"] }, { type: i1.MatCardAvatar, selector: "[mat-card-avatar], [matCardAvatar]" }, { type: i1.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { type: i1.MatCardSubtitle, selector: "mat-card-subtitle, [mat-card-subtitle], [matCardSubtitle]" }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.MatCardContent, selector: "mat-card-content, [mat-card-content], [matCardContent]" }, { type: i1.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }], pipes: { "mtnaWfSanitizeHtml": i6.MtnaWfSanitizeHtmlPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
40
+ MtnaWfStepCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfStepCardComponent, selector: "mtna-wf-step-card", inputs: { color: "color", step: "step", subtitle: "subtitle" }, outputs: { focused: "focused" }, host: { properties: { "class.active": "this.active" } }, usesInheritance: true, ngImport: i0, template: "<mat-card cdkMonitorSubtreeFocus (cdkFocusChange)=\"handleFocusChange($event)\">\n <mat-card-header>\n <mtna-status-circle mat-card-avatar [circleNumber]=\"step?.num\" [optional]=\"step?.optional\" [status]=\"step?.status\"></mtna-status-circle>\n <mat-card-title>{{ step?.label }}</mat-card-title>\n <mat-card-subtitle [innerHTML]=\"subtitle | mtnaWfSanitizeHtml\"></mat-card-subtitle>\n <p *ngIf=\"step?.optional\" class=\"optional mat-caption\" i18n>Optional</p>\n </mat-card-header>\n\n <mat-divider [inset]=\"true\"></mat-divider>\n\n <mat-card-content>\n <ng-content select=\"[cardContent]\"></ng-content>\n </mat-card-content>\n\n <mat-card-actions>\n <ng-content select=\"[cardActions]\"></ng-content>\n </mat-card-actions>\n</mat-card>\n", styles: ["mtna-wf-step-card{display:block;position:relative}mtna-wf-step-card.active:before{transform-origin:top;transform:scaleY(1)}mtna-wf-step-card:before{content:\"\";display:block;position:absolute;top:0;left:0;bottom:0;width:5px;transition:transform .4s cubic-bezier(.25,.8,.25,1);transform-origin:bottom;transform:scaleY(0);z-index:1;border-top-left-radius:2px;border-bottom-left-radius:2px}mtna-wf-step-card mat-card-header{position:relative}mtna-wf-step-card mat-card-header mat-card-title{line-height:24px;margin-right:100px}mtna-wf-step-card mat-card-header mtna-status-circle[mat-card-avatar]{width:24px;height:24px}mtna-wf-step-card mat-card-header>.optional:not(.mtna-status-circle){position:absolute;right:16px;top:0;margin:0;line-height:24px}mtna-wf-step-card mat-card-actions{padding:0;margin:0}mtna-wf-step-card mat-card-content{margin-top:16px}mtna-wf-step-card mat-card-content [cardcontent]>:first-child{margin-top:0}\n"], components: [{ type: i1.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { type: i1.MatCardHeader, selector: "mat-card-header" }, { type: i2.MtnaStatusCircleComponent, selector: "mtna-status-circle", inputs: ["color", "circleNumber", "incompleteIcon", "status", "validIcon", "optional"] }, { type: i3.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }], directives: [{ type: i4.CdkMonitorFocus, selector: "[cdkMonitorElementFocus], [cdkMonitorSubtreeFocus]", outputs: ["cdkFocusChange"] }, { type: i1.MatCardAvatar, selector: "[mat-card-avatar], [matCardAvatar]" }, { type: i1.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { type: i1.MatCardSubtitle, selector: "mat-card-subtitle, [mat-card-subtitle], [matCardSubtitle]" }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.MatCardContent, selector: "mat-card-content, [mat-card-content], [matCardContent]" }, { type: i1.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }], pipes: { "mtnaWfSanitizeHtml": i6.MtnaWfSanitizeHtmlPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
33
41
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfStepCardComponent, decorators: [{
34
42
  type: Component,
35
43
  args: [{
@@ -50,4 +58,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
50
58
  }], focused: [{
51
59
  type: Output
52
60
  }] } });
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcC1jYXJkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dlYi1mb3JtLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL3N0ZXAtY2FyZC9zdGVwLWNhcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvd2ViLWZvcm0tYW5ndWxhci9zcmMvbGliL2NvbXBvbmVudHMvc3RlcC1jYXJkL3N0ZXAtY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFjLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM1SSxPQUFPLEVBQVksVUFBVSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7Ozs7Ozs7O0FBSTlELGdFQUFnRTtBQUNoRSxNQUFNLGtCQUFrQixHQUFHLFVBQVUsQ0FDbkM7SUFDRSxZQUFtQixXQUF1QjtRQUF2QixnQkFBVyxHQUFYLFdBQVcsQ0FBWTtJQUFHLENBQUM7Q0FDL0MsRUFDRCxRQUFRLENBQ1QsQ0FBQztBQVVGLE1BQU0sT0FBTyx1QkFBd0IsU0FBUSxrQkFBa0I7SUFXN0QsWUFBWSxVQUFzQjtRQUNoQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUM7UUFIVixZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQVksQ0FBQztJQUlqRCxDQUFDO0lBWkQsSUFDSSxNQUFNOztRQUNSLE9BQU8sQ0FBQyxDQUFDLENBQUEsTUFBQSxJQUFJLENBQUMsSUFBSSwwQ0FBRSxNQUFNLENBQUEsQ0FBQztJQUM3QixDQUFDO0lBV0QsaUJBQWlCLENBQUMsS0FBa0I7UUFDbEMsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsS0FBSyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDL0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQzlCO0lBQ0gsQ0FBQzs7cUhBbkJVLHVCQUF1Qjt5R0FBdkIsdUJBQXVCLDBPQ3RCcEMsZ3dCQWtCQTs0RkRJYSx1QkFBdUI7a0JBUm5DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG1CQUFtQjtvQkFDN0IsV0FBVyxFQUFFLDRCQUE0QjtvQkFDekMsU0FBUyxFQUFFLENBQUMsNEJBQTRCLENBQUM7b0JBQ3pDLE1BQU0sRUFBRSxDQUFDLE9BQU8sQ0FBQztvQkFDakIsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2lCQUN0QztpR0FHSyxNQUFNO3NCQURULFdBQVc7dUJBQUMsY0FBYztnQkFLbEIsSUFBSTtzQkFBWixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBRUksT0FBTztzQkFBaEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZvY3VzT3JpZ2luIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2ExMXknO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLCBIb3N0QmluZGluZywgSW5wdXQsIE91dHB1dCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENhbkNvbG9yLCBtaXhpbkNvbG9yIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5cbmltcG9ydCB7IEZvcm1TdGVwIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2Zvcm0tc3RlcHBlci9mb3JtLXN0ZXAubW9kZWwnO1xuXG4vKiBlc2xpbnQtZGlzYWJsZSBAYW5ndWxhci1lc2xpbnQvbm8taW5wdXRzLW1ldGFkYXRhLXByb3BlcnR5ICovXG5jb25zdCBfU3RlcENhcmRNaXhpbkJhc2UgPSBtaXhpbkNvbG9yKFxuICBjbGFzcyB7XG4gICAgY29uc3RydWN0b3IocHVibGljIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmKSB7fVxuICB9LFxuICAnYWNjZW50J1xuKTtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbXRuYS13Zi1zdGVwLWNhcmQnLFxuICB0ZW1wbGF0ZVVybDogJy4vc3RlcC1jYXJkLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vc3RlcC1jYXJkLmNvbXBvbmVudC5zY3NzJ10sXG4gIGlucHV0czogWydjb2xvciddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbn0pXG5leHBvcnQgY2xhc3MgTXRuYVdmU3RlcENhcmRDb21wb25lbnQgZXh0ZW5kcyBfU3RlcENhcmRNaXhpbkJhc2UgaW1wbGVtZW50cyBDYW5Db2xvciB7XG4gIEBIb3N0QmluZGluZygnY2xhc3MuYWN0aXZlJylcbiAgZ2V0IGFjdGl2ZSgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gISF0aGlzLnN0ZXA/LmFjdGl2ZTtcbiAgfVxuXG4gIEBJbnB1dCgpIHN0ZXA6IEZvcm1TdGVwIHwgbnVsbCB8IHVuZGVmaW5lZDtcbiAgQElucHV0KCkgc3VidGl0bGU6IHN0cmluZyB8IG51bGwgfCB1bmRlZmluZWQ7XG5cbiAgQE91dHB1dCgpIGZvY3VzZWQgPSBuZXcgRXZlbnRFbWl0dGVyPEZvcm1TdGVwPigpO1xuXG4gIGNvbnN0cnVjdG9yKGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHtcbiAgICBzdXBlcihlbGVtZW50UmVmKTtcbiAgfVxuXG4gIGhhbmRsZUZvY3VzQ2hhbmdlKGV2ZW50OiBGb2N1c09yaWdpbikge1xuICAgIGlmICghIXRoaXMuc3RlcCAmJiAhIWV2ZW50ICYmICF0aGlzLnN0ZXAuYWN0aXZlKSB7XG4gICAgICB0aGlzLmZvY3VzZWQuZW1pdCh0aGlzLnN0ZXApO1xuICAgIH1cbiAgfVxufVxuIiwiPG1hdC1jYXJkIGNka01vbml0b3JTdWJ0cmVlRm9jdXMgKGNka0ZvY3VzQ2hhbmdlKT1cImhhbmRsZUZvY3VzQ2hhbmdlKCRldmVudClcIj5cbiAgPG1hdC1jYXJkLWhlYWRlcj5cbiAgICA8bXRuYS1zdGF0dXMtY2lyY2xlIG1hdC1jYXJkLWF2YXRhciBbY2lyY2xlTnVtYmVyXT1cInN0ZXA/Lm51bVwiIFtvcHRpb25hbF09XCJzdGVwPy5vcHRpb25hbFwiIFtzdGF0dXNdPVwic3RlcD8uc3RhdHVzXCI+PC9tdG5hLXN0YXR1cy1jaXJjbGU+XG4gICAgPG1hdC1jYXJkLXRpdGxlPnt7IHN0ZXA/LmxhYmVsIH19PC9tYXQtY2FyZC10aXRsZT5cbiAgICA8bWF0LWNhcmQtc3VidGl0bGUgW2lubmVySFRNTF09XCJzdWJ0aXRsZSB8IG10bmFXZlNhbml0aXplSHRtbFwiPjwvbWF0LWNhcmQtc3VidGl0bGU+XG4gICAgPHAgKm5nSWY9XCJzdGVwPy5vcHRpb25hbFwiIGNsYXNzPVwib3B0aW9uYWwgbWF0LWNhcHRpb25cIj5PcHRpb25hbDwvcD5cbiAgPC9tYXQtY2FyZC1oZWFkZXI+XG5cbiAgPG1hdC1kaXZpZGVyIFtpbnNldF09XCJ0cnVlXCI+PC9tYXQtZGl2aWRlcj5cblxuICA8bWF0LWNhcmQtY29udGVudD5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbY2FyZENvbnRlbnRdXCI+PC9uZy1jb250ZW50PlxuICA8L21hdC1jYXJkLWNvbnRlbnQ+XG5cbiAgPG1hdC1jYXJkLWFjdGlvbnM+XG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW2NhcmRBY3Rpb25zXVwiPjwvbmctY29udGVudD5cbiAgPC9tYXQtY2FyZC1hY3Rpb25zPlxuPC9tYXQtY2FyZD5cbiJdfQ==
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcC1jYXJkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dlYi1mb3JtLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL3N0ZXAtY2FyZC9zdGVwLWNhcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvd2ViLWZvcm0tYW5ndWxhci9zcmMvbGliL2NvbXBvbmVudHMvc3RlcC1jYXJkL3N0ZXAtY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFjLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM1SSxPQUFPLEVBQVksVUFBVSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7Ozs7Ozs7O0FBSTlELGdFQUFnRTtBQUNoRSxNQUFNLGtCQUFrQixHQUFHLFVBQVUsQ0FDbkM7SUFDRSxZQUFtQixXQUF1QjtRQUF2QixnQkFBVyxHQUFYLFdBQVcsQ0FBWTtJQUFHLENBQUM7Q0FDL0MsRUFDRCxRQUFRLENBQ1QsQ0FBQztBQVVGLE1BQU0sT0FBTyx1QkFBd0IsU0FBUSxrQkFBa0I7SUFxQjdELFlBQVksVUFBc0I7UUFDaEMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBSFYsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFZLENBQUM7SUFJakQsQ0FBQztJQXRCRCxJQUNJLE1BQU07O1FBQ1IsT0FBTyxDQUFDLENBQUMsQ0FBQSxNQUFBLElBQUksQ0FBQyxJQUFJLDBDQUFFLE1BQU0sQ0FBQSxDQUFDO0lBQzdCLENBQUM7SUFFRCw4Q0FBOEM7SUFDOUMsSUFDSSxJQUFJO1FBQ04sT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3BCLENBQUM7SUFDRCxJQUFJLElBQUksQ0FBQyxJQUFpQztRQUN4QyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQztRQUNsQixPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsa0JBQWtCLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBV0QsaUJBQWlCLENBQUMsS0FBa0I7UUFDbEMsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsS0FBSyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDL0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQzlCO0lBQ0gsQ0FBQzs7cUhBN0JVLHVCQUF1Qjt5R0FBdkIsdUJBQXVCLDBPQ3RCcEMscXdCQWtCQTs0RkRJYSx1QkFBdUI7a0JBUm5DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG1CQUFtQjtvQkFDN0IsV0FBVyxFQUFFLDRCQUE0QjtvQkFDekMsU0FBUyxFQUFFLENBQUMsNEJBQTRCLENBQUM7b0JBQ3pDLE1BQU0sRUFBRSxDQUFDLE9BQU8sQ0FBQztvQkFDakIsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2lCQUN0QztpR0FHSyxNQUFNO3NCQURULFdBQVc7dUJBQUMsY0FBYztnQkFPdkIsSUFBSTtzQkFEUCxLQUFLO2dCQVVHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBRUksT0FBTztzQkFBaEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZvY3VzT3JpZ2luIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2ExMXknO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLCBIb3N0QmluZGluZywgSW5wdXQsIE91dHB1dCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENhbkNvbG9yLCBtaXhpbkNvbG9yIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5cbmltcG9ydCB7IEZvcm1TdGVwIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2Zvcm0tc3RlcHBlci9mb3JtLXN0ZXAubW9kZWwnO1xuXG4vKiBlc2xpbnQtZGlzYWJsZSBAYW5ndWxhci1lc2xpbnQvbm8taW5wdXRzLW1ldGFkYXRhLXByb3BlcnR5ICovXG5jb25zdCBfU3RlcENhcmRNaXhpbkJhc2UgPSBtaXhpbkNvbG9yKFxuICBjbGFzcyB7XG4gICAgY29uc3RydWN0b3IocHVibGljIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmKSB7fVxuICB9LFxuICAnYWNjZW50J1xuKTtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbXRuYS13Zi1zdGVwLWNhcmQnLFxuICB0ZW1wbGF0ZVVybDogJy4vc3RlcC1jYXJkLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vc3RlcC1jYXJkLmNvbXBvbmVudC5zY3NzJ10sXG4gIGlucHV0czogWydjb2xvciddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbn0pXG5leHBvcnQgY2xhc3MgTXRuYVdmU3RlcENhcmRDb21wb25lbnQgZXh0ZW5kcyBfU3RlcENhcmRNaXhpbkJhc2UgaW1wbGVtZW50cyBDYW5Db2xvciB7XG4gIEBIb3N0QmluZGluZygnY2xhc3MuYWN0aXZlJylcbiAgZ2V0IGFjdGl2ZSgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gISF0aGlzLnN0ZXA/LmFjdGl2ZTtcbiAgfVxuXG4gIC8vIEBJbnB1dCgpIHN0ZXA6IEZvcm1TdGVwIHwgbnVsbCB8IHVuZGVmaW5lZDtcbiAgQElucHV0KClcbiAgZ2V0IHN0ZXAoKTogRm9ybVN0ZXAgfCBudWxsIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gdGhpcy5fc3RlcDtcbiAgfVxuICBzZXQgc3RlcChzdGVwOiBGb3JtU3RlcCB8IG51bGwgfCB1bmRlZmluZWQpIHtcbiAgICB0aGlzLl9zdGVwID0gc3RlcDtcbiAgICBjb25zb2xlLndhcm4oeyBzdGVwSW5zaWRlU3RlcENhcmQ6IHN0ZXAgfSk7XG4gIH1cbiAgcHJpdmF0ZSBfc3RlcDogRm9ybVN0ZXAgfCBudWxsIHwgdW5kZWZpbmVkO1xuXG4gIEBJbnB1dCgpIHN1YnRpdGxlOiBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkO1xuXG4gIEBPdXRwdXQoKSBmb2N1c2VkID0gbmV3IEV2ZW50RW1pdHRlcjxGb3JtU3RlcD4oKTtcblxuICBjb25zdHJ1Y3RvcihlbGVtZW50UmVmOiBFbGVtZW50UmVmKSB7XG4gICAgc3VwZXIoZWxlbWVudFJlZik7XG4gIH1cblxuICBoYW5kbGVGb2N1c0NoYW5nZShldmVudDogRm9jdXNPcmlnaW4pIHtcbiAgICBpZiAoISF0aGlzLnN0ZXAgJiYgISFldmVudCAmJiAhdGhpcy5zdGVwLmFjdGl2ZSkge1xuICAgICAgdGhpcy5mb2N1c2VkLmVtaXQodGhpcy5zdGVwKTtcbiAgICB9XG4gIH1cbn1cbiIsIjxtYXQtY2FyZCBjZGtNb25pdG9yU3VidHJlZUZvY3VzIChjZGtGb2N1c0NoYW5nZSk9XCJoYW5kbGVGb2N1c0NoYW5nZSgkZXZlbnQpXCI+XG4gIDxtYXQtY2FyZC1oZWFkZXI+XG4gICAgPG10bmEtc3RhdHVzLWNpcmNsZSBtYXQtY2FyZC1hdmF0YXIgW2NpcmNsZU51bWJlcl09XCJzdGVwPy5udW1cIiBbb3B0aW9uYWxdPVwic3RlcD8ub3B0aW9uYWxcIiBbc3RhdHVzXT1cInN0ZXA/LnN0YXR1c1wiPjwvbXRuYS1zdGF0dXMtY2lyY2xlPlxuICAgIDxtYXQtY2FyZC10aXRsZT57eyBzdGVwPy5sYWJlbCB9fTwvbWF0LWNhcmQtdGl0bGU+XG4gICAgPG1hdC1jYXJkLXN1YnRpdGxlIFtpbm5lckhUTUxdPVwic3VidGl0bGUgfCBtdG5hV2ZTYW5pdGl6ZUh0bWxcIj48L21hdC1jYXJkLXN1YnRpdGxlPlxuICAgIDxwICpuZ0lmPVwic3RlcD8ub3B0aW9uYWxcIiBjbGFzcz1cIm9wdGlvbmFsIG1hdC1jYXB0aW9uXCIgaTE4bj5PcHRpb25hbDwvcD5cbiAgPC9tYXQtY2FyZC1oZWFkZXI+XG5cbiAgPG1hdC1kaXZpZGVyIFtpbnNldF09XCJ0cnVlXCI+PC9tYXQtZGl2aWRlcj5cblxuICA8bWF0LWNhcmQtY29udGVudD5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbY2FyZENvbnRlbnRdXCI+PC9uZy1jb250ZW50PlxuICA8L21hdC1jYXJkLWNvbnRlbnQ+XG5cbiAgPG1hdC1jYXJkLWFjdGlvbnM+XG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW2NhcmRBY3Rpb25zXVwiPjwvbmctY29udGVudD5cbiAgPC9tYXQtY2FyZC1hY3Rpb25zPlxuPC9tYXQtY2FyZD5cbiJdfQ==