windows-plus-utilities 0.0.88 → 0.0.90

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.
@@ -2,6 +2,7 @@
2
2
  * Public API Surface of windows-plus-utilities
3
3
  */
4
4
  export * from './components/step/step.component';
5
+ export * from './util/factory/wizard-step-factory';
5
6
  export * from './util/helper/wizard-builder.service';
6
7
  export * from './util/interface/modal-step.interface';
7
8
  export * from './util/interface/step-definition.interface';
@@ -10,4 +11,4 @@ export * from './util/interface/wizard-modal.interface';
10
11
  export * from './util/interface/wizard-state.interface';
11
12
  export * from './util/service/wizard-step.service';
12
13
  export * from './util/service/step.service';
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3dpbmRvd3MtcGx1cy11dGlsaXRpZXMvbW9kYWwtd2l6YXJkL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFDSCxjQUFjLGtDQUFrQyxDQUFDO0FBRWpELGNBQWMsc0NBQXNDLENBQUE7QUFFcEQsY0FBYyx1Q0FBdUMsQ0FBQTtBQUNyRCxjQUFjLDRDQUE0QyxDQUFBO0FBQzFELGNBQWMsMENBQTBDLENBQUE7QUFDeEQsY0FBYyx5Q0FBeUMsQ0FBQTtBQUN2RCxjQUFjLHlDQUF5QyxDQUFBO0FBRXZELGNBQWMsb0NBQW9DLENBQUE7QUFDbEQsY0FBYyw2QkFBNkIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiB3aW5kb3dzLXBsdXMtdXRpbGl0aWVzXHJcbiAqL1xyXG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvc3RlcC9zdGVwLmNvbXBvbmVudCc7XHJcblxyXG5leHBvcnQgKiBmcm9tICcuL3V0aWwvaGVscGVyL3dpemFyZC1idWlsZGVyLnNlcnZpY2UnXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL3V0aWwvaW50ZXJmYWNlL21vZGFsLXN0ZXAuaW50ZXJmYWNlJ1xyXG5leHBvcnQgKiBmcm9tICcuL3V0aWwvaW50ZXJmYWNlL3N0ZXAtZGVmaW5pdGlvbi5pbnRlcmZhY2UnXHJcbmV4cG9ydCAqIGZyb20gJy4vdXRpbC9pbnRlcmZhY2Uvc3RlcHBlZC1tb2RhbC5pbnRlcmZhY2UnXHJcbmV4cG9ydCAqIGZyb20gJy4vdXRpbC9pbnRlcmZhY2Uvd2l6YXJkLW1vZGFsLmludGVyZmFjZSdcclxuZXhwb3J0ICogZnJvbSAnLi91dGlsL2ludGVyZmFjZS93aXphcmQtc3RhdGUuaW50ZXJmYWNlJ1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi91dGlsL3NlcnZpY2Uvd2l6YXJkLXN0ZXAuc2VydmljZSdcclxuZXhwb3J0ICogZnJvbSAnLi91dGlsL3NlcnZpY2Uvc3RlcC5zZXJ2aWNlJyJdfQ==
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3dpbmRvd3MtcGx1cy11dGlsaXRpZXMvbW9kYWwtd2l6YXJkL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFDSCxjQUFjLGtDQUFrQyxDQUFDO0FBRWpELGNBQWMsb0NBQW9DLENBQUE7QUFFbEQsY0FBYyxzQ0FBc0MsQ0FBQTtBQUVwRCxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMsNENBQTRDLENBQUE7QUFDMUQsY0FBYywwQ0FBMEMsQ0FBQTtBQUN4RCxjQUFjLHlDQUF5QyxDQUFBO0FBQ3ZELGNBQWMseUNBQXlDLENBQUE7QUFFdkQsY0FBYyxvQ0FBb0MsQ0FBQTtBQUNsRCxjQUFjLDZCQUE2QixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHdpbmRvd3MtcGx1cy11dGlsaXRpZXNcclxuICovXHJcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9zdGVwL3N0ZXAuY29tcG9uZW50JztcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vdXRpbC9mYWN0b3J5L3dpemFyZC1zdGVwLWZhY3RvcnknXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL3V0aWwvaGVscGVyL3dpemFyZC1idWlsZGVyLnNlcnZpY2UnXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL3V0aWwvaW50ZXJmYWNlL21vZGFsLXN0ZXAuaW50ZXJmYWNlJ1xyXG5leHBvcnQgKiBmcm9tICcuL3V0aWwvaW50ZXJmYWNlL3N0ZXAtZGVmaW5pdGlvbi5pbnRlcmZhY2UnXHJcbmV4cG9ydCAqIGZyb20gJy4vdXRpbC9pbnRlcmZhY2Uvc3RlcHBlZC1tb2RhbC5pbnRlcmZhY2UnXHJcbmV4cG9ydCAqIGZyb20gJy4vdXRpbC9pbnRlcmZhY2Uvd2l6YXJkLW1vZGFsLmludGVyZmFjZSdcclxuZXhwb3J0ICogZnJvbSAnLi91dGlsL2ludGVyZmFjZS93aXphcmQtc3RhdGUuaW50ZXJmYWNlJ1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi91dGlsL3NlcnZpY2Uvd2l6YXJkLXN0ZXAuc2VydmljZSdcclxuZXhwb3J0ICogZnJvbSAnLi91dGlsL3NlcnZpY2Uvc3RlcC5zZXJ2aWNlJyJdfQ==
@@ -0,0 +1,17 @@
1
+ /**
2
+ * Factory helper for building dynamic wizard step flows.
3
+ */
4
+ export class WizardStepFactory {
5
+ constructor(masterSteps) {
6
+ this.masterSteps = masterSteps;
7
+ }
8
+ /**
9
+ * Resolves the active step list based on context conditions.
10
+ *
11
+ * @param context The current wizard context.
12
+ */
13
+ build(context) {
14
+ return this.masterSteps.filter(step => !step.condition || step.condition(context));
15
+ }
16
+ }
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l6YXJkLXN0ZXAtZmFjdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dpbmRvd3MtcGx1cy11dGlsaXRpZXMvbW9kYWwtd2l6YXJkL3V0aWwvZmFjdG9yeS93aXphcmQtc3RlcC1mYWN0b3J5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGlCQUFpQjtJQUM1QixZQUNtQixXQUFnQztRQUFoQyxnQkFBVyxHQUFYLFdBQVcsQ0FBcUI7SUFDL0MsQ0FBQztJQUVMOzs7O09BSUc7SUFDSCxLQUFLLENBQUMsT0FBVTtRQUNkLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FDcEMsQ0FBQyxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQzNDLENBQUE7SUFDSCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdGVwRGVmaW5pdGlvbiB9IGZyb20gJy4uL2ludGVyZmFjZS9zdGVwLWRlZmluaXRpb24uaW50ZXJmYWNlJ1xyXG5cclxuLyoqXHJcbiAqIEZhY3RvcnkgaGVscGVyIGZvciBidWlsZGluZyBkeW5hbWljIHdpemFyZCBzdGVwIGZsb3dzLlxyXG4gKi9cclxuZXhwb3J0IGNsYXNzIFdpemFyZFN0ZXBGYWN0b3J5PFQ+IHtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgbWFzdGVyU3RlcHM6IFN0ZXBEZWZpbml0aW9uPFQ+W11cclxuICApIHsgfVxyXG5cclxuICAvKipcclxuICAgKiBSZXNvbHZlcyB0aGUgYWN0aXZlIHN0ZXAgbGlzdCBiYXNlZCBvbiBjb250ZXh0IGNvbmRpdGlvbnMuXHJcbiAgICpcclxuICAgKiBAcGFyYW0gY29udGV4dCBUaGUgY3VycmVudCB3aXphcmQgY29udGV4dC5cclxuICAgKi9cclxuICBidWlsZChjb250ZXh0OiBUKTogU3RlcERlZmluaXRpb248VD5bXSB7XHJcbiAgICByZXR1cm4gdGhpcy5tYXN0ZXJTdGVwcy5maWx0ZXIoc3RlcCA9PlxyXG4gICAgICAhc3RlcC5jb25kaXRpb24gfHwgc3RlcC5jb25kaXRpb24oY29udGV4dClcclxuICAgIClcclxuICB9XHJcbn0iXX0=
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcC1kZWZpbml0aW9uLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dpbmRvd3MtcGx1cy11dGlsaXRpZXMvbW9kYWwtd2l6YXJkL3V0aWwvaW50ZXJmYWNlL3N0ZXAtZGVmaW5pdGlvbi5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBAYXV0aG9yIEFsZXggSG9kc29uXHJcbiAqIEBkZXNjcmlwdGlvbiBhbiBpbnRlcmZhY2UgZGVmaW5pbmcgdGhlIGNvbmZpZ3VyYXRpb24gZm9yIGEgc2luZ2xlIHdpemFyZCBzdGVwXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFN0ZXBEZWZpbml0aW9uPFQ+IHtcclxuICBpZDogc3RyaW5nXHJcbiAgdGl0bGU6IHN0cmluZ1xyXG4gIHNsdWc6IHN0cmluZ1xyXG5cdGlzQ29tcGxldGU6IGJvb2xlYW5cclxuICBwYXJhbWV0ZXJzPzogVFtdXHJcbiAgb25FeGl0PzogKGNvbnRleHQ/OiBhbnkpID0+IFByb21pc2U8Ym9vbGVhbj4gfCBib29sZWFuXHJcbn0iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcC1kZWZpbml0aW9uLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dpbmRvd3MtcGx1cy11dGlsaXRpZXMvbW9kYWwtd2l6YXJkL3V0aWwvaW50ZXJmYWNlL3N0ZXAtZGVmaW5pdGlvbi5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBAYXV0aG9yIEFsZXggSG9kc29uXHJcbiAqIEBkZXNjcmlwdGlvbiBhbiBpbnRlcmZhY2UgZGVmaW5pbmcgdGhlIGNvbmZpZ3VyYXRpb24gZm9yIGEgc2luZ2xlIHdpemFyZCBzdGVwXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFN0ZXBEZWZpbml0aW9uPFQ+IHtcclxuXHQvKipcclxuXHQgKiBVbmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIHN0ZXAuXHJcblx0ICovXHJcbiAgaWQ6IHN0cmluZ1xyXG4gIC8qKlxyXG4gICAqIEh1bWFuLXJlYWRhYmxlIHN0ZXAgdGl0bGUuXHJcbiAgICovXHJcbiAgdGl0bGU6IHN0cmluZ1xyXG4gIC8qKlxyXG4gICAqIFVuaXF1ZSBpZGVudGlmaWVyIHVzZWQgZm9yIHJvdXRpbmcgYW5kIGxvb2t1cC5cclxuICAgKi9cclxuICBzbHVnOiBzdHJpbmdcclxuXHQvKipcclxuXHQgKiBJbmRpY2F0ZXMgd2hldGhlciB0aGUgc3RlcCBpcyBjb21wbGV0ZWQuIFRoaXMgY2FuIGJlIHVzZWQgdG8gZW5hYmxlL2Rpc2FibGUgbmF2aWdhdGlvbiBvciBzaG93IHByb2dyZXNzLlxyXG5cdCAqL1xyXG5cdGlzQ29tcGxldGU6IGJvb2xlYW5cclxuICAvKipcclxuICAgKiBPcHRpb25hbCBndWFyZCBleGVjdXRlZCBiZWZvcmUgbGVhdmluZyB0aGUgc3RlcC5cclxuICAgKiBSZXR1cm4gZmFsc2UgdG8gYmxvY2sgbmF2aWdhdGlvbi5cclxuICAgKi9cclxuICBvbkV4aXQ/OiAoY29udGV4dD86IGFueSkgPT4gUHJvbWlzZTxib29sZWFuPiB8IGJvb2xlYW5cclxuICAvKipcclxuICAgKiBPcHRpb25hbCBjb25kaXRpb25hbCB2aXNpYmlsaXR5IHJ1bGUuXHJcbiAgICogSWYgcHJvdmlkZWQsIHRoZSBzdGVwIHdpbGwgb25seSBiZSBpbmNsdWRlZCB3aGVuIHRydWUuXHJcbiAgICovXHJcbiAgY29uZGl0aW9uPzogKGNvbnRleHQ6IFQpID0+IGJvb2xlYW5cclxufSJdfQ==
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l6YXJkLXN0YXRlLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dpbmRvd3MtcGx1cy11dGlsaXRpZXMvbW9kYWwtd2l6YXJkL3V0aWwvaW50ZXJmYWNlL3dpemFyZC1zdGF0ZS5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFN0ZXBEZWZpbml0aW9uIH0gZnJvbSAnLi9zdGVwLWRlZmluaXRpb24uaW50ZXJmYWNlJ1xyXG4vKipcclxuICogQGF1dGhvciBBbGV4IEhvZHNvblxyXG4gKiBAZGVzY3JpcHRpb24gYW4gaW50ZXJmYWNlIGRlZmluaW5nIHRoZSBwcm9wZXJ0aWVzIGZvciB0aGUgd2l6YXJkIG1vZGFsJ3Mgc3RhdGVcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgV2l6YXJkU3RhdGU8VD4ge1xyXG5cdHN0ZXBzOiBTdGVwRGVmaW5pdGlvbjxUPltdXHJcblx0Y3VycmVudEluZGV4OiBudW1iZXJcclxufSJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l6YXJkLXN0YXRlLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dpbmRvd3MtcGx1cy11dGlsaXRpZXMvbW9kYWwtd2l6YXJkL3V0aWwvaW50ZXJmYWNlL3dpemFyZC1zdGF0ZS5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFN0ZXBEZWZpbml0aW9uIH0gZnJvbSAnLi9zdGVwLWRlZmluaXRpb24uaW50ZXJmYWNlJ1xyXG4vKipcclxuICogQGF1dGhvciBBbGV4IEhvZHNvblxyXG4gKiBAZGVzY3JpcHRpb24gYW4gaW50ZXJmYWNlIGRlZmluaW5nIHRoZSBwcm9wZXJ0aWVzIGZvciB0aGUgd2l6YXJkIG1vZGFsJ3Mgc3RhdGVcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgV2l6YXJkU3RhdGU8VD4ge1xyXG4gIC8qKlxyXG4gICAqIE9yZGVyZWQgYWN0aXZlIHN0ZXBzIGluIHRoZSB3aXphcmQuXHJcbiAgICovXHJcbiAgc3RlcHM6IFN0ZXBEZWZpbml0aW9uPFQ+W11cclxuICAvKipcclxuICAgKiBDdXJyZW50IGFjdGl2ZSBzdGVwIGluZGV4LlxyXG4gICAqL1xyXG4gIGN1cnJlbnRJbmRleDogbnVtYmVyXHJcbiAgLyoqXHJcbiAgICogU2hhcmVkIHdpemFyZCBjb250ZXh0IG9iamVjdC5cclxuICAgKi9cclxuICBjb250ZXh0OiBUXHJcbn0iXX0=
@@ -1,140 +1,145 @@
1
1
  import { Injectable } from '@angular/core';
2
- import { BehaviorSubject, map } from 'rxjs';
2
+ import { BehaviorSubject } from 'rxjs';
3
+ import { map } from 'rxjs/operators';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "@angular/router";
5
6
  /**
6
- * A finite state machine service used to manage wizard-style step navigation.
7
+ * Generic reusable wizard step controller.
7
8
  *
8
- * This service maintains an immutable list of {@link StepDefinition} objects and
9
- * tracks the current active step index internally. It exposes reactive streams
10
- * for step data and navigation state, and coordinates router navigation when
11
- * transitions occur.
9
+ * Handles:
10
+ * - Navigation
11
+ * - Conditional step resolution
12
+ * - Dynamic step insertion/removal
13
+ * - Context persistence
14
+ * - Router synchronization
12
15
  *
13
- * The service is intentionally component-scoped and must be provided at the
14
- * component level. Each wizard instance should create and initialize its own
15
- * service instance.
16
- *
17
- * @typeParam T - The type used for step parameter definitions.
16
+ * @template T The shared wizard context type.
18
17
  */
