@y3krulez/angular-archwizard
Version:
The port of angular-archwizard, supporting IVY and thus being compatible with Angular16+
365 lines • 46.5 kB
JavaScript
import { Component, ContentChildren, HostBinding, Input, } from '@angular/core';
import { WizardStep } from '../util/wizard-step.interface';
import { MovingDirection } from '../util/moving-direction.enum';
import { ConfigurableNavigationMode } from '../navigation/configurable-navigation-mode';
import { WIZARD_TOKEN } from '../navigation/wizard.interface';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "./wizard-navigation-bar.component";
/**
* The `aw-wizard` component defines the root component of a wizard.
* Through the setting of input parameters for the `aw-wizard` component it's possible to change the location and size
* of its navigation bar.
*
* ### Syntax
* ```html
* <aw-wizard [navBarLocation]="location of navigation bar" [navBarLayout]="layout of navigation bar">
* ...
* </aw-wizard>
* ```
*
* ### Example
*
* Without completion step:
*
* ```html
* <aw-wizard navBarLocation="top" navBarLayout="small">
* <aw-wizard-step>...</aw-wizard-step>
* <aw-wizard-step>...</aw-wizard-step>
* </aw-wizard>
* ```
*
* With completion step:
*
* ```html
* <aw-wizard navBarLocation="top" navBarLayout="small">
* <aw-wizard-step>...</aw-wizard-step>
* <aw-wizard-step>...</aw-wizard-step>
* <aw-wizard-completion-step>...</aw-wizard-completion-step>
* </aw-wizard>
* ```
*
* @author Marc Arndt
*/
export class WizardComponent {
/**
* The initially selected step, represented by its index
* Beware: This initial default is only used if no wizard step has been enhanced with the `selected` directive
*/
get defaultStepIndex() {
// This value can be either:
// - the index of a wizard step with a `selected` directive, or
// - the default step index, set in the [[WizardComponent]]
const foundDefaultStep = this.wizardSteps.find(step => step.defaultSelected);
if (foundDefaultStep) {
return this.getIndexOfStep(foundDefaultStep);
}
else {
return this._defaultStepIndex;
}
}
set defaultStepIndex(defaultStepIndex) {
this._defaultStepIndex = defaultStepIndex;
}
/**
* Constructor
*/
constructor() {
/**
* The location of the navigation bar inside the wizard.
* This location can be either top, bottom, left or right
*/
this.navBarLocation = 'top';
/**
* The layout of the navigation bar inside the wizard.
* The layout can be either small, large-filled, large-empty or large-symbols
*/
this.navBarLayout = 'small';
/**
* The direction in which the steps inside the navigation bar should be shown.
* The direction can be either `left-to-right` or `right-to-left`
*/
this.navBarDirection = 'left-to-right';
this._defaultStepIndex = 0;
/**
* True, if the navigation bar shouldn't be used for navigating
*/
this.disableNavigationBar = false;
/**
* The navigation mode used to navigate inside the wizard
*
* For outside access, use the [[navigation]] getter.
*/
this._navigation = new ConfigurableNavigationMode();
/**
* An array representation of all wizard steps belonging to this model
*
* For outside access, use the [[wizardSteps]] getter.
*/
this._wizardSteps = [];
/**
* The index of the currently visible and selected step inside the wizardSteps QueryList.
* If this wizard contains no steps, currentStepIndex is -1
*
* Note: Do not modify this field directly. Instead, use navigation methods:
* [[goToStep]], [[goToPreviousStep]], [[goToNextStep]].
*/
this.currentStepIndex = -1;
}
/**
* Returns true if this wizard uses a horizontal orientation.
* The wizard uses a horizontal orientation, iff the navigation bar is shown at the top or bottom of this wizard
*
* @returns True if this wizard uses a horizontal orientation
*/
get horizontalOrientation() {
return this.navBarLocation === 'top' || this.navBarLocation === 'bottom';
}
/**
* Returns true if this wizard uses a vertical orientation.
* The wizard uses a vertical orientation, iff the navigation bar is shown at the left or right of this wizard
*
* @returns True if this wizard uses a vertical orientation
*/
get verticalOrientation() {
return this.navBarLocation === 'left' || this.navBarLocation === 'right';
}
/**
* Initialization work
*/
ngAfterContentInit() {
// add a subscriber to the wizard steps QueryList to listen to changes in the DOM
this.wizardStepsQueryList.changes.subscribe(changedWizardSteps => {
this.updateWizardSteps(changedWizardSteps.toArray());
});
// initialize the model
this.updateWizardSteps(this.wizardStepsQueryList.toArray());
// finally reset the whole wizard component
setTimeout(() => this.reset());
}
/**
* The WizardStep object belonging to the currently visible and selected step.
* The currentStep is always the currently selected wizard step.
* The currentStep can be either completed, if it was visited earlier,
* or not completed, if it is visited for the first time or its state is currently out of date.
*
* If this wizard contains no steps, currentStep is null
*/
get currentStep() {
if (this.hasStep(this.currentStepIndex)) {
return this.wizardSteps[this.currentStepIndex];
}
else {
return null;
}
}
/**
* The completeness of the wizard.
* If the wizard has been completed, i.e. all steps are either completed or optional, this value is true, otherwise it is false
*/
get completed() {
return this.wizardSteps.every(step => step.completed || step.optional);
}
/**
* An array representation of all wizard steps belonging to this model
*/
get wizardSteps() {
return this._wizardSteps;
}
/**
* Updates the wizard steps to the new array
*
* @param wizardSteps The updated wizard steps
*/
updateWizardSteps(wizardSteps) {
// the wizard is currently not in the initialization phase
if (this.wizardSteps.length > 0 && this.currentStepIndex > -1) {
this.currentStepIndex = wizardSteps.indexOf(this.wizardSteps[this.currentStepIndex]);
}
this._wizardSteps = wizardSteps;
}
/**
* The navigation mode used to navigate inside the wizard
*/
get navigation() {
return this._navigation;
}
/**
* Updates the navigation mode for this wizard component
*
* @param navigation The updated navigation mode
*/
set navigation(navigation) {
this._navigation = navigation;
}
/**
* Checks if a given index `stepIndex` is inside the range of possible wizard steps inside this wizard
*
* @param stepIndex The to be checked index of a step inside this wizard
* @returns True if the given `stepIndex` is contained inside this wizard, false otherwise
*/
hasStep(stepIndex) {
return this.wizardSteps.length > 0 && 0 <= stepIndex && stepIndex < this.wizardSteps.length;
}
/**
* Checks if this wizard has a previous step, compared to the current step
*
* @returns True if this wizard has a previous step before the current step
*/
hasPreviousStep() {
return this.hasStep(this.currentStepIndex - 1);
}
/**
* Checks if this wizard has a next step, compared to the current step
*
* @returns True if this wizard has a next step after the current step
*/
hasNextStep() {
return this.hasStep(this.currentStepIndex + 1);
}
/**
* Checks if this wizard is currently inside its last step
*
* @returns True if the wizard is currently inside its last step
*/
isLastStep() {
return this.wizardSteps.length > 0 && this.currentStepIndex === this.wizardSteps.length - 1;
}
/**
* Finds the [[WizardStep]] at the given index `stepIndex`.
* If no [[WizardStep]] exists at the given index an Error is thrown
*
* @param stepIndex The given index
* @returns The found [[WizardStep]] at the given index `stepIndex`
* @throws An `Error` is thrown, if the given index `stepIndex` doesn't exist
*/
getStepAtIndex(stepIndex) {
if (!this.hasStep(stepIndex)) {
throw new Error(`Expected a known step, but got stepIndex: ${stepIndex}.`);
}
return this.wizardSteps[stepIndex];
}
/**
* Finds the index of the step with the given `stepId`.
* If no step with the given `stepId` exists, `-1` is returned
*
* @param stepId The given step id
* @returns The found index of a step with the given step id, or `-1` if no step with the given id is included in the wizard
*/
getIndexOfStepWithId(stepId) {
return this.wizardSteps.findIndex(step => step.stepId === stepId);
}
/**
* Finds the index of the given [[WizardStep]] `step`.
* If the given [[WizardStep]] is not contained inside this wizard, `-1` is returned
*
* @param step The given [[WizardStep]]
* @returns The found index of `step` or `-1` if the step is not included in the wizard
*/
getIndexOfStep(step) {
return this.wizardSteps.indexOf(step);
}
/**
* Calculates the correct [[MovingDirection]] value for a given `destinationStep` compared to the `currentStepIndex`.
*
* @param destinationStep The given destination step
* @returns The calculated [[MovingDirection]]
*/
getMovingDirection(destinationStep) {
let movingDirection;
if (destinationStep > this.currentStepIndex) {
movingDirection = MovingDirection.Forwards;
}
else if (destinationStep < this.currentStepIndex) {
movingDirection = MovingDirection.Backwards;
}
else {
movingDirection = MovingDirection.Stay;
}
return movingDirection;
}
/**
* Checks, whether a wizard step, as defined by the given destination index, can be transitioned to.
*
* This method controls navigation by [[goToStep]], [[goToPreviousStep]], and [[goToNextStep]] directives.
* Navigation by navigation bar is governed by [[isNavigable]].
*
* @param destinationIndex The index of the destination step
* @returns A [[Promise]] containing `true`, if the destination step can be transitioned to and false otherwise
*/
canGoToStep(destinationIndex) {
return this.navigation.canGoToStep(this, destinationIndex);
}
/**
* Tries to transition to the wizard step, as denoted by the given destination index.
*
* Note: You do not have to call [[canGoToStep]] before calling [[goToStep]].
* The [[canGoToStep]] method will be called automatically.
*
* @param destinationIndex The index of the destination wizard step, which should be entered
* @param preFinalize An event emitter, to be called before the step has been transitioned
* @param postFinalize An event emitter, to be called after the step has been transitioned
*/
goToStep(destinationIndex, preFinalize, postFinalize) {
return this.navigation.goToStep(this, destinationIndex, preFinalize, postFinalize);
}
/**
* Tries to transition the wizard to the previous step
*
* @param preFinalize An event emitter, to be called before the step has been transitioned
* @param postFinalize An event emitter, to be called after the step has been transitioned
*/
goToPreviousStep(preFinalize, postFinalize) {
return this.navigation.goToStep(this, this.currentStepIndex - 1, preFinalize, postFinalize);
}
/**
* Tries to transition the wizard to the next step
*
* @param preFinalize An event emitter, to be called before the step has been transitioned
* @param postFinalize An event emitter, to be called after the step has been transitioned
*/
goToNextStep(preFinalize, postFinalize) {
return this.navigation.goToStep(this, this.currentStepIndex + 1, preFinalize, postFinalize);
}
/**
* Checks, whether the wizard step, located at the given index, can be navigated to using the navigation bar.
*
* @param destinationIndex The index of the destination step
* @returns True if the step can be navigated to, false otherwise
*/
isNavigable(destinationIndex) {
return this.navigation.isNavigable(this, destinationIndex);
}
/**
* Resets the state of this wizard.
*/
reset() {
this.navigation.reset(this);
}
}
WizardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: WizardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
WizardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: WizardComponent, selector: "aw-wizard", inputs: { navBarLocation: "navBarLocation", navBarLayout: "navBarLayout", navBarDirection: "navBarDirection", defaultStepIndex: "defaultStepIndex", disableNavigationBar: "disableNavigationBar" }, host: { properties: { "class.horizontal": "this.horizontalOrientation", "class.vertical": "this.verticalOrientation" } }, providers: [{ provide: WIZARD_TOKEN, useExisting: WizardComponent }], queries: [{ propertyName: "wizardStepsQueryList", predicate: WizardStep, descendants: true }], ngImport: i0, template: "<aw-wizard-navigation-bar\r\n *ngIf=\"navBarLocation == 'top' || navBarLocation == 'left'\"\r\n [ngClass]=\"{\r\n 'vertical': navBarLocation == 'left',\r\n 'horizontal': navBarLocation == 'top',\r\n 'small': navBarLayout == 'small',\r\n 'large-filled': navBarLayout == 'large-filled',\r\n 'large-filled-symbols': navBarLayout == 'large-filled-symbols',\r\n 'large-empty': navBarLayout == 'large-empty',\r\n 'large-empty-symbols': navBarLayout == 'large-empty-symbols'\r\n }\">\r\n</aw-wizard-navigation-bar>\r\n\r\n<div [ngClass]=\"{\r\n 'wizard-steps': true,\r\n 'vertical': navBarLocation == 'left' || navBarLocation == 'right',\r\n 'horizontal': navBarLocation == 'top' || navBarLocation == 'bottom'\r\n}\">\r\n <ng-content></ng-content>\r\n</div>\r\n\r\n<aw-wizard-navigation-bar\r\n *ngIf=\"navBarLocation == 'bottom' || navBarLocation == 'right'\"\r\n [ngClass]=\"{\r\n 'vertical': navBarLocation == 'right',\r\n 'horizontal': navBarLocation == 'bottom',\r\n 'small': navBarLayout == 'small',\r\n 'large-filled': navBarLayout == 'large-filled',\r\n 'large-filled-symbols': navBarLayout == 'large-filled-symbols',\r\n 'large-empty': navBarLayout == 'large-empty',\r\n 'large-empty-symbols': navBarLayout == 'large-empty-symbols'\r\n }\">\r\n</aw-wizard-navigation-bar>\r\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.WizardNavigationBarComponent, selector: "aw-wizard-navigation-bar" }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: WizardComponent, decorators: [{
type: Component,
args: [{ selector: 'aw-wizard', providers: [{ provide: WIZARD_TOKEN, useExisting: WizardComponent }], template: "<aw-wizard-navigation-bar\r\n *ngIf=\"navBarLocation == 'top' || navBarLocation == 'left'\"\r\n [ngClass]=\"{\r\n 'vertical': navBarLocation == 'left',\r\n 'horizontal': navBarLocation == 'top',\r\n 'small': navBarLayout == 'small',\r\n 'large-filled': navBarLayout == 'large-filled',\r\n 'large-filled-symbols': navBarLayout == 'large-filled-symbols',\r\n 'large-empty': navBarLayout == 'large-empty',\r\n 'large-empty-symbols': navBarLayout == 'large-empty-symbols'\r\n }\">\r\n</aw-wizard-navigation-bar>\r\n\r\n<div [ngClass]=\"{\r\n 'wizard-steps': true,\r\n 'vertical': navBarLocation == 'left' || navBarLocation == 'right',\r\n 'horizontal': navBarLocation == 'top' || navBarLocation == 'bottom'\r\n}\">\r\n <ng-content></ng-content>\r\n</div>\r\n\r\n<aw-wizard-navigation-bar\r\n *ngIf=\"navBarLocation == 'bottom' || navBarLocation == 'right'\"\r\n [ngClass]=\"{\r\n 'vertical': navBarLocation == 'right',\r\n 'horizontal': navBarLocation == 'bottom',\r\n 'small': navBarLayout == 'small',\r\n 'large-filled': navBarLayout == 'large-filled',\r\n 'large-filled-symbols': navBarLayout == 'large-filled-symbols',\r\n 'large-empty': navBarLayout == 'large-empty',\r\n 'large-empty-symbols': navBarLayout == 'large-empty-symbols'\r\n }\">\r\n</aw-wizard-navigation-bar>\r\n" }]
}], ctorParameters: function () { return []; }, propDecorators: { wizardStepsQueryList: [{
type: ContentChildren,
args: [WizardStep, { descendants: true }]
}], navBarLocation: [{
type: Input
}], navBarLayout: [{
type: Input
}], navBarDirection: [{
type: Input
}], defaultStepIndex: [{
type: Input
}], disableNavigationBar: [{
type: Input
}], horizontalOrientation: [{
type: HostBinding,
args: ['class.horizontal']
}], verticalOrientation: [{
type: HostBinding,
args: ['class.vertical']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wizard.component.js","sourceRoot":"","sources":["../../../../src/lib/components/wizard.component.ts","../../../../src/lib/components/wizard.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentInit,\r\n  Component,\r\n  ContentChildren,\r\n  HostBinding,\r\n  Input,\r\n  QueryList,\r\n  EventEmitter,\r\n} from '@angular/core';\r\nimport {NavigationMode} from '../navigation/navigation-mode.interface';\r\nimport {WizardStep} from '../util/wizard-step.interface';\r\nimport {MovingDirection} from '../util/moving-direction.enum';\r\nimport {ConfigurableNavigationMode} from '../navigation/configurable-navigation-mode';\r\nimport { WIZARD_TOKEN, Wizard } from '../navigation/wizard.interface';\r\n\r\n/**\r\n * The `aw-wizard` component defines the root component of a wizard.\r\n * Through the setting of input parameters for the `aw-wizard` component it's possible to change the location and size\r\n * of its navigation bar.\r\n *\r\n * ### Syntax\r\n * ```html\r\n * <aw-wizard [navBarLocation]=\"location of navigation bar\" [navBarLayout]=\"layout of navigation bar\">\r\n *     ...\r\n * </aw-wizard>\r\n * ```\r\n *\r\n * ### Example\r\n *\r\n * Without completion step:\r\n *\r\n * ```html\r\n * <aw-wizard navBarLocation=\"top\" navBarLayout=\"small\">\r\n *     <aw-wizard-step>...</aw-wizard-step>\r\n *     <aw-wizard-step>...</aw-wizard-step>\r\n * </aw-wizard>\r\n * ```\r\n *\r\n * With completion step:\r\n *\r\n * ```html\r\n * <aw-wizard navBarLocation=\"top\" navBarLayout=\"small\">\r\n *     <aw-wizard-step>...</aw-wizard-step>\r\n *     <aw-wizard-step>...</aw-wizard-step>\r\n *     <aw-wizard-completion-step>...</aw-wizard-completion-step>\r\n * </aw-wizard>\r\n * ```\r\n *\r\n * @author Marc Arndt\r\n */\r\n@Component({\r\n  selector: 'aw-wizard',\r\n  templateUrl: 'wizard.component.html',\r\n  providers: [{ provide: WIZARD_TOKEN, useExisting: WizardComponent }]\r\n})\r\nexport class WizardComponent implements AfterContentInit, Wizard {\r\n  /**\r\n   * A QueryList containing all [[WizardStep]]s inside this wizard\r\n   */\r\n  @ContentChildren(WizardStep, { descendants: true })\r\n  public wizardStepsQueryList: QueryList<WizardStep>;\r\n\r\n  /**\r\n   * The location of the navigation bar inside the wizard.\r\n   * This location can be either top, bottom, left or right\r\n   */\r\n  @Input()\r\n  public navBarLocation = 'top';\r\n\r\n  /**\r\n   * The layout of the navigation bar inside the wizard.\r\n   * The layout can be either small, large-filled, large-empty or large-symbols\r\n   */\r\n  @Input()\r\n  public navBarLayout = 'small';\r\n\r\n  /**\r\n   * The direction in which the steps inside the navigation bar should be shown.\r\n   * The direction can be either `left-to-right` or `right-to-left`\r\n   */\r\n  @Input()\r\n  public navBarDirection = 'left-to-right';\r\n\r\n  /**\r\n   * The initially selected step, represented by its index\r\n   * Beware: This initial default is only used if no wizard step has been enhanced with the `selected` directive\r\n   */\r\n  @Input()\r\n  public get defaultStepIndex(): number {\r\n    // This value can be either:\r\n    // - the index of a wizard step with a `selected` directive, or\r\n    // - the default step index, set in the [[WizardComponent]]\r\n\r\n    const foundDefaultStep = this.wizardSteps.find(step => step.defaultSelected);\r\n\r\n    if (foundDefaultStep) {\r\n      return this.getIndexOfStep(foundDefaultStep);\r\n    } else {\r\n      return this._defaultStepIndex;\r\n    }\r\n  }\r\n  public set defaultStepIndex(defaultStepIndex: number) {\r\n    this._defaultStepIndex = defaultStepIndex;\r\n  }\r\n  private _defaultStepIndex = 0;\r\n\r\n  /**\r\n   * True, if the navigation bar shouldn't be used for navigating\r\n   */\r\n  @Input()\r\n  public disableNavigationBar = false;\r\n\r\n  /**\r\n   * The navigation mode used to navigate inside the wizard\r\n   *\r\n   * For outside access, use the [[navigation]] getter.\r\n   */\r\n  private _navigation: NavigationMode = new ConfigurableNavigationMode();\r\n\r\n  /**\r\n   * An array representation of all wizard steps belonging to this model\r\n   *\r\n   * For outside access, use the [[wizardSteps]] getter.\r\n   */\r\n  private _wizardSteps: WizardStep[] = [];\r\n\r\n  /**\r\n   * The index of the currently visible and selected step inside the wizardSteps QueryList.\r\n   * If this wizard contains no steps, currentStepIndex is -1\r\n   *\r\n   * Note: Do not modify this field directly.  Instead, use navigation methods:\r\n   * [[goToStep]], [[goToPreviousStep]], [[goToNextStep]].\r\n   */\r\n  public currentStepIndex = -1;\r\n\r\n  /**\r\n   * Constructor\r\n   */\r\n  constructor() {\r\n  }\r\n\r\n  /**\r\n   * Returns true if this wizard uses a horizontal orientation.\r\n   * The wizard uses a horizontal orientation, iff the navigation bar is shown at the top or bottom of this wizard\r\n   *\r\n   * @returns True if this wizard uses a horizontal orientation\r\n   */\r\n  @HostBinding('class.horizontal')\r\n  public get horizontalOrientation(): boolean {\r\n    return this.navBarLocation === 'top' || this.navBarLocation === 'bottom';\r\n  }\r\n\r\n  /**\r\n   * Returns true if this wizard uses a vertical orientation.\r\n   * The wizard uses a vertical orientation, iff the navigation bar is shown at the left or right of this wizard\r\n   *\r\n   * @returns True if this wizard uses a vertical orientation\r\n   */\r\n  @HostBinding('class.vertical')\r\n  public get verticalOrientation(): boolean {\r\n    return this.navBarLocation === 'left' || this.navBarLocation === 'right';\r\n  }\r\n\r\n  /**\r\n   * Initialization work\r\n   */\r\n  public ngAfterContentInit(): void {\r\n    // add a subscriber to the wizard steps QueryList to listen to changes in the DOM\r\n    this.wizardStepsQueryList.changes.subscribe(changedWizardSteps => {\r\n      this.updateWizardSteps(changedWizardSteps.toArray());\r\n    });\r\n\r\n    // initialize the model\r\n    this.updateWizardSteps(this.wizardStepsQueryList.toArray());\r\n\r\n    // finally reset the whole wizard component\r\n    setTimeout(() => this.reset());\r\n  }\r\n\r\n  /**\r\n   * The WizardStep object belonging to the currently visible and selected step.\r\n   * The currentStep is always the currently selected wizard step.\r\n   * The currentStep can be either completed, if it was visited earlier,\r\n   * or not completed, if it is visited for the first time or its state is currently out of date.\r\n   *\r\n   * If this wizard contains no steps, currentStep is null\r\n   */\r\n  public get currentStep(): WizardStep {\r\n    if (this.hasStep(this.currentStepIndex)) {\r\n      return this.wizardSteps[this.currentStepIndex];\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * The completeness of the wizard.\r\n   * If the wizard has been completed, i.e. all steps are either completed or optional, this value is true, otherwise it is false\r\n   */\r\n  public get completed(): boolean {\r\n    return this.wizardSteps.every(step => step.completed || step.optional);\r\n  }\r\n\r\n  /**\r\n   * An array representation of all wizard steps belonging to this model\r\n   */\r\n  public get wizardSteps(): WizardStep[] {\r\n    return this._wizardSteps;\r\n  }\r\n\r\n  /**\r\n   * Updates the wizard steps to the new array\r\n   *\r\n   * @param wizardSteps The updated wizard steps\r\n   */\r\n  private updateWizardSteps(wizardSteps: WizardStep[]): void {\r\n    // the wizard is currently not in the initialization phase\r\n    if (this.wizardSteps.length > 0 && this.currentStepIndex > -1) {\r\n      this.currentStepIndex = wizardSteps.indexOf(this.wizardSteps[this.currentStepIndex]);\r\n    }\r\n\r\n    this._wizardSteps = wizardSteps;\r\n  }\r\n\r\n  /**\r\n   * The navigation mode used to navigate inside the wizard\r\n   */\r\n  public get navigation(): NavigationMode {\r\n    return this._navigation;\r\n  }\r\n\r\n  /**\r\n   * Updates the navigation mode for this wizard component\r\n   *\r\n   * @param navigation The updated navigation mode\r\n   */\r\n  public set navigation(navigation: NavigationMode) {\r\n    this._navigation = navigation;\r\n  }\r\n\r\n  /**\r\n   * Checks if a given index `stepIndex` is inside the range of possible wizard steps inside this wizard\r\n   *\r\n   * @param stepIndex The to be checked index of a step inside this wizard\r\n   * @returns True if the given `stepIndex` is contained inside this wizard, false otherwise\r\n   */\r\n  public hasStep(stepIndex: number): boolean {\r\n    return this.wizardSteps.length > 0 && 0 <= stepIndex && stepIndex < this.wizardSteps.length;\r\n  }\r\n\r\n  /**\r\n   * Checks if this wizard has a previous step, compared to the current step\r\n   *\r\n   * @returns True if this wizard has a previous step before the current step\r\n   */\r\n  public hasPreviousStep(): boolean {\r\n    return this.hasStep(this.currentStepIndex - 1);\r\n  }\r\n\r\n  /**\r\n   * Checks if this wizard has a next step, compared to the current step\r\n   *\r\n   * @returns True if this wizard has a next step after the current step\r\n   */\r\n  public hasNextStep(): boolean {\r\n    return this.hasStep(this.currentStepIndex + 1);\r\n  }\r\n\r\n  /**\r\n   * Checks if this wizard is currently inside its last step\r\n   *\r\n   * @returns True if the wizard is currently inside its last step\r\n   */\r\n  public isLastStep(): boolean {\r\n    return this.wizardSteps.length > 0 && this.currentStepIndex === this.wizardSteps.length - 1;\r\n  }\r\n\r\n  /**\r\n   * Finds the [[WizardStep]] at the given index `stepIndex`.\r\n   * If no [[WizardStep]] exists at the given index an Error is thrown\r\n   *\r\n   * @param stepIndex The given index\r\n   * @returns The found [[WizardStep]] at the given index `stepIndex`\r\n   * @throws An `Error` is thrown, if the given index `stepIndex` doesn't exist\r\n   */\r\n  public getStepAtIndex(stepIndex: number): WizardStep {\r\n    if (!this.hasStep(stepIndex)) {\r\n      throw new Error(`Expected a known step, but got stepIndex: ${stepIndex}.`);\r\n    }\r\n\r\n    return this.wizardSteps[stepIndex];\r\n  }\r\n\r\n  /**\r\n   * Finds the index of the step with the given `stepId`.\r\n   * If no step with the given `stepId` exists, `-1` is returned\r\n   *\r\n   * @param stepId The given step id\r\n   * @returns The found index of a step with the given step id, or `-1` if no step with the given id is included in the wizard\r\n   */\r\n  public getIndexOfStepWithId(stepId: string): number {\r\n    return this.wizardSteps.findIndex(step => step.stepId === stepId);\r\n  }\r\n\r\n  /**\r\n   * Finds the index of the given [[WizardStep]] `step`.\r\n   * If the given [[WizardStep]] is not contained inside this wizard, `-1` is returned\r\n   *\r\n   * @param step The given [[WizardStep]]\r\n   * @returns The found index of `step` or `-1` if the step is not included in the wizard\r\n   */\r\n  public getIndexOfStep(step: WizardStep): number {\r\n    return this.wizardSteps.indexOf(step);\r\n  }\r\n\r\n  /**\r\n   * Calculates the correct [[MovingDirection]] value for a given `destinationStep` compared to the `currentStepIndex`.\r\n   *\r\n   * @param destinationStep The given destination step\r\n   * @returns The calculated [[MovingDirection]]\r\n   */\r\n  public getMovingDirection(destinationStep: number): MovingDirection {\r\n    let movingDirection: MovingDirection;\r\n\r\n    if (destinationStep > this.currentStepIndex) {\r\n      movingDirection = MovingDirection.Forwards;\r\n    } else if (destinationStep < this.currentStepIndex) {\r\n      movingDirection = MovingDirection.Backwards;\r\n    } else {\r\n      movingDirection = MovingDirection.Stay;\r\n    }\r\n\r\n    return movingDirection;\r\n  }\r\n\r\n  /**\r\n   * Checks, whether a wizard step, as defined by the given destination index, can be transitioned to.\r\n   *\r\n   * This method controls navigation by [[goToStep]], [[goToPreviousStep]], and [[goToNextStep]] directives.\r\n   * Navigation by navigation bar is governed by [[isNavigable]].\r\n   *\r\n   * @param destinationIndex The index of the destination step\r\n   * @returns A [[Promise]] containing `true`, if the destination step can be transitioned to and false otherwise\r\n   */\r\n  public canGoToStep(destinationIndex: number): Promise<boolean> {\r\n    return this.navigation.canGoToStep(this, destinationIndex);\r\n  }\r\n\r\n  /**\r\n   * Tries to transition to the wizard step, as denoted by the given destination index.\r\n   *\r\n   * Note: You do not have to call [[canGoToStep]] before calling [[goToStep]].\r\n   * The [[canGoToStep]] method will be called automatically.\r\n   *\r\n   * @param destinationIndex The index of the destination wizard step, which should be entered\r\n   * @param preFinalize An event emitter, to be called before the step has been transitioned\r\n   * @param postFinalize An event emitter, to be called after the step has been transitioned\r\n   */\r\n  public goToStep(destinationIndex: number, preFinalize?: EventEmitter<void>, postFinalize?: EventEmitter<void>): void {\r\n    return this.navigation.goToStep(this, destinationIndex, preFinalize, postFinalize);\r\n  }\r\n\r\n  /**\r\n   * Tries to transition the wizard to the previous step\r\n   *\r\n   * @param preFinalize An event emitter, to be called before the step has been transitioned\r\n   * @param postFinalize An event emitter, to be called after the step has been transitioned\r\n   */\r\n  public goToPreviousStep(preFinalize?: EventEmitter<void>, postFinalize?: EventEmitter<void>): void {\r\n    return this.navigation.goToStep(this, this.currentStepIndex - 1, preFinalize, postFinalize);\r\n  }\r\n\r\n  /**\r\n   * Tries to transition the wizard to the next step\r\n   *\r\n   * @param preFinalize An event emitter, to be called before the step has been transitioned\r\n   * @param postFinalize An event emitter, to be called after the step has been transitioned\r\n   */\r\n  public goToNextStep(preFinalize?: EventEmitter<void>, postFinalize?: EventEmitter<void>): void {\r\n    return this.navigation.goToStep(this, this.currentStepIndex + 1, preFinalize, postFinalize);\r\n  }\r\n\r\n  /**\r\n   * Checks, whether the wizard step, located at the given index, can be navigated to using the navigation bar.\r\n   *\r\n   * @param destinationIndex The index of the destination step\r\n   * @returns True if the step can be navigated to, false otherwise\r\n   */\r\n  public isNavigable(destinationIndex: number): boolean {\r\n    return this.navigation.isNavigable(this, destinationIndex);\r\n  }\r\n\r\n  /**\r\n   * Resets the state of this wizard.\r\n   */\r\n  public reset(): void {\r\n    this.navigation.reset(this);\r\n  }\r\n}\r\n","<aw-wizard-navigation-bar\r\n  *ngIf=\"navBarLocation == 'top' || navBarLocation == 'left'\"\r\n  [ngClass]=\"{\r\n    'vertical': navBarLocation == 'left',\r\n    'horizontal': navBarLocation == 'top',\r\n    'small': navBarLayout == 'small',\r\n    'large-filled': navBarLayout == 'large-filled',\r\n    'large-filled-symbols': navBarLayout == 'large-filled-symbols',\r\n    'large-empty': navBarLayout == 'large-empty',\r\n    'large-empty-symbols': navBarLayout == 'large-empty-symbols'\r\n  }\">\r\n</aw-wizard-navigation-bar>\r\n\r\n<div [ngClass]=\"{\r\n  'wizard-steps': true,\r\n  'vertical': navBarLocation == 'left' || navBarLocation == 'right',\r\n  'horizontal': navBarLocation == 'top' || navBarLocation == 'bottom'\r\n}\">\r\n  <ng-content></ng-content>\r\n</div>\r\n\r\n<aw-wizard-navigation-bar\r\n  *ngIf=\"navBarLocation == 'bottom' || navBarLocation == 'right'\"\r\n  [ngClass]=\"{\r\n    'vertical': navBarLocation == 'right',\r\n    'horizontal': navBarLocation == 'bottom',\r\n    'small': navBarLayout == 'small',\r\n    'large-filled': navBarLayout == 'large-filled',\r\n    'large-filled-symbols': navBarLayout == 'large-filled-symbols',\r\n    'large-empty': navBarLayout == 'large-empty',\r\n    'large-empty-symbols': navBarLayout == 'large-empty-symbols'\r\n  }\">\r\n</aw-wizard-navigation-bar>\r\n"]}