@wlcm/angular 17.3.5 → 17.4.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/package.json +7 -1
- package/phone-input/esm2022/lib/directives/phone-input.directive.mjs +8 -2
- package/phone-input/fesm2022/wlcm-angular-phone-input.mjs +7 -1
- package/phone-input/fesm2022/wlcm-angular-phone-input.mjs.map +1 -1
- package/stepper/README.md +7 -0
- package/stepper/esm2022/index.mjs +11 -0
- package/stepper/esm2022/lib/components/step/step.component.mjs +53 -0
- package/stepper/esm2022/lib/components/step-header/step-header.component.mjs +81 -0
- package/stepper/esm2022/lib/components/stepper/stepper.component.mjs +15 -0
- package/stepper/esm2022/lib/components/stepper-header/stepper-header.component.mjs +16 -0
- package/stepper/esm2022/lib/constants/step.constants.mjs +9 -0
- package/stepper/esm2022/lib/constants/stepper.stepper.mjs +3 -0
- package/stepper/esm2022/lib/directives/load-on-active-step.directive.mjs +51 -0
- package/stepper/esm2022/lib/models/step.models.mjs +60 -0
- package/stepper/esm2022/lib/models/stepper.models.mjs +114 -0
- package/stepper/esm2022/lib/stepper.module.mjs +34 -0
- package/stepper/esm2022/wlcm-angular-stepper.mjs +5 -0
- package/stepper/fesm2022/wlcm-angular-stepper.mjs +387 -0
- package/stepper/fesm2022/wlcm-angular-stepper.mjs.map +1 -0
- package/stepper/index.d.ts +10 -0
- package/stepper/lib/components/step/step.component.d.ts +16 -0
- package/stepper/lib/components/step-header/step-header.component.d.ts +20 -0
- package/stepper/lib/components/stepper/stepper.component.d.ts +6 -0
- package/stepper/lib/components/stepper-header/stepper-header.component.d.ts +8 -0
- package/stepper/lib/constants/step.constants.d.ts +4 -0
- package/stepper/lib/constants/stepper.stepper.d.ts +3 -0
- package/stepper/lib/directives/load-on-active-step.directive.d.ts +13 -0
- package/stepper/lib/models/step.models.d.ts +43 -0
- package/stepper/lib/models/stepper.models.d.ts +44 -0
- package/stepper/lib/stepper.module.d.ts +12 -0
- package/styles/components/stepper/_step-header.scss +123 -0
- package/styles/components/stepper/_step.scss +15 -0
- package/styles/components/stepper/_stepper-header.scss +13 -0
- package/styles/components/stepper/_stepper.scss +6 -0
- package/styles/components/stepper/indes.scss +9 -0
- package/styles/core/_all-theme.scss +2 -0
@@ -0,0 +1,60 @@
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
2
|
+
import { BehaviorSubject } from 'rxjs';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
export class WlcmStep {
|
5
|
+
}
|
6
|
+
export class WlcmStepBase extends WlcmStep {
|
7
|
+
set key(value) {
|
8
|
+
this._key$.next(value);
|
9
|
+
}
|
10
|
+
get key() {
|
11
|
+
return this._key$.value;
|
12
|
+
}
|
13
|
+
set label(value) {
|
14
|
+
this._label$.next(value);
|
15
|
+
}
|
16
|
+
get label() {
|
17
|
+
return this._label$.value;
|
18
|
+
}
|
19
|
+
set completed(value) {
|
20
|
+
this._completed$.next(value);
|
21
|
+
}
|
22
|
+
get completed() {
|
23
|
+
return this._completed$.value;
|
24
|
+
}
|
25
|
+
set disabled(value) {
|
26
|
+
this._disabled$.next(value);
|
27
|
+
}
|
28
|
+
get disabled() {
|
29
|
+
return this._disabled$.value;
|
30
|
+
}
|
31
|
+
constructor(options) {
|
32
|
+
super();
|
33
|
+
this.options = options;
|
34
|
+
this._key$ = new BehaviorSubject(null);
|
35
|
+
this.key$ = this._key$.asObservable();
|
36
|
+
this._label$ = new BehaviorSubject('');
|
37
|
+
this.label$ = this._label$.asObservable();
|
38
|
+
this._completed$ = new BehaviorSubject(false);
|
39
|
+
this.completed$ = this._completed$.asObservable();
|
40
|
+
this._disabled$ = new BehaviorSubject(false);
|
41
|
+
this.disabled$ = this._disabled$.asObservable();
|
42
|
+
this.disabled = this.options.hasOwnProperty('completed') ? this.options.completed : false;
|
43
|
+
this.disabled = this.options.hasOwnProperty('disabled') ? this.options.disabled : 'on_any_previous_incomplete';
|
44
|
+
}
|
45
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepBase, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive }); }
|
46
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: WlcmStepBase, inputs: { key: "key", label: "label", completed: "completed", disabled: "disabled" }, usesInheritance: true, ngImport: i0 }); }
|
47
|
+
}
|
48
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepBase, decorators: [{
|
49
|
+
type: Directive
|
50
|
+
}], ctorParameters: () => [{ type: undefined }], propDecorators: { key: [{
|
51
|
+
type: Input
|
52
|
+
}], label: [{
|
53
|
+
type: Input,
|
54
|
+
args: [{ required: true }]
|
55
|
+
}], completed: [{
|
56
|
+
type: Input
|
57
|
+
}], disabled: [{
|
58
|
+
type: Input
|
59
|
+
}] } });
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcC5tb2RlbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9tb2R1bGVzL3N0ZXBwZXIvc3JjL2xpYi9tb2RlbHMvc3RlcC5tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFFLGVBQWUsRUFBYyxNQUFNLE1BQU0sQ0FBQzs7QUFVbkQsTUFBTSxPQUFnQixRQUFRO0NBb0I3QjtBQUdELE1BQU0sT0FBZ0IsWUFBYSxTQUFRLFFBQVE7SUFDakQsSUFBYSxHQUFHLENBQUMsS0FBYztRQUM3QixJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN6QixDQUFDO0lBQ0QsSUFBSSxHQUFHO1FBQ0wsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQztJQUMxQixDQUFDO0lBTUQsSUFBK0IsS0FBSyxDQUFDLEtBQWE7UUFDaEQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0IsQ0FBQztJQUNELElBQUksS0FBSztRQUNQLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUM7SUFDNUIsQ0FBQztJQU1ELElBQWEsU0FBUyxDQUFDLEtBQWM7UUFDbkMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUNELElBQUksU0FBUztRQUNYLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUM7SUFDaEMsQ0FBQztJQU1ELElBQWEsUUFBUSxDQUFDLEtBQTJCO1FBQy9DLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFDRCxJQUFJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDO0lBQy9CLENBQUM7SUFNRCxZQUFzQixPQUF3QjtRQUM1QyxLQUFLLEVBQUUsQ0FBQztRQURZLFlBQU8sR0FBUCxPQUFPLENBQWlCO1FBckM3QixVQUFLLEdBQTZCLElBQUksZUFBZSxDQUFVLElBQUksQ0FBQyxDQUFDO1FBRTdFLFNBQUksR0FBd0IsSUFBSSxDQUFDLEtBQUssQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQVM5QyxZQUFPLEdBQTRCLElBQUksZUFBZSxDQUFTLEVBQUUsQ0FBQyxDQUFDO1FBRTNFLFdBQU0sR0FBdUIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQVNqRCxnQkFBVyxHQUE2QixJQUFJLGVBQWUsQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUVwRixlQUFVLEdBQXdCLElBQUksQ0FBQyxXQUFXLENBQUMsWUFBWSxFQUFFLENBQUM7UUFTMUQsZUFBVSxHQUEwQyxJQUFJLGVBQWUsQ0FBdUIsS0FBSyxDQUFDLENBQUM7UUFFN0csY0FBUyxHQUFxQyxJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBS3BGLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBVSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7UUFFM0YsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFTLENBQUMsQ0FBQyxDQUFDLDRCQUE0QixDQUFDO0lBQ2xILENBQUM7OEdBbkRtQixZQUFZO2tHQUFaLFlBQVk7OzJGQUFaLFlBQVk7a0JBRGpDLFNBQVM7MkVBRUssR0FBRztzQkFBZixLQUFLO2dCQVd5QixLQUFLO3NCQUFuQyxLQUFLO3VCQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRTtnQkFXWixTQUFTO3NCQUFyQixLQUFLO2dCQVdPLFFBQVE7c0JBQXBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcblxuZXhwb3J0IHR5cGUgV2xjbVN0ZXBEaXNhYmxlVmFsdWUgPSAnb25fYW55X3ByZXZpb3VzX2luY29tcGxldGUnIHwgYm9vbGVhbjtcblxuZXhwb3J0IGludGVyZmFjZSBXbGNtU3RlcE9wdGlvbnMge1xuICBjb21wbGV0ZWQ/OiBib29sZWFuO1xuXG4gIGRpc2FibGVkPzogV2xjbVN0ZXBEaXNhYmxlVmFsdWU7XG59XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBXbGNtU3RlcCB7XG4gIGFic3RyYWN0IHNldCBrZXkodmFsdWU6IHVua25vd24pO1xuICBhYnN0cmFjdCBnZXQga2V5KCk6IHVua25vd247XG5cbiAgYWJzdHJhY3Qga2V5JDogT2JzZXJ2YWJsZTx1bmtub3duPjtcblxuICBhYnN0cmFjdCBzZXQgbGFiZWwodmFsdWU6IHN0cmluZyk7XG4gIGFic3RyYWN0IGdldCBsYWJlbCgpOiBzdHJpbmc7XG5cbiAgYWJzdHJhY3QgbGFiZWwkOiBPYnNlcnZhYmxlPHN0cmluZz47XG5cbiAgYWJzdHJhY3Qgc2V0IGNvbXBsZXRlZCh2YWx1ZTogYm9vbGVhbik7XG4gIGFic3RyYWN0IGdldCBjb21wbGV0ZWQoKTogYm9vbGVhbjtcblxuICBhYnN0cmFjdCBjb21wbGV0ZWQkOiBPYnNlcnZhYmxlPGJvb2xlYW4+O1xuXG4gIGFic3RyYWN0IHNldCBkaXNhYmxlZCh2YWx1ZTogV2xjbVN0ZXBEaXNhYmxlVmFsdWUpO1xuICBhYnN0cmFjdCBnZXQgZGlzYWJsZWQoKTogV2xjbVN0ZXBEaXNhYmxlVmFsdWU7XG5cbiAgYWJzdHJhY3QgZGlzYWJsZWQkOiBPYnNlcnZhYmxlPFdsY21TdGVwRGlzYWJsZVZhbHVlPjtcbn1cblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgV2xjbVN0ZXBCYXNlIGV4dGVuZHMgV2xjbVN0ZXAge1xuICBASW5wdXQoKSBzZXQga2V5KHZhbHVlOiB1bmtub3duKSB7XG4gICAgdGhpcy5fa2V5JC5uZXh0KHZhbHVlKTtcbiAgfVxuICBnZXQga2V5KCk6IHVua25vd24ge1xuICAgIHJldHVybiB0aGlzLl9rZXkkLnZhbHVlO1xuICB9XG5cbiAgcHJpdmF0ZSByZWFkb25seSBfa2V5JDogQmVoYXZpb3JTdWJqZWN0PHVua25vd24+ID0gbmV3IEJlaGF2aW9yU3ViamVjdDx1bmtub3duPihudWxsKTtcblxuICByZWFkb25seSBrZXkkOiBPYnNlcnZhYmxlPHVua25vd24+ID0gdGhpcy5fa2V5JC5hc09ic2VydmFibGUoKTtcblxuICBASW5wdXQoeyByZXF1aXJlZDogdHJ1ZSB9KSBzZXQgbGFiZWwodmFsdWU6IHN0cmluZykge1xuICAgIHRoaXMuX2xhYmVsJC5uZXh0KHZhbHVlKTtcbiAgfVxuICBnZXQgbGFiZWwoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fbGFiZWwkLnZhbHVlO1xuICB9XG5cbiAgcHJpdmF0ZSByZWFkb25seSBfbGFiZWwkOiBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPiA9IG5ldyBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPignJyk7XG5cbiAgcmVhZG9ubHkgbGFiZWwkOiBPYnNlcnZhYmxlPHN0cmluZz4gPSB0aGlzLl9sYWJlbCQuYXNPYnNlcnZhYmxlKCk7XG5cbiAgQElucHV0KCkgc2V0IGNvbXBsZXRlZCh2YWx1ZTogYm9vbGVhbikge1xuICAgIHRoaXMuX2NvbXBsZXRlZCQubmV4dCh2YWx1ZSk7XG4gIH1cbiAgZ2V0IGNvbXBsZXRlZCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5fY29tcGxldGVkJC52YWx1ZTtcbiAgfVxuXG4gIHByaXZhdGUgcmVhZG9ubHkgX2NvbXBsZXRlZCQ6IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPiA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4oZmFsc2UpO1xuXG4gIHJlYWRvbmx5IGNvbXBsZXRlZCQ6IE9ic2VydmFibGU8Ym9vbGVhbj4gPSB0aGlzLl9jb21wbGV0ZWQkLmFzT2JzZXJ2YWJsZSgpO1xuXG4gIEBJbnB1dCgpIHNldCBkaXNhYmxlZCh2YWx1ZTogV2xjbVN0ZXBEaXNhYmxlVmFsdWUpIHtcbiAgICB0aGlzLl9kaXNhYmxlZCQubmV4dCh2YWx1ZSk7XG4gIH1cbiAgZ2V0IGRpc2FibGVkKCk6IFdsY21TdGVwRGlzYWJsZVZhbHVlIHtcbiAgICByZXR1cm4gdGhpcy5fZGlzYWJsZWQkLnZhbHVlO1xuICB9XG5cbiAgcHJpdmF0ZSByZWFkb25seSBfZGlzYWJsZWQkOiBCZWhhdmlvclN1YmplY3Q8V2xjbVN0ZXBEaXNhYmxlVmFsdWU+ID0gbmV3IEJlaGF2aW9yU3ViamVjdDxXbGNtU3RlcERpc2FibGVWYWx1ZT4oZmFsc2UpO1xuXG4gIHJlYWRvbmx5IGRpc2FibGVkJDogT2JzZXJ2YWJsZTxXbGNtU3RlcERpc2FibGVWYWx1ZT4gPSB0aGlzLl9kaXNhYmxlZCQuYXNPYnNlcnZhYmxlKCk7XG5cbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIG9wdGlvbnM6IFdsY21TdGVwT3B0aW9ucykge1xuICAgIHN1cGVyKCk7XG5cbiAgICB0aGlzLmRpc2FibGVkID0gdGhpcy5vcHRpb25zLmhhc093blByb3BlcnR5KCdjb21wbGV0ZWQnKSA/IHRoaXMub3B0aW9ucy5jb21wbGV0ZWQhIDogZmFsc2U7XG5cbiAgICB0aGlzLmRpc2FibGVkID0gdGhpcy5vcHRpb25zLmhhc093blByb3BlcnR5KCdkaXNhYmxlZCcpID8gdGhpcy5vcHRpb25zLmRpc2FibGVkISA6ICdvbl9hbnlfcHJldmlvdXNfaW5jb21wbGV0ZSc7XG4gIH1cbn1cbiJdfQ==
|
@@ -0,0 +1,114 @@
|
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
2
|
+
import { ChangeDetectorRef, Directive, contentChildren, effect } from '@angular/core';
|
3
|
+
import { BehaviorSubject, Subject, combineLatest, distinctUntilChanged, filter, map, skip, takeUntil, } from 'rxjs';
|
4
|
+
import { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';
|
5
|
+
import { WLCM_STEP } from '../constants/step.constants';
|
6
|
+
import * as i0 from "@angular/core";
|
7
|
+
export class WlcmStepsNavigator {
|
8
|
+
}
|
9
|
+
let WlcmStepperBase = class WlcmStepperBase extends WlcmStepsNavigator {
|
10
|
+
constructor(changeDetector) {
|
11
|
+
super();
|
12
|
+
this.changeDetector = changeDetector;
|
13
|
+
this._listUpdated$ = new Subject();
|
14
|
+
this._keyToIndexMap = new Map();
|
15
|
+
this._steps = contentChildren(WLCM_STEP, { descendants: true });
|
16
|
+
this._active$ = new BehaviorSubject(null);
|
17
|
+
this.active$ = this._active$.asObservable();
|
18
|
+
this._minIncompleteStepIndex$ = new BehaviorSubject(0);
|
19
|
+
this.minIncompleteStepIndex$ = this._minIncompleteStepIndex$
|
20
|
+
.asObservable()
|
21
|
+
.pipe(filter((index) => index !== Infinity));
|
22
|
+
effect(() => this._handleUpdatedList(this._steps()));
|
23
|
+
}
|
24
|
+
get active() {
|
25
|
+
return this._active$.value;
|
26
|
+
}
|
27
|
+
get isActiveCompleted() {
|
28
|
+
return this.active.completed;
|
29
|
+
}
|
30
|
+
get minIncompleteStepIndex() {
|
31
|
+
return this._minIncompleteStepIndex$.value;
|
32
|
+
}
|
33
|
+
next() {
|
34
|
+
if (!this.canActivateNext())
|
35
|
+
return;
|
36
|
+
const index = this._activeIndex + 1;
|
37
|
+
if (index < this._steps().length)
|
38
|
+
this.activate(this._steps()[index].key);
|
39
|
+
}
|
40
|
+
previous() {
|
41
|
+
const index = this._activeIndex - 1;
|
42
|
+
if (index >= 0)
|
43
|
+
this.activate(this._steps()[index].key);
|
44
|
+
}
|
45
|
+
activate(key) {
|
46
|
+
if (!this._keyToIndexMap.has(key))
|
47
|
+
return;
|
48
|
+
const step = this._getStep(key);
|
49
|
+
this._active$.next(step);
|
50
|
+
this.changeDetector.markForCheck();
|
51
|
+
}
|
52
|
+
canActivateNext() {
|
53
|
+
return this.isActiveCompleted;
|
54
|
+
}
|
55
|
+
isCurrentOrPrevious(key) {
|
56
|
+
const index = this._keyToIndexMap.get(key);
|
57
|
+
const activeIndex = this._activeIndex;
|
58
|
+
return index === activeIndex || activeIndex > index;
|
59
|
+
}
|
60
|
+
getStepIndex(key) {
|
61
|
+
return this._keyToIndexMap.get(key);
|
62
|
+
}
|
63
|
+
get _activeIndex() {
|
64
|
+
return this._keyToIndexMap.get(this.active.key);
|
65
|
+
}
|
66
|
+
_getStep(key) {
|
67
|
+
return this._steps()[this._keyToIndexMap.get(key)];
|
68
|
+
}
|
69
|
+
_handleUpdatedList(list) {
|
70
|
+
this._listUpdated$.next();
|
71
|
+
this._keyToIndexMap.clear();
|
72
|
+
list.forEach((step, index) => {
|
73
|
+
if (!step.key)
|
74
|
+
step.key = `${index}`;
|
75
|
+
this._keyToIndexMap.set(step.key, index);
|
76
|
+
this._handleKeyChanges(step, index);
|
77
|
+
});
|
78
|
+
this._handleCompleteChanges(list);
|
79
|
+
if (!this._active$.value)
|
80
|
+
this.activate(list[0].key);
|
81
|
+
}
|
82
|
+
_handleKeyChanges(step, index) {
|
83
|
+
let previousKey = step.key;
|
84
|
+
step.key$
|
85
|
+
.pipe(skip(1))
|
86
|
+
.pipe(untilDestroyed(this), takeUntil(this._listUpdated$))
|
87
|
+
.subscribe((newKey) => {
|
88
|
+
this._keyToIndexMap.delete(previousKey);
|
89
|
+
this._keyToIndexMap.set(newKey, index);
|
90
|
+
previousKey = newKey;
|
91
|
+
});
|
92
|
+
}
|
93
|
+
_handleCompleteChanges(list) {
|
94
|
+
combineLatest(list.map((step, index) => step.completed$
|
95
|
+
.pipe(distinctUntilChanged())
|
96
|
+
.pipe(map((isCompleted) => (isCompleted ? Infinity : index)))))
|
97
|
+
.pipe(untilDestroyed(this), takeUntil(this._listUpdated$))
|
98
|
+
.subscribe((indexes) => {
|
99
|
+
const minIndex = Math.min(...indexes);
|
100
|
+
this._minIncompleteStepIndex$.next(minIndex !== Infinity ? minIndex : -1);
|
101
|
+
});
|
102
|
+
}
|
103
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperBase, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
104
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.2.0", version: "17.3.5", type: WlcmStepperBase, queries: [{ propertyName: "_steps", predicate: WLCM_STEP, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0 }); }
|
105
|
+
};
|
106
|
+
WlcmStepperBase = __decorate([
|
107
|
+
UntilDestroy(),
|
108
|
+
__metadata("design:paramtypes", [ChangeDetectorRef])
|
109
|
+
], WlcmStepperBase);
|
110
|
+
export { WlcmStepperBase };
|
111
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperBase, decorators: [{
|
112
|
+
type: Directive
|
113
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }] });
|
114
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.models.js","sourceRoot":"","sources":["../../../../../../modules/stepper/src/lib/models/stepper.models.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Directive, Signal, contentChildren, effect } from '@angular/core';\nimport {\n  BehaviorSubject,\n  Observable,\n  Subject,\n  combineLatest,\n  distinctUntilChanged,\n  filter,\n  map,\n  skip,\n  takeUntil,\n} from 'rxjs';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { WLCM_STEP } from '../constants/step.constants';\nimport { WlcmStep } from './step.models';\n\nexport abstract class WlcmStepsNavigator {\n  abstract get active(): WlcmStep;\n\n  abstract readonly active$: Observable<WlcmStep | null>;\n\n  abstract get minIncompleteStepIndex(): number;\n\n  abstract readonly minIncompleteStepIndex$: Observable<number>;\n\n  abstract get isActiveCompleted(): boolean;\n\n  abstract next(): void;\n\n  abstract previous(): void;\n\n  abstract activate(key: unknown): void;\n\n  abstract canActivateNext(): boolean;\n\n  abstract isCurrentOrPrevious(key: unknown): boolean;\n\n  abstract getStepIndex(key: unknown): number | undefined;\n}\n\n@UntilDestroy()\n@Directive()\nexport class WlcmStepperBase extends WlcmStepsNavigator {\n  private _listUpdated$: Subject<void> = new Subject();\n\n  private _keyToIndexMap: Map<unknown, number> = new Map();\n\n  protected _steps: Signal<ReadonlyArray<WlcmStep>> = contentChildren(WLCM_STEP, { descendants: true });\n\n  private readonly _active$: BehaviorSubject<WlcmStep | null> = new BehaviorSubject<WlcmStep | null>(null);\n\n  readonly active$: Observable<WlcmStep | null> = this._active$.asObservable();\n\n  private readonly _minIncompleteStepIndex$: BehaviorSubject<number> = new BehaviorSubject(0);\n\n  readonly minIncompleteStepIndex$: Observable<number> = this._minIncompleteStepIndex$\n    .asObservable()\n    .pipe(filter((index: number) => index !== Infinity));\n\n  constructor(protected changeDetector: ChangeDetectorRef) {\n    super();\n\n    effect(() => this._handleUpdatedList(this._steps()));\n  }\n\n  get active(): WlcmStep {\n    return this._active$.value!;\n  }\n\n  get isActiveCompleted(): boolean {\n    return this.active.completed;\n  }\n\n  get minIncompleteStepIndex(): number {\n    return this._minIncompleteStepIndex$.value;\n  }\n\n  next(): void {\n    if (!this.canActivateNext()) return;\n\n    const index: number = this._activeIndex + 1;\n\n    if (index < this._steps().length) this.activate(this._steps()[index].key);\n  }\n\n  previous(): void {\n    const index: number = this._activeIndex - 1;\n\n    if (index >= 0) this.activate(this._steps()[index].key);\n  }\n\n  activate(key: unknown): void {\n    if (!this._keyToIndexMap.has(key)) return;\n\n    const step: WlcmStep = this._getStep(key);\n\n    this._active$.next(step);\n\n    this.changeDetector.markForCheck();\n  }\n\n  canActivateNext(): boolean {\n    return this.isActiveCompleted;\n  }\n\n  isCurrentOrPrevious(key: unknown): boolean {\n    const index: number = this._keyToIndexMap.get(key)!;\n\n    const activeIndex: number = this._activeIndex;\n\n    return index === activeIndex || activeIndex > index;\n  }\n\n  getStepIndex(key: unknown): number | undefined {\n    return this._keyToIndexMap.get(key);\n  }\n\n  private get _activeIndex(): number {\n    return this._keyToIndexMap.get(this.active.key)!;\n  }\n\n  private _getStep(key: unknown): WlcmStep {\n    return this._steps()[this._keyToIndexMap.get(key)!];\n  }\n\n  private _handleUpdatedList(list: ReadonlyArray<WlcmStep>): void {\n    this._listUpdated$.next();\n\n    this._keyToIndexMap.clear();\n\n    list.forEach((step: WlcmStep, index: number) => {\n      if (!step.key) step.key = `${index}`;\n\n      this._keyToIndexMap.set(step.key, index);\n\n      this._handleKeyChanges(step, index);\n    });\n\n    this._handleCompleteChanges(list);\n\n    if (!this._active$.value) this.activate(list[0].key);\n  }\n\n  private _handleKeyChanges(step: WlcmStep, index: number): void {\n    let previousKey: unknown = step.key;\n\n    step.key$\n      .pipe(skip(1))\n      .pipe(untilDestroyed(this), takeUntil(this._listUpdated$))\n      .subscribe((newKey: unknown) => {\n        this._keyToIndexMap.delete(previousKey);\n\n        this._keyToIndexMap.set(newKey, index);\n\n        previousKey = newKey;\n      });\n  }\n\n  private _handleCompleteChanges(list: ReadonlyArray<WlcmStep>): void {\n    combineLatest(\n      list.map((step: WlcmStep, index: number) =>\n        step.completed$\n          .pipe(distinctUntilChanged())\n          .pipe(map((isCompleted: boolean) => (isCompleted ? Infinity : index)))\n      )\n    )\n      .pipe(untilDestroyed(this), takeUntil(this._listUpdated$))\n      .subscribe((indexes: number[]) => {\n        const minIndex: number = Math.min(...indexes);\n\n        this._minIncompleteStepIndex$.next(minIndex !== Infinity ? minIndex : -1);\n      });\n  }\n}\n"]}
|
@@ -0,0 +1,34 @@
|
|
1
|
+
import { NgModule } from '@angular/core';
|
2
|
+
import { CommonModule } from '@angular/common';
|
3
|
+
import { WlcmStepperComponent } from './components/stepper/stepper.component';
|
4
|
+
import { WlcmStepHeaderComponent } from './components/step-header/step-header.component';
|
5
|
+
import { WlcmStepperHeaderComponent } from './components/stepper-header/stepper-header.component';
|
6
|
+
import { WlcmStepComponent } from './components/step/step.component';
|
7
|
+
import { WlcmLoadOnActiveStepDirective } from './directives/load-on-active-step.directive';
|
8
|
+
import * as i0 from "@angular/core";
|
9
|
+
const publicComponents = [
|
10
|
+
WlcmStepComponent,
|
11
|
+
WlcmStepperComponent,
|
12
|
+
WlcmStepHeaderComponent,
|
13
|
+
WlcmStepperHeaderComponent,
|
14
|
+
];
|
15
|
+
const publicDirectives = [WlcmLoadOnActiveStepDirective];
|
16
|
+
export class WlcmStepperModule {
|
17
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
18
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperModule, imports: [CommonModule, WlcmStepComponent,
|
19
|
+
WlcmStepperComponent,
|
20
|
+
WlcmStepHeaderComponent,
|
21
|
+
WlcmStepperHeaderComponent, WlcmLoadOnActiveStepDirective], exports: [WlcmStepComponent,
|
22
|
+
WlcmStepperComponent,
|
23
|
+
WlcmStepHeaderComponent,
|
24
|
+
WlcmStepperHeaderComponent, WlcmLoadOnActiveStepDirective] }); }
|
25
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperModule, imports: [CommonModule, publicComponents] }); }
|
26
|
+
}
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperModule, decorators: [{
|
28
|
+
type: NgModule,
|
29
|
+
args: [{
|
30
|
+
imports: [CommonModule, ...publicComponents, ...publicDirectives],
|
31
|
+
exports: [...publicComponents, ...publicDirectives],
|
32
|
+
}]
|
33
|
+
}] });
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcHBlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9tb2R1bGVzL3N0ZXBwZXIvc3JjL2xpYi9zdGVwcGVyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFRLE1BQU0sZUFBZSxDQUFDO0FBQy9DLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUM5RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUN6RixPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUNsRyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNyRSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQzs7QUFFM0YsTUFBTSxnQkFBZ0IsR0FBb0I7SUFDeEMsaUJBQWlCO0lBQ2pCLG9CQUFvQjtJQUNwQix1QkFBdUI7SUFDdkIsMEJBQTBCO0NBQzNCLENBQUM7QUFFRixNQUFNLGdCQUFnQixHQUFvQixDQUFDLDZCQUE2QixDQUFDLENBQUM7QUFNMUUsTUFBTSxPQUFPLGlCQUFpQjs4R0FBakIsaUJBQWlCOytHQUFqQixpQkFBaUIsWUFIbEIsWUFBWSxFQVR0QixpQkFBaUI7WUFDakIsb0JBQW9CO1lBQ3BCLHVCQUF1QjtZQUN2QiwwQkFBMEIsRUFHZSw2QkFBNkIsYUFOdEUsaUJBQWlCO1lBQ2pCLG9CQUFvQjtZQUNwQix1QkFBdUI7WUFDdkIsMEJBQTBCLEVBR2UsNkJBQTZCOytHQU0zRCxpQkFBaUIsWUFIbEIsWUFBWSxFQUFLLGdCQUFnQjs7MkZBR2hDLGlCQUFpQjtrQkFKN0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsR0FBRyxnQkFBZ0IsRUFBRSxHQUFHLGdCQUFnQixDQUFDO29CQUNqRSxPQUFPLEVBQUUsQ0FBQyxHQUFHLGdCQUFnQixFQUFFLEdBQUcsZ0JBQWdCLENBQUM7aUJBQ3BEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBXbGNtU3RlcHBlckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9zdGVwcGVyL3N0ZXBwZXIuY29tcG9uZW50JztcbmltcG9ydCB7IFdsY21TdGVwSGVhZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3N0ZXAtaGVhZGVyL3N0ZXAtaGVhZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBXbGNtU3RlcHBlckhlYWRlckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9zdGVwcGVyLWhlYWRlci9zdGVwcGVyLWhlYWRlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgV2xjbVN0ZXBDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvc3RlcC9zdGVwLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBXbGNtTG9hZE9uQWN0aXZlU3RlcERpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy9sb2FkLW9uLWFjdGl2ZS1zdGVwLmRpcmVjdGl2ZSc7XG5cbmNvbnN0IHB1YmxpY0NvbXBvbmVudHM6IFR5cGU8dW5rbm93bj5bXSA9IFtcbiAgV2xjbVN0ZXBDb21wb25lbnQsXG4gIFdsY21TdGVwcGVyQ29tcG9uZW50LFxuICBXbGNtU3RlcEhlYWRlckNvbXBvbmVudCxcbiAgV2xjbVN0ZXBwZXJIZWFkZXJDb21wb25lbnQsXG5dO1xuXG5jb25zdCBwdWJsaWNEaXJlY3RpdmVzOiBUeXBlPHVua25vd24+W10gPSBbV2xjbUxvYWRPbkFjdGl2ZVN0ZXBEaXJlY3RpdmVdO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCAuLi5wdWJsaWNDb21wb25lbnRzLCAuLi5wdWJsaWNEaXJlY3RpdmVzXSxcbiAgZXhwb3J0czogWy4uLnB1YmxpY0NvbXBvbmVudHMsIC4uLnB1YmxpY0RpcmVjdGl2ZXNdLFxufSlcbmV4cG9ydCBjbGFzcyBXbGNtU3RlcHBlck1vZHVsZSB7fVxuIl19
|
@@ -0,0 +1,5 @@
|
|
1
|
+
/**
|
2
|
+
* Generated bundle index. Do not edit.
|
3
|
+
*/
|
4
|
+
export * from './index';
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2xjbS1hbmd1bGFyLXN0ZXBwZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9tb2R1bGVzL3N0ZXBwZXIvc3JjL3dsY20tYW5ndWxhci1zdGVwcGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
|
@@ -0,0 +1,387 @@
|
|
1
|
+
import { __decorate, __metadata } from 'tslib';
|
2
|
+
import * as i1 from '@angular/common';
|
3
|
+
import { CommonModule } from '@angular/common';
|
4
|
+
import * as i0 from '@angular/core';
|
5
|
+
import { InjectionToken, contentChildren, effect, ChangeDetectorRef, Directive, input, ElementRef, Component, Inject, HostBinding, Input, forwardRef, NgZone, TemplateRef, ViewContainerRef, NgModule } from '@angular/core';
|
6
|
+
import { Subject, BehaviorSubject, filter, skip, takeUntil, combineLatest, distinctUntilChanged, map, switchMap, of } from 'rxjs';
|
7
|
+
import { untilDestroyed, UntilDestroy } from '@ngneat/until-destroy';
|
8
|
+
|
9
|
+
const WLCM_STEPS_NAVIGATOR = new InjectionToken('WLCM_STEPS_NAVIGATOR');
|
10
|
+
|
11
|
+
const WLCM_STEP = new InjectionToken('WLCM_STEP');
|
12
|
+
const WLCM_STEP_OPTIONS = new InjectionToken('WLCM_STEP_OPTIONS', {
|
13
|
+
factory: () => ({
|
14
|
+
completed: false,
|
15
|
+
disabled: 'on_any_previous_incomplete',
|
16
|
+
}),
|
17
|
+
});
|
18
|
+
|
19
|
+
class WlcmStepsNavigator {
|
20
|
+
}
|
21
|
+
let WlcmStepperBase = class WlcmStepperBase extends WlcmStepsNavigator {
|
22
|
+
constructor(changeDetector) {
|
23
|
+
super();
|
24
|
+
this.changeDetector = changeDetector;
|
25
|
+
this._listUpdated$ = new Subject();
|
26
|
+
this._keyToIndexMap = new Map();
|
27
|
+
this._steps = contentChildren(WLCM_STEP, { descendants: true });
|
28
|
+
this._active$ = new BehaviorSubject(null);
|
29
|
+
this.active$ = this._active$.asObservable();
|
30
|
+
this._minIncompleteStepIndex$ = new BehaviorSubject(0);
|
31
|
+
this.minIncompleteStepIndex$ = this._minIncompleteStepIndex$
|
32
|
+
.asObservable()
|
33
|
+
.pipe(filter((index) => index !== Infinity));
|
34
|
+
effect(() => this._handleUpdatedList(this._steps()));
|
35
|
+
}
|
36
|
+
get active() {
|
37
|
+
return this._active$.value;
|
38
|
+
}
|
39
|
+
get isActiveCompleted() {
|
40
|
+
return this.active.completed;
|
41
|
+
}
|
42
|
+
get minIncompleteStepIndex() {
|
43
|
+
return this._minIncompleteStepIndex$.value;
|
44
|
+
}
|
45
|
+
next() {
|
46
|
+
if (!this.canActivateNext())
|
47
|
+
return;
|
48
|
+
const index = this._activeIndex + 1;
|
49
|
+
if (index < this._steps().length)
|
50
|
+
this.activate(this._steps()[index].key);
|
51
|
+
}
|
52
|
+
previous() {
|
53
|
+
const index = this._activeIndex - 1;
|
54
|
+
if (index >= 0)
|
55
|
+
this.activate(this._steps()[index].key);
|
56
|
+
}
|
57
|
+
activate(key) {
|
58
|
+
if (!this._keyToIndexMap.has(key))
|
59
|
+
return;
|
60
|
+
const step = this._getStep(key);
|
61
|
+
this._active$.next(step);
|
62
|
+
this.changeDetector.markForCheck();
|
63
|
+
}
|
64
|
+
canActivateNext() {
|
65
|
+
return this.isActiveCompleted;
|
66
|
+
}
|
67
|
+
isCurrentOrPrevious(key) {
|
68
|
+
const index = this._keyToIndexMap.get(key);
|
69
|
+
const activeIndex = this._activeIndex;
|
70
|
+
return index === activeIndex || activeIndex > index;
|
71
|
+
}
|
72
|
+
getStepIndex(key) {
|
73
|
+
return this._keyToIndexMap.get(key);
|
74
|
+
}
|
75
|
+
get _activeIndex() {
|
76
|
+
return this._keyToIndexMap.get(this.active.key);
|
77
|
+
}
|
78
|
+
_getStep(key) {
|
79
|
+
return this._steps()[this._keyToIndexMap.get(key)];
|
80
|
+
}
|
81
|
+
_handleUpdatedList(list) {
|
82
|
+
this._listUpdated$.next();
|
83
|
+
this._keyToIndexMap.clear();
|
84
|
+
list.forEach((step, index) => {
|
85
|
+
if (!step.key)
|
86
|
+
step.key = `${index}`;
|
87
|
+
this._keyToIndexMap.set(step.key, index);
|
88
|
+
this._handleKeyChanges(step, index);
|
89
|
+
});
|
90
|
+
this._handleCompleteChanges(list);
|
91
|
+
if (!this._active$.value)
|
92
|
+
this.activate(list[0].key);
|
93
|
+
}
|
94
|
+
_handleKeyChanges(step, index) {
|
95
|
+
let previousKey = step.key;
|
96
|
+
step.key$
|
97
|
+
.pipe(skip(1))
|
98
|
+
.pipe(untilDestroyed(this), takeUntil(this._listUpdated$))
|
99
|
+
.subscribe((newKey) => {
|
100
|
+
this._keyToIndexMap.delete(previousKey);
|
101
|
+
this._keyToIndexMap.set(newKey, index);
|
102
|
+
previousKey = newKey;
|
103
|
+
});
|
104
|
+
}
|
105
|
+
_handleCompleteChanges(list) {
|
106
|
+
combineLatest(list.map((step, index) => step.completed$
|
107
|
+
.pipe(distinctUntilChanged())
|
108
|
+
.pipe(map((isCompleted) => (isCompleted ? Infinity : index)))))
|
109
|
+
.pipe(untilDestroyed(this), takeUntil(this._listUpdated$))
|
110
|
+
.subscribe((indexes) => {
|
111
|
+
const minIndex = Math.min(...indexes);
|
112
|
+
this._minIncompleteStepIndex$.next(minIndex !== Infinity ? minIndex : -1);
|
113
|
+
});
|
114
|
+
}
|
115
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperBase, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
116
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.2.0", version: "17.3.5", type: WlcmStepperBase, queries: [{ propertyName: "_steps", predicate: WLCM_STEP, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0 }); }
|
117
|
+
};
|
118
|
+
WlcmStepperBase = __decorate([
|
119
|
+
UntilDestroy(),
|
120
|
+
__metadata("design:paramtypes", [ChangeDetectorRef])
|
121
|
+
], WlcmStepperBase);
|
122
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperBase, decorators: [{
|
123
|
+
type: Directive
|
124
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }] });
|
125
|
+
|
126
|
+
let WlcmStepHeaderComponent = class WlcmStepHeaderComponent {
|
127
|
+
get isPassed() {
|
128
|
+
return this._key && this.navigator.isCurrentOrPrevious(this._key);
|
129
|
+
}
|
130
|
+
get isCompleted() {
|
131
|
+
return this._step.completed;
|
132
|
+
}
|
133
|
+
constructor(elementRef, navigator) {
|
134
|
+
this.elementRef = elementRef;
|
135
|
+
this.navigator = navigator;
|
136
|
+
this.step = input.required();
|
137
|
+
this._stepUpdated$ = new Subject();
|
138
|
+
effect(() => this._handleDisableStatusChanges());
|
139
|
+
}
|
140
|
+
activate() {
|
141
|
+
if (this.navigator.active?.key === this.step().key)
|
142
|
+
return;
|
143
|
+
this.navigator.activate(this.step().key);
|
144
|
+
}
|
145
|
+
get element() {
|
146
|
+
return this.elementRef.nativeElement;
|
147
|
+
}
|
148
|
+
get _key() {
|
149
|
+
return this.step().key;
|
150
|
+
}
|
151
|
+
get _step() {
|
152
|
+
return this.step();
|
153
|
+
}
|
154
|
+
_handleDisableStatusChanges() {
|
155
|
+
this._stepUpdated$.next();
|
156
|
+
this.step()
|
157
|
+
.disabled$.pipe(switchMap((value) => {
|
158
|
+
if (value === 'on_any_previous_incomplete') {
|
159
|
+
return this.navigator.minIncompleteStepIndex$.pipe(map((minIndex) => {
|
160
|
+
if (minIndex < 0)
|
161
|
+
return false;
|
162
|
+
return minIndex < this.navigator.getStepIndex(this.step().key);
|
163
|
+
}));
|
164
|
+
}
|
165
|
+
return of(value);
|
166
|
+
}))
|
167
|
+
.pipe(untilDestroyed(this), takeUntil(this._stepUpdated$))
|
168
|
+
.subscribe((isDisabled) => {
|
169
|
+
if (isDisabled) {
|
170
|
+
return this.element.classList.add('wlcm-step-header-disabled');
|
171
|
+
}
|
172
|
+
this.element.classList.remove('wlcm-step-header-disabled');
|
173
|
+
});
|
174
|
+
}
|
175
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepHeaderComponent, deps: [{ token: i0.ElementRef }, { token: WLCM_STEPS_NAVIGATOR }], target: i0.ɵɵFactoryTarget.Component }); }
|
176
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.5", type: WlcmStepHeaderComponent, isStandalone: true, selector: "wlcm-step-header", inputs: { step: { classPropertyName: "step", publicName: "step", isSignal: true, isRequired: true, transformFunction: null } }, host: { properties: { "class.wlcm-step-header-passed": "this.isPassed", "class.wlcm-step-header-completed": "this.isCompleted" }, classAttribute: "wlcm-step-header" }, ngImport: i0, template: "<button class=\"wlcm-step-header-button\" (click)=\"activate()\">\n <span class=\"wlcm-step-header-label\">{{ step().label$ | async }}</span>\n\n <div class=\"wlcm-step-header-progress-bar\">\n <div class=\"wlcm-step-header-complete-indicator\"></div>\n\n <div class=\"wlcm-step-header-pass-indicator\"></div>\n </div>\n</button>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] }); }
|
177
|
+
};
|
178
|
+
WlcmStepHeaderComponent = __decorate([
|
179
|
+
UntilDestroy(),
|
180
|
+
__metadata("design:paramtypes", [ElementRef, WlcmStepsNavigator])
|
181
|
+
], WlcmStepHeaderComponent);
|
182
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepHeaderComponent, decorators: [{
|
183
|
+
type: Component,
|
184
|
+
args: [{ selector: 'wlcm-step-header', host: { class: 'wlcm-step-header' }, standalone: true, imports: [CommonModule], template: "<button class=\"wlcm-step-header-button\" (click)=\"activate()\">\n <span class=\"wlcm-step-header-label\">{{ step().label$ | async }}</span>\n\n <div class=\"wlcm-step-header-progress-bar\">\n <div class=\"wlcm-step-header-complete-indicator\"></div>\n\n <div class=\"wlcm-step-header-pass-indicator\"></div>\n </div>\n</button>\n" }]
|
185
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: WlcmStepsNavigator, decorators: [{
|
186
|
+
type: Inject,
|
187
|
+
args: [WLCM_STEPS_NAVIGATOR]
|
188
|
+
}] }], propDecorators: { isPassed: [{
|
189
|
+
type: HostBinding,
|
190
|
+
args: ['class.wlcm-step-header-passed']
|
191
|
+
}], isCompleted: [{
|
192
|
+
type: HostBinding,
|
193
|
+
args: ['class.wlcm-step-header-completed']
|
194
|
+
}] } });
|
195
|
+
|
196
|
+
class WlcmStep {
|
197
|
+
}
|
198
|
+
class WlcmStepBase extends WlcmStep {
|
199
|
+
set key(value) {
|
200
|
+
this._key$.next(value);
|
201
|
+
}
|
202
|
+
get key() {
|
203
|
+
return this._key$.value;
|
204
|
+
}
|
205
|
+
set label(value) {
|
206
|
+
this._label$.next(value);
|
207
|
+
}
|
208
|
+
get label() {
|
209
|
+
return this._label$.value;
|
210
|
+
}
|
211
|
+
set completed(value) {
|
212
|
+
this._completed$.next(value);
|
213
|
+
}
|
214
|
+
get completed() {
|
215
|
+
return this._completed$.value;
|
216
|
+
}
|
217
|
+
set disabled(value) {
|
218
|
+
this._disabled$.next(value);
|
219
|
+
}
|
220
|
+
get disabled() {
|
221
|
+
return this._disabled$.value;
|
222
|
+
}
|
223
|
+
constructor(options) {
|
224
|
+
super();
|
225
|
+
this.options = options;
|
226
|
+
this._key$ = new BehaviorSubject(null);
|
227
|
+
this.key$ = this._key$.asObservable();
|
228
|
+
this._label$ = new BehaviorSubject('');
|
229
|
+
this.label$ = this._label$.asObservable();
|
230
|
+
this._completed$ = new BehaviorSubject(false);
|
231
|
+
this.completed$ = this._completed$.asObservable();
|
232
|
+
this._disabled$ = new BehaviorSubject(false);
|
233
|
+
this.disabled$ = this._disabled$.asObservable();
|
234
|
+
this.disabled = this.options.hasOwnProperty('completed') ? this.options.completed : false;
|
235
|
+
this.disabled = this.options.hasOwnProperty('disabled') ? this.options.disabled : 'on_any_previous_incomplete';
|
236
|
+
}
|
237
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepBase, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive }); }
|
238
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: WlcmStepBase, inputs: { key: "key", label: "label", completed: "completed", disabled: "disabled" }, usesInheritance: true, ngImport: i0 }); }
|
239
|
+
}
|
240
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepBase, decorators: [{
|
241
|
+
type: Directive
|
242
|
+
}], ctorParameters: () => [{ type: undefined }], propDecorators: { key: [{
|
243
|
+
type: Input
|
244
|
+
}], label: [{
|
245
|
+
type: Input,
|
246
|
+
args: [{ required: true }]
|
247
|
+
}], completed: [{
|
248
|
+
type: Input
|
249
|
+
}], disabled: [{
|
250
|
+
type: Input
|
251
|
+
}] } });
|
252
|
+
|
253
|
+
let WlcmStepComponent = class WlcmStepComponent extends WlcmStepBase {
|
254
|
+
constructor(zone, elementRef, changeDetectorRef, options, stepsNavigator) {
|
255
|
+
super(options);
|
256
|
+
this.zone = zone;
|
257
|
+
this.elementRef = elementRef;
|
258
|
+
this.changeDetectorRef = changeDetectorRef;
|
259
|
+
this.options = options;
|
260
|
+
this.stepsNavigator = stepsNavigator;
|
261
|
+
this.zone.runOutsideAngular(() => this._handleActiveChanges());
|
262
|
+
}
|
263
|
+
get element() {
|
264
|
+
return this.elementRef.nativeElement;
|
265
|
+
}
|
266
|
+
_handleActiveChanges() {
|
267
|
+
this.stepsNavigator.active$.pipe(untilDestroyed(this)).subscribe((active) => {
|
268
|
+
if (active?.key === this.key) {
|
269
|
+
this.element.classList.add('wlcm-step-active');
|
270
|
+
return this.changeDetectorRef.markForCheck();
|
271
|
+
}
|
272
|
+
this.element.classList.remove('wlcm-step-active');
|
273
|
+
});
|
274
|
+
}
|
275
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepComponent, deps: [{ token: i0.NgZone }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: WLCM_STEP_OPTIONS }, { token: WLCM_STEPS_NAVIGATOR }], target: i0.ɵɵFactoryTarget.Component }); }
|
276
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: WlcmStepComponent, isStandalone: true, selector: "wlcm-step", host: { classAttribute: "wlcm-step" }, providers: [{ provide: WLCM_STEP, useExisting: forwardRef(() => WlcmStepComponent) }], usesInheritance: true, ngImport: i0, template: "<ng-content></ng-content>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
|
277
|
+
};
|
278
|
+
WlcmStepComponent = __decorate([
|
279
|
+
UntilDestroy(),
|
280
|
+
__metadata("design:paramtypes", [NgZone,
|
281
|
+
ElementRef,
|
282
|
+
ChangeDetectorRef, Object, WlcmStepsNavigator])
|
283
|
+
], WlcmStepComponent);
|
284
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepComponent, decorators: [{
|
285
|
+
type: Component,
|
286
|
+
args: [{ selector: 'wlcm-step', host: { class: 'wlcm-step' }, standalone: true, imports: [CommonModule], providers: [{ provide: WLCM_STEP, useExisting: forwardRef(() => WlcmStepComponent) }], template: "<ng-content></ng-content>\n" }]
|
287
|
+
}], ctorParameters: () => [{ type: i0.NgZone }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
|
288
|
+
type: Inject,
|
289
|
+
args: [WLCM_STEP_OPTIONS]
|
290
|
+
}] }, { type: WlcmStepsNavigator, decorators: [{
|
291
|
+
type: Inject,
|
292
|
+
args: [WLCM_STEPS_NAVIGATOR]
|
293
|
+
}] }] });
|
294
|
+
|
295
|
+
class WlcmStepperHeaderComponent {
|
296
|
+
constructor() {
|
297
|
+
this.steps = input.required();
|
298
|
+
}
|
299
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
300
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: WlcmStepperHeaderComponent, isStandalone: true, selector: "wlcm-stepper-header", inputs: { steps: { classPropertyName: "steps", publicName: "steps", isSignal: true, isRequired: true, transformFunction: null } }, host: { classAttribute: "wlcm-stepper-header" }, ngImport: i0, template: "@for (step of steps(); track step) {\n<wlcm-step-header [step]=\"step\"></wlcm-step-header>\n}\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: WlcmStepHeaderComponent, selector: "wlcm-step-header", inputs: ["step"] }] }); }
|
301
|
+
}
|
302
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperHeaderComponent, decorators: [{
|
303
|
+
type: Component,
|
304
|
+
args: [{ selector: 'wlcm-stepper-header', host: { class: 'wlcm-stepper-header' }, standalone: true, imports: [CommonModule, WlcmStepHeaderComponent], template: "@for (step of steps(); track step) {\n<wlcm-step-header [step]=\"step\"></wlcm-step-header>\n}\n" }]
|
305
|
+
}] });
|
306
|
+
|
307
|
+
class WlcmStepperComponent extends WlcmStepperBase {
|
308
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
309
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: WlcmStepperComponent, isStandalone: true, selector: "wlcm-stepper", host: { classAttribute: "wlcm-stepper" }, providers: [{ provide: WLCM_STEPS_NAVIGATOR, useExisting: forwardRef(() => WlcmStepperComponent) }], usesInheritance: true, ngImport: i0, template: "<wlcm-stepper-header [steps]=\"_steps()\"></wlcm-stepper-header>\n\n<ng-content select=\"wlcm-step\"></ng-content>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: WlcmStepperHeaderComponent, selector: "wlcm-stepper-header", inputs: ["steps"] }] }); }
|
310
|
+
}
|
311
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperComponent, decorators: [{
|
312
|
+
type: Component,
|
313
|
+
args: [{ selector: 'wlcm-stepper', host: { class: 'wlcm-stepper' }, standalone: true, imports: [CommonModule, WlcmStepperHeaderComponent], providers: [{ provide: WLCM_STEPS_NAVIGATOR, useExisting: forwardRef(() => WlcmStepperComponent) }], template: "<wlcm-stepper-header [steps]=\"_steps()\"></wlcm-stepper-header>\n\n<ng-content select=\"wlcm-step\"></ng-content>\n" }]
|
314
|
+
}] });
|
315
|
+
|
316
|
+
let WlcmLoadOnActiveStepDirective = class WlcmLoadOnActiveStepDirective {
|
317
|
+
constructor(step, navigator, templateRef, viewContainer) {
|
318
|
+
this.step = step;
|
319
|
+
this.navigator = navigator;
|
320
|
+
this.templateRef = templateRef;
|
321
|
+
this.viewContainer = viewContainer;
|
322
|
+
this.navigator.active$.pipe(untilDestroyed(this)).subscribe((active) => {
|
323
|
+
if (active?.key === step.key) {
|
324
|
+
this.viewContainer.clear();
|
325
|
+
this.viewContainer.createEmbeddedView(this.templateRef);
|
326
|
+
}
|
327
|
+
else {
|
328
|
+
this.viewContainer.clear();
|
329
|
+
}
|
330
|
+
});
|
331
|
+
}
|
332
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmLoadOnActiveStepDirective, deps: [{ token: WLCM_STEP }, { token: WLCM_STEPS_NAVIGATOR }, { token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
333
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.5", type: WlcmLoadOnActiveStepDirective, isStandalone: true, selector: "[wlcmLoadOnActiveStep]", ngImport: i0 }); }
|
334
|
+
};
|
335
|
+
WlcmLoadOnActiveStepDirective = __decorate([
|
336
|
+
UntilDestroy(),
|
337
|
+
__metadata("design:paramtypes", [WlcmStep,
|
338
|
+
WlcmStepsNavigator,
|
339
|
+
TemplateRef,
|
340
|
+
ViewContainerRef])
|
341
|
+
], WlcmLoadOnActiveStepDirective);
|
342
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmLoadOnActiveStepDirective, decorators: [{
|
343
|
+
type: Directive,
|
344
|
+
args: [{
|
345
|
+
selector: '[wlcmLoadOnActiveStep]',
|
346
|
+
standalone: true,
|
347
|
+
}]
|
348
|
+
}], ctorParameters: () => [{ type: WlcmStep, decorators: [{
|
349
|
+
type: Inject,
|
350
|
+
args: [WLCM_STEP]
|
351
|
+
}] }, { type: WlcmStepsNavigator, decorators: [{
|
352
|
+
type: Inject,
|
353
|
+
args: [WLCM_STEPS_NAVIGATOR]
|
354
|
+
}] }, { type: i0.TemplateRef }, { type: i0.ViewContainerRef }] });
|
355
|
+
|
356
|
+
const publicComponents = [
|
357
|
+
WlcmStepComponent,
|
358
|
+
WlcmStepperComponent,
|
359
|
+
WlcmStepHeaderComponent,
|
360
|
+
WlcmStepperHeaderComponent,
|
361
|
+
];
|
362
|
+
const publicDirectives = [WlcmLoadOnActiveStepDirective];
|
363
|
+
class WlcmStepperModule {
|
364
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
365
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperModule, imports: [CommonModule, WlcmStepComponent,
|
366
|
+
WlcmStepperComponent,
|
367
|
+
WlcmStepHeaderComponent,
|
368
|
+
WlcmStepperHeaderComponent, WlcmLoadOnActiveStepDirective], exports: [WlcmStepComponent,
|
369
|
+
WlcmStepperComponent,
|
370
|
+
WlcmStepHeaderComponent,
|
371
|
+
WlcmStepperHeaderComponent, WlcmLoadOnActiveStepDirective] }); }
|
372
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperModule, imports: [CommonModule, publicComponents] }); }
|
373
|
+
}
|
374
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmStepperModule, decorators: [{
|
375
|
+
type: NgModule,
|
376
|
+
args: [{
|
377
|
+
imports: [CommonModule, ...publicComponents, ...publicDirectives],
|
378
|
+
exports: [...publicComponents, ...publicDirectives],
|
379
|
+
}]
|
380
|
+
}] });
|
381
|
+
|
382
|
+
/**
|
383
|
+
* Generated bundle index. Do not edit.
|
384
|
+
*/
|
385
|
+
|
386
|
+
export { WLCM_STEP, WLCM_STEPS_NAVIGATOR, WLCM_STEP_OPTIONS, WlcmLoadOnActiveStepDirective, WlcmStep, WlcmStepComponent, WlcmStepHeaderComponent, WlcmStepperComponent, WlcmStepperHeaderComponent, WlcmStepperModule, WlcmStepsNavigator };
|
387
|
+
//# sourceMappingURL=wlcm-angular-stepper.mjs.map
|