19
18
  export class WizardStepService {
20
- /**
21
- * Creates a new WizardStepService instance.
22
- *
23
- * @param router - Angular Router used to update the URL when step changes occur.
24
- * @param activatedRoute - The current route used as the relative base for navigation.
25
- */
26
19
  constructor(router, activatedRoute) {
27
20
  this.router = router;
28
21
  this.activatedRoute = activatedRoute;
29
22
  /**
30
- * Internal state container for the wizard.
31
- *
32
- * Holds the ordered step definitions and the currently active index.
33
- * A `null` value indicates the wizard has not yet been initialized.
23
+ * Internal wizard state container.
34
24
  */
35
25
  this.state$ = new BehaviorSubject(null);
36
26
  /**
37
- * Emits whether forward navigation is currently allowed.
38
- *
39
- * This can be controlled externally (e.g., form validity).
27
+ * Controls whether forward navigation is allowed.
40
28
  */
41
29
  this.stepForwardAvailability$ = new BehaviorSubject(false);
42
30
  }
43
31
  /**
44
- * Initializes the wizard with an ordered list of step definitions.
45
- *
46
- * This method must be called before navigation methods are used.
47
- * It resets the wizard state and navigates to the first step.
32
+ * Initializes the wizard.
48
33
  *
49
- * @param steps - The ordered collection of step definitions.
34
+ * @param factory The step factory defining the wizard flow.
35
+ * @param initialContext Initial shared context object.
50
36
  */
51
- initialize(steps) {
37
+ initialize(factory, initialContext, onComplete) {
38
+ this.factory = factory;
39
+ this.completionHandler = onComplete;
40
+ const steps = factory.build(initialContext);
52
41
  this.state$.next({
53
- steps: [...steps], // defensive copy
54
- currentIndex: 0
42
+ steps,
43
+ currentIndex: 0,
44
+ context: initialContext
55
45
  });
56
46
  this.navigate();
57
47
  }
58
48
  /**
59
- * Returns the currently active step synchronously.
60
- *
61
- * @returns The active {@link StepDefinition}, or `null` if not initialized.
49
+ * Returns the current step synchronously.
62
50
  */
63
51
  getCurrentStep() {
64
- return this.state$.value?.steps[this.state$.value.currentIndex] ?? null;
52
+ const state = this.state$.value;
53
+ if (!state)
54
+ return null;
55
+ return state.steps[state.currentIndex] ?? null;
65
56
  }
66
57
  /**
67
- * Emits the currently active step whenever the wizard state changes.
68
- *
69
- * @returns Observable stream of the active step or `null` if uninitialized.
58
+ * Observable stream of current step.
70
59
  */
71
60
  getCurrentStep$() {
72
61
  return this.state$.pipe(map(state => state ? state.steps[state.currentIndex] : null));
73
62
  }
74
63
  /**
75
- * Emits the full ordered list of wizard steps.
76
- *
77
- * @returns Observable stream of step definitions.
64
+ * Observable stream of all active steps.
78
65
  */
79
66
  getSteps$() {
80
67
  return this.state$.pipe(map(state => state?.steps ?? []));
81
68
  }
82
69
  /**
83
- * Emits the current active step index.
84
- *
85
- * @returns Observable stream of the current index (0-based).
70
+ * Observable stream of the current index.
86
71
  */
87
72
  getCurrentIndex$() {
88
73
  return this.state$.pipe(map(state => state?.currentIndex ?? 0));
89
74
  }
90
75
  /**
91
- * Attempts to transition to the next step.
76
+ * Returns the shared wizard context.
77
+ */
78
+ getContext() {
79
+ return this.state$.value?.context ?? null;
80
+ }
81
+ /**
82
+ * Advances to the next step.
92
83
  *
93
- * If the current step defines an `onExit` guard, it will be executed before
94
- * transitioning. If the guard returns `false` (or resolves to `false`),
95
- * the transition is cancelled.
84
+ * Executes:
85
+ * - onExit guard
86
+ * - context merge
87
+ * - step recomposition
88
+ * - navigation
96
89
  *
97
- * @param context - Optional contextual data passed to the `onExit` guard.
90
+ * @param partialContext Optional context updates.
91
+ * @param completionProcedure Optional procedure to run when the wizard is completed.
98
92
  */
99
- async next(context) {
93
+ async next(partialContext) {
100
94
  const state = this.state$.value;
101
- if (!state)
95
+ if (!state || !this.factory)
102
96
  return;
103
97
  const current = state.steps[state.currentIndex];
98
+ const updatedContext = {
99
+ ...state.context,
100
+ ...partialContext
101
+ };
102
+ // Run exit guard
104
103
  if (current.onExit) {
105
- const allowed = await current.onExit(context);
104
+ const allowed = await current.onExit(updatedContext);
106
105
  if (!allowed)
107
106
  return;
108
107
  }
109
- if (state.currentIndex < state.steps.length - 1) {
110
- this.state$.next({
111
- ...state,
112
- currentIndex: state.currentIndex + 1
113
- });
114
- this.navigate();
108
+ // 🔥 Re-resolve steps AFTER context update
109
+ const resolved = this.factory.build(updatedContext);
110
+ const currentSlug = current.slug;
111
+ const newIndex = resolved.findIndex(s => s.slug === currentSlug);
112
+ const isLastAfterResolution = newIndex === resolved.length - 1;
113
+ // If last after re-evaluation → complete
114
+ if (isLastAfterResolution) {
115
+ await this.completionHandler?.(updatedContext);
116
+ return;
115
117
  }
118
+ // Otherwise move forward
119
+ this.state$.next({
120
+ steps: resolved,
121
+ currentIndex: newIndex + 1,
122
+ context: updatedContext
123
+ });
124
+ this.navigate();
116
125
  }
117
126
  /**
118
- * Moves the wizard to the previous step if possible.
119
- *
120
- * No guards are executed during backward navigation.
127
+ * Navigates to the previous step.
121
128
  */
122
129
  previous() {
123
130
  const state = this.state$.value;
124
131
  if (!state)
125
132
  return;
126
- if (state.currentIndex > 0) {
127
- this.state$.next({
128
- ...state,
129
- currentIndex: state.currentIndex - 1
130
- });
131
- this.navigate();
132
- }
133
+ if (state.currentIndex === 0)
134
+ return;
135
+ this.state$.next({
136
+ ...state,
137
+ currentIndex: state.currentIndex - 1
138
+ });
139
+ this.navigate();
133
140
  }
134
141
  /**
135
- * Determines whether the current step is the final step.
136
- *
137
- * @returns `true` if on the last step; otherwise `false`.
142
+ * Returns whether the wizard is currently on the last step.
138
143
  */
139
144
  isLast() {
140
145
  const state = this.state$.value;
@@ -143,30 +148,19 @@ export class WizardStepService {
143
148
  return state.currentIndex === state.steps.length - 1;
144
149
  }
145
150
  /**
146
- * Sets whether forward navigation is currently permitted.
147
- *
148
- * This is typically controlled by external validation logic (e.g., form state).
149
- *
150
- * @param available - `true` if forward navigation should be allowed.
151
+ * Sets forward navigation availability.
151
152
  */
152
153
  setStepForwardAvailability(available) {
153
154
  this.stepForwardAvailability$.next(available);
154
155
  }
155
156
  /**
156
- * Emits the forward navigation availability state.
157
- *
158
- * @returns Observable stream of the forward navigation flag.
157
+ * Returns observable forward navigation state.
159
158
  */
160
159
  getStepForwardAvailability() {
161
160
  return this.stepForwardAvailability$.asObservable();
162
161
  }
163
162
  /**
164
- * Navigates the router to the currently active step.
165
- *
166
- * This method updates the URL relative to the injected route
167
- * using the pattern: `step-{slug}`.
168
- *
169
- * @internal
163
+ * Navigates the Angular router to the current step.
170
164
  */
171
165
  navigate() {
172
166
  const step = this.getCurrentStep();
@@ -174,20 +168,10 @@ export class WizardStepService {
174
168
  return;
175
169
  this.router.navigate([`step-${step.slug}`], { relativeTo: this.activatedRoute });
176
170
  }
177
- /**
178
- * Navigates the router away from any "step" route.
179
- *
180
- * This methods updates the URL relative to the injected route, removing every after `/step-
181
- */
182
- clearStepRoute() {
183
- const url = this.router.url;
184
- const [initial] = url.split('/step-');
185
- this.router.navigate([initial]);
186
- }
187
171
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: WizardStepService, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Injectable }); }
188
172
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: WizardStepService }); }
189
173
  }
190
174
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: WizardStepService, decorators: [{
191
175
  type: Injectable
192
176
  }], ctorParameters: () => [{ type: i1.Router }, { type: i1.ActivatedRoute }] });
