@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.
- package/_index.scss +1 -2
- package/bundles/mtna-web-form-angular.umd.js +1219 -539
- package/bundles/mtna-web-form-angular.umd.js.map +1 -1
- package/esm2015/lib/components/acknowledge-dialog/acknowledge-dialog.component.js +2 -2
- package/esm2015/lib/components/base-form/base-form.component.js +243 -0
- package/esm2015/lib/components/base-form/index.js +2 -0
- package/esm2015/lib/components/base-items/base-group-item.component.js +5 -5
- package/esm2015/lib/components/base-items/base-parent-value-item.component.js +3 -2
- package/esm2015/lib/components/base-items/base-section-item.component.js +6 -5
- package/esm2015/lib/components/form/form.component.js +13 -239
- package/esm2015/lib/components/form-item/form-item.component.js +2 -2
- package/esm2015/lib/components/form-item-component-provider/form-item-injected-components.js +7 -1
- package/esm2015/lib/components/form-item-dialog/form-item-dialog.component.js +6 -5
- package/esm2015/lib/components/form-item-dialog/form-item-dialog.module.js +5 -4
- package/esm2015/lib/components/form-item-impl/boolean/boolean.component.js +2 -2
- package/esm2015/lib/components/form-item-impl/checkbox/checkbox.component.js +7 -5
- package/esm2015/lib/components/form-item-impl/checkbox/checkbox.module.js +5 -1
- package/esm2015/lib/components/form-item-impl/date/date.component.js +3 -2
- package/esm2015/lib/components/form-item-impl/date-range/date-range.component.js +6 -2
- package/esm2015/lib/components/form-item-impl/dropdown/dropdown.component.js +2 -2
- package/esm2015/lib/components/form-item-impl/file-upload/file-upload.component.js +3 -2
- package/esm2015/lib/components/form-item-impl/form-group/form-group.component.js +2 -2
- package/esm2015/lib/components/form-item-impl/i18n-input/i18n-input.component.js +3 -2
- package/esm2015/lib/components/form-item-impl/input/input.component.js +3 -2
- package/esm2015/lib/components/form-item-impl/multiple-choice/multiple-choice.component.js +2 -2
- package/esm2015/lib/components/form-item-impl/repeatable-item-container/repeatable-item-container.component.js +3 -2
- package/esm2015/lib/components/form-item-impl/search/resource-search.component.js +2 -2
- package/esm2015/lib/components/form-item-impl/year-quarter/year-quarter.component.js +2 -3
- package/esm2015/lib/components/form-stepper/form-step/form-step.component.js +10 -3
- package/esm2015/lib/components/form-stepper/form-step-group/form-step-group.component.js +4 -2
- package/esm2015/lib/components/form-stepper/form-stepper/form-stepper.component.js +52 -10
- package/esm2015/lib/components/form-stepper/form-stepper.module.js +17 -5
- package/esm2015/lib/components/index.js +2 -1
- package/esm2015/lib/components/progressive-form/index.js +3 -0
- package/esm2015/lib/components/progressive-form/progressive-form/index.js +3 -0
- package/esm2015/lib/components/progressive-form/progressive-form/progressive-form.component.js +287 -0
- package/esm2015/lib/components/progressive-form/progressive-form/progressive-form.module.js +68 -0
- package/esm2015/lib/components/progressive-form/progressive-form-section/index.js +3 -0
- package/esm2015/lib/components/progressive-form/progressive-form-section/progressive-form-section.component.js +27 -0
- package/esm2015/lib/components/progressive-form/progressive-form-section/progressive-form-section.module.js +54 -0
- package/esm2015/lib/components/step-card/step-card.component.js +10 -2
- package/esm2015/lib/components/step-card/step-card.module.js +27 -4
- package/esm2015/lib/models/form-stepper/form-step-group.model.js +8 -2
- package/esm2015/lib/models/form-stepper/form-step.model.js +7 -1
- package/esm2015/lib/models/index.js +2 -1
- package/esm2015/lib/models/progressive-form/index.js +4 -0
- package/esm2015/lib/models/progressive-form/outline-step.model.js +2 -0
- package/esm2015/lib/models/progressive-form/progressive-form-section.model.js +6 -0
- package/esm2015/lib/models/progressive-form/progressive-form.model.js +6 -0
- package/esm2015/lib/pipes/child-step-active.pipe.js +28 -0
- package/esm2015/lib/pipes/coerce-form-step-group.pipe.js +29 -0
- package/esm2015/lib/pipes/coerce-form-step.pipe.js +29 -0
- package/esm2015/lib/pipes/date-quarter.pipe.js +13 -13
- package/esm2015/lib/pipes/get-active-form-step-item.pipe.js +33 -0
- package/esm2015/lib/pipes/get-progressive-form-item.pipe.js +40 -0
- package/esm2015/lib/pipes/get-selected-option.pipe.js +4 -3
- package/esm2015/lib/pipes/get-step-aria-label.pipe.js +55 -0
- package/esm2015/lib/pipes/index.js +7 -1
- package/esm2015/lib/pipes/items-with-value.pipe.js +5 -10
- package/esm2015/lib/services/dialog.service.js +4 -3
- package/esm2015/lib/services/form-manager.service.js +19 -7
- package/esm2015/lib/services/ng-form.service.js +7 -1
- package/esm2015/lib/services/ui.service.js +15 -15
- package/esm2015/lib/utilities/generate-form-steps.js +20 -5
- package/esm2015/lib/utilities/serializer-util.js +12 -5
- package/esm2015/lib/utilities/update-step-status.js +1 -1
- package/esm2015/public-api.js +1 -2
- package/fesm2015/mtna-web-form-angular.js +962 -364
- package/fesm2015/mtna-web-form-angular.js.map +1 -1
- package/lib/components/base-form/base-form.component.d.ts +89 -0
- package/lib/components/base-form/index.d.ts +1 -0
- package/lib/components/base-items/base-group-item.component.d.ts +2 -0
- package/lib/components/base-items/base-section-item.component.d.ts +2 -1
- package/lib/components/form/form.component.d.ts +4 -86
- package/lib/components/form-item-dialog/form-item-dialog.module.d.ts +2 -1
- package/lib/components/form-item-impl/checkbox/_checkbox-theme.scss +11 -2
- package/lib/components/form-item-impl/checkbox/checkbox.component.d.ts +1 -0
- package/lib/components/form-item-impl/checkbox/checkbox.module.d.ts +11 -10
- package/lib/components/form-item-impl/date/date.component.d.ts +1 -0
- package/lib/components/form-item-impl/date-range/date-range.component.d.ts +1 -0
- package/lib/components/form-item-impl/dropdown/_dropdown-theme.scss +35 -0
- package/lib/components/form-item-impl/file-upload/file-upload.component.d.ts +1 -0
- package/lib/components/form-item-impl/i18n-input/i18n-input.component.d.ts +1 -0
- package/lib/components/form-item-impl/input/input.component.d.ts +1 -0
- package/lib/components/form-item-impl/repeatable-item-container/repeatable-item-container.component.d.ts +1 -0
- package/lib/components/form-stepper/form-step/form-step.component.d.ts +7 -0
- package/lib/components/form-stepper/form-step-group/form-step-group.component.d.ts +2 -0
- package/lib/components/form-stepper/form-stepper/_form-stepper-theme.scss +30 -15
- package/lib/components/form-stepper/form-stepper/form-stepper.component.d.ts +15 -1
- package/lib/components/form-stepper/form-stepper.module.d.ts +5 -1
- package/lib/components/index.d.ts +1 -0
- package/lib/components/progressive-form/index.d.ts +2 -0
- package/lib/components/progressive-form/progressive-form/index.d.ts +2 -0
- package/lib/components/progressive-form/progressive-form/progressive-form.component.d.ts +101 -0
- package/lib/components/progressive-form/progressive-form/progressive-form.module.d.ts +19 -0
- package/lib/components/progressive-form/progressive-form-section/index.d.ts +2 -0
- package/lib/components/progressive-form/progressive-form-section/progressive-form-section.component.d.ts +9 -0
- package/lib/components/progressive-form/progressive-form-section/progressive-form-section.module.d.ts +16 -0
- package/lib/components/step-card/step-card.component.d.ts +3 -1
- package/lib/components/step-card/step-card.module.d.ts +2 -1
- package/lib/core/_all-color.scss +2 -2
- package/lib/core/_all-theme.scss +2 -2
- package/lib/core/_all-typography.scss +2 -2
- package/lib/models/form-stepper/form-step-group.model.d.ts +5 -1
- package/lib/models/form-stepper/form-step.model.d.ts +3 -0
- package/lib/models/index.d.ts +1 -0
- package/lib/models/progressive-form/index.d.ts +3 -0
- package/lib/models/progressive-form/outline-step.model.d.ts +7 -0
- package/lib/models/progressive-form/progressive-form-section.model.d.ts +4 -0
- package/lib/models/progressive-form/progressive-form.model.d.ts +7 -0
- package/lib/pipes/child-step-active.pipe.d.ts +13 -0
- package/lib/pipes/coerce-form-step-group.pipe.d.ts +13 -0
- package/lib/pipes/coerce-form-step.pipe.d.ts +13 -0
- package/lib/pipes/get-active-form-step-item.pipe.d.ts +13 -0
- package/lib/pipes/get-progressive-form-item.pipe.d.ts +14 -0
- package/lib/pipes/get-step-aria-label.pipe.d.ts +17 -0
- package/lib/pipes/index.d.ts +6 -0
- package/lib/pipes/items-with-value.pipe.d.ts +0 -1
- package/lib/services/dialog.service.d.ts +1 -0
- package/lib/services/form-manager.service.d.ts +13 -4
- package/lib/services/ng-form.service.d.ts +6 -0
- package/lib/utilities/generate-form-steps.d.ts +5 -1
- package/lib/utilities/update-step-status.d.ts +2 -2
- package/package.json +1 -1
- package/public-api.d.ts +0 -1
- package/esm2015/lib/directives/base-form-item-control.directive.js +0 -58
- package/esm2015/lib/directives/base-parent-item-control.directive.js +0 -42
- package/esm2015/lib/directives/base-single-selection-parent.directive.js +0 -53
- package/esm2015/lib/directives/form-item.directive.js +0 -22
- package/esm2015/lib/directives/index.js +0 -5
- package/lib/directives/base-form-item-control.directive.d.ts +0 -26
- package/lib/directives/base-parent-item-control.directive.d.ts +0 -19
- package/lib/directives/base-single-selection-parent.directive.d.ts +0 -26
- package/lib/directives/form-item.directive.d.ts +0 -13
- package/lib/directives/index.d.ts +0 -4
|
@@ -16,7 +16,7 @@ export class MtnaWfAcknowledgeDialogComponent {
|
|
|
16
16
|
}
|
|
17
17
|
}
|
|
18
18
|
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 });
|
|
19
|
-
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: i2.MtnaWfFormItemComponent, selector: "mtna-wf-item", inputs: ["color", "control", "header", "inList", "item", "parentIds", "readonly", "step"], outputs: ["focusedSection"] }, { type: i3.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: i4.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: i4.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"] }] });
|
|
19
|
+
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 i18n>CANCEL</button>\n <button [mat-dialog-close]=\"true\" color=\"accent\" mat-raised-button i18n>ACKNOWLEDGE</button>\n</mat-dialog-actions>\n", components: [{ type: i2.MtnaWfFormItemComponent, selector: "mtna-wf-item", inputs: ["color", "control", "header", "inList", "item", "parentIds", "readonly", "step"], outputs: ["focusedSection"] }, { type: i3.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: i4.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: i4.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"] }] });
|
|
20
20
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfAcknowledgeDialogComponent, decorators: [{
|
|
21
21
|
type: Component,
|
|
22
22
|
args: [{
|
|
@@ -27,4 +27,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
27
27
|
type: Inject,
|
|
28
28
|
args: [MAT_DIALOG_DATA]
|
|
29
29
|
}] }, { type: i1.MatDialogRef }]; } });
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNrbm93bGVkZ2UtZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dlYi1mb3JtLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2Fja25vd2xlZGdlLWRpYWxvZy9hY2tub3dsZWRnZS1kaWFsb2cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvd2ViLWZvcm0tYW5ndWxhci9zcmMvbGliL2NvbXBvbmVudHMvYWNrbm93bGVkZ2UtZGlhbG9nL2Fja25vd2xlZGdlLWRpYWxvZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsZUFBZSxFQUFnQixNQUFNLDBCQUEwQixDQUFDOzs7Ozs7O0FBSXpFOztHQUVHO0FBS0gsTUFBTSxPQUFPLGdDQUFnQztJQUMzQyxZQUNrQyxJQUE4QixFQUN2RCxTQUFrRTtRQUR6QyxTQUFJLEdBQUosSUFBSSxDQUEwQjtRQUN2RCxjQUFTLEdBQVQsU0FBUyxDQUF5RDtJQUN4RSxDQUFDOzs4SEFKTyxnQ0FBZ0Msa0JBRWpDLGVBQWU7a0hBRmQsZ0NBQWdDLGtFQ1o3QyxzY0FRQTs0RkRJYSxnQ0FBZ0M7a0JBSjVDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLDRCQUE0QjtvQkFDdEMsV0FBVyxFQUFFLHFDQUFxQztpQkFDbkQ7OzBCQUdJLE1BQU07MkJBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNQVRfRElBTE9HX0RBVEEsIE1hdERpYWxvZ1JlZiB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5cbmltcG9ydCB7IE10bmFXZkZvcm1JdGVtRGlhbG9nRGF0YSB9IGZyb20gJy4uLy4uL21vZGVscy9mb3JtLWl0ZW0tZGlhbG9nLWRhdGEubW9kZWwnO1xuXG4vKipcbiAqIEEgZGlhbG9nIHRoYXQgcmVuZGVycyBhIGZvcm0gaXRlbSB0aGF0IHJlcHJlc2VudHMgc29tZXRoaW5nIHRoZSB1c2VyIG5lZWRzIHRvIGFja25vd2xlZGdlLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdtdG5hLXdmLWFja25vd2xlZGdlLWRpYWxvZycsXG4gIHRlbXBsYXRlVXJsOiAnLi9hY2tub3dsZWRnZS1kaWFsb2cuY29tcG9uZW50Lmh0bWwnLFxufSlcbmV4cG9ydCBjbGFzcyBNdG5hV2ZBY2tub3dsZWRnZURpYWxvZ0NvbXBvbmVudCB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKSBwdWJsaWMgZGF0YTogTXRuYVdmRm9ybUl0ZW1EaWFsb2dEYXRhLFxuICAgIHB1YmxpYyBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxNdG5hV2ZBY2tub3dsZWRnZURpYWxvZ0NvbXBvbmVudCwgYm9vbGVhbj5cbiAgKSB7fVxufVxuIiwiPGgyICpuZ0lmPVwiZGF0YS50aXRsZSBhcyB0aXRsZVwiIG1hdC1kaWFsb2ctdGl0bGU+e3sgdGl0bGUgfX08L2gyPlxuPG1hdC1kaWFsb2ctY29udGVudD5cbiAgPG10bmEtd2YtaXRlbSAqbmdGb3I9XCJsZXQgaXRlbSBvZiBkYXRhLmZvcm1JdGVtc1wiIFtpdGVtXT1cIml0ZW1cIiBbcmVhZG9ubHldPVwidHJ1ZVwiPjwvbXRuYS13Zi1pdGVtPlxuPC9tYXQtZGlhbG9nLWNvbnRlbnQ+XG48bWF0LWRpYWxvZy1hY3Rpb25zIGFsaWduPVwiZW5kXCI+XG4gIDxidXR0b24gW21hdC1kaWFsb2ctY2xvc2VdPVwiZmFsc2VcIiBtYXQtYnV0dG9uIGkxOG4+Q0FOQ0VMPC9idXR0b24+XG4gIDxidXR0b24gW21hdC1kaWFsb2ctY2xvc2VdPVwidHJ1ZVwiIGNvbG9yPVwiYWNjZW50XCIgbWF0LXJhaXNlZC1idXR0b24gaTE4bj5BQ0tOT1dMRURHRTwvYnV0dG9uPlxuPC9tYXQtZGlhbG9nLWFjdGlvbnM+XG4iXX0=
|
|
@@ -0,0 +1,243 @@
|
|
|
1
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
|
+
import { mixinDestroyNotifier } from '@mtna/core-angular';
|
|
4
|
+
import { BehaviorSubject, Subscription } from 'rxjs';
|
|
5
|
+
import { distinctUntilChanged, skipWhile, takeUntil } from 'rxjs/operators';
|
|
6
|
+
import { findFormControl } from '../../utilities';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "../../services";
|
|
9
|
+
const _BaseFormComponent = mixinDestroyNotifier(class {
|
|
10
|
+
});
|
|
11
|
+
export class MtnaWfBaseFormComponent extends _BaseFormComponent {
|
|
12
|
+
constructor(mtnaFormManager, ngFormService, uiService) {
|
|
13
|
+
super();
|
|
14
|
+
this.mtnaFormManager = mtnaFormManager;
|
|
15
|
+
this.ngFormService = ngFormService;
|
|
16
|
+
this.uiService = uiService;
|
|
17
|
+
this._emitStatusOnMtnaFormChange = false;
|
|
18
|
+
this.readonly$ = new BehaviorSubject(true);
|
|
19
|
+
/**
|
|
20
|
+
* Emitted every time a form control's validation status changes.
|
|
21
|
+
* The `id` is the form control's name and the `status` is the new validation status for the control.
|
|
22
|
+
*/
|
|
23
|
+
this.status = new EventEmitter();
|
|
24
|
+
this.focusedSection = new EventEmitter();
|
|
25
|
+
this.mtnaFormChange = new EventEmitter();
|
|
26
|
+
this.componentIds = [];
|
|
27
|
+
this._hasPreviousForm = false;
|
|
28
|
+
this._initialStatusEmitted = false;
|
|
29
|
+
this._constructionDate = new Date();
|
|
30
|
+
// Initialize the subscription to observe input changes
|
|
31
|
+
this._subscribeAndEmitMtnaFormChanges();
|
|
32
|
+
}
|
|
33
|
+
set annotations(map) {
|
|
34
|
+
this.uiService.registerAnnotations(map);
|
|
35
|
+
}
|
|
36
|
+
/** Whether to emit the status of each step each time the {@link mtnaForm} is set to a new value. Defaults to false.*/
|
|
37
|
+
get emitStatusOnMtnaFormChange() {
|
|
38
|
+
return this._emitStatusOnMtnaFormChange;
|
|
39
|
+
}
|
|
40
|
+
set emitStatusOnMtnaFormChange(emitStatusOnMtnaFormChange) {
|
|
41
|
+
this._emitStatusOnMtnaFormChange = coerceBooleanProperty(emitStatusOnMtnaFormChange);
|
|
42
|
+
}
|
|
43
|
+
get mtnaForm() {
|
|
44
|
+
return this._mtnaForm;
|
|
45
|
+
}
|
|
46
|
+
set mtnaForm(form) {
|
|
47
|
+
if (!!form && !this.ngForm) {
|
|
48
|
+
// serialize the form when input is set the first time
|
|
49
|
+
this._handleFormSerialization(form);
|
|
50
|
+
this._checkAndSubscribeToFormStatus();
|
|
51
|
+
}
|
|
52
|
+
this._mtnaForm = form;
|
|
53
|
+
if (form) {
|
|
54
|
+
this.mtnaFormManager.setMtnaForm(form);
|
|
55
|
+
// If indicated, re-emit the status of each step when there is a new form
|
|
56
|
+
if (this.emitStatusOnMtnaFormChange && this.ngForm) {
|
|
57
|
+
for (const key in this._steps) {
|
|
58
|
+
if (Object.prototype.hasOwnProperty.call(this._steps, key)) {
|
|
59
|
+
this._emitFormControlStatus(key);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* The form can contain sections not included in the steps.
|
|
67
|
+
* To avoid misalignment of steps-to-sections, we map each step to
|
|
68
|
+
* its instanceId
|
|
69
|
+
*/
|
|
70
|
+
set steps(newSteps) {
|
|
71
|
+
if (!!newSteps && !!newSteps.length) {
|
|
72
|
+
if (!this._steps) {
|
|
73
|
+
this._steps = {};
|
|
74
|
+
}
|
|
75
|
+
for (const step of newSteps) {
|
|
76
|
+
this._steps[step.instanceId] = step;
|
|
77
|
+
}
|
|
78
|
+
this._checkAndSubscribeToFormStatus();
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
get readonly() {
|
|
82
|
+
return this.readonly$.value;
|
|
83
|
+
}
|
|
84
|
+
set readonly(r) {
|
|
85
|
+
const newValue = coerceBooleanProperty(r);
|
|
86
|
+
if (newValue !== this.readonly$.value) {
|
|
87
|
+
this.readonly$.next(r);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
ngAfterViewInit() {
|
|
91
|
+
const afterViewInitDate = new Date();
|
|
92
|
+
const secondsToRender = (afterViewInitDate.getTime() - this._constructionDate.getTime()) / 1000;
|
|
93
|
+
console.warn('[MtnaFormComponent] afterViewInit - took ', secondsToRender, ' to render');
|
|
94
|
+
}
|
|
95
|
+
ngOnDestroy() {
|
|
96
|
+
super.ngOnDestroy();
|
|
97
|
+
this.uiService.resetComponentMap();
|
|
98
|
+
}
|
|
99
|
+
_trackByInstanceId(index, formItem) {
|
|
100
|
+
return formItem.instanceId;
|
|
101
|
+
}
|
|
102
|
+
/** Subscribe and emit form status changes for the steps. */
|
|
103
|
+
_checkAndSubscribeToFormStatus() {
|
|
104
|
+
// Only subscribe once both the steps and the angular have been initialized
|
|
105
|
+
if (this.ngForm && this._steps) {
|
|
106
|
+
// Update form status subscriptions anytime the readonly input changes
|
|
107
|
+
this.readonly$.pipe(takeUntil(this.destroyed$), distinctUntilChanged()).subscribe((readonly) => {
|
|
108
|
+
if (readonly) {
|
|
109
|
+
// Don't emit statuses while form is in readonly
|
|
110
|
+
this._unsubscribeFromNgFormChanges();
|
|
111
|
+
}
|
|
112
|
+
else if (!this._ngFormStatusChangeSub || this._ngFormStatusChangeSub.closed) {
|
|
113
|
+
// For performance, subscribe should only trigger again if the subscription didn't previously exist
|
|
114
|
+
this._emitInitialStepsStatusAndSubscribeToChanges(!this._initialStatusEmitted);
|
|
115
|
+
this._initialStatusEmitted = true;
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
/**
|
|
121
|
+
* Find a form control with the given name, then emit it's status.
|
|
122
|
+
*
|
|
123
|
+
* @param name — The unique name of the form control to find and emit the status for.
|
|
124
|
+
*/
|
|
125
|
+
_emitFormControlStatus(name) {
|
|
126
|
+
if (this.ngForm) {
|
|
127
|
+
const control = findFormControl(name, this.ngForm);
|
|
128
|
+
if (control) {
|
|
129
|
+
this.status.emit({
|
|
130
|
+
id: name,
|
|
131
|
+
status: control.status,
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* @param emitInitialValues Whether to emit initial step values or just listen for future changes
|
|
138
|
+
*/
|
|
139
|
+
_emitInitialStepsStatusAndSubscribeToChanges(emitInitialValues) {
|
|
140
|
+
if (this._steps && this.ngForm) {
|
|
141
|
+
this._unsubscribeFromNgFormChanges();
|
|
142
|
+
this._ngFormStatusChangeSub = new Subscription();
|
|
143
|
+
// Find the form control for each step and only subscribe to those.
|
|
144
|
+
for (const key in this._steps) {
|
|
145
|
+
if (Object.prototype.hasOwnProperty.call(this._steps, key)) {
|
|
146
|
+
const control = findFormControl(key, this.ngForm);
|
|
147
|
+
if (control) {
|
|
148
|
+
if (emitInitialValues) {
|
|
149
|
+
this.status.emit({
|
|
150
|
+
id: key,
|
|
151
|
+
// Angular introduced this status in v13, once we update, this type cast can be removed.
|
|
152
|
+
status: control.status,
|
|
153
|
+
});
|
|
154
|
+
}
|
|
155
|
+
// Subscribe to status changes of each step & emit on change
|
|
156
|
+
this._ngFormStatusChangeSub.add(control.statusChanges.pipe(takeUntil(this.destroyed$), distinctUntilChanged()).subscribe((status) => {
|
|
157
|
+
this.status.emit({ id: key, status });
|
|
158
|
+
}));
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* Observes input changes for readOnly, in order to handle internal change subscriptions.
|
|
166
|
+
* When the form is not readonly, we subscribe to form status & form item changes, so we can emit them.
|
|
167
|
+
* When the form is readonly, we do not want to emit any changes, so we unsubscribe.
|
|
168
|
+
*/
|
|
169
|
+
_subscribeAndEmitMtnaFormChanges() {
|
|
170
|
+
this.readonly$
|
|
171
|
+
.pipe(takeUntil(this.destroyed$),
|
|
172
|
+
// we don't want to create subscriptions until we have a form to subscribe to
|
|
173
|
+
skipWhile(() => !this.mtnaForm), distinctUntilChanged())
|
|
174
|
+
.subscribe((readonly) => {
|
|
175
|
+
if (readonly) {
|
|
176
|
+
this._unsubscribeFromMtnaFormChanges();
|
|
177
|
+
}
|
|
178
|
+
else if (!this._mtnaFormItemChangeSub || this._mtnaFormItemChangeSub.closed) {
|
|
179
|
+
// For performance, subscribe should only trigger again if one of the subscriptions didn't previously exist
|
|
180
|
+
this._subscribeToMtnaFormItemChanges();
|
|
181
|
+
}
|
|
182
|
+
});
|
|
183
|
+
}
|
|
184
|
+
_handleFormSerialization(form) {
|
|
185
|
+
// Get the registered form from the service if it exists
|
|
186
|
+
this._hasPreviousForm = this.ngFormService.hasForm();
|
|
187
|
+
if (this._hasPreviousForm) {
|
|
188
|
+
this.ngForm = this.ngFormService.getForm();
|
|
189
|
+
// FIXME this is necessary because the initial visiblity is based on the mtnaForm item's disable property
|
|
190
|
+
// If the user changes a value, goes to another tab (destroying form) and comes back, the initial values are incorrect
|
|
191
|
+
this.mtnaForm = this.mtnaFormManager.insertNewValues(form, this.ngFormService.getFormValue());
|
|
192
|
+
}
|
|
193
|
+
else {
|
|
194
|
+
this.ngForm = this.mtnaFormManager.serializeMtnaFormItem(form);
|
|
195
|
+
this.ngFormService.setForm(this.ngForm);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
/**
|
|
199
|
+
* Adds or removes a FormItem whenever a new MtnaWfFormItemChange occurs,
|
|
200
|
+
* and emits a new MtnaForm.
|
|
201
|
+
*/
|
|
202
|
+
_subscribeToMtnaFormItemChanges() {
|
|
203
|
+
this._unsubscribeFromMtnaFormChanges();
|
|
204
|
+
this._mtnaFormItemChangeSub = this.mtnaFormManager.formChanges
|
|
205
|
+
.pipe(takeUntil(this.destroyed$), skipWhile((change) => !change))
|
|
206
|
+
.subscribe((newForm) => this.mtnaFormChange.emit(newForm));
|
|
207
|
+
}
|
|
208
|
+
_unsubscribeFromNgFormChanges() {
|
|
209
|
+
if (!!this._ngFormStatusChangeSub && !this._ngFormStatusChangeSub.closed) {
|
|
210
|
+
this._ngFormStatusChangeSub.unsubscribe();
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
_unsubscribeFromMtnaFormChanges() {
|
|
214
|
+
if (!!this._mtnaFormItemChangeSub && !this._mtnaFormItemChangeSub.closed) {
|
|
215
|
+
this._mtnaFormItemChangeSub.unsubscribe();
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
MtnaWfBaseFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfBaseFormComponent, deps: [{ token: i1.MtnaWfManagerService }, { token: i1.MtnaWfNgFormService }, { token: i1.MtnaWfUIService }], target: i0.ɵɵFactoryTarget.Component });
|
|
220
|
+
MtnaWfBaseFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfBaseFormComponent, selector: "ng-component", inputs: { annotations: "annotations", emitStatusOnMtnaFormChange: "emitStatusOnMtnaFormChange", mtnaForm: "mtnaForm", steps: "steps", readonly: "readonly" }, outputs: { status: "status", focusedSection: "focusedSection", mtnaFormChange: "mtnaFormChange" }, usesInheritance: true, ngImport: i0, template: ``, isInline: true });
|
|
221
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfBaseFormComponent, decorators: [{
|
|
222
|
+
type: Component,
|
|
223
|
+
args: [{
|
|
224
|
+
template: ``,
|
|
225
|
+
}]
|
|
226
|
+
}], ctorParameters: function () { return [{ type: i1.MtnaWfManagerService }, { type: i1.MtnaWfNgFormService }, { type: i1.MtnaWfUIService }]; }, propDecorators: { annotations: [{
|
|
227
|
+
type: Input
|
|
228
|
+
}], emitStatusOnMtnaFormChange: [{
|
|
229
|
+
type: Input
|
|
230
|
+
}], mtnaForm: [{
|
|
231
|
+
type: Input
|
|
232
|
+
}], steps: [{
|
|
233
|
+
type: Input
|
|
234
|
+
}], readonly: [{
|
|
235
|
+
type: Input
|
|
236
|
+
}], status: [{
|
|
237
|
+
type: Output
|
|
238
|
+
}], focusedSection: [{
|
|
239
|
+
type: Output
|
|
240
|
+
}], mtnaFormChange: [{
|
|
241
|
+
type: Output
|
|
242
|
+
}] } });
|
|
243
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/web-form-angular/src/lib/components/base-form/base-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { AfterViewInit, Component, EventEmitter, Input, OnDestroy, Output } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { CanDestroyNotify, mixinDestroyNotifier } from '@mtna/core-angular';\nimport { AnnotatableNumberMap } from '@mtna/pojo-social-angular';\nimport { Form, FormControlStatus, FormItem } from '@mtna/web-form-ts';\nimport { BehaviorSubject, Subscription } from 'rxjs';\nimport { distinctUntilChanged, skipWhile, takeUntil } from 'rxjs/operators';\n\nimport { FormStep } from '../../models';\nimport { MtnaWfManagerService, MtnaWfNgFormService, MtnaWfUIService } from '../../services';\nimport { findFormControl } from '../../utilities';\n\nconst _BaseFormComponent = mixinDestroyNotifier(class {});\n\n@Component({\n  template: ``,\n})\nexport class MtnaWfBaseFormComponent<F extends Form = Form>\n  extends _BaseFormComponent\n  implements AfterViewInit, CanDestroyNotify, OnDestroy\n{\n  static ngAcceptInputType_emitStatusOnMtnaFormChange: BooleanInput;\n  static ngAcceptInputTypes_readonly: BooleanInput;\n\n  @Input()\n  set annotations(map: AnnotatableNumberMap) {\n    this.uiService.registerAnnotations(map);\n  }\n\n  /** Whether to emit the status of each step each time the {@link mtnaForm} is set to a new value. Defaults to false.*/\n  @Input()\n  get emitStatusOnMtnaFormChange(): boolean {\n    return this._emitStatusOnMtnaFormChange;\n  }\n  set emitStatusOnMtnaFormChange(emitStatusOnMtnaFormChange: boolean) {\n    this._emitStatusOnMtnaFormChange = coerceBooleanProperty(emitStatusOnMtnaFormChange);\n  }\n  private _emitStatusOnMtnaFormChange = false;\n\n  @Input()\n  get mtnaForm(): F | null | undefined {\n    return this._mtnaForm;\n  }\n  set mtnaForm(form: F | null | undefined) {\n    if (!!form && !this.ngForm) {\n      // serialize the form when input is set the first time\n      this._handleFormSerialization(form);\n      this._checkAndSubscribeToFormStatus();\n    }\n    this._mtnaForm = form;\n    if (form) {\n      this.mtnaFormManager.setMtnaForm(form);\n\n      // If indicated, re-emit the status of each step when there is a new form\n      if (this.emitStatusOnMtnaFormChange && this.ngForm) {\n        for (const key in this._steps) {\n          if (Object.prototype.hasOwnProperty.call(this._steps, key)) {\n            this._emitFormControlStatus(key);\n          }\n        }\n      }\n    }\n  }\n  private _mtnaForm: F | null | undefined;\n\n  /**\n   * The form can contain sections not included in the steps.\n   * To avoid misalignment of steps-to-sections, we map each step to\n   * its instanceId\n   */\n  @Input()\n  set steps(newSteps: Array<FormStep> | null | undefined) {\n    if (!!newSteps && !!newSteps.length) {\n      if (!this._steps) {\n        this._steps = {};\n      }\n      for (const step of newSteps) {\n        this._steps[step.instanceId] = step;\n      }\n      this._checkAndSubscribeToFormStatus();\n    }\n  }\n\n  @Input()\n  get readonly(): boolean {\n    return this.readonly$.value;\n  }\n  set readonly(r: boolean) {\n    const newValue = coerceBooleanProperty(r);\n    if (newValue !== this.readonly$.value) {\n      this.readonly$.next(r);\n    }\n  }\n  private readonly$ = new BehaviorSubject<boolean>(true);\n\n  /**\n   * Emitted every time a form control's validation status changes.\n   * The `id` is the form control's name and the `status` is the new validation status for the control.\n   */\n  @Output() status = new EventEmitter<{ id: string; status: FormControlStatus }>();\n  @Output() focusedSection = new EventEmitter<FormStep>();\n  @Output() mtnaFormChange = new EventEmitter<F>();\n\n  ngForm: FormGroup | undefined;\n  componentIds = [];\n  _steps: { [id: string]: FormStep } | undefined;\n\n  private _constructionDate: Date;\n  private _hasPreviousForm = false;\n  private _ngFormStatusChangeSub?: Subscription;\n  private _mtnaFormItemChangeSub?: Subscription;\n  private _initialStatusEmitted = false;\n\n  constructor(\n    protected mtnaFormManager: MtnaWfManagerService,\n    protected ngFormService: MtnaWfNgFormService,\n    protected uiService: MtnaWfUIService\n  ) {\n    super();\n    this._constructionDate = new Date();\n    // Initialize the subscription to observe input changes\n    this._subscribeAndEmitMtnaFormChanges();\n  }\n\n  ngAfterViewInit(): void {\n    const afterViewInitDate = new Date();\n    const secondsToRender = (afterViewInitDate.getTime() - this._constructionDate.getTime()) / 1000;\n    console.warn('[MtnaFormComponent] afterViewInit - took ', secondsToRender, ' to render');\n  }\n\n  ngOnDestroy() {\n    super.ngOnDestroy();\n    this.uiService.resetComponentMap();\n  }\n\n  _trackByInstanceId(index: number, formItem: FormItem) {\n    return formItem.instanceId;\n  }\n\n  /** Subscribe and emit form status changes for the steps. */\n  private _checkAndSubscribeToFormStatus() {\n    // Only subscribe once both the steps and the angular have been initialized\n    if (this.ngForm && this._steps) {\n      // Update form status subscriptions anytime the readonly input changes\n      this.readonly$.pipe(takeUntil(this.destroyed$), distinctUntilChanged()).subscribe((readonly) => {\n        if (readonly) {\n          // Don't emit statuses while form is in readonly\n          this._unsubscribeFromNgFormChanges();\n        } else if (!this._ngFormStatusChangeSub || this._ngFormStatusChangeSub.closed) {\n          // For performance, subscribe should only trigger again if the subscription didn't previously exist\n          this._emitInitialStepsStatusAndSubscribeToChanges(!this._initialStatusEmitted);\n          this._initialStatusEmitted = true;\n        }\n      });\n    }\n  }\n\n  /**\n   * Find a form control with the given name, then emit it's status.\n   *\n   * @param name — The unique name of the form control to find and emit the status for.\n   */\n  private _emitFormControlStatus(name: string) {\n    if (this.ngForm) {\n      const control = findFormControl(name, this.ngForm);\n      if (control) {\n        this.status.emit({\n          id: name,\n          status: control.status as FormControlStatus,\n        });\n      }\n    }\n  }\n\n  /**\n   * @param emitInitialValues Whether to emit initial step values or just listen for future changes\n   */\n  private _emitInitialStepsStatusAndSubscribeToChanges(emitInitialValues: boolean) {\n    if (this._steps && this.ngForm) {\n      this._unsubscribeFromNgFormChanges();\n      this._ngFormStatusChangeSub = new Subscription();\n\n      // Find the form control for each step and only subscribe to those.\n      for (const key in this._steps) {\n        if (Object.prototype.hasOwnProperty.call(this._steps, key)) {\n          const control = findFormControl(key, this.ngForm);\n          if (control) {\n            if (emitInitialValues) {\n              this.status.emit({\n                id: key,\n                // Angular introduced this status in v13, once we update, this type cast can be removed.\n                status: control.status as FormControlStatus,\n              });\n            }\n            // Subscribe to status changes of each step & emit on change\n            this._ngFormStatusChangeSub.add(\n              control.statusChanges.pipe(takeUntil(this.destroyed$), distinctUntilChanged()).subscribe((status) => {\n                this.status.emit({ id: key, status });\n              })\n            );\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * Observes input changes for readOnly, in order to handle internal change subscriptions.\n   * When the form is not readonly, we subscribe to form status & form item changes, so we can emit them.\n   * When the form is readonly, we do not want to emit any changes, so we unsubscribe.\n   */\n  private _subscribeAndEmitMtnaFormChanges() {\n    this.readonly$\n      .pipe(\n        takeUntil(this.destroyed$),\n        // we don't want to create subscriptions until we have a form to subscribe to\n        skipWhile(() => !this.mtnaForm),\n        distinctUntilChanged()\n      )\n      .subscribe((readonly) => {\n        if (readonly) {\n          this._unsubscribeFromMtnaFormChanges();\n        } else if (!this._mtnaFormItemChangeSub || this._mtnaFormItemChangeSub.closed) {\n          // For performance, subscribe should only trigger again if one of the subscriptions didn't previously exist\n          this._subscribeToMtnaFormItemChanges();\n        }\n      });\n  }\n\n  private _handleFormSerialization(form: Form) {\n    // Get the registered form from the service if it exists\n    this._hasPreviousForm = this.ngFormService.hasForm();\n    if (this._hasPreviousForm) {\n      this.ngForm = this.ngFormService.getForm();\n      // FIXME this is necessary because the initial visiblity is based on the mtnaForm item's disable property\n      // If the user changes a value, goes to another tab (destroying form) and comes back, the initial values are incorrect\n      this.mtnaForm = this.mtnaFormManager.insertNewValues(form, this.ngFormService.getFormValue()) as F;\n    } else {\n      this.ngForm = this.mtnaFormManager.serializeMtnaFormItem(form) as FormGroup;\n      this.ngFormService.setForm(this.ngForm);\n    }\n  }\n\n  /**\n   * Adds or removes a FormItem whenever a new MtnaWfFormItemChange occurs,\n   * and emits a new MtnaForm.\n   */\n  private _subscribeToMtnaFormItemChanges() {\n    this._unsubscribeFromMtnaFormChanges();\n    this._mtnaFormItemChangeSub = this.mtnaFormManager.formChanges\n      .pipe(\n        takeUntil(this.destroyed$),\n        skipWhile((change) => !change)\n      )\n      .subscribe((newForm: Form) => this.mtnaFormChange.emit(newForm as F));\n  }\n\n  private _unsubscribeFromNgFormChanges() {\n    if (!!this._ngFormStatusChangeSub && !this._ngFormStatusChangeSub.closed) {\n      this._ngFormStatusChangeSub.unsubscribe();\n    }\n  }\n\n  private _unsubscribeFromMtnaFormChanges() {\n    if (!!this._mtnaFormItemChangeSub && !this._mtnaFormItemChangeSub.closed) {\n      this._mtnaFormItemChangeSub.unsubscribe();\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './base-form.component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy93ZWItZm9ybS1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9iYXNlLWZvcm0vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1QkFBdUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYmFzZS1mb3JtLmNvbXBvbmVudCc7XG4iXX0=
|
|
@@ -3,8 +3,8 @@ import { MtnaWfBaseFormItemControl } from './base-form-item-control.component';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
/* eslint-disable-next-line @angular-eslint/component-class-suffix */
|
|
5
5
|
export class MtnaWfBaseGroupItem extends MtnaWfBaseFormItemControl {
|
|
6
|
-
constructor() {
|
|
7
|
-
super(
|
|
6
|
+
constructor(cdr) {
|
|
7
|
+
super(cdr);
|
|
8
8
|
this._parentIds = new Array();
|
|
9
9
|
}
|
|
10
10
|
get parentIds() {
|
|
@@ -17,14 +17,14 @@ export class MtnaWfBaseGroupItem extends MtnaWfBaseFormItemControl {
|
|
|
17
17
|
return item.instanceId;
|
|
18
18
|
}
|
|
19
19
|
}
|
|
20
|
-
MtnaWfBaseGroupItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfBaseGroupItem, deps:
|
|
20
|
+
MtnaWfBaseGroupItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfBaseGroupItem, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
21
21
|
MtnaWfBaseGroupItem.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfBaseGroupItem, selector: "ng-component", inputs: { parentIds: "parentIds" }, usesInheritance: true, ngImport: i0, template: ``, isInline: true });
|
|
22
22
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfBaseGroupItem, decorators: [{
|
|
23
23
|
type: Component,
|
|
24
24
|
args: [{
|
|
25
25
|
template: ``,
|
|
26
26
|
}]
|
|
27
|
-
}], propDecorators: { parentIds: [{
|
|
27
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { parentIds: [{
|
|
28
28
|
type: Input
|
|
29
29
|
}] } });
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1ncm91cC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dlYi1mb3JtLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2Jhc2UtaXRlbXMvYmFzZS1ncm91cC1pdGVtLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXFCLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFJcEUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sb0NBQW9DLENBQUM7O0FBSy9FLHFFQUFxRTtBQUNyRSxNQUFNLE9BQWdCLG1CQUE2QyxTQUFRLHlCQUF1QztJQWNoSCxZQUFZLEdBQXNCO1FBQ2hDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQVBMLGVBQVUsR0FBRyxJQUFJLEtBQUssRUFBVSxDQUFDO0lBUXpDLENBQUM7SUFmRCxJQUNJLFNBQVM7UUFDWCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDekIsQ0FBQztJQUNELElBQUksU0FBUyxDQUFDLEtBQW9CO1FBQ2hDLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO0lBQzFCLENBQUM7SUFHRCxrQkFBa0IsQ0FBQyxLQUFhLEVBQUUsSUFBYztRQUM5QyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDekIsQ0FBQzs7aUhBWm1CLG1CQUFtQjtxR0FBbkIsbUJBQW1CLCtHQUg3QixFQUFFOzRGQUdRLG1CQUFtQjtrQkFKeEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsRUFBRTtpQkFDYjt3R0FJSyxTQUFTO3NCQURaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgRm9ybUl0ZW0sIEZvcm1JdGVtR3JvdXAgfSBmcm9tICdAbXRuYS93ZWItZm9ybS10cyc7XG5cbmltcG9ydCB7IE10bmFXZkJhc2VGb3JtSXRlbUNvbnRyb2wgfSBmcm9tICcuL2Jhc2UtZm9ybS1pdGVtLWNvbnRyb2wuY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlOiBgYCxcbn0pXG4vKiBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L2NvbXBvbmVudC1jbGFzcy1zdWZmaXggKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBNdG5hV2ZCYXNlR3JvdXBJdGVtPEkgZXh0ZW5kcyBGb3JtSXRlbUdyb3VwPiBleHRlbmRzIE10bmFXZkJhc2VGb3JtSXRlbUNvbnRyb2w8SSwgRm9ybUdyb3VwPiB7XG4gIEBJbnB1dCgpXG4gIGdldCBwYXJlbnRJZHMoKTogQXJyYXk8c3RyaW5nPiB7XG4gICAgcmV0dXJuIHRoaXMuX3BhcmVudElkcztcbiAgfVxuICBzZXQgcGFyZW50SWRzKHZhbHVlOiBBcnJheTxzdHJpbmc+KSB7XG4gICAgdGhpcy5fcGFyZW50SWRzID0gdmFsdWU7XG4gIH1cbiAgcHJpdmF0ZSBfcGFyZW50SWRzID0gbmV3IEFycmF5PHN0cmluZz4oKTtcblxuICBfdHJhY2tCeUluc3RhbmNlSWQoaW5kZXg6IG51bWJlciwgaXRlbTogRm9ybUl0ZW0pIHtcbiAgICByZXR1cm4gaXRlbS5pbnN0YW5jZUlkO1xuICB9XG5cbiAgY29uc3RydWN0b3IoY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge1xuICAgIHN1cGVyKGNkcik7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -19,7 +19,8 @@ export class MtnaWfBaseParentValueItem extends MtnaWfBaseValueItem {
|
|
|
19
19
|
return super.control;
|
|
20
20
|
}
|
|
21
21
|
set control(control) {
|
|
22
|
-
|
|
22
|
+
// Checks for a wrapping form group around this item.
|
|
23
|
+
if (control instanceof FormGroup && control.get(this.item.instanceId)) {
|
|
23
24
|
super.control = control.get(this.item.instanceId);
|
|
24
25
|
this.controlWrapper = control;
|
|
25
26
|
}
|
|
@@ -40,4 +41,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
40
41
|
}], toggleFormItems: [{
|
|
41
42
|
type: Output
|
|
42
43
|
}] } });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1wYXJlbnQtdmFsdWUtaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy93ZWItZm9ybS1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9iYXNlLWl0ZW1zL2Jhc2UtcGFyZW50LXZhbHVlLWl0ZW0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkUsT0FBTyxFQUFtQixTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUk1RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7QUFLbEUscUVBQXFFO0FBQ3JFLE1BQU0sT0FBZ0IseUJBQW1GLFNBQVEsbUJBQXlCO0lBSjFJOztRQVlVLGVBQVUsR0FBRyxJQUFJLEtBQUssRUFBVSxDQUFDO1FBZS9CLG9CQUFlLEdBQUcsSUFBSSxZQUFZLEVBQXVCLENBQUM7S0FHckU7SUF6QkMsSUFDSSxTQUFTO1FBQ1gsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ3pCLENBQUM7SUFDRCxJQUFJLFNBQVMsQ0FBQyxLQUFvQjtRQUNoQyxJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztJQUMxQixDQUFDO0lBR0QsSUFBYSxPQUFPO1FBQ2xCLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQztJQUN2QixDQUFDO0lBQ0QsSUFBYSxPQUFPLENBQUMsT0FBNkI7UUFDaEQscURBQXFEO1FBQ3JELElBQUksT0FBTyxZQUFZLFNBQVMsSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUU7WUFDckUsS0FBSyxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFNLENBQUM7WUFDdkQsSUFBSSxDQUFDLGNBQWMsR0FBRyxPQUFPLENBQUM7U0FDL0I7YUFBTTtZQUNMLEtBQUssQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1NBQ3pCO0lBQ0gsQ0FBQzs7dUhBckJtQix5QkFBeUI7MkdBQXpCLHlCQUF5QixnS0FIbkMsRUFBRTs0RkFHUSx5QkFBeUI7a0JBSjlDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLEVBQUU7aUJBQ2I7OEJBSUssU0FBUztzQkFEWixLQUFLO2dCQXNCSSxlQUFlO3NCQUF4QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFic3RyYWN0Q29udHJvbCwgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgVmFsdWVJdGVtIH0gZnJvbSAnQG10bmEvd2ViLWZvcm0tdHMnO1xuXG5pbXBvcnQgeyBUb2dnbGVGb3JtSXRlbXNEYXRhIH0gZnJvbSAnLi4vLi4vbW9kZWxzL3RvZ2dsZS1mb3JtLWl0ZW0tZGF0YS5tb2RlbCc7XG5pbXBvcnQgeyBNdG5hV2ZCYXNlVmFsdWVJdGVtIH0gZnJvbSAnLi9iYXNlLXZhbHVlLWl0ZW0uY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlOiBgYCxcbn0pXG4vKiBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L2NvbXBvbmVudC1jbGFzcy1zdWZmaXggKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBNdG5hV2ZCYXNlUGFyZW50VmFsdWVJdGVtPEkgZXh0ZW5kcyBWYWx1ZUl0ZW08dW5rbm93bj4sIEMgZXh0ZW5kcyBBYnN0cmFjdENvbnRyb2w+IGV4dGVuZHMgTXRuYVdmQmFzZVZhbHVlSXRlbTxJLCBDPiB7XG4gIEBJbnB1dCgpXG4gIGdldCBwYXJlbnRJZHMoKTogQXJyYXk8c3RyaW5nPiB7XG4gICAgcmV0dXJuIHRoaXMuX3BhcmVudElkcztcbiAgfVxuICBzZXQgcGFyZW50SWRzKHZhbHVlOiBBcnJheTxzdHJpbmc+KSB7XG4gICAgdGhpcy5fcGFyZW50SWRzID0gdmFsdWU7XG4gIH1cbiAgcHJpdmF0ZSBfcGFyZW50SWRzID0gbmV3IEFycmF5PHN0cmluZz4oKTtcblxuICBvdmVycmlkZSBnZXQgY29udHJvbCgpOiBDIHwgbnVsbCB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIHN1cGVyLmNvbnRyb2w7XG4gIH1cbiAgb3ZlcnJpZGUgc2V0IGNvbnRyb2woY29udHJvbDogQyB8IG51bGwgfCB1bmRlZmluZWQpIHtcbiAgICAvLyBDaGVja3MgZm9yIGEgd3JhcHBpbmcgZm9ybSBncm91cCBhcm91bmQgdGhpcyBpdGVtLlxuICAgIGlmIChjb250cm9sIGluc3RhbmNlb2YgRm9ybUdyb3VwICYmIGNvbnRyb2wuZ2V0KHRoaXMuaXRlbS5pbnN0YW5jZUlkKSkge1xuICAgICAgc3VwZXIuY29udHJvbCA9IGNvbnRyb2wuZ2V0KHRoaXMuaXRlbS5pbnN0YW5jZUlkKSBhcyBDO1xuICAgICAgdGhpcy5jb250cm9sV3JhcHBlciA9IGNvbnRyb2w7XG4gICAgfSBlbHNlIHtcbiAgICAgIHN1cGVyLmNvbnRyb2wgPSBjb250cm9sO1xuICAgIH1cbiAgfVxuXG4gIEBPdXRwdXQoKSB0b2dnbGVGb3JtSXRlbXMgPSBuZXcgRXZlbnRFbWl0dGVyPFRvZ2dsZUZvcm1JdGVtc0RhdGE+KCk7XG5cbiAgY29udHJvbFdyYXBwZXI6IEZvcm1Hcm91cCB8IHVuZGVmaW5lZDtcbn1cbiJdfQ==
|
|
@@ -3,8 +3,8 @@ import { MtnaWfBaseGroupItem } from './base-group-item.component';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
/* eslint-disable-next-line @angular-eslint/component-class-suffix */
|
|
5
5
|
export class MtnaWfBaseSectionItem extends MtnaWfBaseGroupItem {
|
|
6
|
-
constructor() {
|
|
7
|
-
super(
|
|
6
|
+
constructor(cdr) {
|
|
7
|
+
super(cdr);
|
|
8
8
|
this.focused = new EventEmitter();
|
|
9
9
|
}
|
|
10
10
|
get step() {
|
|
@@ -12,18 +12,19 @@ export class MtnaWfBaseSectionItem extends MtnaWfBaseGroupItem {
|
|
|
12
12
|
}
|
|
13
13
|
set step(value) {
|
|
14
14
|
this._step = value;
|
|
15
|
+
console.warn({ value });
|
|
15
16
|
}
|
|
16
17
|
}
|
|
17
|
-
MtnaWfBaseSectionItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfBaseSectionItem, deps:
|
|
18
|
+
MtnaWfBaseSectionItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfBaseSectionItem, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
18
19
|
MtnaWfBaseSectionItem.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfBaseSectionItem, selector: "ng-component", inputs: { step: "step" }, outputs: { focused: "focused" }, usesInheritance: true, ngImport: i0, template: ``, isInline: true });
|
|
19
20
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfBaseSectionItem, decorators: [{
|
|
20
21
|
type: Component,
|
|
21
22
|
args: [{
|
|
22
23
|
template: ``,
|
|
23
24
|
}]
|
|
24
|
-
}], propDecorators: { step: [{
|
|
25
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { step: [{
|
|
25
26
|
type: Input
|
|
26
27
|
}], focused: [{
|
|
27
28
|
type: Output
|
|
28
29
|
}] } });
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1zZWN0aW9uLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvd2ViLWZvcm0tYW5ndWxhci9zcmMvbGliL2NvbXBvbmVudHMvYmFzZS1pdGVtcy9iYXNlLXNlY3Rpb24taXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFxQixTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFJMUYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7O0FBS2xFLHFFQUFxRTtBQUNyRSxNQUFNLE9BQWdCLHFCQUF5QyxTQUFRLG1CQUFzQjtJQWEzRixZQUFZLEdBQXNCO1FBQ2hDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUhILFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBWSxDQUFDO0lBSWpELENBQUM7SUFkRCxJQUNJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztJQUNELElBQUksSUFBSSxDQUFDLEtBQWtDO1FBQ3pDLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQzFCLENBQUM7O21IQVJtQixxQkFBcUI7dUdBQXJCLHFCQUFxQixzSUFIL0IsRUFBRTs0RkFHUSxxQkFBcUI7a0JBSjFDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLEVBQUU7aUJBQ2I7d0dBSUssSUFBSTtzQkFEUCxLQUFLO2dCQVVJLE9BQU87c0JBQWhCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNlY3Rpb24gfSBmcm9tICdAbXRuYS93ZWItZm9ybS10cyc7XG5cbmltcG9ydCB7IEZvcm1TdGVwIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2Zvcm0tc3RlcHBlci9mb3JtLXN0ZXAubW9kZWwnO1xuaW1wb3J0IHsgTXRuYVdmQmFzZUdyb3VwSXRlbSB9IGZyb20gJy4vYmFzZS1ncm91cC1pdGVtLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICB0ZW1wbGF0ZTogYGAsXG59KVxuLyogZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBhbmd1bGFyLWVzbGludC9jb21wb25lbnQtY2xhc3Mtc3VmZml4ICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgTXRuYVdmQmFzZVNlY3Rpb25JdGVtPFMgZXh0ZW5kcyBTZWN0aW9uPiBleHRlbmRzIE10bmFXZkJhc2VHcm91cEl0ZW08Uz4ge1xuICBASW5wdXQoKVxuICBnZXQgc3RlcCgpOiBGb3JtU3RlcCB8IG51bGwgfCB1bmRlZmluZWQge1xuICAgIHJldHVybiB0aGlzLl9zdGVwO1xuICB9XG4gIHNldCBzdGVwKHZhbHVlOiBGb3JtU3RlcCB8IG51bGwgfCB1bmRlZmluZWQpIHtcbiAgICB0aGlzLl9zdGVwID0gdmFsdWU7XG4gICAgY29uc29sZS53YXJuKHsgdmFsdWUgfSk7XG4gIH1cbiAgcHJpdmF0ZSBfc3RlcDogRm9ybVN0ZXAgfCBudWxsIHwgdW5kZWZpbmVkO1xuXG4gIEBPdXRwdXQoKSBmb2N1c2VkID0gbmV3IEV2ZW50RW1pdHRlcjxGb3JtU3RlcD4oKTtcblxuICBjb25zdHJ1Y3RvcihjZHI6IENoYW5nZURldGVjdG9yUmVmKSB7XG4gICAgc3VwZXIoY2RyKTtcbiAgfVxufVxuIl19
|