@mtna/web-form-angular 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/_index.scss +25 -0
- package/bundles/mtna-web-form-angular.umd.js +4982 -0
- package/bundles/mtna-web-form-angular.umd.js.map +1 -0
- package/esm2015/lib/core/animations.js +8 -0
- package/esm2015/lib/core/api-config.js +3 -0
- package/esm2015/lib/core/index.js +7 -0
- package/esm2015/lib/core/pipes/coerce-date-item.pipe.js +23 -0
- package/esm2015/lib/core/pipes/coerce-form-group.pipe.js +35 -0
- package/esm2015/lib/core/pipes/date-quarter.pipe.js +43 -0
- package/esm2015/lib/core/pipes/get-auto-complete.pipe.js +42 -0
- package/esm2015/lib/core/pipes/get-available-quarters.pipe.js +29 -0
- package/esm2015/lib/core/pipes/get-form-control-error.pipe.js +20 -0
- package/esm2015/lib/core/pipes/get-list-icon.pipe.js +53 -0
- package/esm2015/lib/core/pipes/get-object-type.pipe.js +17 -0
- package/esm2015/lib/core/pipes/get-selected-option.pipe.js +20 -0
- package/esm2015/lib/core/pipes/index.js +71 -0
- package/esm2015/lib/core/pipes/items-with-value.pipe.js +30 -0
- package/esm2015/lib/core/pipes/sanitize-html.pipe.js +23 -0
- package/esm2015/lib/core/services/api.service.js +67 -0
- package/esm2015/lib/core/services/form-manager.service.js +465 -0
- package/esm2015/lib/core/services/index.js +5 -0
- package/esm2015/lib/core/services/ng-form.service.js +150 -0
- package/esm2015/lib/core/services/ui.service.js +333 -0
- package/esm2015/lib/core/utilities/find-form-control.js +29 -0
- package/esm2015/lib/core/utilities/find-form-item.js +25 -0
- package/esm2015/lib/core/utilities/flatten-steps.js +10 -0
- package/esm2015/lib/core/utilities/generate-form-steps.js +25 -0
- package/esm2015/lib/core/utilities/index.js +9 -0
- package/esm2015/lib/core/utilities/is-form-group.js +6 -0
- package/esm2015/lib/core/utilities/serializer-util.js +358 -0
- package/esm2015/lib/core/utilities/update-step-status.js +38 -0
- package/esm2015/lib/core/validators/index.js +3 -0
- package/esm2015/lib/core/validators/instant-validation-result-error-state-matcher.js +23 -0
- package/esm2015/lib/core/validators/validation-result-validator.js +19 -0
- package/esm2015/lib/file-upload/file-upload.component.js +66 -0
- package/esm2015/lib/file-upload/index.js +2 -0
- package/esm2015/lib/form/base-form-item.model.js +2 -0
- package/esm2015/lib/form/form-disabler.component.js +38 -0
- package/esm2015/lib/form/form-item.directive.js +22 -0
- package/esm2015/lib/form/form.component.js +250 -0
- package/esm2015/lib/form/form.module.js +214 -0
- package/esm2015/lib/form/index.js +5 -0
- package/esm2015/lib/form/white-list.model.js +11 -0
- package/esm2015/lib/form-item-controls/base-form-item-control.directive.js +58 -0
- package/esm2015/lib/form-item-controls/base-parent-item-control.directive.js +42 -0
- package/esm2015/lib/form-item-controls/base-single-selection-parent.directive.js +53 -0
- package/esm2015/lib/form-item-controls/date-range.component.js +84 -0
- package/esm2015/lib/form-item-controls/date.component.js +134 -0
- package/esm2015/lib/form-item-controls/dropdown.component.js +109 -0
- package/esm2015/lib/form-item-controls/index.js +8 -0
- package/esm2015/lib/form-item-controls/input.component.js +149 -0
- package/esm2015/lib/form-item-controls/year-quarter-range.component.js +75 -0
- package/esm2015/lib/form-item-controls/year-quarter.component.js +228 -0
- package/esm2015/lib/form-stepper/form-step-group.component.js +95 -0
- package/esm2015/lib/form-stepper/form-step-group.pipe.js +20 -0
- package/esm2015/lib/form-stepper/form-step.component.js +110 -0
- package/esm2015/lib/form-stepper/form-step.util.js +28 -0
- package/esm2015/lib/form-stepper/form-stepper.component.js +115 -0
- package/esm2015/lib/form-stepper/form-stepper.module.js +53 -0
- package/esm2015/lib/form-stepper/index.js +8 -0
- package/esm2015/lib/form-stepper/models/base-form-step.model.js +6 -0
- package/esm2015/lib/form-stepper/models/form-step-group.model.js +13 -0
- package/esm2015/lib/form-stepper/models/form-step.model.js +12 -0
- package/esm2015/lib/form-stepper/models/index.js +4 -0
- package/esm2015/lib/groups/form-item-dialog-data.model.js +14 -0
- package/esm2015/lib/groups/group-components.js +646 -0
- package/esm2015/lib/groups/index.js +3 -0
- package/esm2015/lib/groups/repeatable-item.component.js +23 -0
- package/esm2015/lib/item-header/index.js +2 -0
- package/esm2015/lib/item-header/item-header.component.js +108 -0
- package/esm2015/lib/static-form-items/index.js +3 -0
- package/esm2015/lib/static-form-items/ordered-list-item.js +50 -0
- package/esm2015/lib/static-form-items/unordered-list-item.js +52 -0
- package/esm2015/lib/step-card/index.js +2 -0
- package/esm2015/lib/step-card/step-card.component.js +53 -0
- package/esm2015/mtna-web-form-angular.js +5 -0
- package/esm2015/public-api.js +10 -0
- package/fesm2015/mtna-web-form-angular.js +4614 -0
- package/fesm2015/mtna-web-form-angular.js.map +1 -0
- package/lib/_index.scss +25 -0
- package/lib/core/_all-color.scss +25 -0
- package/lib/core/_all-theme.scss +28 -0
- package/lib/core/_all-typography.scss +25 -0
- package/lib/core/_core-theme.scss +43 -0
- package/lib/core/animations.d.ts +2 -0
- package/lib/core/api-config.d.ts +5 -0
- package/lib/core/index.d.ts +6 -0
- package/lib/core/pipes/coerce-date-item.pipe.d.ts +11 -0
- package/lib/core/pipes/coerce-form-group.pipe.d.ts +23 -0
- package/lib/core/pipes/date-quarter.pipe.d.ts +7 -0
- package/lib/core/pipes/get-auto-complete.pipe.d.ts +7 -0
- package/lib/core/pipes/get-available-quarters.pipe.d.ts +8 -0
- package/lib/core/pipes/get-form-control-error.pipe.d.ts +14 -0
- package/lib/core/pipes/get-list-icon.pipe.d.ts +7 -0
- package/lib/core/pipes/get-object-type.pipe.d.ts +7 -0
- package/lib/core/pipes/get-selected-option.pipe.d.ts +8 -0
- package/lib/core/pipes/index.d.ts +28 -0
- package/lib/core/pipes/items-with-value.pipe.d.ts +13 -0
- package/lib/core/pipes/sanitize-html.pipe.d.ts +10 -0
- package/lib/core/services/api.service.d.ts +41 -0
- package/lib/core/services/form-manager.service.d.ts +184 -0
- package/lib/core/services/index.d.ts +4 -0
- package/lib/core/services/ng-form.service.d.ts +76 -0
- package/lib/core/services/ui.service.d.ts +123 -0
- package/lib/core/utilities/find-form-control.d.ts +11 -0
- package/lib/core/utilities/find-form-item.d.ts +10 -0
- package/lib/core/utilities/flatten-steps.d.ts +7 -0
- package/lib/core/utilities/generate-form-steps.d.ts +3 -0
- package/lib/core/utilities/index.d.ts +8 -0
- package/lib/core/utilities/is-form-group.d.ts +3 -0
- package/lib/core/utilities/serializer-util.d.ts +81 -0
- package/lib/core/utilities/update-step-status.d.ts +14 -0
- package/lib/core/validators/index.d.ts +2 -0
- package/lib/core/validators/instant-validation-result-error-state-matcher.d.ts +13 -0
- package/lib/core/validators/validation-result-validator.d.ts +12 -0
- package/lib/file-upload/file-upload.component.d.ts +23 -0
- package/lib/file-upload/index.d.ts +1 -0
- package/lib/form/base-form-item.model.d.ts +15 -0
- package/lib/form/form-disabler.component.d.ts +6 -0
- package/lib/form/form-item.directive.d.ts +13 -0
- package/lib/form/form.component.d.ts +89 -0
- package/lib/form/form.module.d.ts +52 -0
- package/lib/form/index.d.ts +4 -0
- package/lib/form/white-list.model.d.ts +6 -0
- package/lib/form-item-controls/_date-item-theme.scss +29 -0
- package/lib/form-item-controls/_form-control-theme.scss +28 -0
- package/lib/form-item-controls/_year-quarter-item-theme.scss +28 -0
- package/lib/form-item-controls/base-form-item-control.directive.d.ts +26 -0
- package/lib/form-item-controls/base-parent-item-control.directive.d.ts +19 -0
- package/lib/form-item-controls/base-single-selection-parent.directive.d.ts +26 -0
- package/lib/form-item-controls/date-range.component.d.ts +12 -0
- package/lib/form-item-controls/date.component.d.ts +24 -0
- package/lib/form-item-controls/dropdown.component.d.ts +9 -0
- package/lib/form-item-controls/index.d.ts +7 -0
- package/lib/form-item-controls/input.component.d.ts +14 -0
- package/lib/form-item-controls/year-quarter-range.component.d.ts +9 -0
- package/lib/form-item-controls/year-quarter.component.d.ts +33 -0
- package/lib/form-stepper/_form-step-group-theme.scss +43 -0
- package/lib/form-stepper/_form-stepper-theme.scss +72 -0
- package/lib/form-stepper/form-step-group.component.d.ts +23 -0
- package/lib/form-stepper/form-step-group.pipe.d.ts +11 -0
- package/lib/form-stepper/form-step.component.d.ts +27 -0
- package/lib/form-stepper/form-step.util.d.ts +27 -0
- package/lib/form-stepper/form-stepper.component.d.ts +35 -0
- package/lib/form-stepper/form-stepper.module.d.ts +18 -0
- package/lib/form-stepper/index.d.ts +7 -0
- package/lib/form-stepper/models/base-form-step.model.d.ts +4 -0
- package/lib/form-stepper/models/form-step-group.model.d.ts +8 -0
- package/lib/form-stepper/models/form-step.model.d.ts +11 -0
- package/lib/form-stepper/models/index.d.ts +3 -0
- package/lib/groups/_checkbox-theme.scss +62 -0
- package/lib/groups/_form-group-theme.scss +32 -0
- package/lib/groups/_multiple-choice-theme.scss +65 -0
- package/lib/groups/_repeatable-item-theme.scss +28 -0
- package/lib/groups/form-item-dialog-data.model.d.ts +13 -0
- package/lib/groups/group-components.d.ts +221 -0
- package/lib/groups/index.d.ts +2 -0
- package/lib/groups/repeatable-item.component.d.ts +5 -0
- package/lib/item-header/_item-header-theme.scss +28 -0
- package/lib/item-header/index.d.ts +1 -0
- package/lib/item-header/item-header.component.d.ts +35 -0
- package/lib/static-form-items/index.d.ts +2 -0
- package/lib/static-form-items/ordered-list-item.d.ts +11 -0
- package/lib/static-form-items/unordered-list-item.d.ts +11 -0
- package/lib/step-card/_step-card-theme.scss +42 -0
- package/lib/step-card/index.d.ts +1 -0
- package/lib/step-card/step-card.component.d.ts +21 -0
- package/mtna-web-form-angular.d.ts +5 -0
- package/package.json +43 -0
- package/public-api.d.ts +9 -0
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, HostBinding, Inject, InjectionToken, Input, Optional, ViewEncapsulation, } from '@angular/core';
|
|
2
|
+
import { FormControl } from '@angular/forms';
|
|
3
|
+
import { isPresent } from '@mtna/core-ts';
|
|
4
|
+
import { merge, Subject } from 'rxjs';
|
|
5
|
+
import { takeUntil } from 'rxjs/operators';
|
|
6
|
+
import { BaseFormItemControl } from './base-form-item-control.directive';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/material/form-field";
|
|
9
|
+
import * as i2 from "@angular/material/select";
|
|
10
|
+
import * as i3 from "@angular/material/core";
|
|
11
|
+
import * as i4 from "@angular/common";
|
|
12
|
+
import * as i5 from "@angular/flex-layout/flex";
|
|
13
|
+
import * as i6 from "@mtna/core-angular";
|
|
14
|
+
import * as i7 from "@angular/forms";
|
|
15
|
+
import * as i8 from "../core/pipes/get-form-control-error.pipe";
|
|
16
|
+
import * as i9 from "../core/pipes/get-available-quarters.pipe";
|
|
17
|
+
import * as i10 from "../core/pipes/date-quarter.pipe";
|
|
18
|
+
export const MTNA_WF_DEFAULT_YEAR_RANGE = new InjectionToken('mtna.wf.default.year.range');
|
|
19
|
+
export class MtnaWfYearQuarterComponent extends BaseFormItemControl {
|
|
20
|
+
constructor(defaultYearRange) {
|
|
21
|
+
super();
|
|
22
|
+
this.yearQuarterItemClass = true;
|
|
23
|
+
this._quarterControl = new FormControl();
|
|
24
|
+
this._yearControl = new FormControl();
|
|
25
|
+
this._yearSelection = new Array();
|
|
26
|
+
this.destroyObs = new Subject();
|
|
27
|
+
/**
|
|
28
|
+
* Sets the quarter value to `null` if the year & quarter is out of bounds of the range limits.
|
|
29
|
+
* Otherwise, returns original value
|
|
30
|
+
*
|
|
31
|
+
* @param value `[number, number]` The selected [year, quarter] value
|
|
32
|
+
* @returns `[number, number]` The original [year, quarter] value OR [year, null]
|
|
33
|
+
*/
|
|
34
|
+
this.withinRangeLimits = ([year, quarter]) => {
|
|
35
|
+
var _a, _b;
|
|
36
|
+
const beyondUpperLimit =
|
|
37
|
+
// year matches end year range limit
|
|
38
|
+
year === ((_a = this.rangeLimits) === null || _a === void 0 ? void 0 : _a.end.year) &&
|
|
39
|
+
// quarter limit was provided
|
|
40
|
+
isPresent(this.rangeLimits.end.quarter) &&
|
|
41
|
+
// selected quarter is beyond quarter limit
|
|
42
|
+
quarter > this.rangeLimits.end.quarter;
|
|
43
|
+
const beyondLowerLimit =
|
|
44
|
+
// year matches start year range limit
|
|
45
|
+
year === ((_b = this.rangeLimits) === null || _b === void 0 ? void 0 : _b.start.year) &&
|
|
46
|
+
// quarter limit was provided
|
|
47
|
+
isPresent(this.rangeLimits.start.quarter) &&
|
|
48
|
+
// selected quarter is beyond quarter limit
|
|
49
|
+
quarter < this.rangeLimits.start.quarter;
|
|
50
|
+
if (beyondLowerLimit || beyondUpperLimit) {
|
|
51
|
+
this._quarterControl.setValue(null, { emitEvent: false });
|
|
52
|
+
return [year, null];
|
|
53
|
+
}
|
|
54
|
+
return [year, quarter];
|
|
55
|
+
};
|
|
56
|
+
this.defaultYearRange = defaultYearRange || { numFutureYears: 25, numPastYears: 25 };
|
|
57
|
+
}
|
|
58
|
+
ngAfterViewInit() {
|
|
59
|
+
if (!this.readonly) {
|
|
60
|
+
// Observe Year & Quarter value changes && set them on the item's control
|
|
61
|
+
merge(this._yearControl.valueChanges, this._quarterControl.valueChanges)
|
|
62
|
+
.pipe(takeUntil(this.destroyObs))
|
|
63
|
+
.subscribe(() => {
|
|
64
|
+
var _a, _b, _c, _d;
|
|
65
|
+
if (!((_a = this.control) === null || _a === void 0 ? void 0 : _a.dirty) && (this._yearControl.dirty || this._quarterControl.dirty)) {
|
|
66
|
+
(_b = this.control) === null || _b === void 0 ? void 0 : _b.markAsDirty();
|
|
67
|
+
(_c = this.control) === null || _c === void 0 ? void 0 : _c.markAsTouched();
|
|
68
|
+
}
|
|
69
|
+
if (isPresent(this._yearControl.value)) {
|
|
70
|
+
const [year, quarter] = this.withinRangeLimits([this._yearControl.value, this._quarterControl.value]);
|
|
71
|
+
(_d = this.control) === null || _d === void 0 ? void 0 : _d.setValue({ year, quarter });
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
// FIXME not sure we need this until we starting making this control
|
|
75
|
+
// required/unrequired at the right time. Even then, this is super inneficient
|
|
76
|
+
/*
|
|
77
|
+
// Listen to this control for disabling local controls
|
|
78
|
+
this.control.statusChanges
|
|
79
|
+
.pipe(
|
|
80
|
+
startWith(this.control.status),
|
|
81
|
+
takeUntil(this.destroyObs)
|
|
82
|
+
)
|
|
83
|
+
.subscribe(status => {
|
|
84
|
+
console.warn('statusChanges', status, this.control);
|
|
85
|
+
// if this control is enabled, enable local controls if disabled
|
|
86
|
+
if (this.control.enabled) {
|
|
87
|
+
if (this._quarterControl.disabled || this._yearControl.disabled) {
|
|
88
|
+
console.warn('[YearQuarterItem] enable the things');
|
|
89
|
+
// this._quarterControl.enable();
|
|
90
|
+
// this._yearControl.enable();
|
|
91
|
+
}
|
|
92
|
+
// else this control is disabled, so disable local controls if enabled
|
|
93
|
+
} else if (this._quarterControl.enabled || this._yearControl.enabled) {
|
|
94
|
+
console.warn('[YearQuarterItem] disable the things');
|
|
95
|
+
// this._yearControl.disable();
|
|
96
|
+
// this._quarterControl.disable();
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
*/
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
ngOnDestroy() {
|
|
103
|
+
this.destroyObs.next();
|
|
104
|
+
this.destroyObs.complete();
|
|
105
|
+
}
|
|
106
|
+
ngOnInit() {
|
|
107
|
+
var _a, _b, _c;
|
|
108
|
+
// Set any initial value onto the Year & Quarter controls
|
|
109
|
+
this._yearControl.setValue(((_a = this.control) === null || _a === void 0 ? void 0 : _a.value) ? this.control.value.year : null);
|
|
110
|
+
this._quarterControl.setValue(((_b = this.control) === null || _b === void 0 ? void 0 : _b.value) ? this.control.value.quarter : null);
|
|
111
|
+
// Create range limits if none exist
|
|
112
|
+
if (!this.rangeLimits) {
|
|
113
|
+
const thisYear = new Date().getFullYear();
|
|
114
|
+
this.rangeLimits = {
|
|
115
|
+
start: {
|
|
116
|
+
year: thisYear - this.defaultYearRange.numPastYears,
|
|
117
|
+
quarter: null,
|
|
118
|
+
},
|
|
119
|
+
end: {
|
|
120
|
+
year: thisYear + this.defaultYearRange.numFutureYears,
|
|
121
|
+
quarter: null,
|
|
122
|
+
},
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
// Populate the year selection
|
|
126
|
+
for (let i = this.rangeLimits.start.year || 0; i <= (this.rangeLimits.end.year || 0); i++) {
|
|
127
|
+
this._yearSelection.push(i);
|
|
128
|
+
}
|
|
129
|
+
if (this.readonly) {
|
|
130
|
+
(_c = this.control) === null || _c === void 0 ? void 0 : _c.disable();
|
|
131
|
+
this._quarterControl.disable();
|
|
132
|
+
this._yearControl.disable();
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
MtnaWfYearQuarterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfYearQuarterComponent, deps: [{ token: MTNA_WF_DEFAULT_YEAR_RANGE, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
137
|
+
MtnaWfYearQuarterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfYearQuarterComponent, selector: "mtna-wf-year-quarter-item", inputs: { rangeLimits: "rangeLimits" }, host: { properties: { "class.mtna-wf-year-quarter-item": "this.yearQuarterItemClass" } }, usesInheritance: true, ngImport: i0, template: `
|
|
138
|
+
<ng-container *ngTemplateOutlet="header"></ng-container>
|
|
139
|
+
<div
|
|
140
|
+
*ngIf="control"
|
|
141
|
+
class="year-quarter-container"
|
|
142
|
+
fxLayout="row"
|
|
143
|
+
fxLayoutGap="8px"
|
|
144
|
+
[mtnaHighlight]="indicatorStatus === 'ACTIVE' && !hasItemHeader"
|
|
145
|
+
>
|
|
146
|
+
<mat-form-field>
|
|
147
|
+
<mat-select [formControl]="_yearControl" aria-label="year selection">
|
|
148
|
+
<mat-option *ngFor="let year of _yearSelection" [value]="year">{{ year }}</mat-option>
|
|
149
|
+
</mat-select>
|
|
150
|
+
<mat-error *ngFor="let error of control.errors | keyvalue">
|
|
151
|
+
{{ error | mtnaWfGetControlError : item }}
|
|
152
|
+
</mat-error>
|
|
153
|
+
</mat-form-field>
|
|
154
|
+
|
|
155
|
+
<mat-form-field>
|
|
156
|
+
<mat-select [formControl]="_quarterControl" aria-label="quarter selection">
|
|
157
|
+
<mat-option>None</mat-option>
|
|
158
|
+
<mat-option *ngFor="let quarter of _yearControl.value | mtnaWfGetQuarters : rangeLimits" [value]="quarter">{{
|
|
159
|
+
$any(quarter) | mtnaWfDateQuarter : 'short'
|
|
160
|
+
}}</mat-option>
|
|
161
|
+
</mat-select>
|
|
162
|
+
<mat-error *ngFor="let error of control.errors | keyvalue">
|
|
163
|
+
{{ error | mtnaWfGetControlError : item }}
|
|
164
|
+
</mat-error>
|
|
165
|
+
</mat-form-field>
|
|
166
|
+
</div>
|
|
167
|
+
`, isInline: true, styles: [".mtna-wf-control-item .mat-form-field{width:100%}.mtna-wf-control-item .mtna-wf-error-container{font-size:75%;line-height:1;min-height:1em;margin-top:-.75rem}.mtna-wf-control-item .control-item-content{padding:.35em .75em .625em}.mtna-wf-control-item .mtna-wf-item-header~:not(.mtna-wf-error-container):not(.mat-list){padding-left:.75em}.mtna-wf-control-item .mtna-wf-item-header~:not(.mtna-wf-error-container):not(.mat-list).mat-form-field{width:calc(100% - .75em)}\n", "\n .mtna-wf-year-quarter-item .year-quarter-container > .mat-form-field {\n max-width: 75px;\n }\n .mtna-wf-year-quarter-item .year-quarter-container > .mat-form-field:first-of-type {\n margin-right: 8px;\n }\n "], components: [{ type: i1.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i2.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { type: i3.MatOption, selector: "mat-option", exportAs: ["matOption"] }], directives: [{ type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.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: i5.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"] }, { type: i6.MtnaHighlightDirective, selector: "[mtnaHighlight]", inputs: ["mtnaHighlight", "mtnaHighlightColor"], exportAs: ["mtnaHighlight"] }, { type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i7.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "keyvalue": i4.KeyValuePipe, "mtnaWfGetControlError": i8.MtnaGetFormControlErrorPipe, "mtnaWfGetQuarters": i9.MtnaWfGetAvailableQuartersPipe, "mtnaWfDateQuarter": i10.DateQuarterPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
168
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfYearQuarterComponent, decorators: [{
|
|
169
|
+
type: Component,
|
|
170
|
+
args: [{
|
|
171
|
+
selector: 'mtna-wf-year-quarter-item',
|
|
172
|
+
template: `
|
|
173
|
+
<ng-container *ngTemplateOutlet="header"></ng-container>
|
|
174
|
+
<div
|
|
175
|
+
*ngIf="control"
|
|
176
|
+
class="year-quarter-container"
|
|
177
|
+
fxLayout="row"
|
|
178
|
+
fxLayoutGap="8px"
|
|
179
|
+
[mtnaHighlight]="indicatorStatus === 'ACTIVE' && !hasItemHeader"
|
|
180
|
+
>
|
|
181
|
+
<mat-form-field>
|
|
182
|
+
<mat-select [formControl]="_yearControl" aria-label="year selection">
|
|
183
|
+
<mat-option *ngFor="let year of _yearSelection" [value]="year">{{ year }}</mat-option>
|
|
184
|
+
</mat-select>
|
|
185
|
+
<mat-error *ngFor="let error of control.errors | keyvalue">
|
|
186
|
+
{{ error | mtnaWfGetControlError : item }}
|
|
187
|
+
</mat-error>
|
|
188
|
+
</mat-form-field>
|
|
189
|
+
|
|
190
|
+
<mat-form-field>
|
|
191
|
+
<mat-select [formControl]="_quarterControl" aria-label="quarter selection">
|
|
192
|
+
<mat-option>None</mat-option>
|
|
193
|
+
<mat-option *ngFor="let quarter of _yearControl.value | mtnaWfGetQuarters : rangeLimits" [value]="quarter">{{
|
|
194
|
+
$any(quarter) | mtnaWfDateQuarter : 'short'
|
|
195
|
+
}}</mat-option>
|
|
196
|
+
</mat-select>
|
|
197
|
+
<mat-error *ngFor="let error of control.errors | keyvalue">
|
|
198
|
+
{{ error | mtnaWfGetControlError : item }}
|
|
199
|
+
</mat-error>
|
|
200
|
+
</mat-form-field>
|
|
201
|
+
</div>
|
|
202
|
+
`,
|
|
203
|
+
styleUrls: [`form-control.scss`],
|
|
204
|
+
styles: [
|
|
205
|
+
`
|
|
206
|
+
.mtna-wf-year-quarter-item .year-quarter-container > .mat-form-field {
|
|
207
|
+
max-width: 75px;
|
|
208
|
+
}
|
|
209
|
+
.mtna-wf-year-quarter-item .year-quarter-container > .mat-form-field:first-of-type {
|
|
210
|
+
margin-right: 8px;
|
|
211
|
+
}
|
|
212
|
+
`,
|
|
213
|
+
],
|
|
214
|
+
encapsulation: ViewEncapsulation.None,
|
|
215
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
216
|
+
}]
|
|
217
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
218
|
+
type: Optional
|
|
219
|
+
}, {
|
|
220
|
+
type: Inject,
|
|
221
|
+
args: [MTNA_WF_DEFAULT_YEAR_RANGE]
|
|
222
|
+
}] }]; }, propDecorators: { yearQuarterItemClass: [{
|
|
223
|
+
type: HostBinding,
|
|
224
|
+
args: ['class.mtna-wf-year-quarter-item']
|
|
225
|
+
}], rangeLimits: [{
|
|
226
|
+
type: Input
|
|
227
|
+
}] } });
|
|
228
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"year-quarter.component.js","sourceRoot":"","sources":["../../../../../../projects/web-form-angular/src/lib/form-item-controls/year-quarter.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  HostBinding,\n  Inject,\n  InjectionToken,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormControl } from '@angular/forms';\n\nimport { isPresent } from '@mtna/core-ts';\nimport { DateRange, YearQuarter, YearQuarterRangeItem } from '@mtna/web-form-ts';\n\nimport { merge, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { BaseFormItemControl } from './base-form-item-control.directive';\n\nexport const MTNA_WF_DEFAULT_YEAR_RANGE = new InjectionToken<MtnaWfDefaultYearRange>('mtna.wf.default.year.range');\n\nexport interface MtnaWfDefaultYearRange {\n  numPastYears: number;\n  numFutureYears: number;\n}\n\n@Component({\n  selector: 'mtna-wf-year-quarter-item',\n  template: `\n    <ng-container *ngTemplateOutlet=\"header\"></ng-container>\n    <div\n      *ngIf=\"control\"\n      class=\"year-quarter-container\"\n      fxLayout=\"row\"\n      fxLayoutGap=\"8px\"\n      [mtnaHighlight]=\"indicatorStatus === 'ACTIVE' && !hasItemHeader\"\n    >\n      <mat-form-field>\n        <mat-select [formControl]=\"_yearControl\" aria-label=\"year selection\">\n          <mat-option *ngFor=\"let year of _yearSelection\" [value]=\"year\">{{ year }}</mat-option>\n        </mat-select>\n        <mat-error *ngFor=\"let error of control.errors | keyvalue\">\n          {{ error | mtnaWfGetControlError : item }}\n        </mat-error>\n      </mat-form-field>\n\n      <mat-form-field>\n        <mat-select [formControl]=\"_quarterControl\" aria-label=\"quarter selection\">\n          <mat-option>None</mat-option>\n          <mat-option *ngFor=\"let quarter of _yearControl.value | mtnaWfGetQuarters : rangeLimits\" [value]=\"quarter\">{{\n            $any(quarter) | mtnaWfDateQuarter : 'short'\n          }}</mat-option>\n        </mat-select>\n        <mat-error *ngFor=\"let error of control.errors | keyvalue\">\n          {{ error | mtnaWfGetControlError : item }}\n        </mat-error>\n      </mat-form-field>\n    </div>\n  `,\n  styleUrls: [`form-control.scss`],\n  styles: [\n    `\n      .mtna-wf-year-quarter-item .year-quarter-container > .mat-form-field {\n        max-width: 75px;\n      }\n      .mtna-wf-year-quarter-item .year-quarter-container > .mat-form-field:first-of-type {\n        margin-right: 8px;\n      }\n    `,\n  ],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class MtnaWfYearQuarterComponent extends BaseFormItemControl<YearQuarterRangeItem> implements AfterViewInit, OnDestroy, OnInit {\n  @HostBinding('class.mtna-wf-year-quarter-item') yearQuarterItemClass = true;\n  @Input() rangeLimits: DateRange<YearQuarter> | null | undefined;\n\n  _quarterControl = new FormControl();\n  _yearControl = new FormControl();\n  _yearSelection = new Array<number>();\n\n  private destroyObs = new Subject<void>();\n  private defaultYearRange: MtnaWfDefaultYearRange;\n\n  constructor(@Optional() @Inject(MTNA_WF_DEFAULT_YEAR_RANGE) defaultYearRange?: MtnaWfDefaultYearRange) {\n    super();\n    this.defaultYearRange = defaultYearRange || { numFutureYears: 25, numPastYears: 25 };\n  }\n\n  ngAfterViewInit() {\n    if (!this.readonly) {\n      // Observe Year & Quarter value changes && set them on the item's control\n      merge(this._yearControl.valueChanges, this._quarterControl.valueChanges)\n        .pipe(takeUntil(this.destroyObs))\n        .subscribe(() => {\n          if (!this.control?.dirty && (this._yearControl.dirty || this._quarterControl.dirty)) {\n            this.control?.markAsDirty();\n            this.control?.markAsTouched();\n          }\n          if (isPresent(this._yearControl.value)) {\n            const [year, quarter] = this.withinRangeLimits([this._yearControl.value, this._quarterControl.value]);\n            this.control?.setValue({ year, quarter });\n          }\n        });\n\n      // FIXME not sure we need this until we starting making this control\n      // required/unrequired at the right time. Even then, this is super inneficient\n\n      /*\n      // Listen to this control for disabling local controls\n      this.control.statusChanges\n        .pipe(\n          startWith(this.control.status),\n          takeUntil(this.destroyObs)\n        )\n        .subscribe(status => {\n          console.warn('statusChanges', status, this.control);\n          // if this control is enabled, enable local controls if disabled\n          if (this.control.enabled) {\n            if (this._quarterControl.disabled || this._yearControl.disabled) {\n              console.warn('[YearQuarterItem] enable the things');\n              // this._quarterControl.enable();\n              // this._yearControl.enable();\n            }\n            // else this control is disabled, so disable local controls if enabled\n          } else if (this._quarterControl.enabled || this._yearControl.enabled) {\n            console.warn('[YearQuarterItem] disable the things');\n            // this._yearControl.disable();\n            // this._quarterControl.disable();\n          }\n        });\n        */\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyObs.next();\n    this.destroyObs.complete();\n  }\n\n  ngOnInit() {\n    // Set any initial value onto the Year & Quarter controls\n    this._yearControl.setValue(this.control?.value ? this.control.value.year : null);\n    this._quarterControl.setValue(this.control?.value ? this.control.value.quarter : null);\n\n    // Create range limits if none exist\n    if (!this.rangeLimits) {\n      const thisYear = new Date().getFullYear();\n      this.rangeLimits = {\n        start: {\n          year: thisYear - this.defaultYearRange.numPastYears,\n          quarter: null,\n        },\n        end: {\n          year: thisYear + this.defaultYearRange.numFutureYears,\n          quarter: null,\n        },\n      };\n    }\n\n    // Populate the year selection\n    for (let i = this.rangeLimits.start.year || 0; i <= (this.rangeLimits.end.year || 0); i++) {\n      this._yearSelection.push(i);\n    }\n\n    if (this.readonly) {\n      this.control?.disable();\n      this._quarterControl.disable();\n      this._yearControl.disable();\n    }\n  }\n\n  /**\n   * Sets the quarter value to `null` if the year & quarter is out of bounds of the range limits.\n   * Otherwise, returns original value\n   *\n   * @param value `[number, number]` The selected [year, quarter] value\n   * @returns `[number, number]` The original [year, quarter] value OR [year, null]\n   */\n  private withinRangeLimits: (value: [number, number]) => [number, number | null] = ([year, quarter]) => {\n    const beyondUpperLimit =\n      // year matches end year range limit\n      year === this.rangeLimits?.end.year &&\n      // quarter limit was provided\n      isPresent(this.rangeLimits.end.quarter) &&\n      // selected quarter is beyond quarter limit\n      quarter > this.rangeLimits.end.quarter;\n\n    const beyondLowerLimit =\n      // year matches start year range limit\n      year === this.rangeLimits?.start.year &&\n      // quarter limit was provided\n      isPresent(this.rangeLimits.start.quarter) &&\n      // selected quarter is beyond quarter limit\n      quarter < this.rangeLimits.start.quarter;\n\n    if (beyondLowerLimit || beyondUpperLimit) {\n      this._quarterControl.setValue(null, { emitEvent: false });\n      return [year, null];\n    }\n\n    return [year, quarter];\n  };\n}\n"]}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { mixinColor } from '@angular/material/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "./form-step.component";
|
|
5
|
+
import * as i2 from "@angular/material/divider";
|
|
6
|
+
import * as i3 from "@angular/material/button";
|
|
7
|
+
import * as i4 from "@angular/material/icon";
|
|
8
|
+
import * as i5 from "@angular/common";
|
|
9
|
+
import * as i6 from "@angular/material/tooltip";
|
|
10
|
+
/* eslint-disable @angular-eslint/no-inputs-metadata-property */
|
|
11
|
+
const _FormStepMixinBase = mixinColor(class {
|
|
12
|
+
constructor(_elementRef) {
|
|
13
|
+
this._elementRef = _elementRef;
|
|
14
|
+
}
|
|
15
|
+
}, 'primary');
|
|
16
|
+
export class MtnaWfFormStepGroupComponent extends _FormStepMixinBase {
|
|
17
|
+
constructor(elementRef) {
|
|
18
|
+
super(elementRef);
|
|
19
|
+
/** Whether all but the first step is hidden*/
|
|
20
|
+
this.collapsed = false;
|
|
21
|
+
this._steps = [];
|
|
22
|
+
this.selected = new EventEmitter();
|
|
23
|
+
}
|
|
24
|
+
/** Steps to be displayed */
|
|
25
|
+
get steps() {
|
|
26
|
+
return this._steps;
|
|
27
|
+
}
|
|
28
|
+
set steps(steps) {
|
|
29
|
+
this._steps = steps;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
MtnaWfFormStepGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormStepGroupComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
+
MtnaWfFormStepGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfFormStepGroupComponent, selector: "mtna-wf-step-group", inputs: { color: "color", collapsed: "collapsed", incompleteIcon: "incompleteIcon", steps: "steps" }, outputs: { selected: "selected" }, usesInheritance: true, ngImport: i0, template: `
|
|
34
|
+
<ng-container *ngFor="let step of steps | slice : 0 : (collapsed ? 1 : steps.length); let last = last">
|
|
35
|
+
<mtna-wf-step
|
|
36
|
+
[clickable]="step.status !== 'DISABLED'"
|
|
37
|
+
[color]="color"
|
|
38
|
+
[incompleteIcon]="incompleteIcon"
|
|
39
|
+
[step]="step"
|
|
40
|
+
(click)="selected.emit(step)"
|
|
41
|
+
></mtna-wf-step>
|
|
42
|
+
<mat-divider *ngIf="!last" [vertical]="true"></mat-divider>
|
|
43
|
+
<p *ngIf="collapsed" class="show-more mat-caption">and {{ steps.length - 1 }} more...</p>
|
|
44
|
+
</ng-container>
|
|
45
|
+
<button
|
|
46
|
+
mat-icon-button
|
|
47
|
+
class="collapse-button"
|
|
48
|
+
[color]="color"
|
|
49
|
+
(click)="collapsed = !collapsed"
|
|
50
|
+
[matTooltip]="collapsed ? 'View All' : 'Hide'"
|
|
51
|
+
>
|
|
52
|
+
<mat-icon>{{ collapsed ? 'expand_more' : 'expand_less' }}</mat-icon>
|
|
53
|
+
</button>
|
|
54
|
+
`, isInline: true, styles: ["mtna-wf-step-group{border-style:solid;border-radius:4px;border-width:1px;display:block;margin:4px 4px 16px 8px;padding-bottom:16px;position:relative}mtna-wf-step-group .collapse-button{bottom:-19px;left:calc(50% - 20px);position:absolute;z-index:10}mtna-wf-step-group .collapse-button:after{bottom:8px;content:\"\";height:12px;left:calc(50% - 16px);position:absolute;width:32px;z-index:-1}mtna-wf-step-group mtna-wf-step li{padding-left:8px}mtna-wf-step-group mat-divider.mat-divider{margin-left:20px}mtna-wf-step-group .show-more{margin:0;text-align:center}\n"], components: [{ type: i1.MtnaWfFormStepComponent, selector: "mtna-wf-step", inputs: ["color", "step", "clickable", "incompleteIcon"] }, { type: i2.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { 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"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }], pipes: { "slice": i5.SlicePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
55
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormStepGroupComponent, decorators: [{
|
|
56
|
+
type: Component,
|
|
57
|
+
args: [{
|
|
58
|
+
selector: 'mtna-wf-step-group',
|
|
59
|
+
template: `
|
|
60
|
+
<ng-container *ngFor="let step of steps | slice : 0 : (collapsed ? 1 : steps.length); let last = last">
|
|
61
|
+
<mtna-wf-step
|
|
62
|
+
[clickable]="step.status !== 'DISABLED'"
|
|
63
|
+
[color]="color"
|
|
64
|
+
[incompleteIcon]="incompleteIcon"
|
|
65
|
+
[step]="step"
|
|
66
|
+
(click)="selected.emit(step)"
|
|
67
|
+
></mtna-wf-step>
|
|
68
|
+
<mat-divider *ngIf="!last" [vertical]="true"></mat-divider>
|
|
69
|
+
<p *ngIf="collapsed" class="show-more mat-caption">and {{ steps.length - 1 }} more...</p>
|
|
70
|
+
</ng-container>
|
|
71
|
+
<button
|
|
72
|
+
mat-icon-button
|
|
73
|
+
class="collapse-button"
|
|
74
|
+
[color]="color"
|
|
75
|
+
(click)="collapsed = !collapsed"
|
|
76
|
+
[matTooltip]="collapsed ? 'View All' : 'Hide'"
|
|
77
|
+
>
|
|
78
|
+
<mat-icon>{{ collapsed ? 'expand_more' : 'expand_less' }}</mat-icon>
|
|
79
|
+
</button>
|
|
80
|
+
`,
|
|
81
|
+
styleUrls: ['form-step-group.component.scss'],
|
|
82
|
+
inputs: ['color'],
|
|
83
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
84
|
+
encapsulation: ViewEncapsulation.None,
|
|
85
|
+
}]
|
|
86
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { collapsed: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], incompleteIcon: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], steps: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], selected: [{
|
|
93
|
+
type: Output
|
|
94
|
+
}] } });
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1zdGVwLWdyb3VwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dlYi1mb3JtLWFuZ3VsYXIvc3JjL2xpYi9mb3JtLXN0ZXBwZXIvZm9ybS1zdGVwLWdyb3VwLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9ILE9BQU8sRUFBWSxVQUFVLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7Ozs7Ozs7QUFJOUQsZ0VBQWdFO0FBQ2hFLE1BQU0sa0JBQWtCLEdBQUcsVUFBVSxDQUNuQztJQUNFLFlBQW1CLFdBQXVCO1FBQXZCLGdCQUFXLEdBQVgsV0FBVyxDQUFZO0lBQUcsQ0FBQztDQUMvQyxFQUNELFNBQVMsQ0FDVixDQUFDO0FBK0JGLE1BQU0sT0FBTyw0QkFBNkIsU0FBUSxrQkFBa0I7SUFnQmxFLFlBQVksVUFBc0I7UUFDaEMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBaEJwQiw4Q0FBOEM7UUFDckMsY0FBUyxHQUFHLEtBQUssQ0FBQztRQVVuQixXQUFNLEdBQWUsRUFBRSxDQUFDO1FBRXRCLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBWSxDQUFDO0lBSWxELENBQUM7SUFkRCw0QkFBNEI7SUFDNUIsSUFDSSxLQUFLO1FBQ1AsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQ3JCLENBQUM7SUFDRCxJQUFJLEtBQUssQ0FBQyxLQUFpQjtRQUN6QixJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQztJQUN0QixDQUFDOzswSEFYVSw0QkFBNEI7OEdBQTVCLDRCQUE0QiwwTkEzQjdCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FxQlQ7NEZBTVUsNEJBQTRCO2tCQTdCeEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsb0JBQW9CO29CQUM5QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXFCVDtvQkFDRCxTQUFTLEVBQUUsQ0FBQyxnQ0FBZ0MsQ0FBQztvQkFDN0MsTUFBTSxFQUFFLENBQUMsT0FBTyxDQUFDO29CQUNqQixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7aUJBQ3RDO2lHQUdVLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csY0FBYztzQkFBdEIsS0FBSztnQkFHRixLQUFLO3NCQURSLEtBQUs7Z0JBU0ksUUFBUTtzQkFBakIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENhbkNvbG9yLCBtaXhpbkNvbG9yIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5cbmltcG9ydCB7IEZvcm1TdGVwIH0gZnJvbSAnLi9tb2RlbHMvaW5kZXgnO1xuXG4vKiBlc2xpbnQtZGlzYWJsZSBAYW5ndWxhci1lc2xpbnQvbm8taW5wdXRzLW1ldGFkYXRhLXByb3BlcnR5ICovXG5jb25zdCBfRm9ybVN0ZXBNaXhpbkJhc2UgPSBtaXhpbkNvbG9yKFxuICBjbGFzcyB7XG4gICAgY29uc3RydWN0b3IocHVibGljIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmKSB7fVxuICB9LFxuICAncHJpbWFyeSdcbik7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ210bmEtd2Ytc3RlcC1ncm91cCcsXG4gIHRlbXBsYXRlOiBgXG4gICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgc3RlcCBvZiBzdGVwcyB8IHNsaWNlIDogMCA6IChjb2xsYXBzZWQgPyAxIDogc3RlcHMubGVuZ3RoKTsgbGV0IGxhc3QgPSBsYXN0XCI+XG4gICAgICA8bXRuYS13Zi1zdGVwXG4gICAgICAgIFtjbGlja2FibGVdPVwic3RlcC5zdGF0dXMgIT09ICdESVNBQkxFRCdcIlxuICAgICAgICBbY29sb3JdPVwiY29sb3JcIlxuICAgICAgICBbaW5jb21wbGV0ZUljb25dPVwiaW5jb21wbGV0ZUljb25cIlxuICAgICAgICBbc3RlcF09XCJzdGVwXCJcbiAgICAgICAgKGNsaWNrKT1cInNlbGVjdGVkLmVtaXQoc3RlcClcIlxuICAgICAgPjwvbXRuYS13Zi1zdGVwPlxuICAgICAgPG1hdC1kaXZpZGVyICpuZ0lmPVwiIWxhc3RcIiBbdmVydGljYWxdPVwidHJ1ZVwiPjwvbWF0LWRpdmlkZXI+XG4gICAgICA8cCAqbmdJZj1cImNvbGxhcHNlZFwiIGNsYXNzPVwic2hvdy1tb3JlIG1hdC1jYXB0aW9uXCI+YW5kIHt7IHN0ZXBzLmxlbmd0aCAtIDEgfX0gbW9yZS4uLjwvcD5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8YnV0dG9uXG4gICAgICBtYXQtaWNvbi1idXR0b25cbiAgICAgIGNsYXNzPVwiY29sbGFwc2UtYnV0dG9uXCJcbiAgICAgIFtjb2xvcl09XCJjb2xvclwiXG4gICAgICAoY2xpY2spPVwiY29sbGFwc2VkID0gIWNvbGxhcHNlZFwiXG4gICAgICBbbWF0VG9vbHRpcF09XCJjb2xsYXBzZWQgPyAnVmlldyBBbGwnIDogJ0hpZGUnXCJcbiAgICA+XG4gICAgICA8bWF0LWljb24+e3sgY29sbGFwc2VkID8gJ2V4cGFuZF9tb3JlJyA6ICdleHBhbmRfbGVzcycgfX08L21hdC1pY29uPlxuICAgIDwvYnV0dG9uPlxuICBgLFxuICBzdHlsZVVybHM6IFsnZm9ybS1zdGVwLWdyb3VwLmNvbXBvbmVudC5zY3NzJ10sXG4gIGlucHV0czogWydjb2xvciddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbn0pXG5leHBvcnQgY2xhc3MgTXRuYVdmRm9ybVN0ZXBHcm91cENvbXBvbmVudCBleHRlbmRzIF9Gb3JtU3RlcE1peGluQmFzZSBpbXBsZW1lbnRzIENhbkNvbG9yIHtcbiAgLyoqIFdoZXRoZXIgYWxsIGJ1dCB0aGUgZmlyc3Qgc3RlcCBpcyBoaWRkZW4qL1xuICBASW5wdXQoKSBjb2xsYXBzZWQgPSBmYWxzZTtcbiAgQElucHV0KCkgaW5jb21wbGV0ZUljb246IHN0cmluZyB8IG51bGwgfCB1bmRlZmluZWQ7XG4gIC8qKiBTdGVwcyB0byBiZSBkaXNwbGF5ZWQgKi9cbiAgQElucHV0KClcbiAgZ2V0IHN0ZXBzKCkge1xuICAgIHJldHVybiB0aGlzLl9zdGVwcztcbiAgfVxuICBzZXQgc3RlcHMoc3RlcHM6IEZvcm1TdGVwW10pIHtcbiAgICB0aGlzLl9zdGVwcyA9IHN0ZXBzO1xuICB9XG4gIHByaXZhdGUgX3N0ZXBzOiBGb3JtU3RlcFtdID0gW107XG5cbiAgQE91dHB1dCgpIHNlbGVjdGVkID0gbmV3IEV2ZW50RW1pdHRlcjxGb3JtU3RlcD4oKTtcblxuICBjb25zdHJ1Y3RvcihlbGVtZW50UmVmOiBFbGVtZW50UmVmKSB7XG4gICAgc3VwZXIoZWxlbWVudFJlZik7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { isFormStepGroup } from './models/index';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* Pipe to determine if a FormStep is a FormStepGroup or a single step.
|
|
6
|
+
*/
|
|
7
|
+
export class MtnaWfFormStepGroupPipe {
|
|
8
|
+
transform(step) {
|
|
9
|
+
return isFormStepGroup(step);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
MtnaWfFormStepGroupPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormStepGroupPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
13
|
+
MtnaWfFormStepGroupPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormStepGroupPipe, name: "mtnaWfStepGroupPipe" });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormStepGroupPipe, decorators: [{
|
|
15
|
+
type: Pipe,
|
|
16
|
+
args: [{
|
|
17
|
+
name: 'mtnaWfStepGroupPipe',
|
|
18
|
+
}]
|
|
19
|
+
}] });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1zdGVwLWdyb3VwLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy93ZWItZm9ybS1hbmd1bGFyL3NyYy9saWIvZm9ybS1zdGVwcGVyL2Zvcm0tc3RlcC1ncm91cC5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBRXBELE9BQU8sRUFBMkIsZUFBZSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7O0FBRTFFOztHQUVHO0FBSUgsTUFBTSxPQUFPLHVCQUF1QjtJQUNsQyxTQUFTLENBQUMsSUFBOEI7UUFDdEMsT0FBTyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0IsQ0FBQzs7cUhBSFUsdUJBQXVCO21IQUF2Qix1QkFBdUI7NEZBQXZCLHVCQUF1QjtrQkFIbkMsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUscUJBQXFCO2lCQUM1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRm9ybVN0ZXAsIEZvcm1TdGVwR3JvdXAsIGlzRm9ybVN0ZXBHcm91cCB9IGZyb20gJy4vbW9kZWxzL2luZGV4JztcblxuLyoqXG4gKiBQaXBlIHRvIGRldGVybWluZSBpZiBhIEZvcm1TdGVwIGlzIGEgRm9ybVN0ZXBHcm91cCBvciBhIHNpbmdsZSBzdGVwLlxuICovXG5AUGlwZSh7XG4gIG5hbWU6ICdtdG5hV2ZTdGVwR3JvdXBQaXBlJyxcbn0pXG5leHBvcnQgY2xhc3MgTXRuYVdmRm9ybVN0ZXBHcm91cFBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgdHJhbnNmb3JtKHN0ZXA6IEZvcm1TdGVwIHwgRm9ybVN0ZXBHcm91cCk6IHN0ZXAgaXMgRm9ybVN0ZXBHcm91cCB7XG4gICAgcmV0dXJuIGlzRm9ybVN0ZXBHcm91cChzdGVwKTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { mixinColor } from '@angular/material/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@mtna/core-angular";
|
|
5
|
+
import * as i2 from "@angular/flex-layout/flex";
|
|
6
|
+
import * as i3 from "@angular/material/core";
|
|
7
|
+
import * as i4 from "@angular/common";
|
|
8
|
+
/* eslint-disable @angular-eslint/no-inputs-metadata-property */
|
|
9
|
+
const _FormStepMixinBase = mixinColor(class {
|
|
10
|
+
constructor(_elementRef) {
|
|
11
|
+
this._elementRef = _elementRef;
|
|
12
|
+
}
|
|
13
|
+
}, 'primary');
|
|
14
|
+
export class MtnaWfFormStepComponent extends _FormStepMixinBase {
|
|
15
|
+
constructor(elementRef) {
|
|
16
|
+
super(elementRef);
|
|
17
|
+
this.disabled = false;
|
|
18
|
+
this._clickable = true;
|
|
19
|
+
}
|
|
20
|
+
get step() {
|
|
21
|
+
return this._step;
|
|
22
|
+
}
|
|
23
|
+
set step(step) {
|
|
24
|
+
this._step = step;
|
|
25
|
+
this.disabled = step.status === 'DISABLED';
|
|
26
|
+
}
|
|
27
|
+
get clickable() {
|
|
28
|
+
return !this.disabled && this._clickable;
|
|
29
|
+
}
|
|
30
|
+
set clickable(clickable) {
|
|
31
|
+
this._clickable = clickable;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Prevents click event if this step is not clickable
|
|
35
|
+
*/
|
|
36
|
+
_haltClickEvent(event) {
|
|
37
|
+
if (!this.clickable) {
|
|
38
|
+
event.preventDefault();
|
|
39
|
+
event.stopImmediatePropagation();
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
MtnaWfFormStepComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormStepComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
44
|
+
MtnaWfFormStepComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: MtnaWfFormStepComponent, selector: "mtna-wf-step", inputs: { color: "color", step: "step", clickable: "clickable", incompleteIcon: "incompleteIcon" }, host: { properties: { "class.disabled": "this.disabled", "class.clickable": "this.clickable" } }, usesInheritance: true, ngImport: i0, template: `
|
|
45
|
+
<li
|
|
46
|
+
fxLayout="row"
|
|
47
|
+
fxLayoutAlign="start center"
|
|
48
|
+
matRipple
|
|
49
|
+
[matRippleDisabled]="!clickable"
|
|
50
|
+
[class.active-step]="step.active"
|
|
51
|
+
(click)="_haltClickEvent($event)"
|
|
52
|
+
>
|
|
53
|
+
<mtna-status-circle
|
|
54
|
+
[color]="color"
|
|
55
|
+
[circleNumber]="step.num"
|
|
56
|
+
[incompleteIcon]="incompleteIcon"
|
|
57
|
+
[optional]="step.optional"
|
|
58
|
+
[status]="step.status"
|
|
59
|
+
></mtna-status-circle>
|
|
60
|
+
<div fxLayout="column" fxFlex="100">
|
|
61
|
+
<p class="step-title">{{ step.label }}</p>
|
|
62
|
+
<p *ngIf="step.optional || disabled" class="step-status">{{ disabled ? step.disabledText || 'Not Applicable' : 'Optional' }}</p>
|
|
63
|
+
</div>
|
|
64
|
+
</li>
|
|
65
|
+
`, isInline: true, styles: ["mtna-wf-step li{padding:8px 16px;position:relative;-webkit-user-select:none;-o-user-select:none;user-select:none;line-height:24px;font-size:14px;transition:background-color .15s cubic-bezier(0,0,.2,1)}mtna-wf-step li:after{content:\"\";display:block;position:absolute;top:0;right:0;bottom:0;width:5px;transition:transform .4s cubic-bezier(.25,.8,.25,1);transform-origin:bottom;transform:scaleY(0);z-index:1}mtna-wf-step li .step-title,mtna-wf-step li .step-status{margin:0}mtna-wf-step.disabled{font-style:italic}\n"], components: [{ type: i1.MtnaStatusCircleComponent, selector: "mtna-status-circle", inputs: ["color", "circleNumber", "incompleteIcon", "status", "validIcon", "optional"] }], directives: [{ type: i2.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: i2.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: i3.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleRadius", "matRippleDisabled", "matRippleTrigger", "matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleAnimation"], exportAs: ["matRipple"] }, { type: i2.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: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
66
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MtnaWfFormStepComponent, decorators: [{
|
|
67
|
+
type: Component,
|
|
68
|
+
args: [{
|
|
69
|
+
selector: 'mtna-wf-step',
|
|
70
|
+
template: `
|
|
71
|
+
<li
|
|
72
|
+
fxLayout="row"
|
|
73
|
+
fxLayoutAlign="start center"
|
|
74
|
+
matRipple
|
|
75
|
+
[matRippleDisabled]="!clickable"
|
|
76
|
+
[class.active-step]="step.active"
|
|
77
|
+
(click)="_haltClickEvent($event)"
|
|
78
|
+
>
|
|
79
|
+
<mtna-status-circle
|
|
80
|
+
[color]="color"
|
|
81
|
+
[circleNumber]="step.num"
|
|
82
|
+
[incompleteIcon]="incompleteIcon"
|
|
83
|
+
[optional]="step.optional"
|
|
84
|
+
[status]="step.status"
|
|
85
|
+
></mtna-status-circle>
|
|
86
|
+
<div fxLayout="column" fxFlex="100">
|
|
87
|
+
<p class="step-title">{{ step.label }}</p>
|
|
88
|
+
<p *ngIf="step.optional || disabled" class="step-status">{{ disabled ? step.disabledText || 'Not Applicable' : 'Optional' }}</p>
|
|
89
|
+
</div>
|
|
90
|
+
</li>
|
|
91
|
+
`,
|
|
92
|
+
styleUrls: ['form-step.component.scss'],
|
|
93
|
+
inputs: ['color'],
|
|
94
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
95
|
+
encapsulation: ViewEncapsulation.None,
|
|
96
|
+
}]
|
|
97
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { disabled: [{
|
|
98
|
+
type: HostBinding,
|
|
99
|
+
args: ['class.disabled']
|
|
100
|
+
}], step: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], clickable: [{
|
|
103
|
+
type: HostBinding,
|
|
104
|
+
args: ['class.clickable']
|
|
105
|
+
}, {
|
|
106
|
+
type: Input
|
|
107
|
+
}], incompleteIcon: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}] } });
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1zdGVwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dlYi1mb3JtLWFuZ3VsYXIvc3JjL2xpYi9mb3JtLXN0ZXBwZXIvZm9ybS1zdGVwLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFjLFdBQVcsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdEgsT0FBTyxFQUFZLFVBQVUsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7Ozs7QUFJOUQsZ0VBQWdFO0FBQ2hFLE1BQU0sa0JBQWtCLEdBQUcsVUFBVSxDQUNuQztJQUNFLFlBQW1CLFdBQXVCO1FBQXZCLGdCQUFXLEdBQVgsV0FBVyxDQUFZO0lBQUcsQ0FBQztDQUMvQyxFQUNELFNBQVMsQ0FDVixDQUFDO0FBK0JGLE1BQU0sT0FBTyx1QkFBd0IsU0FBUSxrQkFBa0I7SUF5QjdELFlBQVksVUFBc0I7UUFDaEMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBekJXLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFvQnhDLGVBQVUsR0FBRyxJQUFJLENBQUM7SUFNMUIsQ0FBQztJQXhCRCxJQUNJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztJQUNELElBQUksSUFBSSxDQUFDLElBQWM7UUFDckIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7UUFDbEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsTUFBTSxLQUFLLFVBQVUsQ0FBQztJQUM3QyxDQUFDO0lBR0QsSUFFSSxTQUFTO1FBQ1gsT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQztJQUMzQyxDQUFDO0lBQ0QsSUFBSSxTQUFTLENBQUMsU0FBa0I7UUFDOUIsSUFBSSxDQUFDLFVBQVUsR0FBRyxTQUFTLENBQUM7SUFDOUIsQ0FBQztJQVNEOztPQUVHO0lBQ0gsZUFBZSxDQUFDLEtBQVk7UUFDMUIsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbkIsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQ3ZCLEtBQUssQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1NBQ2xDO0lBQ0gsQ0FBQzs7cUhBckNVLHVCQUF1Qjt5R0FBdkIsdUJBQXVCLGlSQTNCeEI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXFCVDs0RkFNVSx1QkFBdUI7a0JBN0JuQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxjQUFjO29CQUN4QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXFCVDtvQkFDRCxTQUFTLEVBQUUsQ0FBQywwQkFBMEIsQ0FBQztvQkFDdkMsTUFBTSxFQUFFLENBQUMsT0FBTyxDQUFDO29CQUNqQixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7aUJBQ3RDO2lHQUVnQyxRQUFRO3NCQUF0QyxXQUFXO3VCQUFDLGdCQUFnQjtnQkFHekIsSUFBSTtzQkFEUCxLQUFLO2dCQVlGLFNBQVM7c0JBRlosV0FBVzt1QkFBQyxpQkFBaUI7O3NCQUM3QixLQUFLO2dCQVNHLGNBQWM7c0JBQXRCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBIb3N0QmluZGluZywgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDYW5Db2xvciwgbWl4aW5Db2xvciB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuXG5pbXBvcnQgeyBGb3JtU3RlcCB9IGZyb20gJy4vbW9kZWxzL2luZGV4JztcblxuLyogZXNsaW50LWRpc2FibGUgQGFuZ3VsYXItZXNsaW50L25vLWlucHV0cy1tZXRhZGF0YS1wcm9wZXJ0eSAqL1xuY29uc3QgX0Zvcm1TdGVwTWl4aW5CYXNlID0gbWl4aW5Db2xvcihcbiAgY2xhc3Mge1xuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBfZWxlbWVudFJlZjogRWxlbWVudFJlZikge31cbiAgfSxcbiAgJ3ByaW1hcnknXG4pO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdtdG5hLXdmLXN0ZXAnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxsaVxuICAgICAgZnhMYXlvdXQ9XCJyb3dcIlxuICAgICAgZnhMYXlvdXRBbGlnbj1cInN0YXJ0IGNlbnRlclwiXG4gICAgICBtYXRSaXBwbGVcbiAgICAgIFttYXRSaXBwbGVEaXNhYmxlZF09XCIhY2xpY2thYmxlXCJcbiAgICAgIFtjbGFzcy5hY3RpdmUtc3RlcF09XCJzdGVwLmFjdGl2ZVwiXG4gICAgICAoY2xpY2spPVwiX2hhbHRDbGlja0V2ZW50KCRldmVudClcIlxuICAgID5cbiAgICAgIDxtdG5hLXN0YXR1cy1jaXJjbGVcbiAgICAgICAgW2NvbG9yXT1cImNvbG9yXCJcbiAgICAgICAgW2NpcmNsZU51bWJlcl09XCJzdGVwLm51bVwiXG4gICAgICAgIFtpbmNvbXBsZXRlSWNvbl09XCJpbmNvbXBsZXRlSWNvblwiXG4gICAgICAgIFtvcHRpb25hbF09XCJzdGVwLm9wdGlvbmFsXCJcbiAgICAgICAgW3N0YXR1c109XCJzdGVwLnN0YXR1c1wiXG4gICAgICA+PC9tdG5hLXN0YXR1cy1jaXJjbGU+XG4gICAgICA8ZGl2IGZ4TGF5b3V0PVwiY29sdW1uXCIgZnhGbGV4PVwiMTAwXCI+XG4gICAgICAgIDxwIGNsYXNzPVwic3RlcC10aXRsZVwiPnt7IHN0ZXAubGFiZWwgfX08L3A+XG4gICAgICAgIDxwICpuZ0lmPVwic3RlcC5vcHRpb25hbCB8fCBkaXNhYmxlZFwiIGNsYXNzPVwic3RlcC1zdGF0dXNcIj57eyBkaXNhYmxlZCA/IHN0ZXAuZGlzYWJsZWRUZXh0IHx8ICdOb3QgQXBwbGljYWJsZScgOiAnT3B0aW9uYWwnIH19PC9wPlxuICAgICAgPC9kaXY+XG4gICAgPC9saT5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJ2Zvcm0tc3RlcC5jb21wb25lbnQuc2NzcyddLFxuICBpbnB1dHM6IFsnY29sb3InXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG59KVxuZXhwb3J0IGNsYXNzIE10bmFXZkZvcm1TdGVwQ29tcG9uZW50IGV4dGVuZHMgX0Zvcm1TdGVwTWl4aW5CYXNlIGltcGxlbWVudHMgQ2FuQ29sb3Ige1xuICBASG9zdEJpbmRpbmcoJ2NsYXNzLmRpc2FibGVkJykgZGlzYWJsZWQgPSBmYWxzZTtcblxuICBASW5wdXQoKVxuICBnZXQgc3RlcCgpOiBGb3JtU3RlcCB7XG4gICAgcmV0dXJuIHRoaXMuX3N0ZXA7XG4gIH1cbiAgc2V0IHN0ZXAoc3RlcDogRm9ybVN0ZXApIHtcbiAgICB0aGlzLl9zdGVwID0gc3RlcDtcbiAgICB0aGlzLmRpc2FibGVkID0gc3RlcC5zdGF0dXMgPT09ICdESVNBQkxFRCc7XG4gIH1cbiAgcHJpdmF0ZSBfc3RlcCE6IEZvcm1TdGVwO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MuY2xpY2thYmxlJylcbiAgQElucHV0KClcbiAgZ2V0IGNsaWNrYWJsZSgpIHtcbiAgICByZXR1cm4gIXRoaXMuZGlzYWJsZWQgJiYgdGhpcy5fY2xpY2thYmxlO1xuICB9XG4gIHNldCBjbGlja2FibGUoY2xpY2thYmxlOiBib29sZWFuKSB7XG4gICAgdGhpcy5fY2xpY2thYmxlID0gY2xpY2thYmxlO1xuICB9XG4gIHByaXZhdGUgX2NsaWNrYWJsZSA9IHRydWU7XG5cbiAgQElucHV0KCkgaW5jb21wbGV0ZUljb246IHN0cmluZyB8IG51bGwgfCB1bmRlZmluZWQ7XG5cbiAgY29uc3RydWN0b3IoZWxlbWVudFJlZjogRWxlbWVudFJlZikge1xuICAgIHN1cGVyKGVsZW1lbnRSZWYpO1xuICB9XG5cbiAgLyoqXG4gICAqIFByZXZlbnRzIGNsaWNrIGV2ZW50IGlmIHRoaXMgc3RlcCBpcyBub3QgY2xpY2thYmxlXG4gICAqL1xuICBfaGFsdENsaWNrRXZlbnQoZXZlbnQ6IEV2ZW50KSB7XG4gICAgaWYgKCF0aGlzLmNsaWNrYWJsZSkge1xuICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgIGV2ZW50LnN0b3BJbW1lZGlhdGVQcm9wYWdhdGlvbigpO1xuICAgIH1cbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export function everyStepStatus(statusToCheck, steps, a, b, c) {
|
|
2
|
+
if (!steps || !steps.length) {
|
|
3
|
+
return false;
|
|
4
|
+
}
|
|
5
|
+
let exclusionIds = c || [];
|
|
6
|
+
let includeDisabled = false;
|
|
7
|
+
let includeOptional = false;
|
|
8
|
+
// If 'a' is not null, determine if it's the 'includeDisabled' boolean, or the exclusionIds array
|
|
9
|
+
if (a !== null && a !== undefined) {
|
|
10
|
+
if (Array.isArray(a)) {
|
|
11
|
+
exclusionIds = a;
|
|
12
|
+
}
|
|
13
|
+
else {
|
|
14
|
+
includeDisabled = a;
|
|
15
|
+
includeOptional = b || false;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
return steps
|
|
19
|
+
.filter((s) =>
|
|
20
|
+
// Step ID is not excluded
|
|
21
|
+
!exclusionIds.some((id) => id === s.instanceId) &&
|
|
22
|
+
// Step status is not disabled, unless checking for disabled status
|
|
23
|
+
(includeDisabled ? true : s.status !== 'DISABLED') &&
|
|
24
|
+
// Step is required, unless optional steps should be checked
|
|
25
|
+
(includeOptional ? true : !s.optional))
|
|
26
|
+
.every((s) => s.status === statusToCheck);
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1zdGVwLnV0aWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy93ZWItZm9ybS1hbmd1bGFyL3NyYy9saWIvZm9ybS1zdGVwcGVyL2Zvcm0tc3RlcC51dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXdDQSxNQUFNLFVBQVUsZUFBZSxDQUM3QixhQUEyQixFQUMzQixLQUFzQixFQUN0QixDQUEyQixFQUMzQixDQUFXLEVBQ1gsQ0FBaUI7SUFFakIsSUFBSSxDQUFDLEtBQUssSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUU7UUFDM0IsT0FBTyxLQUFLLENBQUM7S0FDZDtJQUNELElBQUksWUFBWSxHQUFHLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDM0IsSUFBSSxlQUFlLEdBQUcsS0FBSyxDQUFDO0lBQzVCLElBQUksZUFBZSxHQUFHLEtBQUssQ0FBQztJQUM1QixpR0FBaUc7SUFDakcsSUFBSSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsS0FBSyxTQUFTLEVBQUU7UUFDakMsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQ3BCLFlBQVksR0FBRyxDQUFDLENBQUM7U0FDbEI7YUFBTTtZQUNMLGVBQWUsR0FBRyxDQUFDLENBQUM7WUFDcEIsZUFBZSxHQUFHLENBQUMsSUFBSSxLQUFLLENBQUM7U0FDOUI7S0FDRjtJQUNELE9BQU8sS0FBSztTQUNULE1BQU0sQ0FDTCxDQUFDLENBQUMsRUFBRSxFQUFFO0lBQ0osMEJBQTBCO0lBQzFCLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQyxVQUFVLENBQUM7UUFDL0MsbUVBQW1FO1FBQ25FLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEtBQUssVUFBVSxDQUFDO1FBQ2xELDREQUE0RDtRQUM1RCxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FDekM7U0FDQSxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxNQUFNLEtBQUssYUFBYSxDQUFDLENBQUM7QUFDOUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENpcmNsZVN0YXR1cyB9IGZyb20gJ0BtdG5hL2NvcmUtYW5ndWxhcic7XG5cbmltcG9ydCB7IEZvcm1TdGVwIH0gZnJvbSAnLi9tb2RlbHMvaW5kZXgnO1xuXG4vKipcbiAqIERldGVybWluZXMgaWYgZXZlcnkgc3RlcCBtYXRjaGVzIGEgZ2l2ZW4gc3RhdHVzXG4gKiBAcGFyYW0gc3RhdHVzVG9DaGVjayBDaXJjbGVTdGF0dXMgdG8gbWF0Y2ggYWdhaW5zdFxuICogQHBhcmFtIHN0ZXBzIEZvcm1TdGVwcyB3aXRoIHN0YXR1c2VzIHRvIGNoZWNrXG4gKiBAcGFyYW0gaW5jbHVkZURpc2FibGVkIElmIGZhbHNlIG9yIG5vdCBzdXBwbGllZCwgZGlzYWJsZWQgc3RlcHMgYXJlIGV4Y2x1ZGVkIGZyb20gY2hlY2tcbiAqIEBwYXJhbSBpbmNsdWRlT3B0aW9uYWwgSWYgZmFsc2Ugb3Igbm90IHN1cHBsaWVkLCBvcHRpb25hbCBzdGVwcyBhcmUgZXhjbHVkZWQgZnJvbSBjaGVja1xuICogQHBhcmFtIGV4Y2x1c2lvbklkcyBzdHJpbmdbXSBJRHMgb2Ygc3RlcHMgdG8gZXhjbHVkZSBmcm9tIGNoZWNrXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBldmVyeVN0ZXBTdGF0dXMoXG4gIHN0YXR1c1RvQ2hlY2s6IENpcmNsZVN0YXR1cyxcbiAgc3RlcHM6IEFycmF5PEZvcm1TdGVwPixcbiAgaW5jbHVkZURpc2FibGVkPzogYm9vbGVhbixcbiAgaW5jbHVkZU9wdGlvbmFsPzogYm9vbGVhblxuKTogYm9vbGVhbjtcbi8qKlxuICogRGV0ZXJtaW5lcyBpZiBldmVyeSBzdGVwIG1hdGNoZXMgYSBnaXZlbiBzdGF0dXNcbiAqIEBwYXJhbSBzdGF0dXNUb0NoZWNrIENpcmNsZVN0YXR1cyB0byBtYXRjaCBhZ2FpbnN0XG4gKiBAcGFyYW0gc3RlcHMgRm9ybVN0ZXBzIHdpdGggc3RhdHVzZXMgdG8gY2hlY2tcbiAqIEBwYXJhbSBleGNsdXNpb25JZHMgc3RyaW5nW10gSURzIG9mIHN0ZXBzIHRvIGV4Y2x1ZGUgZnJvbSBjaGVja1xuICovXG5leHBvcnQgZnVuY3Rpb24gZXZlcnlTdGVwU3RhdHVzKHN0YXR1c1RvQ2hlY2s6IENpcmNsZVN0YXR1cywgc3RlcHM6IEFycmF5PEZvcm1TdGVwPiwgZXhjbHVzaW9uSWRzPzogQXJyYXk8c3RyaW5nPik6IGJvb2xlYW47XG4vKipcbiAqIERldGVybWluZXMgaWYgZXZlcnkgc3RlcCBtYXRjaGVzIGEgZ2l2ZW4gc3RhdHVzXG4gKiBAcGFyYW0gc3RhdHVzVG9DaGVjayBDaXJjbGVTdGF0dXMgdG8gbWF0Y2ggYWdhaW5zdFxuICogQHBhcmFtIHN0ZXBzIEZvcm1TdGVwcyB3aXRoIHN0YXR1c2VzIHRvIGNoZWNrXG4gKiBAcGFyYW0gaW5jbHVkZURpc2FibGVkIElmIGZhbHNlIG9yIG5vdCBzdXBwbGllZCwgZGlzYWJsZWQgc3RlcHMgYXJlIGV4Y2x1ZGVkIGZyb20gY2hlY2tcbiAqIEBwYXJhbSBpbmNsdWRlT3B0aW9uYWwgSWYgZmFsc2Ugb3Igbm90IHN1cHBsaWVkLCBvcHRpb25hbCBzdGVwcyBhcmUgZXhjbHVkZWQgZnJvbSBjaGVja1xuICogQHBhcmFtIGV4Y2x1c2lvbklkcyBzdHJpbmdbXSBJRHMgb2Ygc3RlcHMgdG8gZXhjbHVkZSBmcm9tIGNoZWNrXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBldmVyeVN0ZXBTdGF0dXMoXG4gIHN0YXR1c1RvQ2hlY2s6IENpcmNsZVN0YXR1cyxcbiAgc3RlcHM6IEFycmF5PEZvcm1TdGVwPixcbiAgaW5jbHVkZURpc2FibGVkPzogYm9vbGVhbixcbiAgaW5jbHVkZU9wdGlvbmFsPzogYm9vbGVhbixcbiAgZXhjbHVzaW9uSWRzPzogQXJyYXk8c3RyaW5nPlxuKTogYm9vbGVhbjtcbmV4cG9ydCBmdW5jdGlvbiBldmVyeVN0ZXBTdGF0dXMoXG4gIHN0YXR1c1RvQ2hlY2s6IENpcmNsZVN0YXR1cyxcbiAgc3RlcHM6IEFycmF5PEZvcm1TdGVwPixcbiAgYT86IGJvb2xlYW4gfCBBcnJheTxzdHJpbmc+LFxuICBiPzogYm9vbGVhbixcbiAgYz86IEFycmF5PHN0cmluZz5cbik6IGJvb2xlYW4ge1xuICBpZiAoIXN0ZXBzIHx8ICFzdGVwcy5sZW5ndGgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgbGV0IGV4Y2x1c2lvbklkcyA9IGMgfHwgW107XG4gIGxldCBpbmNsdWRlRGlzYWJsZWQgPSBmYWxzZTtcbiAgbGV0IGluY2x1ZGVPcHRpb25hbCA9IGZhbHNlO1xuICAvLyBJZiAnYScgaXMgbm90IG51bGwsIGRldGVybWluZSBpZiBpdCdzIHRoZSAnaW5jbHVkZURpc2FibGVkJyBib29sZWFuLCBvciB0aGUgZXhjbHVzaW9uSWRzIGFycmF5XG4gIGlmIChhICE9PSBudWxsICYmIGEgIT09IHVuZGVmaW5lZCkge1xuICAgIGlmIChBcnJheS5pc0FycmF5KGEpKSB7XG4gICAgICBleGNsdXNpb25JZHMgPSBhO1xuICAgIH0gZWxzZSB7XG4gICAgICBpbmNsdWRlRGlzYWJsZWQgPSBhO1xuICAgICAgaW5jbHVkZU9wdGlvbmFsID0gYiB8fCBmYWxzZTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIHN0ZXBzXG4gICAgLmZpbHRlcihcbiAgICAgIChzKSA9PlxuICAgICAgICAvLyBTdGVwIElEIGlzIG5vdCBleGNsdWRlZFxuICAgICAgICAhZXhjbHVzaW9uSWRzLnNvbWUoKGlkKSA9PiBpZCA9PT0gcy5pbnN0YW5jZUlkKSAmJlxuICAgICAgICAvLyBTdGVwIHN0YXR1cyBpcyBub3QgZGlzYWJsZWQsIHVubGVzcyBjaGVja2luZyBmb3IgZGlzYWJsZWQgc3RhdHVzXG4gICAgICAgIChpbmNsdWRlRGlzYWJsZWQgPyB0cnVlIDogcy5zdGF0dXMgIT09ICdESVNBQkxFRCcpICYmXG4gICAgICAgIC8vIFN0ZXAgaXMgcmVxdWlyZWQsIHVubGVzcyBvcHRpb25hbCBzdGVwcyBzaG91bGQgYmUgY2hlY2tlZFxuICAgICAgICAoaW5jbHVkZU9wdGlvbmFsID8gdHJ1ZSA6ICFzLm9wdGlvbmFsKVxuICAgIClcbiAgICAuZXZlcnkoKHMpID0+IHMuc3RhdHVzID09PSBzdGF0dXNUb0NoZWNrKTtcbn1cbiJdfQ==
|