193
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l6YXJkLXN0ZXAuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dpbmRvd3MtcGx1cy11dGlsaXRpZXMvbW9kYWwtd2l6YXJkL3V0aWwvc2VydmljZS93aXphcmQtc3RlcC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFFMUMsT0FBTyxFQUFFLGVBQWUsRUFBYyxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUE7OztBQUd2RDs7Ozs7Ozs7Ozs7OztHQWFHO0FBRUgsTUFBTSxPQUFPLGlCQUFpQjtJQWlCN0I7Ozs7O09BS0c7SUFDSCxZQUNTLE1BQWMsRUFDZCxjQUE4QjtRQUQ5QixXQUFNLEdBQU4sTUFBTSxDQUFRO1FBQ2QsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBdkJ2Qzs7Ozs7V0FLRztRQUNLLFdBQU0sR0FBRyxJQUFJLGVBQWUsQ0FBd0IsSUFBSSxDQUFDLENBQUE7UUFFakU7Ozs7V0FJRztRQUNLLDZCQUF3QixHQUFHLElBQUksZUFBZSxDQUFVLEtBQUssQ0FBQyxDQUFBO0lBV2xFLENBQUM7SUFFTDs7Ozs7OztPQU9HO0lBQ0gsVUFBVSxDQUFDLEtBQTBCO1FBQ3BDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDO1lBQ2hCLEtBQUssRUFBRSxDQUFDLEdBQUcsS0FBSyxDQUFDLEVBQUUsaUJBQWlCO1lBQ3BDLFlBQVksRUFBRSxDQUFDO1NBQ2YsQ0FBQyxDQUFBO1FBRUYsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFBO0lBQ2hCLENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsY0FBYztRQUNiLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxJQUFJLElBQUksQ0FBQTtJQUN4RSxDQUFD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QUcsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFBO1FBQ2xDLElBQUksQ0FBQyxJQUFJO1lBQUUsT0FBTTtRQUVqQixJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FDbkIsQ0FBQyxRQUFRLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxFQUNyQixFQUFFLFVBQVUsRUFBRSxJQUFJLENBQUMsY0FBYyxFQUFFLENBQ25DLENBQUE7SUFDRixDQUFDO0lBQ0Q7Ozs7T0FJRztJQUNILGNBQWM7UUFDYixNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQTtRQUMzQixNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQTtRQUNyQyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUE7SUFDaEMsQ0FBQzs4R0FuTVcsaUJBQWlCO2tIQUFqQixpQkFBaUI7OzJGQUFqQixpQkFBaUI7a0JBRDdCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcclxuaW1wb3J0IHsgUm91dGVyLCBBY3RpdmF0ZWRSb3V0ZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcidcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlLCBtYXAgfSBmcm9tICdyeGpzJ1xyXG5pbXBvcnQgeyBTdGVwRGVmaW5pdGlvbiB9IGZyb20gJy4uL2ludGVyZmFjZS9zdGVwLWRlZmluaXRpb24uaW50ZXJmYWNlJ1xyXG5pbXBvcnQgeyBXaXphcmRTdGF0ZSB9IGZyb20gJy4uL2ludGVyZmFjZS93aXphcmQtc3RhdGUuaW50ZXJmYWNlJ1xyXG4vKipcclxuICogQSBmaW5pdGUgc3RhdGUgbWFjaGluZSBzZXJ2aWNlIHVzZWQgdG8gbWFuYWdlIHdpemFyZC1zdHlsZSBzdGVwIG5hdmlnYXRpb24uXHJcbiAqXHJcbiAqIFRoaXMgc2VydmljZSBtYWludGFpbnMgYW4gaW1tdXRhYmxlIGxpc3Qgb2Yge0BsaW5rIFN0ZXBEZWZpbml0aW9ufSBvYmplY3RzIGFuZFxyXG4gKiB0cmFja3MgdGhlIGN1cnJlbnQgYWN0aXZlIHN0ZXAgaW5kZXggaW50ZXJuYWxseS4gSXQgZXhwb3NlcyByZWFjdGl2ZSBzdHJlYW1zXHJcbiAqIGZvciBzdGVwIGRhdGEgYW5kIG5hdmlnYXRpb24gc3RhdGUsIGFuZCBjb29yZGluYXRlcyByb3V0ZXIgbmF2aWdhdGlvbiB3aGVuXHJcbiAqIHRyYW5zaXRpb25zIG9jY3VyLlxyXG4gKlxyXG4gKiBUaGUgc2VydmljZSBpcyBpbnRlbnRpb25hbGx5IGNvbXBvbmVudC1zY29wZWQgYW5kIG11c3QgYmUgcHJvdmlkZWQgYXQgdGhlXHJcbiAqIGNvbXBvbmVudCBsZXZlbC4gRWFjaCB3aXphcmQgaW5zdGFuY2Ugc2hvdWxkIGNyZWF0ZSBhbmQgaW5pdGlhbGl6ZSBpdHMgb3duXHJcbiAqIHNlcnZpY2UgaW5zdGFuY2UuXHJcbiAqXHJcbiAqIEB0eXBlUGFyYW0gVCAtIFRoZSB0eXBlIHVzZWQgZm9yIHN0ZXAgcGFyYW1ldGVyIGRlZmluaXRpb25zLlxyXG4gKi9cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgV2l6YXJkU3RlcFNlcnZpY2U8VD4ge1xyXG5cclxuXHQvKipcclxuXHQgKiBJbnRlcm5hbCBzdGF0ZSBjb250YWluZXIgZm9yIHRoZSB3aXphcmQuXHJcblx0ICpcclxuXHQgKiBIb2xkcyB0aGUgb3JkZXJlZCBzdGVwIGRlZmluaXRpb25zIGFuZCB0aGUgY3VycmVudGx5IGFjdGl2ZSBpbmRleC5cclxuXHQgKiBBIGBudWxsYCB2YWx1ZSBpbmRpY2F0ZXMgdGhlIHdpemFyZCBoYXMgbm90IHlldCBiZWVuIGluaXRpYWxpemVkLlxyXG5cdCAqL1xyXG5cdHByaXZhdGUgc3RhdGUkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxXaXphcmRTdGF0ZTxUPiB8IG51bGw+KG51bGwpXHJcblxyXG5cdC8qKlxyXG5cdCAqIEVtaXRzIHdoZXRoZXIgZm9yd2FyZCBuYXZpZ2F0aW9uIGlzIGN1cnJlbnRseSBhbGxvd2VkLlxyXG5cdCAqXHJcblx0ICogVGhpcyBjYW4gYmUgY29udHJvbGxlZCBleHRlcm5hbGx5IChlLmcuLCBmb3JtIHZhbGlkaXR5KS5cclxuXHQgKi9cclxuXHRwcml2YXRlIHN0ZXBGb3J3YXJkQXZhaWxhYmlsaXR5JCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4oZmFsc2UpXHJcblxyXG5cdC8qKlxyXG5cdCAqIENyZWF0ZXMgYSBuZXcgV2l6YXJkU3RlcFNlcnZpY2UgaW5zdGFuY2UuXHJcblx0ICpcclxuXHQgKiBAcGFyYW0gcm91dGVyIC0gQW5ndWxhciBSb3V0ZXIgdXNlZCB0byB1cGRhdGUgdGhlIFVSTCB3aGVuIHN0ZXAgY2hhbmdlcyBvY2N1ci5cclxuXHQgKiBAcGFyYW0gYWN0aXZhdGVkUm91dGUgLSBUaGUgY3VycmVudCByb3V0ZSB1c2VkIGFzIHRoZSByZWxhdGl2ZSBiYXNlIGZvciBuYXZpZ2F0aW9uLlxyXG5cdCAqL1xyXG5cdGNvbnN0cnVjdG9yKFxyXG5cdFx0cHJpdmF0ZSByb3V0ZXI6IFJvdXRlcixcclxuXHRcdHByaXZhdGUgYWN0aXZhdGVkUm91dGU6IEFjdGl2YXRlZFJvdXRlXHJcblx0KSB7IH1cclxuXHJcblx0LyoqXHJcblx0ICogSW5pdGlhbGl6ZXMgdGhlIHdpemFyZCB3aXRoIGFuIG9yZGVyZWQgbGlzdCBvZiBzdGVwIGRlZmluaXRpb25zLlxyXG5cdCAqXHJcblx0ICogVGhpcyBtZXRob2QgbXVzdCBiZSBjYWxsZWQgYmVmb3JlIG5hdmlnYXRpb24gbWV0aG9kcyBhcmUgdXNlZC5cclxuXHQgKiBJdCByZXNldHMgdGhlIHdpemFyZCBzdGF0ZSBhbmQgbmF2aWdhdGVzIHRvIHRoZSBmaXJzdCBzdGVwLlxyXG5cdCAqXHJcblx0ICogQHBhcmFtIHN0ZXBzIC0gVGhlIG9yZGVyZWQgY29sbGVjdGlvbiBvZiBzdGVwIGRlZmluaXRpb25zLlxyXG5cdCAqL1xyXG5cdGluaXRpYWxpemUoc3RlcHM6IFN0ZXBEZWZpbml0aW9uPFQ+W10pOiB2b2lkIHtcclxuXHRcdHRoaXMuc3RhdGUkLm5leHQoe1xyXG5cdFx0XHRzdGVwczogWy4uLnN0ZXBzXSwgLy8gZGVmZW5zaXZlIGNvcHlcclxuXHRcdFx0Y3VycmVudEluZGV4OiAwXHJcblx0XHR9KVxyXG5cclxuXHRcdHRoaXMubmF2aWdhdGUoKVxyXG5cdH1cclxuXHJcblx0LyoqXHJcblx0ICogUmV0dXJucyB0aGUgY3VycmVudGx5IGFjdGl2ZSBzdGVwIHN5bmNocm9ub3VzbHkuXHJcblx0ICpcclxuXHQgKiBAcmV0dXJucyBUaGUgYWN0aXZlIHtAbGluayBTdGVwRGVmaW5pdGlvbn0sIG9yIGBudWxsYCBpZiBub3QgaW5pdGlhbGl6ZWQuXHJcblx0ICovXHJcblx0Z2V0Q3VycmVudFN0ZXAoKTogU3RlcERlZmluaXRpb248VD4gfCBudWxsIHtcclxuXHRcdHJldHVybiB0aGlzLnN0YXRlJC52YWx1ZT8uc3RlcHNbdGhpcy5zdGF0ZSQudmFsdWUuY3VycmVudEluZGV4XSA/PyBudWxsXHJcblx0fVxyXG5cclxuXHQvKipcclxuXHQgKiBFbWl0cyB0aGUgY3VycmVudGx5IGFjdGl2ZSBzdGVwIHdoZW5ldmVyIHRoZSB3aXphcmQgc3RhdGUgY2hhbmdlcy5cclxuXHQgKlxyXG5cdCAqIEByZXR1cm5zIE9ic2VydmFibGUgc3RyZWFtIG9mIHRoZSBhY3RpdmUgc3RlcCBvciBgbnVsbGAgaWYgdW5pbml0aWFsaXplZC5cclxuXHQgKi9cclxuXHRnZXRDdXJyZW50U3RlcCQoKTogT2JzZXJ2YWJsZTxTdGVwRGVmaW5pdGlvbjxUPiB8IG51bGw+IHtcclxuXHRcdHJldHVybiB0aGlzLnN0YXRlJC5waXBlKFxyXG5cdFx0XHRtYXAoc3RhdGUgPT5cclxuXHRcdFx0XHRzdGF0ZSA/IHN0YXRlLnN0ZXBzW3N0YXRlLmN1cnJlbnRJbmRleF0gOiBudWxsXHJcblx0XHRcdClcclxuXHRcdClcclxuXHR9XHJcblxyXG5cdC8qKlxyXG5cdCAqIEVtaXRzIHRoZSBmdWxsIG9yZGVyZWQgbGlzdCBvZiB3aXphcmQgc3RlcHMuXHJcblx0ICpcclxuXHQgKiBAcmV0dXJucyBPYnNlcnZhYmxlIHN0cmVhbSBvZiBzdGVwIGRlZmluaXRpb25zLlxyXG5cdCAqL1xyXG5cdGdldFN0ZXBzJCgpOiBPYnNlcnZhYmxlPFN0ZXBEZWZpbml0aW9uPFQ+W10+IHtcclxuXHRcdHJldHVybiB0aGlzLnN0YXRlJC5waXBlKFxyXG5cdFx0XHRtYXAoc3RhdGUgPT4gc3RhdGU/LnN0ZXBzID8/IFtdKVxyXG5cdFx0KVxyXG5cdH1cclxuXHJcblx0LyoqXHJcblx0ICogRW1pdHMgdGhlIGN1cnJlbnQgYWN0aXZlIHN0ZXAgaW5kZXguXHJcblx0ICpcclxuXHQgKiBAcmV0dXJucyBPYnNlcnZhYmxlIHN0cmVhbSBvZiB0aGUgY3VycmVudCBpbmRleCAoMC1iYXNlZCkuXHJcblx0ICovXHJcblx0Z2V0Q3VycmVudEluZGV4JCgpOiBPYnNlcnZhYmxlPG51bWJlcj4ge1xyXG5cdFx0cmV0dXJuIHRoaXMuc3RhdGUkLnBpcGUoXHJcblx0XHRcdG1hcChzdGF0ZSA9PiBzdGF0ZT8uY3VycmVudEluZGV4ID8/IDApXHJcblx0XHQpXHJcblx0fVxyXG5cclxuXHQvKipcclxuXHQgKiBBdHRlbXB0cyB0byB0cmFuc2l0aW9uIHRvIHRoZSBuZXh0IHN0ZXAuXHJcblx0ICpcclxuXHQgKiBJZiB0aGUgY3VycmVudCBzdGVwIGRlZmluZXMgYW4gYG9uRXhpdGAgZ3VhcmQsIGl0IHdpbGwgYmUgZXhlY3V0ZWQgYmVmb3JlXHJcblx0ICogdHJhbnNpdGlvbmluZy4gSWYgdGhlIGd1YXJkIHJldHVybnMgYGZhbHNlYCAob3IgcmVzb2x2ZXMgdG8gYGZhbHNlYCksXHJcblx0ICogdGhlIHRyYW5zaXRpb24gaXMgY2FuY2VsbGVkLlxyXG5cdCAqXHJcblx0ICogQHBhcmFtIGNvbnRleHQgLSBPcHRpb25hbCBjb250ZXh0dWFsIGRhdGEgcGFzc2VkIHRvIHRoZSBgb25FeGl0YCBndWFyZC5cclxuXHQgKi9cclxuXHRhc3luYyBuZXh0KGNvbnRleHQ/OiBhbnkpOiBQcm9taXNlPHZvaWQ+IHtcclxuXHRcdGNvbnN0IHN0YXRlID0gdGhpcy5zdGF0ZSQudmFsdWVcclxuXHRcdGlmICghc3RhdGUpIHJldHVyblxyXG5cclxuXHRcdGNvbnN0IGN1cnJlbnQgPSBzdGF0ZS5zdGVwc1tzdGF0ZS5jdXJyZW50SW5kZXhdXHJcblxyXG5cdFx0aWYgKGN1cnJlbnQub25FeGl0KSB7XHJcblx0XHRcdGNvbnN0IGFsbG93ZWQgPSBhd2FpdCBjdXJyZW50Lm9uRXhpdChjb250ZXh0KVxyXG5cdFx0XHRpZiAoIWFsbG93ZWQpIHJldHVyblxyXG5cdFx0fVxyXG5cclxuXHRcdGlmIChzdGF0ZS5jdXJyZW50SW5kZXggPCBzdGF0ZS5zdGVwcy5sZW5ndGggLSAxKSB7XHJcblx0XHRcdHRoaXMuc3RhdGUkLm5leHQoe1xyXG5cdFx0XHRcdC4uLnN0YXRlLFxyXG5cdFx0XHRcdGN1cnJlbnRJbmRleDogc3RhdGUuY3VycmVudEluZGV4ICsgMVxyXG5cdFx0XHR9KVxyXG5cclxuXHRcdFx0dGhpcy5uYXZpZ2F0ZSgpXHJcblx0XHR9XHJcblx0fVxyXG5cclxuXHQvKipcclxuXHQgKiBNb3ZlcyB0aGUgd2l6YXJkIHRvIHRoZSBwcmV2aW91cyBzdGVwIGlmIHBvc3NpYmxlLlxyXG5cdCAqXHJcblx0ICogTm8gZ3VhcmRzIGFyZSBleGVjdXRlZCBkdXJpbmcgYmFja3dhcmQgbmF2aWdhdGlvbi5cclxuXHQgKi9cclxuXHRwcmV2aW91cygpOiB2b2lkIHtcclxuXHRcdGNvbnN0IHN0YXRlID0gdGhpcy5zdGF0ZSQudmFsdWVcclxuXHRcdGlmICghc3RhdGUpIHJldHVyblxyXG5cclxuXHRcdGlmIChzdGF0ZS5jdXJyZW50SW5kZXggPiAwKSB7XHJcblx0XHRcdHRoaXMuc3RhdGUkLm5leHQoe1xyXG5cdFx0XHRcdC4uLnN0YXRlLFxyXG5cdFx0XHRcdGN1cnJlbnRJbmRleDogc3RhdGUuY3VycmVudEluZGV4IC0gMVxyXG5cdFx0XHR9KVxyXG5cclxuXHRcdFx0dGhpcy5uYXZpZ2F0ZSgpXHJcblx0XHR9XHJcblx0fVxyXG5cclxuXHQvKipcclxuXHQgKiBEZXRlcm1pbmVzIHdoZXRoZXIgdGhlIGN1cnJlbnQgc3RlcCBpcyB0aGUgZmluYWwgc3RlcC5cclxuXHQgKlxyXG5cdCAqIEByZXR1cm5zIGB0cnVlYCBpZiBvbiB0aGUgbGFzdCBzdGVwOyBvdGhlcndpc2UgYGZhbHNlYC5cclxuXHQgKi9cclxuXHRpc0xhc3QoKTogYm9vbGVhbiB7XHJcblx0XHRjb25zdCBzdGF0ZSA9IHRoaXMuc3RhdGUkLnZhbHVlXHJcblx0XHRpZiAoIXN0YXRlKSByZXR1cm4gZmFsc2VcclxuXHRcdHJldHVybiBzdGF0ZS5jdXJyZW50SW5kZXggPT09IHN0YXRlLnN0ZXBzLmxlbmd0aCAtIDFcclxuXHR9XHJcblxyXG5cdC8qKlxyXG5cdCAqIFNldHMgd2hldGhlciBmb3J3YXJkIG5hdmlnYXRpb24gaXMgY3VycmVudGx5IHBlcm1pdHRlZC5cclxuXHQgKlxyXG5cdCAqIFRoaXMgaXMgdHlwaWNhbGx5IGNvbnRyb2xsZWQgYnkgZXh0ZXJuYWwgdmFsaWRhdGlvbiBsb2dpYyAoZS5nLiwgZm9ybSBzdGF0ZSkuXHJcblx0ICpcclxuXHQgKiBAcGFyYW0gYXZhaWxhYmxlIC0gYHRydWVgIGlmIGZvcndhcmQgbmF2aWdhdGlvbiBzaG91bGQgYmUgYWxsb3dlZC5cclxuXHQgKi9cclxuXHRzZXRTdGVwRm9yd2FyZEF2YWlsYWJpbGl0eShhdmFpbGFibGU6IGJvb2xlYW4pOiB2b2lkIHtcclxuXHRcdHRoaXMuc3RlcEZvcndhcmRBdmFpbGFiaWxpdHkkLm5leHQoYXZhaWxhYmxlKVxyXG5cdH1cclxuXHJcblx0LyoqXHJcblx0ICogRW1pdHMgdGhlIGZvcndhcmQgbmF2aWdhdGlvbiBhdmFpbGFiaWxpdHkgc3RhdGUuXHJcblx0ICpcclxuXHQgKiBAcmV0dXJucyBPYnNlcnZhYmxlIHN0cmVhbSBvZiB0aGUgZm9yd2FyZCBuYXZpZ2F0aW9uIGZsYWcuXHJcblx0ICovXHJcblx0Z2V0U3RlcEZvcndhcmRBdmFpbGFiaWxpdHkoKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XHJcblx0XHRyZXR1cm4gdGhpcy5zdGVwRm9yd2FyZEF2YWlsYWJpbGl0eSQuYXNPYnNlcnZhYmxlKClcclxuXHR9XHJcblxyXG5cdC8qKlxyXG5cdCAqIE5hdmlnYXRlcyB0aGUgcm91dGVyIHRvIHRoZSBjdXJyZW50bHkgYWN0aXZlIHN0ZXAuXHJcblx0ICpcclxuXHQgKiBUaGlzIG1ldGhvZCB1cGRhdGVzIHRoZSBVUkwgcmVsYXRpdmUgdG8gdGhlIGluamVjdGVkIHJvdXRlXHJcblx0ICogdXNpbmcgdGhlIHBhdHRlcm46IGBzdGVwLXtzbHVnfWAuXHJcblx0ICpcclxuXHQgKiBAaW50ZXJuYWxcclxuXHQgKi9cclxuXHRwcml2YXRlIG5hdmlnYXRlKCk6IHZvaWQge1xyXG5cdFx0Y29uc3Qgc3RlcCA9IHRoaXMuZ2V0Q3VycmVudFN0ZXAoKVxyXG5cdFx0aWYgKCFzdGVwKSByZXR1cm5cclxuXHJcblx0XHR0aGlzLnJvdXRlci5uYXZpZ2F0ZShcclxuXHRcdFx0W2BzdGVwLSR7c3RlcC5zbHVnfWBdLFxyXG5cdFx0XHR7IHJlbGF0aXZlVG86IHRoaXMuYWN0aXZhdGVkUm91dGUgfVxyXG5cdFx0KVxyXG5cdH1cclxuXHQvKipcclxuXHQgKiBOYXZpZ2F0ZXMgdGhlIHJvdXRlciBhd2F5IGZyb20gYW55IFwic3RlcFwiIHJvdXRlLlxyXG5cdCAqIFxyXG5cdCAqIFRoaXMgbWV0aG9kcyB1cGRhdGVzIHRoZSBVUkwgcmVsYXRpdmUgdG8gdGhlIGluamVjdGVkIHJvdXRlLCByZW1vdmluZyBldmVyeSBhZnRlciBgL3N0ZXAtXHJcblx0ICovXHJcblx0Y2xlYXJTdGVwUm91dGUoKTogdm9pZCB7XHJcblx0XHRjb25zdCB1cmwgPSB0aGlzLnJvdXRlci51cmxcclxuXHRcdGNvbnN0IFtpbml0aWFsXSA9IHVybC5zcGxpdCgnL3N0ZXAtJylcclxuXHRcdHRoaXMucm91dGVyLm5hdmlnYXRlKFtpbml0aWFsXSlcclxuXHR9XHJcbn1cclxuXHJcbiJdfQ==
177
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l6YXJkLXN0ZXAuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3dpbmRvd3MtcGx1cy11dGlsaXRpZXMvbW9kYWwtd2l6YXJkL3V0aWwvc2VydmljZS93aXphcmQtc3RlcC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFFMUMsT0FBTyxFQUFFLGVBQWUsRUFBYyxNQUFNLE1BQU0sQ0FBQTtBQUNsRCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUE7OztBQUtwQzs7Ozs7Ozs7Ozs7R0FXRztBQUVILE1BQU0sT0FBTyxpQkFBaUI7SUFvQjVCLFlBQ21CLE1BQWMsRUFDZCxjQUE4QjtRQUQ5QixXQUFNLEdBQU4sTUFBTSxDQUFRO1FBQ2QsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBcEJqRDs7V0FFRztRQUNjLFdBQU0sR0FBRyxJQUFJLGVBQWUsQ0FBd0IsSUFBSSxDQUFDLENBQUE7UUFJMUU7O1dBRUc7UUFDYyw2QkFBd0IsR0FDdkMsSUFBSSxlQUFlLENBQVUsS0FBSyxDQUFDLENBQUE7SUFVakMsQ0FBQztJQUVMOzs7OztPQUtHO0lBQ0gsVUFBVSxDQUFDLE9BQTZCLEVBQUUsY0FBaUIsRUFBSSxVQUFnRDtRQUU3RyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQTtRQUN4QixJQUFJLENBQUMsaUJBQWlCLEdBQUcsVUFBVSxDQUFBO1FBRWpDLE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLENBQUE7UUFFM0MsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUM7WUFDZixLQUFLO1lBQ0wsWUFBWSxFQUFFLENBQUM7WUFDZixPQUFPLEVBQUUsY0FBYztTQUN4QixDQUFDLENBQUE7UUFFRixJQUFJLENBQUMsUUFBUSxFQUFFLENBQUE7SUFD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TVUsaUJBQWlCO2tIQUFqQixpQkFBaUI7OzJGQUFqQixpQkFBaUI7a0JBRDdCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcclxuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGUsIFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcidcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcydcclxuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnXHJcbmltcG9ydCB7IFdpemFyZFN0YXRlIH0gZnJvbSAnLi4vaW50ZXJmYWNlL3dpemFyZC1zdGF0ZS5pbnRlcmZhY2UnXHJcbmltcG9ydCB7IFdpemFyZFN0ZXBGYWN0b3J5IH0gZnJvbSAnLi4vZmFjdG9yeS93aXphcmQtc3RlcC1mYWN0b3J5J1xyXG5pbXBvcnQgeyBTdGVwRGVmaW5pdGlvbiB9IGZyb20gJy4uL2ludGVyZmFjZS9zdGVwLWRlZmluaXRpb24uaW50ZXJmYWNlJ1xyXG5cclxuLyoqXHJcbiAqIEdlbmVyaWMgcmV1c2FibGUgd2l6YXJkIHN0ZXAgY29udHJvbGxlci5cclxuICpcclxuICogSGFuZGxlczpcclxuICogLSBOYXZpZ2F0aW9uXHJcbiAqIC0gQ29uZGl0aW9uYWwgc3RlcCByZXNvbHV0aW9uXHJcbiAqIC0gRHluYW1pYyBzdGVwIGluc2VydGlvbi9yZW1vdmFsXHJcbiAqIC0gQ29udGV4dCBwZXJzaXN0ZW5jZVxyXG4gKiAtIFJvdXRlciBzeW5jaHJvbml6YXRpb25cclxuICpcclxuICogQHRlbXBsYXRlIFQgVGhlIHNoYXJlZCB3aXphcmQgY29udGV4dCB0eXBlLlxyXG4gKi9cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgV2l6YXJkU3RlcFNlcnZpY2U8VD4ge1xyXG5cclxuICAvKipcclxuICAgKiBJbnRlcm5hbCB3aXphcmQgc3RhdGUgY29udGFpbmVyLlxyXG4gICAqL1xyXG4gIHByaXZhdGUgcmVhZG9ubHkgc3RhdGUkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxXaXphcmRTdGF0ZTxUPiB8IG51bGw+KG51bGwpXHJcblxyXG5cdHByaXZhdGUgY29tcGxldGlvbkhhbmRsZXI/OiAoY29udGV4dDogVCkgPT4gUHJvbWlzZTx2b2lkPiB8IHZvaWRcclxuXHJcbiAgLyoqXHJcbiAgICogQ29udHJvbHMgd2hldGhlciBmb3J3YXJkIG5hdmlnYXRpb24gaXMgYWxsb3dlZC5cclxuICAgKi9cclxuICBwcml2YXRlIHJlYWRvbmx5IHN0ZXBGb3J3YXJkQXZhaWxhYmlsaXR5JCA9XHJcbiAgICBuZXcgQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+KGZhbHNlKVxyXG5cclxuICAvKipcclxuICAgKiBUaGUgc3RlcCBmYWN0b3J5IHVzZWQgdG8gcmVzb2x2ZSBhY3RpdmUgc3RlcHMuXHJcbiAgICovXHJcbiAgcHJpdmF0ZSBmYWN0b3J5PzogV2l6YXJkU3RlcEZhY3Rvcnk8VD5cclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IHJvdXRlcjogUm91dGVyLFxyXG4gICAgcHJpdmF0ZSByZWFkb25seSBhY3RpdmF0ZWRSb3V0ZTogQWN0aXZhdGVkUm91dGVcclxuICApIHsgfVxyXG5cclxuICAvKipcclxuICAgKiBJbml0aWFsaXplcyB0aGUgd2l6YXJkLlxyXG4gICAqXHJcbiAgICogQHBhcmFtIGZhY3RvcnkgVGhlIHN0ZXAgZmFjdG9yeSBkZWZpbmluZyB0aGUgd2l6YXJkIGZsb3cuXHJcbiAgICogQHBhcmFtIGluaXRpYWxDb250ZXh0IEluaXRpYWwgc2hhcmVkIGNvbnRleHQgb2JqZWN0LlxyXG4gICAqL1xyXG4gIGluaXRpYWxpemUoZmFjdG9yeTogV2l6YXJkU3RlcEZhY3Rvcnk8VD4sIGluaXRpYWxDb250ZXh0OiBULCAgIG9uQ29tcGxldGU6IChjb250ZXh0OiBUKSA9PiBQcm9taXNlPHZvaWQ+IHwgdm9pZFxyXG4pOiB2b2lkIHtcclxuICAgIHRoaXMuZmFjdG9yeSA9IGZhY3RvcnlcclxuXHRcdHRoaXMuY29tcGxldGlvbkhhbmRsZXIgPSBvbkNvbXBsZXRlXHJcblxyXG4gICAgY29uc3Qgc3RlcHMgPSBmYWN0b3J5LmJ1aWxkKGluaXRpYWxDb250ZXh0KVxyXG5cclxuICAgIHRoaXMuc3RhdGUkLm5leHQoe1xyXG4gICAgICBzdGVwcyxcclxuICAgICAgY3VycmVudEluZGV4OiAwLFxyXG4gICAgICBjb250ZXh0OiBpbml0aWFsQ29udGV4dFxyXG4gICAgfSlcclxuXHJcbiAgICB0aGlzLm5hdmlnYXRlKClcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFJldHVybnMgdGhlIGN1cnJlbnQgc3RlcCBzeW5jaHJvbm91c2x5LlxyXG4gICAqL1xyXG4gIGdldEN1cnJlbnRTdGVwKCk6IFN0ZXBEZWZpbml0aW9uPFQ+IHwgbnVsbCB7XHJcbiAgICBjb25zdCBzdGF0ZSA9IHRoaXMuc3RhdGUkLnZhbHVlXHJcbiAgICBpZiAoIXN0YXRlKSByZXR1cm4gbnVsbFxyXG4gICAgcmV0dXJuIHN0YXRlLnN0ZXBzW3N0YXRlLmN1cnJlbnRJbmRleF0gPz8gbnVsbFxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogT2JzZXJ2YWJsZSBzdHJlYW0gb2YgY3VycmVudCBzdGVwLlxyXG4gICAqL1xyXG4gIGdldEN1cnJlbnRTdGVwJCgpOiBPYnNlcnZhYmxlPFN0ZXBEZWZpbml0aW9uPFQ+IHwgbnVsbD4ge1xyXG4gICAgcmV0dXJuIHRoaXMuc3RhdGUkLnBpcGUoXHJcbiAgICAgIG1hcChzdGF0ZSA9PlxyXG4gICAgICAgIHN0YXRlID8gc3RhdGUuc3RlcHNbc3RhdGUuY3VycmVudEluZGV4XSA6IG51bGxcclxuICAgICAgKVxyXG4gICAgKVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogT2JzZXJ2YWJsZSBzdHJlYW0gb2YgYWxsIGFjdGl2ZSBzdGVwcy5cclxuICAgKi9cclxuICBnZXRTdGVwcyQoKTogT2JzZXJ2YWJsZTxTdGVwRGVmaW5pdGlvbjxUPltdPiB7XHJcbiAgICByZXR1cm4gdGhpcy5zdGF0ZSQucGlwZShcclxuICAgICAgbWFwKHN0YXRlID0+IHN0YXRlPy5zdGVwcyA/PyBbXSlcclxuICAgIClcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIE9ic2VydmFibGUgc3RyZWFtIG9mIHRoZSBjdXJyZW50IGluZGV4LlxyXG4gICAqL1xyXG4gIGdldEN1cnJlbnRJbmRleCQoKTogT2JzZXJ2YWJsZTxudW1iZXI+IHtcclxuICAgIHJldHVybiB0aGlzLnN0YXRlJC5waXBlKFxyXG4gICAgICBtYXAoc3RhdGUgPT4gc3RhdGU/LmN1cnJlbnRJbmRleCA/PyAwKVxyXG4gICAgKVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogUmV0dXJucyB0aGUgc2hhcmVkIHdpemFyZCBjb250ZXh0LlxyXG4gICAqL1xyXG4gIGdldENvbnRleHQoKTogVCB8IG51bGwge1xyXG4gICAgcmV0dXJuIHRoaXMuc3RhdGUkLnZhbHVlPy5jb250ZXh0ID8/IG51bGxcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEFkdmFuY2VzIHRvIHRoZSBuZXh0IHN0ZXAuXHJcbiAgICpcclxuICAgKiBFeGVjdXRlczpcclxuICAgKiAtIG9uRXhpdCBndWFyZFxyXG4gICAqIC0gY29udGV4dCBtZXJnZVxyXG4gICAqIC0gc3RlcCByZWNvbXBvc2l0aW9uXHJcbiAgICogLSBuYXZpZ2F0aW9uXHJcbiAgICpcclxuICAgKiBAcGFyYW0gcGFydGlhbENvbnRleHQgT3B0aW9uYWwgY29udGV4dCB1cGRhdGVzLlxyXG4gICAqIEBwYXJhbSBjb21wbGV0aW9uUHJvY2VkdXJlIE9wdGlvbmFsIHByb2NlZHVyZSB0byBydW4gd2hlbiB0aGUgd2l6YXJkIGlzIGNvbXBsZXRlZC5cclxuICAgKi9cclxuIGFzeW5jIG5leHQocGFydGlhbENvbnRleHQ/OiBQYXJ0aWFsPFQ+KTogUHJvbWlzZTx2b2lkPiB7XHJcbiAgY29uc3Qgc3RhdGUgPSB0aGlzLnN0YXRlJC52YWx1ZVxyXG4gIGlmICghc3RhdGUgfHwgIXRoaXMuZmFjdG9yeSkgcmV0dXJuXHJcblxyXG4gIGNvbnN0IGN1cnJlbnQgPSBzdGF0ZS5zdGVwc1tzdGF0ZS5jdXJyZW50SW5kZXhdXHJcblxyXG4gIGNvbnN0IHVwZGF0ZWRDb250ZXh0ID0ge1xyXG4gICAgLi4uc3RhdGUuY29udGV4dCxcclxuICAgIC4uLnBhcnRpYWxDb250ZXh0XHJcbiAgfVxyXG5cclxuICAvLyBSdW4gZXhpdCBndWFyZFxyXG4gIGlmIChjdXJyZW50Lm9uRXhpdCkge1xyXG4gICAgY29uc3QgYWxsb3dlZCA9IGF3YWl0IGN1cnJlbnQub25FeGl0KHVwZGF0ZWRDb250ZXh0KVxyXG4gICAgaWYgKCFhbGxvd2VkKSByZXR1cm5cclxuICB9XHJcblxyXG4gIC8vIPCflKUgUmUtcmVzb2x2ZSBzdGVwcyBBRlRFUiBjb250ZXh0IHVwZGF0ZVxyXG4gIGNvbnN0IHJlc29sdmVkID0gdGhpcy5mYWN0b3J5LmJ1aWxkKHVwZGF0ZWRDb250ZXh0KVxyXG5cclxuICBjb25zdCBjdXJyZW50U2x1ZyA9IGN1cnJlbnQuc2x1Z1xyXG4gIGNvbnN0IG5ld0luZGV4ID0gcmVzb2x2ZWQuZmluZEluZGV4KHMgPT4gcy5zbHVnID09PSBjdXJyZW50U2x1ZylcclxuXHJcbiAgY29uc3QgaXNMYXN0QWZ0ZXJSZXNvbHV0aW9uID1cclxuICAgIG5ld0luZGV4ID09PSByZXNvbHZlZC5sZW5ndGggLSAxXHJcblxyXG4gIC8vIElmIGxhc3QgYWZ0ZXIgcmUtZXZhbHVhdGlvbiDihpIgY29tcGxldGVcclxuICBpZiAoaXNMYXN0QWZ0ZXJSZXNvbHV0aW9uKSB7XHJcbiAgICBhd2FpdCB0aGlzLmNvbXBsZXRpb25IYW5kbGVyPy4odXBkYXRlZENvbnRleHQpXHJcbiAgICByZXR1cm5cclxuICB9XHJcblxyXG4gIC8vIE90aGVyd2lzZSBtb3ZlIGZvcndhcmRcclxuICB0aGlzLnN0YXRlJC5uZXh0KHtcclxuICAgIHN0ZXBzOiByZXNvbHZlZCxcclxuICAgIGN1cnJlbnRJbmRleDogbmV3SW5kZXggKyAxLFxyXG4gICAgY29udGV4dDogdXBkYXRlZENvbnRleHRcclxuICB9KVxyXG5cclxuICB0aGlzLm5hdmlnYXRlKClcclxufVxyXG5cclxuICAvKipcclxuICAgKiBOYXZpZ2F0ZXMgdG8gdGhlIHByZXZpb3VzIHN0ZXAuXHJcbiAgICovXHJcbiAgcHJldmlvdXMoKTogdm9pZCB7XHJcbiAgICBjb25zdCBzdGF0ZSA9IHRoaXMuc3RhdGUkLnZhbHVlXHJcbiAgICBpZiAoIXN0YXRlKSByZXR1cm5cclxuXHJcbiAgICBpZiAoc3RhdGUuY3VycmVudEluZGV4ID09PSAwKSByZXR1cm5cclxuXHJcbiAgICB0aGlzLnN0YXRlJC5uZXh0KHtcclxuICAgICAgLi4uc3RhdGUsXHJcbiAgICAgIGN1cnJlbnRJbmRleDogc3RhdGUuY3VycmVudEluZGV4IC0gMVxyXG4gICAgfSlcclxuXHJcbiAgICB0aGlzLm5hdmlnYXRlKClcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFJldHVybnMgd2hldGhlciB0aGUgd2l6YXJkIGlzIGN1cnJlbnRseSBvbiB0aGUgbGFzdCBzdGVwLlxyXG4gICAqL1xyXG4gIGlzTGFzdCgpOiBib29sZWFuIHtcclxuICAgIGNvbnN0IHN0YXRlID0gdGhpcy5zdGF0ZSQudmFsdWVcclxuICAgIGlmICghc3RhdGUpIHJldHVybiBmYWxzZVxyXG4gICAgcmV0dXJuIHN0YXRlLmN1cnJlbnRJbmRleCA9PT0gc3RhdGUuc3RlcHMubGVuZ3RoIC0gMVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogU2V0cyBmb3J3YXJkIG5hdmlnYXRpb24gYXZhaWxhYmlsaXR5LlxyXG4gICAqL1xyXG4gIHNldFN0ZXBGb3J3YXJkQXZhaWxhYmlsaXR5KGF2YWlsYWJsZTogYm9vbGVhbik6IHZvaWQge1xyXG4gICAgdGhpcy5zdGVwRm9yd2FyZEF2YWlsYWJpbGl0eSQubmV4dChhdmFpbGFibGUpXHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBSZXR1cm5zIG9ic2VydmFibGUgZm9yd2FyZCBuYXZpZ2F0aW9uIHN0YXRlLlxyXG4gICAqL1xyXG4gIGdldFN0ZXBGb3J3YXJkQXZhaWxhYmlsaXR5KCk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xyXG4gICAgcmV0dXJuIHRoaXMuc3RlcEZvcndhcmRBdmFpbGFiaWxpdHkkLmFzT2JzZXJ2YWJsZSgpXHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBOYXZpZ2F0ZXMgdGhlIEFuZ3VsYXIgcm91dGVyIHRvIHRoZSBjdXJyZW50IHN0ZXAuXHJcbiAgICovXHJcbiAgcHJpdmF0ZSBuYXZpZ2F0ZSgpOiB2b2lkIHtcclxuICAgIGNvbnN0IHN0ZXAgPSB0aGlzLmdldEN1cnJlbnRTdGVwKClcclxuICAgIGlmICghc3RlcCkgcmV0dXJuXHJcblxyXG4gICAgdGhpcy5yb3V0ZXIubmF2aWdhdGUoXHJcbiAgICAgIFtgc3RlcC0ke3N0ZXAuc2x1Z31gXSxcclxuICAgICAgeyByZWxhdGl2ZVRvOiB0aGlzLmFjdGl2YXRlZFJvdXRlIH1cclxuICAgIClcclxuICB9XHJcbn0iXX0=
@@ -2,142 +2,147 @@ import * as i0 from '@angular/core';
2
2
  import { Injectable, Component, Inject } from '@angular/core';
3
3
  import * as i2 from '@angular/common';
4
4
  import { CommonModule } from '@angular/common';
5
- import { BehaviorSubject, map } from 'rxjs';
5
+ import { BehaviorSubject } from 'rxjs';
6
+ import { map } from 'rxjs/operators';
6
7
  import * as i1 from '@angular/router';
7
8
 
8
9
  /**
9
- * A finite state machine service used to manage wizard-style step navigation.
10
+ * Generic reusable wizard step controller.
10
11
  *
11
- * This service maintains an immutable list of {@link StepDefinition} objects and
12
- * tracks the current active step index internally. It exposes reactive streams
13
- * for step data and navigation state, and coordinates router navigation when
14
- * transitions occur.
12
+ * Handles:
13
+ * - Navigation
14
+ * - Conditional step resolution
15
+ * - Dynamic step insertion/removal
16
+ * - Context persistence
17
+ * - Router synchronization
15
18
  *
16
- * The service is intentionally component-scoped and must be provided at the
17
- * component level. Each wizard instance should create and initialize its own
18
- * service instance.
19
- *
20
- * @typeParam T - The type used for step parameter definitions.
19
+ * @template T The shared wizard context type.
21
20
  */
22
21
  class WizardStepService {
23
- /**
24
- * Creates a new WizardStepService instance.
25
- *
26
- * @param router - Angular Router used to update the URL when step changes occur.
27
- * @param activatedRoute - The current route used as the relative base for navigation.
28
- */
29
22
  constructor(router, activatedRoute) {
30
23
  this.router = router;
31
24
  this.activatedRoute = activatedRoute;
32
25
  /**
33
- * Internal state container for the wizard.
34
- *
35
- * Holds the ordered step definitions and the currently active index.
36
- * A `null` value indicates the wizard has not yet been initialized.
26
+ * Internal wizard state container.
37
27
  */
38
28
  this.state$ = new BehaviorSubject(null);
39
29
  /**
40
- * Emits whether forward navigation is currently allowed.
41
- *
42
- * This can be controlled externally (e.g., form validity).
30
+ * Controls whether forward navigation is allowed.
43
31
  */
44
32
  this.stepForwardAvailability$ = new BehaviorSubject(false);
45
33
  }
46
34
  /**
47
- * Initializes the wizard with an ordered list of step definitions.
48
- *
49
- * This method must be called before navigation methods are used.
50
- * It resets the wizard state and navigates to the first step.
35
+ * Initializes the wizard.
51
36
  *
52
- * @param steps - The ordered collection of step definitions.
37
+ * @param factory The step factory defining the wizard flow.
38
+ * @param initialContext Initial shared context object.
53
39
  */
54
- initialize(steps) {
40
+ initialize(factory, initialContext, onComplete) {
41
+ this.factory = factory;
42
+ this.completionHandler = onComplete;
43
+ const steps = factory.build(initialContext);
55
44
  this.state$.next({
56
- steps: [...steps], // defensive copy
57
- currentIndex: 0
45
+ steps,
46
+ currentIndex: 0,
47
+ context: initialContext
58
48
  });
59
49
  this.navigate();
60
50
  }
61
51
  /**
62
- * Returns the currently active step synchronously.
63
- *
64
- * @returns The active {@link StepDefinition}, or `null` if not initialized.
52
+ * Returns the current step synchronously.
65
53
  */
66
54
  getCurrentStep() {
67
- return this.state$.value?.steps[this.state$.value.currentIndex] ?? null;
55
+ const state = this.state$.value;
56
+ if (!state)
57
+ return null;
58
+ return state.steps[state.currentIndex] ?? null;
68
59
  }
69
60
  /**
70
- * Emits the currently active step whenever the wizard state changes.
71
- *
72
- * @returns Observable stream of the active step or `null` if uninitialized.
61
+ * Observable stream of current step.
73
62
  */
74
63
  getCurrentStep$() {
75
64
  return this.state$.pipe(map(state => state ? state.steps[state.currentIndex] : null));
76
65
  }
77
66
  /**
78
- * Emits the full ordered list of wizard steps.
79
- *
80
- * @returns Observable stream of step definitions.
67
+ * Observable stream of all active steps.
81
68
  */
82
69
  getSteps$() {
83
70
  return this.state$.pipe(map(state => state?.steps ?? []));
84
71
  }
85
72
  /**
86
- * Emits the current active step index.
87
- *
88
- * @returns Observable stream of the current index (0-based).
73
+ * Observable stream of the current index.
89
74
  */
90
75
  getCurrentIndex$() {
91
76
  return this.state$.pipe(map(state => state?.currentIndex ?? 0));
92
77
  }
93
78
  /**
94
- * Attempts to transition to the next step.
79
+ * Returns the shared wizard context.
80
+ */
81
+ getContext() {
82
+ return this.state$.value?.context ?? null;
83
+ }
84
+ /**
85
+ * Advances to the next step.
95
86
  *
96
- * If the current step defines an `onExit` guard, it will be executed before
97
- * transitioning. If the guard returns `false` (or resolves to `false`),
98
- * the transition is cancelled.
87
+ * Executes:
88
+ * - onExit guard
89
+ * - context merge
90
+ * - step recomposition
91
+ * - navigation
99
92
  *
100
- * @param context - Optional contextual data passed to the `onExit` guard.
93
+ * @param partialContext Optional context updates.
94
+ * @param completionProcedure Optional procedure to run when the wizard is completed.
101
95
  */
102
- async next(context) {
96
+ async next(partialContext) {
103
97
  const state = this.state$.value;
104
- if (!state)
98
+ if (!state || !this.factory)
105
99
  return;
106
100
  const current = state.steps[state.currentIndex];
101
+ const updatedContext = {
102
+ ...state.context,
103
+ ...partialContext
104
+ };
105
+ // Run exit guard
107
106
  if (current.onExit) {
108
- const allowed = await current.onExit(context);
107
+ const allowed = await current.onExit(updatedContext);
109
108
  if (!allowed)
110
109
  return;
111
110
  }
112
- if (state.currentIndex < state.steps.length - 1) {
113
- this.state$.next({
114
- ...state,
115
- currentIndex: state.currentIndex + 1
116
- });
117
- this.navigate();
111
+ // 🔥 Re-resolve steps AFTER context update
112
+ const resolved = this.factory.build(updatedContext);
113
+ const currentSlug = current.slug;
114
+ const newIndex = resolved.findIndex(s => s.slug === currentSlug);
115
+ const isLastAfterResolution = newIndex === resolved.length - 1;
116
+ // If last after re-evaluation → complete
117
+ if (isLastAfterResolution) {
118
+ await this.completionHandler?.(updatedContext);
119
+ return;
118
120
  }
121
+ // Otherwise move forward
122
+ this.state$.next({
123
+ steps: resolved,
124
+ currentIndex: newIndex + 1,
125
+ context: updatedContext
126
+ });
127
+ this.navigate();
119
128
  }
120
129
  /**
121
- * Moves the wizard to the previous step if possible.
122
- *
123
- * No guards are executed during backward navigation.
130
+ * Navigates to the previous step.
124
131
  */
125
132
  previous() {
126
133
  const state = this.state$.value;
127
134
  if (!state)
128
135
  return;
129
- if (state.currentIndex > 0) {
130
- this.state$.next({
131
- ...state,
132
- currentIndex: state.currentIndex - 1
133
- });
134
- this.navigate();
135
- }
136
+ if (state.currentIndex === 0)
137
+ return;
138
+ this.state$.next({
139
+ ...state,
140
+ currentIndex: state.currentIndex - 1
141
+ });
142
+ this.navigate();
136
143
  }
137
144
  /**
138
- * Determines whether the current step is the final step.
139
- *
140
- * @returns `true` if on the last step; otherwise `false`.
145
+ * Returns whether the wizard is currently on the last step.
141
146
  */
142
147
  isLast() {
143
148
  const state = this.state$.value;
@@ -146,30 +151,19 @@ class WizardStepService {
146
151
  return state.currentIndex === state.steps.length - 1;
147
152
  }
148
153
  /**
149
- * Sets whether forward navigation is currently permitted.
150
- *
151
- * This is typically controlled by external validation logic (e.g., form state).
152
- *
153
- * @param available - `true` if forward navigation should be allowed.
154
+ * Sets forward navigation availability.
154
155
  */
155
156
  setStepForwardAvailability(available) {
156
157
  this.stepForwardAvailability$.next(available);
157
158
  }
158
159
  /**
159
- * Emits the forward navigation availability state.
160
- *
161
- * @returns Observable stream of the forward navigation flag.
160
+ * Returns observable forward navigation state.
162
161
  */
163
162
  getStepForwardAvailability() {
164
163
  return this.stepForwardAvailability$.asObservable();
165
164
  }
166
165
  /**
167
- * Navigates the router to the currently active step.
168
- *
169
- * This method updates the URL relative to the injected route
170
- * using the pattern: `step-{slug}`.
171
- *
172
- * @internal
166
+ * Navigates the Angular router to the current step.
173
167
  */
174
168
  navigate() {
175
169
  const step = this.getCurrentStep();
@@ -177,16 +171,6 @@ class WizardStepService {
177
171
  return;
178
172
  this.router.navigate([`step-${step.slug}`], { relativeTo: this.activatedRoute });
179
173
  }
180
- /**
181
- * Navigates the router away from any "step" route.
182
- *
183
- * This methods updates the URL relative to the injected route, removing every after `/step-
184
- */
185
- clearStepRoute() {
186
- const url = this.router.url;
187
- const [initial] = url.split('/step-');
188
- this.router.navigate([initial]);
189
- }
190
174
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: WizardStepService, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Injectable }); }
191
175
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: WizardStepService }); }
192
176
  }
@@ -227,6 +211,23 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
227
211
  args: [{ selector: 'step', standalone: true, imports: [CommonModule], template: "<div class=\"form-steps-container\">\r\n\t<ng-container *ngFor=\"let step of steps | async; let i = index;\">\r\n\t\t<div class=\"d-flex flex-column align-items-center\">\r\n\t\t\t<div \r\n\t\t\t\t(click)=\"onStepClick(step)\"\r\n\t\t\t\t[ngClass]=\"{ 'step-complete': step.isComplete, 'step-incomplete': !step.isComplete, 'step-current': (currentIndex | async) === i }\"\r\n\t\t\t\tclass=\"step-bubble cursor-pointer\"\r\n\t\t\t>{{ i + 1}}</div>\r\n\t\t\t<div>\r\n\t\t\t\t<span class=\"text-grey\">{{step.title}}</span>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t\t<div *ngIf=\"i < (steps | async)?.length - 1\" class=\"step-divider\"></div>\r\n\t</ng-container>\r\n</div>", styles: [".form-steps-container{display:flex;justify-content:space-between;align-items:center;padding:0 32px;margin-bottom:32px}.step-bubble{padding:20px;border:3px solid var(--wp-primaryBlue);width:12px;height:12px;display:flex;justify-content:center;align-items:center;border-radius:50%;color:var(--wp-primaryBlue);font-size:1em;cursor:pointer;-webkit-user-select:none;user-select:none}.step-divider{height:2px;background:var(--wp-primaryBlue);flex:1;margin:0 10px}.step-current,.step-complete{background:var(--wp-primaryBlue);color:#fff}.step-incomplete{cursor:not-allowed;pointer-events:none}\n"] }]
228
212
  }], ctorParameters: () => [{ type: WizardStepService }] });
229
213
 
214
+ /**
215
+ * Factory helper for building dynamic wizard step flows.
216
+ */
217
+ class WizardStepFactory {
218
+ constructor(masterSteps) {
219
+ this.masterSteps = masterSteps;
220
+ }
221
+ /**
222
+ * Resolves the active step list based on context conditions.
223
+ *
224
+ * @param context The current wizard context.
225
+ */
226
+ build(context) {
227
+ return this.masterSteps.filter(step => !step.condition || step.condition(context));
228
+ }
229
+ }
230
+
230
231
  class WizardBuilder {
231
232
  constructor() {
232
233
  /**
@@ -465,5 +466,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
465
466
  * Generated bundle index. Do not edit.
466
467
  */
467
468
 
468
- export { StepComponent, StepService, WizardBuilder, WizardStepService };
469
+ export { StepComponent, StepService, WizardBuilder, WizardStepFactory, WizardStepService };
469
470
  //# sourceMappingURL=windows-plus-utilities-modal-wizard.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"windows-plus-utilities-modal-wizard.mjs","sources":["../../../projects/windows-plus-utilities/modal-wizard/util/service/wizard-step.service.ts","../../../projects/windows-plus-utilities/modal-wizard/components/step/step.component.ts","../../../projects/windows-plus-utilities/modal-wizard/components/step/step.component.html","../../../projects/windows-plus-utilities/modal-wizard/util/helper/wizard-builder.service.ts","../../../projects/windows-plus-utilities/modal-wizard/util/service/step.service.ts","../../../projects/windows-plus-utilities/modal-wizard/public-api.ts","../../../projects/windows-plus-utilities/modal-wizard/windows-plus-utilities-modal-wizard.ts"],"sourcesContent":["import { Injectable } from '@angular/core'\r\nimport { Router, ActivatedRoute } from '@angular/router'\r\nimport { BehaviorSubject, Observable, map } from 'rxjs'\r\nimport { StepDefinition } from '../interface/step-definition.interface'\r\nimport { WizardState } from '../interface/wizard-state.interface'\r\n/**\r\n * A finite state machine service used to manage wizard-style step navigation.\r\n *\r\n * This service maintains an immutable list of {@link StepDefinition} objects and\r\n * tracks the current active step index internally. It exposes reactive streams\r\n * for step data and navigation state, and coordinates router navigation when\r\n * transitions occur.\r\n *\r\n * The service is intentionally component-scoped and must be provided at the\r\n * component level. Each wizard instance should create and initialize its own\r\n * service instance.\r\n *\r\n * @typeParam T - The type used for step parameter definitions.\r\n */\r\n@Injectable()\r\nexport class WizardStepService<T> {\r\n\r\n\t/**\r\n\t * Internal state container for the wizard.\r\n\t *\r\n\t * Holds the ordered step definitions and the currently active index.\r\n\t * A `null` value indicates the wizard has not yet been initialized.\r\n\t */\r\n\tprivate state$ = new BehaviorSubject<WizardState<T> | null>(null)\r\n\r\n\t/**\r\n\t * Emits whether forward navigation is currently allowed.\r\n\t *\r\n\t * This can be controlled externally (e.g., form validity).\r\n\t */\r\n\tprivate stepForwardAvailability$ = new BehaviorSubject<boolean>(false)\r\n\r\n\t/**\r\n\t * Creates a new WizardStepService instance.\r\n\t *\r\n\t * @param router - Angular Router used to update the URL when step changes occur.\r\n\t * @param activatedRoute - The current route used as the relative base for navigation.\r\n\t */\r\n\tconstructor(\r\n\t\tprivate router: Router,\r\n\t\tprivate activatedRoute: ActivatedRoute\r\n\t) { }\r\n\r\n\t/**\r\n\t * Initializes the wizard with an ordered list of step definitions.\r\n\t *\r\n\t * This method must be called before navigation methods are used.\r\n\t * It resets the wizard state and navigates to the first step.\r\n\t *\r\n\t * @param steps - The ordered collection of step definitions.\r\n\t */\r\n\tinitialize(steps: StepDefinition<T>[]): void {\r\n\t\tthis.state$.next({\r\n\t\t\tsteps: [...steps], // defensive copy\r\n\t\t\tcurrentIndex: 0\r\n\t\t})\r\n\r\n\t\tthis.navigate()\r\n\t}\r\n\r\n\t/**\r\n\t * Returns the currently active step synchronously.\r\n\t *\r\n\t * @returns The active {@link StepDefinition}, or `null` if not initialized.\r\n\t */\r\n\tgetCurrentStep(): StepDefinition<T> | null {\r\n\t\treturn this.state$.value?.steps[this.state$.value.currentIndex] ?? null\r\n\t}\r\n\r\n\t/**\r\n\t * Emits the currently active step whenever the wizard state changes.\r\n\t *\r\n\t * @returns Observable stream of the active step or `null` if uninitialized.\r\n\t */\r\n\tgetCurrentStep$(): Observable<StepDefinition<T> | null> {\r\n\t\treturn this.state$.pipe(\r\n\t\t\tmap(state =>\r\n\t\t\t\tstate ? state.steps[state.currentIndex] : null\r\n\t\t\t)\r\n\t\t)\r\n\t}\r\n\r\n\t/**\r\n\t * Emits the full ordered list of wizard steps.\r\n\t *\r\n\t * @returns Observable stream of step definitions.\r\n\t */\r\n\tgetSteps$(): Observable<StepDefinition<T>[]> {\r\n\t\treturn this.state$.pipe(\r\n\t\t\tmap(state => state?.steps ?? [])\r\n\t\t)\r\n\t}\r\n\r\n\t/**\r\n\t * Emits the current active step index.\r\n\t *\r\n\t * @returns Observable stream of the current index (0-based).\r\n\t */\r\n\tgetCurrentIndex$(): Observable<number> {\r\n\t\treturn this.state$.pipe(\r\n\t\t\tmap(state => state?.currentIndex ?? 0)\r\n\t\t)\r\n\t}\r\n\r\n\t/**\r\n\t * Attempts to transition to the next step.\r\n\t *\r\n\t * If the current step defines an `onExit` guard, it will be executed before\r\n\t * transitioning. If the guard returns `false` (or resolves to `false`),\r\n\t * the transition is cancelled.\r\n\t *\r\n\t * @param context - Optional contextual data passed to the `onExit` guard.\r\n\t */\r\n\tasync next(context?: any): Promise<void> {\r\n\t\tconst state = this.state$.value\r\n\t\tif (!state) return\r\n\r\n\t\tconst current = state.steps[state.currentIndex]\r\n\r\n\t\tif (current.onExit) {\r\n\t\t\tconst allowed = await current.onExit(context)\r\n\t\t\tif (!allowed) return\r\n\t\t}\r\n\r\n\t\tif (state.currentIndex < state.steps.length - 1) {\r\n\t\t\tthis.state$.next({\r\n\t\t\t\t...state,\r\n\t\t\t\tcurrentIndex: state.currentIndex + 1\r\n\t\t\t})\r\n\r\n\t\t\tthis.navigate()\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Moves the wizard to the previous step if possible.\r\n\t *\r\n\t * No guards are executed during backward navigation.\r\n\t */\r\n\tprevious(): void {\r\n\t\tconst state = this.state$.value\r\n\t\tif (!state) return\r\n\r\n\t\tif (state.currentIndex > 0) {\r\n\t\t\tthis.state$.next({\r\n\t\t\t\t...state,\r\n\t\t\t\tcurrentIndex: state.currentIndex - 1\r\n\t\t\t})\r\n\r\n\t\t\tthis.navigate()\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Determines whether the current step is the final step.\r\n\t *\r\n\t * @returns `true` if on the last step; otherwise `false`.\r\n\t */\r\n\tisLast(): boolean {\r\n\t\tconst state = this.state$.value\r\n\t\tif (!state) return false\r\n\t\treturn state.currentIndex === state.steps.length - 1\r\n\t}\r\n\r\n\t/**\r\n\t * Sets whether forward navigation is currently permitted.\r\n\t *\r\n\t * This is typically controlled by external validation logic (e.g., form state).\r\n\t *\r\n\t * @param available - `true` if forward navigation should be allowed.\r\n\t */\r\n\tsetStepForwardAvailability(available: boolean): void {\r\n\t\tthis.stepForwardAvailability$.next(available)\r\n\t}\r\n\r\n\t/**\r\n\t * Emits the forward navigation availability state.\r\n\t *\r\n\t * @returns Observable stream of the forward navigation flag.\r\n\t */\r\n\tgetStepForwardAvailability(): Observable<boolean> {\r\n\t\treturn this.stepForwardAvailability$.asObservable()\r\n\t}\r\n\r\n\t/**\r\n\t * Navigates the router to the currently active step.\r\n\t *\r\n\t * This method updates the URL relative to the injected route\r\n\t * using the pattern: `step-{slug}`.\r\n\t *\r\n\t * @internal\r\n\t */\r\n\tprivate navigate(): void {\r\n\t\tconst step = this.getCurrentStep()\r\n\t\tif (!step) return\r\n\r\n\t\tthis.router.navigate(\r\n\t\t\t[`step-${step.slug}`],\r\n\t\t\t{ relativeTo: this.activatedRoute }\r\n\t\t)\r\n\t}\r\n\t/**\r\n\t * Navigates the router away from any \"step\" route.\r\n\t * \r\n\t * This methods updates the URL relative to the injected route, removing every after `/step-\r\n\t */\r\n\tclearStepRoute(): void {\r\n\t\tconst url = this.router.url\r\n\t\tconst [initial] = url.split('/step-')\r\n\t\tthis.router.navigate([initial])\r\n\t}\r\n}\r\n\r\n","import { Component } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { Observable } from 'rxjs'\r\nimport { StepDefinition } from '../../util/interface/step-definition.interface'\r\nimport { WizardStepService } from '../../util/service/wizard-step.service'\r\n\r\n@Component({\r\n selector: 'step',\r\n standalone: true,\r\n imports: [CommonModule],\r\n templateUrl: './step.component.html',\r\n styleUrls: ['./step.component.sass']\r\n})\r\nexport class StepComponent {\r\n\t/**\r\n\t * @description an observable to the modal steps\r\n\t */\r\n steps: Observable<StepDefinition<any>[]>\r\n\t/**\r\n\t * @description an observable to the current step\r\n\t */\r\n currentIndex: Observable<number>;\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description class constructor specifying the required services and properties\r\n\t * @param stepService the service class which contains access to the modal steps functionality\r\n\t */\r\n constructor(private stepService: WizardStepService<any>) { }\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description the method to be run when the component is rendered\r\n\t */\r\n ngOnInit(): void {\r\n this.steps = this.stepService.getSteps$();\r\n this.currentIndex = this.stepService.getCurrentIndex$();\r\n }\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description handles the user clicking a step\r\n\t * @param step the step clicked\r\n\t */\r\n onStepClick(step: StepDefinition<any>) {\r\n // this.stepService.setCurrentStep(step);\r\n }\r\n}\r\n","<div class=\"form-steps-container\">\r\n\t<ng-container *ngFor=\"let step of steps | async; let i = index;\">\r\n\t\t<div class=\"d-flex flex-column align-items-center\">\r\n\t\t\t<div \r\n\t\t\t\t(click)=\"onStepClick(step)\"\r\n\t\t\t\t[ngClass]=\"{ 'step-complete': step.isComplete, 'step-incomplete': !step.isComplete, 'step-current': (currentIndex | async) === i }\"\r\n\t\t\t\tclass=\"step-bubble cursor-pointer\"\r\n\t\t\t>{{ i + 1}}</div>\r\n\t\t\t<div>\r\n\t\t\t\t<span class=\"text-grey\">{{step.title}}</span>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t\t<div *ngIf=\"i < (steps | async)?.length - 1\" class=\"step-divider\"></div>\r\n\t</ng-container>\r\n</div>","import { StepDefinition } from '../interface/step-definition.interface'\r\n\r\nexport class WizardBuilder<T> {\r\n\t/**\r\n\t * @description an array containing the configuration for the wizard's steps\r\n\t */\r\n\tprivate steps: StepDefinition<T>[] = []\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description adds the specified step to the step array\r\n\t * @param step the step to be added\r\n\t * @returns {WizardBuilder<T>} the wizard builder instance\r\n\t */\r\n\taddStep(step: StepDefinition<T>): WizardBuilder<T> {\r\n\t\tthis.steps.push(step)\r\n\r\n\t\treturn this\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description builds the wizard steps to be used\r\n\t * @returns {StepDefinition<T>[]} an immutable copy of the steps\r\n\t */\r\n\tbuild(): StepDefinition<T>[] {\r\n\t\treturn [...this.steps] // Immutable copy\r\n\t}\r\n}","import { Inject, Injectable } from '@angular/core'\r\nimport { BehaviorSubject, Observable } from 'rxjs'\r\nimport { StepModel } from '../interface/modal-step.interface'\r\nimport { ActivatedRoute, Router } from '@angular/router'\r\n\r\n@Injectable({\r\n\tprovidedIn: 'root'\r\n})\r\nexport class StepService<T> {\r\n\t/**\r\n\t * @description the current index\r\n\t */\r\n\tprivate currentIndex = 0\r\n\t/**\r\n\t * @description the original step configuration\r\n\t */\r\n\toriginalSteps: StepModel<T>[]\r\n\t/**\r\n\t * @description the subject for the modal steps\r\n\t */\r\n\tsteps$: BehaviorSubject<StepModel<T>[]>\r\n\t/**\r\n\t * @description the subject for the current modal step\r\n\t */\r\n\tcurrentStep$: BehaviorSubject<StepModel<T> | null> = new BehaviorSubject<StepModel<T> | null>(null);\r\n\t/**\r\n\t * @description the subject for the step forward availability\r\n\t */\r\n\tstepForwardAvailability$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false)\r\n\t/**\r\n * @author Alex Hodson\r\n * @description class constructor specifying the required services and properties\r\n * @param steps the steps in the modal\r\n */\r\n\tconstructor(\r\n\t\tprivate router: Router,\r\n\t\tprivate activatedRoute: ActivatedRoute,\r\n\t\t@Inject('steps') private stepConfig: StepModel<T>[]\r\n\t) {\r\n\t\tthis.originalSteps = this.buildSteps(stepConfig)\r\n\t\tthis.steps$ = new BehaviorSubject(this.originalSteps)\r\n\t\tthis.currentStep$.next(this.originalSteps[0])\r\n\t}\r\n\tprivate buildSteps(config: Omit<StepModel<T>, 'stepIndex'>[]): StepModel<T>[] {\r\n\t\treturn config.map((step, index) => ({\r\n\t\t\t...step,\r\n\t\t\tstepIndex: index + 1\r\n\t\t}))\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description adjusts the step indexes to be sequential based on their position in the steps array\r\n\t */\r\n\tadjustStepIndexes(): void {\r\n\t\tconst rebuilt = this.steps$.value.map((step, index) => ({\r\n\t\t\t...step,\r\n\t\t\tstepIndex: index + 1\r\n\t\t}))\r\n\r\n\t\tthis.steps$.next(rebuilt)\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description inserts a new step at a specific index, specified by the step index property\r\n\t * @param step the step to be inserted\r\n\t */\r\n\tinsertStep(step: StepModel<T>): void {\r\n\t\tconst current = this.steps$.value\r\n\r\n\t\tconst updated = [\r\n\t\t\t...current.slice(0, step.stepIndex - 1),\r\n\t\t\tstep,\r\n\t\t\t...current.slice(step.stepIndex - 1)\r\n\t\t].map((s, index) => ({\r\n\t\t\t...s,\r\n\t\t\tstepIndex: index + 1\r\n\t\t}))\r\n\r\n\t\tthis.steps$.next(updated)\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description sets the current modal step\r\n\t * @param step the step to be set\r\n\t */\r\n\tsetCurrentStep(step: StepModel<T>): void {\r\n\t\tthis.currentStep$.next(step)\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description returns the current modal step observable\r\n\t * @returns the current modal step observable\r\n\t */\r\n\tgetCurrentStepObservable(): Observable<StepModel<T> | null> {\r\n\t\treturn this.currentStep$.asObservable()\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description returns the current modal step observable\r\n\t * @returns the current modal step observable\r\n\t */\r\n\tgetCurrentStep(): StepModel<T> | null {\r\n\t\treturn this.currentStep$.getValue()\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description retrieves the current steps\r\n\t * @returns the current steps\r\n\t */\r\n\tgetSteps(): StepModel<T>[] {\r\n\t\treturn this.steps$.getValue()\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description returns the modal step observable\r\n\t * @returns the modal step observable\r\n\t */\r\n\tgetStepsObservable(): Observable<StepModel<T>[]> {\r\n\t\treturn this.steps$.asObservable()\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description sets the step forward availability\r\n\t * @param available whether a step forward is available\r\n\t */\r\n\tsetStepForwardAvailability(available: boolean): void {\r\n\t\tthis.stepForwardAvailability$.next(available)\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description returns the step forward availability observable\r\n\t * @returns the step forward availability observable\r\n\t */\r\n\tgetStepForwardAvailability(): Observable<boolean> {\r\n\t\treturn this.stepForwardAvailability$.asObservable()\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description moves to the next modal step\r\n\t */\r\n\tmoveToNextStep(): void {\r\n\t\tif (this.currentIndex < this.steps$.value.length - 1) {\r\n\t\t\tthis.currentIndex++\r\n\t\t\tthis.currentStep$.next(this.steps$.value[this.currentIndex])\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description moves to the previous modal step\r\n\t */\r\n\tmoveToPreviousStep(): void {\r\n\t\tconst previous = this.steps$.getValue()[this.currentIndex - 1]\r\n\r\n\t\tif (!previous) return\r\n\r\n\t\tthis.currentStep$.next({\r\n\t\t\t...previous,\r\n\t\t\t'triggerCallback': false\r\n\t\t})\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description determines whether the current step is the last\r\n\t * @returns whether the step is the last one\r\n\t */\r\n\tisLastStep(): boolean {\r\n\t\treturn this.currentIndex === this.steps$.value.length\r\n\t}\r\n\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description triggers any potential \"after-step\" functionality for the current step and changes the current route with any required parameters\r\n\t * @param getParameterValue the callback which retrieves the value for a step parameter\r\n\t * @param triggerStepCallback the callback which triggers the specific functionality for the specified step index\r\n\t */\r\n\tasync handleStepChange(getParameterValue?: (...args: any) => any, triggerStepCallback?: (...args: any) => Promise<boolean>, revert: boolean = false): Promise<void | null> {\r\n\t\tconst currentStep = this.currentStep$.value\r\n\r\n\t\tif (!currentStep) return\r\n\r\n\t\tconst { stepIndex, triggerCallback } = currentStep\r\n\r\n\t\tif (triggerCallback && triggerStepCallback) {\r\n\t\t\tconst results = await triggerStepCallback(stepIndex)\r\n\r\n\t\t\tif (!results && revert) return this.moveToPreviousStep()\r\n\t\t}\r\n\r\n\t\tthis.handleNavigation(getParameterValue, currentStep)\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description handles the modification of the system route which will navigate to the specified step. If no step is provided, then the stored current step is used\r\n\t * @param getParameterValue the callback which retrieves the value for a step parameter\r\n\t * @param step an optional step which will be used to navigate to\r\n\t */\r\n\thandleNavigation(getParameterValue?: (...args: any) => any, step?: StepModel<T>): void {\r\n\t\tconst currentStep = step || this.currentStep$.value\r\n\r\n\t\tif (!currentStep) return\r\n\r\n\t\tconst { slug, parameters } = currentStep\r\n\r\n\t\tlet route = `step-${slug}`\r\n\t\tif (getParameterValue) parameters.forEach((element) => route += `/${getParameterValue(element)}`)\r\n\t\tthis.router.navigate([route], { relativeTo: this.activatedRoute })\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description clears any route paths and/or parameters created during the step functionality, reverting the url back to the original state when the step paths were appended\r\n\t */\r\n\tclearStepRoute(): void {\r\n\t\tconst url = this.router.url\r\n\t\tconst [initial] = url.split('/step-')\r\n\t\tthis.router.navigate([initial])\r\n\t}\r\n}\r\n","/*\r\n * Public API Surface of windows-plus-utilities\r\n */\r\nexport * from './components/step/step.component';\r\n\r\nexport * from './util/helper/wizard-builder.service'\r\n\r\nexport * from './util/interface/modal-step.interface'\r\nexport * from './util/interface/step-definition.interface'\r\nexport * from './util/interface/stepped-modal.interface'\r\nexport * from './util/interface/wizard-modal.interface'\r\nexport * from './util/interface/wizard-state.interface'\r\n\r\nexport * from './util/service/wizard-step.service'\r\nexport * from './util/service/step.service'","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i1.WizardStepService"],"mappings":"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"}
1
+ {"version":3,"file":"windows-plus-utilities-modal-wizard.mjs","sources":["../../../projects/windows-plus-utilities/modal-wizard/util/service/wizard-step.service.ts","../../../projects/windows-plus-utilities/modal-wizard/components/step/step.component.ts","../../../projects/windows-plus-utilities/modal-wizard/components/step/step.component.html","../../../projects/windows-plus-utilities/modal-wizard/util/factory/wizard-step-factory.ts","../../../projects/windows-plus-utilities/modal-wizard/util/helper/wizard-builder.service.ts","../../../projects/windows-plus-utilities/modal-wizard/util/service/step.service.ts","../../../projects/windows-plus-utilities/modal-wizard/public-api.ts","../../../projects/windows-plus-utilities/modal-wizard/windows-plus-utilities-modal-wizard.ts"],"sourcesContent":["import { Injectable } from '@angular/core'\r\nimport { ActivatedRoute, Router } from '@angular/router'\r\nimport { BehaviorSubject, Observable } from 'rxjs'\r\nimport { map } from 'rxjs/operators'\r\nimport { WizardState } from '../interface/wizard-state.interface'\r\nimport { WizardStepFactory } from '../factory/wizard-step-factory'\r\nimport { StepDefinition } from '../interface/step-definition.interface'\r\n\r\n/**\r\n * Generic reusable wizard step controller.\r\n *\r\n * Handles:\r\n * - Navigation\r\n * - Conditional step resolution\r\n * - Dynamic step insertion/removal\r\n * - Context persistence\r\n * - Router synchronization\r\n *\r\n * @template T The shared wizard context type.\r\n */\r\n@Injectable()\r\nexport class WizardStepService<T> {\r\n\r\n /**\r\n * Internal wizard state container.\r\n */\r\n private readonly state$ = new BehaviorSubject<WizardState<T> | null>(null)\r\n\r\n\tprivate completionHandler?: (context: T) => Promise<void> | void\r\n\r\n /**\r\n * Controls whether forward navigation is allowed.\r\n */\r\n private readonly stepForwardAvailability$ =\r\n new BehaviorSubject<boolean>(false)\r\n\r\n /**\r\n * The step factory used to resolve active steps.\r\n */\r\n private factory?: WizardStepFactory<T>\r\n\r\n constructor(\r\n private readonly router: Router,\r\n private readonly activatedRoute: ActivatedRoute\r\n ) { }\r\n\r\n /**\r\n * Initializes the wizard.\r\n *\r\n * @param factory The step factory defining the wizard flow.\r\n * @param initialContext Initial shared context object.\r\n */\r\n initialize(factory: WizardStepFactory<T>, initialContext: T, onComplete: (context: T) => Promise<void> | void\r\n): void {\r\n this.factory = factory\r\n\t\tthis.completionHandler = onComplete\r\n\r\n const steps = factory.build(initialContext)\r\n\r\n this.state$.next({\r\n steps,\r\n currentIndex: 0,\r\n context: initialContext\r\n })\r\n\r\n this.navigate()\r\n }\r\n\r\n /**\r\n * Returns the current step synchronously.\r\n */\r\n getCurrentStep(): StepDefinition<T> | null {\r\n const state = this.state$.value\r\n if (!state) return null\r\n return state.steps[state.currentIndex] ?? null\r\n }\r\n\r\n /**\r\n * Observable stream of current step.\r\n */\r\n getCurrentStep$(): Observable<StepDefinition<T> | null> {\r\n return this.state$.pipe(\r\n map(state =>\r\n state ? state.steps[state.currentIndex] : null\r\n )\r\n )\r\n }\r\n\r\n /**\r\n * Observable stream of all active steps.\r\n */\r\n getSteps$(): Observable<StepDefinition<T>[]> {\r\n return this.state$.pipe(\r\n map(state => state?.steps ?? [])\r\n )\r\n }\r\n\r\n /**\r\n * Observable stream of the current index.\r\n */\r\n getCurrentIndex$(): Observable<number> {\r\n return this.state$.pipe(\r\n map(state => state?.currentIndex ?? 0)\r\n )\r\n }\r\n\r\n /**\r\n * Returns the shared wizard context.\r\n */\r\n getContext(): T | null {\r\n return this.state$.value?.context ?? null\r\n }\r\n\r\n /**\r\n * Advances to the next step.\r\n *\r\n * Executes:\r\n * - onExit guard\r\n * - context merge\r\n * - step recomposition\r\n * - navigation\r\n *\r\n * @param partialContext Optional context updates.\r\n * @param completionProcedure Optional procedure to run when the wizard is completed.\r\n */\r\n async next(partialContext?: Partial<T>): Promise<void> {\r\n const state = this.state$.value\r\n if (!state || !this.factory) return\r\n\r\n const current = state.steps[state.currentIndex]\r\n\r\n const updatedContext = {\r\n ...state.context,\r\n ...partialContext\r\n }\r\n\r\n // Run exit guard\r\n if (current.onExit) {\r\n const allowed = await current.onExit(updatedContext)\r\n if (!allowed) return\r\n }\r\n\r\n // 🔥 Re-resolve steps AFTER context update\r\n const resolved = this.factory.build(updatedContext)\r\n\r\n const currentSlug = current.slug\r\n const newIndex = resolved.findIndex(s => s.slug === currentSlug)\r\n\r\n const isLastAfterResolution =\r\n newIndex === resolved.length - 1\r\n\r\n // If last after re-evaluation → complete\r\n if (isLastAfterResolution) {\r\n await this.completionHandler?.(updatedContext)\r\n return\r\n }\r\n\r\n // Otherwise move forward\r\n this.state$.next({\r\n steps: resolved,\r\n currentIndex: newIndex + 1,\r\n context: updatedContext\r\n })\r\n\r\n this.navigate()\r\n}\r\n\r\n /**\r\n * Navigates to the previous step.\r\n */\r\n previous(): void {\r\n const state = this.state$.value\r\n if (!state) return\r\n\r\n if (state.currentIndex === 0) return\r\n\r\n this.state$.next({\r\n ...state,\r\n currentIndex: state.currentIndex - 1\r\n })\r\n\r\n this.navigate()\r\n }\r\n\r\n /**\r\n * Returns whether the wizard is currently on the last step.\r\n */\r\n isLast(): boolean {\r\n const state = this.state$.value\r\n if (!state) return false\r\n return state.currentIndex === state.steps.length - 1\r\n }\r\n\r\n /**\r\n * Sets forward navigation availability.\r\n */\r\n setStepForwardAvailability(available: boolean): void {\r\n this.stepForwardAvailability$.next(available)\r\n }\r\n\r\n /**\r\n * Returns observable forward navigation state.\r\n */\r\n getStepForwardAvailability(): Observable<boolean> {\r\n return this.stepForwardAvailability$.asObservable()\r\n }\r\n\r\n /**\r\n * Navigates the Angular router to the current step.\r\n */\r\n private navigate(): void {\r\n const step = this.getCurrentStep()\r\n if (!step) return\r\n\r\n this.router.navigate(\r\n [`step-${step.slug}`],\r\n { relativeTo: this.activatedRoute }\r\n )\r\n }\r\n}","import { Component } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { Observable } from 'rxjs'\r\nimport { StepDefinition } from '../../util/interface/step-definition.interface'\r\nimport { WizardStepService } from '../../util/service/wizard-step.service'\r\n\r\n@Component({\r\n selector: 'step',\r\n standalone: true,\r\n imports: [CommonModule],\r\n templateUrl: './step.component.html',\r\n styleUrls: ['./step.component.sass']\r\n})\r\nexport class StepComponent {\r\n\t/**\r\n\t * @description an observable to the modal steps\r\n\t */\r\n steps: Observable<StepDefinition<any>[]>\r\n\t/**\r\n\t * @description an observable to the current step\r\n\t */\r\n currentIndex: Observable<number>;\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description class constructor specifying the required services and properties\r\n\t * @param stepService the service class which contains access to the modal steps functionality\r\n\t */\r\n constructor(private stepService: WizardStepService<any>) { }\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description the method to be run when the component is rendered\r\n\t */\r\n ngOnInit(): void {\r\n this.steps = this.stepService.getSteps$();\r\n this.currentIndex = this.stepService.getCurrentIndex$();\r\n }\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description handles the user clicking a step\r\n\t * @param step the step clicked\r\n\t */\r\n onStepClick(step: StepDefinition<any>) {\r\n // this.stepService.setCurrentStep(step);\r\n }\r\n}\r\n","<div class=\"form-steps-container\">\r\n\t<ng-container *ngFor=\"let step of steps | async; let i = index;\">\r\n\t\t<div class=\"d-flex flex-column align-items-center\">\r\n\t\t\t<div \r\n\t\t\t\t(click)=\"onStepClick(step)\"\r\n\t\t\t\t[ngClass]=\"{ 'step-complete': step.isComplete, 'step-incomplete': !step.isComplete, 'step-current': (currentIndex | async) === i }\"\r\n\t\t\t\tclass=\"step-bubble cursor-pointer\"\r\n\t\t\t>{{ i + 1}}</div>\r\n\t\t\t<div>\r\n\t\t\t\t<span class=\"text-grey\">{{step.title}}</span>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t\t<div *ngIf=\"i < (steps | async)?.length - 1\" class=\"step-divider\"></div>\r\n\t</ng-container>\r\n</div>","import { StepDefinition } from '../interface/step-definition.interface'\r\n\r\n/**\r\n * Factory helper for building dynamic wizard step flows.\r\n */\r\nexport class WizardStepFactory<T> {\r\n constructor(\r\n private readonly masterSteps: StepDefinition<T>[]\r\n ) { }\r\n\r\n /**\r\n * Resolves the active step list based on context conditions.\r\n *\r\n * @param context The current wizard context.\r\n */\r\n build(context: T): StepDefinition<T>[] {\r\n return this.masterSteps.filter(step =>\r\n !step.condition || step.condition(context)\r\n )\r\n }\r\n}","import { StepDefinition } from '../interface/step-definition.interface'\r\n\r\nexport class WizardBuilder<T> {\r\n\t/**\r\n\t * @description an array containing the configuration for the wizard's steps\r\n\t */\r\n\tprivate steps: StepDefinition<T>[] = []\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description adds the specified step to the step array\r\n\t * @param step the step to be added\r\n\t * @returns {WizardBuilder<T>} the wizard builder instance\r\n\t */\r\n\taddStep(step: StepDefinition<T>): WizardBuilder<T> {\r\n\t\tthis.steps.push(step)\r\n\r\n\t\treturn this\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description builds the wizard steps to be used\r\n\t * @returns {StepDefinition<T>[]} an immutable copy of the steps\r\n\t */\r\n\tbuild(): StepDefinition<T>[] {\r\n\t\treturn [...this.steps] // Immutable copy\r\n\t}\r\n}","import { Inject, Injectable } from '@angular/core'\r\nimport { BehaviorSubject, Observable } from 'rxjs'\r\nimport { StepModel } from '../interface/modal-step.interface'\r\nimport { ActivatedRoute, Router } from '@angular/router'\r\n\r\n@Injectable({\r\n\tprovidedIn: 'root'\r\n})\r\nexport class StepService<T> {\r\n\t/**\r\n\t * @description the current index\r\n\t */\r\n\tprivate currentIndex = 0\r\n\t/**\r\n\t * @description the original step configuration\r\n\t */\r\n\toriginalSteps: StepModel<T>[]\r\n\t/**\r\n\t * @description the subject for the modal steps\r\n\t */\r\n\tsteps$: BehaviorSubject<StepModel<T>[]>\r\n\t/**\r\n\t * @description the subject for the current modal step\r\n\t */\r\n\tcurrentStep$: BehaviorSubject<StepModel<T> | null> = new BehaviorSubject<StepModel<T> | null>(null);\r\n\t/**\r\n\t * @description the subject for the step forward availability\r\n\t */\r\n\tstepForwardAvailability$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false)\r\n\t/**\r\n * @author Alex Hodson\r\n * @description class constructor specifying the required services and properties\r\n * @param steps the steps in the modal\r\n */\r\n\tconstructor(\r\n\t\tprivate router: Router,\r\n\t\tprivate activatedRoute: ActivatedRoute,\r\n\t\t@Inject('steps') private stepConfig: StepModel<T>[]\r\n\t) {\r\n\t\tthis.originalSteps = this.buildSteps(stepConfig)\r\n\t\tthis.steps$ = new BehaviorSubject(this.originalSteps)\r\n\t\tthis.currentStep$.next(this.originalSteps[0])\r\n\t}\r\n\tprivate buildSteps(config: Omit<StepModel<T>, 'stepIndex'>[]): StepModel<T>[] {\r\n\t\treturn config.map((step, index) => ({\r\n\t\t\t...step,\r\n\t\t\tstepIndex: index + 1\r\n\t\t}))\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description adjusts the step indexes to be sequential based on their position in the steps array\r\n\t */\r\n\tadjustStepIndexes(): void {\r\n\t\tconst rebuilt = this.steps$.value.map((step, index) => ({\r\n\t\t\t...step,\r\n\t\t\tstepIndex: index + 1\r\n\t\t}))\r\n\r\n\t\tthis.steps$.next(rebuilt)\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description inserts a new step at a specific index, specified by the step index property\r\n\t * @param step the step to be inserted\r\n\t */\r\n\tinsertStep(step: StepModel<T>): void {\r\n\t\tconst current = this.steps$.value\r\n\r\n\t\tconst updated = [\r\n\t\t\t...current.slice(0, step.stepIndex - 1),\r\n\t\t\tstep,\r\n\t\t\t...current.slice(step.stepIndex - 1)\r\n\t\t].map((s, index) => ({\r\n\t\t\t...s,\r\n\t\t\tstepIndex: index + 1\r\n\t\t}))\r\n\r\n\t\tthis.steps$.next(updated)\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description sets the current modal step\r\n\t * @param step the step to be set\r\n\t */\r\n\tsetCurrentStep(step: StepModel<T>): void {\r\n\t\tthis.currentStep$.next(step)\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description returns the current modal step observable\r\n\t * @returns the current modal step observable\r\n\t */\r\n\tgetCurrentStepObservable(): Observable<StepModel<T> | null> {\r\n\t\treturn this.currentStep$.asObservable()\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description returns the current modal step observable\r\n\t * @returns the current modal step observable\r\n\t */\r\n\tgetCurrentStep(): StepModel<T> | null {\r\n\t\treturn this.currentStep$.getValue()\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description retrieves the current steps\r\n\t * @returns the current steps\r\n\t */\r\n\tgetSteps(): StepModel<T>[] {\r\n\t\treturn this.steps$.getValue()\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description returns the modal step observable\r\n\t * @returns the modal step observable\r\n\t */\r\n\tgetStepsObservable(): Observable<StepModel<T>[]> {\r\n\t\treturn this.steps$.asObservable()\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description sets the step forward availability\r\n\t * @param available whether a step forward is available\r\n\t */\r\n\tsetStepForwardAvailability(available: boolean): void {\r\n\t\tthis.stepForwardAvailability$.next(available)\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description returns the step forward availability observable\r\n\t * @returns the step forward availability observable\r\n\t */\r\n\tgetStepForwardAvailability(): Observable<boolean> {\r\n\t\treturn this.stepForwardAvailability$.asObservable()\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description moves to the next modal step\r\n\t */\r\n\tmoveToNextStep(): void {\r\n\t\tif (this.currentIndex < this.steps$.value.length - 1) {\r\n\t\t\tthis.currentIndex++\r\n\t\t\tthis.currentStep$.next(this.steps$.value[this.currentIndex])\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description moves to the previous modal step\r\n\t */\r\n\tmoveToPreviousStep(): void {\r\n\t\tconst previous = this.steps$.getValue()[this.currentIndex - 1]\r\n\r\n\t\tif (!previous) return\r\n\r\n\t\tthis.currentStep$.next({\r\n\t\t\t...previous,\r\n\t\t\t'triggerCallback': false\r\n\t\t})\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description determines whether the current step is the last\r\n\t * @returns whether the step is the last one\r\n\t */\r\n\tisLastStep(): boolean {\r\n\t\treturn this.currentIndex === this.steps$.value.length\r\n\t}\r\n\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description triggers any potential \"after-step\" functionality for the current step and changes the current route with any required parameters\r\n\t * @param getParameterValue the callback which retrieves the value for a step parameter\r\n\t * @param triggerStepCallback the callback which triggers the specific functionality for the specified step index\r\n\t */\r\n\tasync handleStepChange(getParameterValue?: (...args: any) => any, triggerStepCallback?: (...args: any) => Promise<boolean>, revert: boolean = false): Promise<void | null> {\r\n\t\tconst currentStep = this.currentStep$.value\r\n\r\n\t\tif (!currentStep) return\r\n\r\n\t\tconst { stepIndex, triggerCallback } = currentStep\r\n\r\n\t\tif (triggerCallback && triggerStepCallback) {\r\n\t\t\tconst results = await triggerStepCallback(stepIndex)\r\n\r\n\t\t\tif (!results && revert) return this.moveToPreviousStep()\r\n\t\t}\r\n\r\n\t\tthis.handleNavigation(getParameterValue, currentStep)\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description handles the modification of the system route which will navigate to the specified step. If no step is provided, then the stored current step is used\r\n\t * @param getParameterValue the callback which retrieves the value for a step parameter\r\n\t * @param step an optional step which will be used to navigate to\r\n\t */\r\n\thandleNavigation(getParameterValue?: (...args: any) => any, step?: StepModel<T>): void {\r\n\t\tconst currentStep = step || this.currentStep$.value\r\n\r\n\t\tif (!currentStep) return\r\n\r\n\t\tconst { slug, parameters } = currentStep\r\n\r\n\t\tlet route = `step-${slug}`\r\n\t\tif (getParameterValue) parameters.forEach((element) => route += `/${getParameterValue(element)}`)\r\n\t\tthis.router.navigate([route], { relativeTo: this.activatedRoute })\r\n\t}\r\n\t/**\r\n\t * @author Alex Hodson\r\n\t * @description clears any route paths and/or parameters created during the step functionality, reverting the url back to the original state when the step paths were appended\r\n\t */\r\n\tclearStepRoute(): void {\r\n\t\tconst url = this.router.url\r\n\t\tconst [initial] = url.split('/step-')\r\n\t\tthis.router.navigate([initial])\r\n\t}\r\n}\r\n","/*\r\n * Public API Surface of windows-plus-utilities\r\n */\r\nexport * from './components/step/step.component';\r\n\r\nexport * from './util/factory/wizard-step-factory'\r\n\r\nexport * from './util/helper/wizard-builder.service'\r\n\r\nexport * from './util/interface/modal-step.interface'\r\nexport * from './util/interface/step-definition.interface'\r\nexport * from './util/interface/stepped-modal.interface'\r\nexport * from './util/interface/wizard-modal.interface'\r\nexport * from './util/interface/wizard-state.interface'\r\n\r\nexport * from './util/service/wizard-step.service'\r\nexport * from './util/service/step.service'","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i1.WizardStepService"],"mappings":"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"}
@@ -1,4 +1,5 @@
1
1
  export * from './components/step/step.component';
2
+ export * from './util/factory/wizard-step-factory';
2
3
  export * from './util/helper/wizard-builder.service';
3
4
  export * from './util/interface/modal-step.interface';
4
5
  export * from './util/interface/step-definition.interface';
@@ -0,0 +1,14 @@
1
+ import { StepDefinition } from '../interface/step-definition.interface';
2
+ /**
3
+ * Factory helper for building dynamic wizard step flows.
4
+ */
5
+ export declare class WizardStepFactory<T> {
6
+ private readonly masterSteps;
7
+ constructor(masterSteps: StepDefinition<T>[]);
8
+ /**
9
+ * Resolves the active step list based on context conditions.
10
+ *
11
+ * @param context The current wizard context.
12
+ */
13
+ build(context: T): StepDefinition<T>[];
14
+ }
@@ -3,10 +3,30 @@
3
3
  * @description an interface defining the configuration for a single wizard step
4
4
  */
5
5
  export interface StepDefinition<T> {
6
+ /**
7
+ * Unique identifier for the step.
8
+ */
6
9
  id: string;
10
+ /**
11
+ * Human-readable step title.
12
+ */
7
13
  title: string;
14
+ /**
15
+ * Unique identifier used for routing and lookup.
16
+ */
8
17
  slug: string;
18
+ /**
19
+ * Indicates whether the step is completed. This can be used to enable/disable navigation or show progress.
20
+ */
9
21
  isComplete: boolean;
10
- parameters?: T[];
22
+ /**
23
+ * Optional guard executed before leaving the step.
24
+ * Return false to block navigation.
25
+ */
11
26
  onExit?: (context?: any) => Promise<boolean> | boolean;
27
+ /**
28
+ * Optional conditional visibility rule.
29
+ * If provided, the step will only be included when true.
30
+ */
31
+ condition?: (context: T) => boolean;
12
32
  }
@@ -4,6 +4,16 @@ import { StepDefinition } from './step-definition.interface';
4
4
  * @description an interface defining the properties for the wizard modal's state
5
5
  */
6
6
  export interface WizardState<T> {
7
+ /**
8
+ * Ordered active steps in the wizard.
9
+ */
7
10
  steps: StepDefinition<T>[];
11
+ /**
12
+ * Current active step index.
13
+ */
8
14
  currentIndex: number;
15
+ /**
16
+ * Shared wizard context object.
17
+ */
18
+ context: T;
9
19
  }
@@ -1,128 +1,97 @@
1
- import { Router, ActivatedRoute } from '@angular/router';
1
+ import { ActivatedRoute, Router } from '@angular/router';
2
2
  import { Observable } from 'rxjs';
3
+ import { WizardStepFactory } from '../factory/wizard-step-factory';
3
4
  import { StepDefinition } from '../interface/step-definition.interface';
4
5
  import * as i0 from "@angular/core";
5
6
  /**
6
- * A finite state machine service used to manage wizard-style step navigation.
7
+ * Generic reusable wizard step controller.
7
8
  *
8
- * This service maintains an immutable list of {@link StepDefinition} objects and
9
- * tracks the current active step index internally. It exposes reactive streams
10
- * for step data and navigation state, and coordinates router navigation when
11
- * transitions occur.
9
+ * Handles:
10
+ * - Navigation
11
+ * - Conditional step resolution
12
+ * - Dynamic step insertion/removal
13
+ * - Context persistence
14
+ * - Router synchronization
12
15
  *
13
- * The service is intentionally component-scoped and must be provided at the
14
- * component level. Each wizard instance should create and initialize its own
15
- * service instance.
16
- *
17
- * @typeParam T - The type used for step parameter definitions.
16
+ * @template T The shared wizard context type.
18
17
  */
19
18
  export declare class WizardStepService<T> {
20
- private router;
21
- private activatedRoute;
19
+ private readonly router;
20
+ private readonly activatedRoute;
22
21
  /**
23
- * Internal state container for the wizard.
24
- *
25
- * Holds the ordered step definitions and the currently active index.
26
- * A `null` value indicates the wizard has not yet been initialized.
22
+ * Internal wizard state container.
27
23
  */
28
- private state$;
24
+ private readonly state$;
25
+ private completionHandler?;
29
26
  /**
30
- * Emits whether forward navigation is currently allowed.
31
- *
32
- * This can be controlled externally (e.g., form validity).
27
+ * Controls whether forward navigation is allowed.
33
28
  */
34
- private stepForwardAvailability$;
29
+ private readonly stepForwardAvailability$;
35
30
  /**
36
- * Creates a new WizardStepService instance.
37
- *
38
- * @param router - Angular Router used to update the URL when step changes occur.
39
- * @param activatedRoute - The current route used as the relative base for navigation.
31
+ * The step factory used to resolve active steps.
40
32
  */
33
+ private factory?;
41
34
  constructor(router: Router, activatedRoute: ActivatedRoute);
42
35
  /**
43
- * Initializes the wizard with an ordered list of step definitions.
44
- *
45
- * This method must be called before navigation methods are used.
46
- * It resets the wizard state and navigates to the first step.
36
+ * Initializes the wizard.
47
37
  *
48
- * @param steps - The ordered collection of step definitions.
38
+ * @param factory The step factory defining the wizard flow.
39
+ * @param initialContext Initial shared context object.
49
40
  */
50
- initialize(steps: StepDefinition<T>[]): void;
41
+ initialize(factory: WizardStepFactory<T>, initialContext: T, onComplete: (context: T) => Promise<void> | void): void;
51
42
  /**
52
- * Returns the currently active step synchronously.
53
- *
54
- * @returns The active {@link StepDefinition}, or `null` if not initialized.
43
+ * Returns the current step synchronously.
55
44
  */
56
45
  getCurrentStep(): StepDefinition<T> | null;
57
46
  /**
58
- * Emits the currently active step whenever the wizard state changes.
59
- *
60
- * @returns Observable stream of the active step or `null` if uninitialized.
47
+ * Observable stream of current step.
61
48
  */
62
49
  getCurrentStep$(): Observable<StepDefinition<T> | null>;
63
50
  /**
64
- * Emits the full ordered list of wizard steps.
65
- *
66
- * @returns Observable stream of step definitions.
51
+ * Observable stream of all active steps.
67
52
  */
68
53
  getSteps$(): Observable<StepDefinition<T>[]>;
69
54
  /**
70
- * Emits the current active step index.
71
- *
72
- * @returns Observable stream of the current index (0-based).
55
+ * Observable stream of the current index.
73
56
  */
74
57
  getCurrentIndex$(): Observable<number>;
75
58
  /**
76
- * Attempts to transition to the next step.
59
+ * Returns the shared wizard context.
60
+ */
61
+ getContext(): T | null;
62
+ /**
63
+ * Advances to the next step.
77
64
  *
78
- * If the current step defines an `onExit` guard, it will be executed before
79
- * transitioning. If the guard returns `false` (or resolves to `false`),
80
- * the transition is cancelled.
65
+ * Executes:
66
+ * - onExit guard
67
+ * - context merge
68
+ * - step recomposition
69
+ * - navigation
81
70
  *
82
- * @param context - Optional contextual data passed to the `onExit` guard.
71
+ * @param partialContext Optional context updates.
72
+ * @param completionProcedure Optional procedure to run when the wizard is completed.
83
73
  */
84
- next(context?: any): Promise<void>;
74
+ next(partialContext?: Partial<T>): Promise<void>;
85
75
  /**
86
- * Moves the wizard to the previous step if possible.
87
- *
88
- * No guards are executed during backward navigation.
76
+ * Navigates to the previous step.
89
77
  */
90
78
  previous(): void;
91
79
  /**
92
- * Determines whether the current step is the final step.
93
- *
94
- * @returns `true` if on the last step; otherwise `false`.
80
+ * Returns whether the wizard is currently on the last step.
95
81
  */
96
82
  isLast(): boolean;
97
83
  /**
98
- * Sets whether forward navigation is currently permitted.
99
- *
100
- * This is typically controlled by external validation logic (e.g., form state).
101
- *
102
- * @param available - `true` if forward navigation should be allowed.
84
+ * Sets forward navigation availability.
103
85
  */
104
86
  setStepForwardAvailability(available: boolean): void;
105
87
  /**
106
- * Emits the forward navigation availability state.
107
- *
108
- * @returns Observable stream of the forward navigation flag.
88
+ * Returns observable forward navigation state.
109
89
  */
110
90
  getStepForwardAvailability(): Observable<boolean>;
111
91
  /**
112
- * Navigates the router to the currently active step.
113
- *
114
- * This method updates the URL relative to the injected route
115
- * using the pattern: `step-{slug}`.
116
- *
117
- * @internal
92
+ * Navigates the Angular router to the current step.
118
93
  */
119
94
  private navigate;
120
- /**
121
- * Navigates the router away from any "step" route.
122
- *
123
- * This methods updates the URL relative to the injected route, removing every after `/step-
124
- */
125
- clearStepRoute(): void;
126
95
  static ɵfac: i0.ɵɵFactoryDeclaration<WizardStepService<any>, never>;
127
96
  static ɵprov: i0.ɵɵInjectableDeclaration<WizardStepService<any>>;
128
97
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "windows-plus-utilities",
3
- "version": "0.0.88",
3
+ "version": "0.0.90",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^17.3.8",
6
6
  "@angular/core": "^17.3.8",
@@ -31,18 +31,18 @@
31
31
  "esm": "./esm2022/context-menu/windows-plus-utilities-context-menu.mjs",
32
32
  "default": "./fesm2022/windows-plus-utilities-context-menu.mjs"
33
33
  },
34
- "./empty-display": {
35
- "types": "./empty-display/index.d.ts",
36
- "esm2022": "./esm2022/empty-display/windows-plus-utilities-empty-display.mjs",
37
- "esm": "./esm2022/empty-display/windows-plus-utilities-empty-display.mjs",
38
- "default": "./fesm2022/windows-plus-utilities-empty-display.mjs"
39
- },
40
34
  "./custom-card": {
41
35
  "types": "./custom-card/index.d.ts",
42
36
  "esm2022": "./esm2022/custom-card/windows-plus-utilities-custom-card.mjs",
43
37
  "esm": "./esm2022/custom-card/windows-plus-utilities-custom-card.mjs",
44
38
  "default": "./fesm2022/windows-plus-utilities-custom-card.mjs"
45
39
  },
40
+ "./empty-display": {
41
+ "types": "./empty-display/index.d.ts",
42
+ "esm2022": "./esm2022/empty-display/windows-plus-utilities-empty-display.mjs",
43
+ "esm": "./esm2022/empty-display/windows-plus-utilities-empty-display.mjs",
44
+ "default": "./fesm2022/windows-plus-utilities-empty-display.mjs"
45
+ },
46
46
  "./job-label": {
47
47
  "types": "./job-label/index.d.ts",
48
48
  "esm2022": "./esm2022/job-label/windows-plus-utilities-job-label.mjs",