@kronscht/ng-wizard
Version:
Angular ng-wizard - Angular wizard | stepper
393 lines • 62.2 kB
JavaScript
import { Component, Input, EventEmitter, Output, ContentChildren, QueryList } from '@angular/core';
import { isObservable, of } from 'rxjs';
import { NgWizardDataService } from '../ng-wizard-data.service';
import { NgWizardStep } from '../../utils/interfaces';
import { TOOLBAR_POSITION, STEP_STATE, STEP_STATUS, STEP_DIRECTIN, STEP_POSITION } from '../../utils/enums';
import { merge } from '../../utils/functions';
import * as i0 from "@angular/core";
import * as i1 from "../ng-wizard-data.service";
import * as i2 from "@angular/common";
export class NgWizardComponent {
constructor(ngWizardDataService) {
this.ngWizardDataService = ngWizardDataService;
this.stepChanged = new EventEmitter();
this.themeChanged = new EventEmitter();
this.reseted = new EventEmitter();
this.styles = {};
this.showToolbarTop = false;
this.showPreviousButton = false;
this.showNextButton = false;
this.showToolbarBottom = false;
this.showExtraButtons = false;
this.currentStepIndex = null; // Active step index
}
get pConfig() {
return this._pConfig || {};
}
set pConfig(config) {
this._pConfig = config;
}
ngAfterContentInit() {
this._backupStepStates();
this._init();
// Set toolbar
this._setToolbar();
// Assign plugin events
this._setEvents();
this.resetWizardWatcher = this.ngWizardDataService.resetWizard$.subscribe(() => this._reset());
this.showNextStepWatcher = this.ngWizardDataService.showNextStep$.subscribe(() => this._showNextStep());
this.showPreviousStepWatcher = this.ngWizardDataService.showPreviousStep$.subscribe(() => this._showPreviousStep());
this.showStepWatcher = this.ngWizardDataService.showStep$.subscribe(index => this._showStep(index));
this.setThemeWatcher = this.ngWizardDataService.setTheme$.subscribe(theme => this._setTheme(theme));
}
_init() {
// set config
let defaultConfig = this.ngWizardDataService.getDefaultConfig();
this.config = merge(defaultConfig, this.pConfig);
// set step states
this._initSteps();
// Set the elements
this._initStyles();
// Show the initial step
this._showStep(this.config.selected);
}
_initSteps() {
this.steps.forEach((step, index) => {
step.index = index;
step.status = step.status || STEP_STATUS.untouched;
step.state = step.state || STEP_STATE.normal;
});
// Mark previous steps of the active step as done
if (this.config.selected > 0
&& this.config.anchorSettings.markDoneStep
&& this.config.anchorSettings.markAllPreviousStepsAsDone) {
this.steps.forEach(step => {
if (step.state != STEP_STATE.disabled && step.state != STEP_STATE.hidden) {
step.status = step.index < this.config.selected ? STEP_STATUS.done : step.status;
}
});
}
}
_backupStepStates() {
this.steps.forEach(step => {
step.initialStatus = step.status;
step.initialState = step.state;
});
}
_restoreStepStates() {
this.steps.forEach(step => {
step.status = step.initialStatus;
step.state = step.initialState;
});
}
// PRIVATE FUNCTIONS
_initStyles() {
// Set the main element
this.styles.main = 'ng-wizard-main ng-wizard-theme-' + this.config.theme;
// Set anchor elements
this.styles.step = 'nav-item'; // li
// Make the anchor clickable
if (this.config.anchorSettings.enableAllAnchors && this.config.anchorSettings.anchorClickable) {
this.styles.step += ' clickable';
}
// Set the toolbar styles
this.styles.toolbarTop = 'btn-toolbar ng-wizard-toolbar ng-wizard-toolbar-top justify-content-' + this.config.toolbarSettings.toolbarButtonPosition;
this.styles.toolbarBottom = 'btn-toolbar ng-wizard-toolbar ng-wizard-toolbar-bottom justify-content-' + this.config.toolbarSettings.toolbarButtonPosition;
// Set previous&next buttons
this.styles.previousButton = 'btn btn-secondary ng-wizard-btn-prev';
this.styles.nextButton = 'btn btn-secondary ng-wizard-btn-next';
}
_setToolbar() {
this.showToolbarTop = this.config.toolbarSettings.toolbarPosition == TOOLBAR_POSITION.top ||
this.config.toolbarSettings.toolbarPosition == TOOLBAR_POSITION.both;
this.showToolbarBottom = this.config.toolbarSettings.toolbarPosition == TOOLBAR_POSITION.bottom ||
this.config.toolbarSettings.toolbarPosition == TOOLBAR_POSITION.both;
this.showPreviousButton = this.config.toolbarSettings.showPreviousButton;
this.showNextButton = this.config.toolbarSettings.showNextButton;
this.showExtraButtons = this.config.toolbarSettings.toolbarExtraButtons && this.config.toolbarSettings.toolbarExtraButtons.length > 0;
}
_setEvents() {
//TODO: keyNavigation
// Keyboard navigation event
if (this.config.keyNavigation) {
// $(document).keyup(function (e) {
// mi._keyNav(e);
// });
}
}
_getStepCssClass(selectedStep) {
let stepClass = this.styles.step;
switch (selectedStep.state) {
case STEP_STATE.disabled:
stepClass += ' disabled';
break;
case STEP_STATE.error:
stepClass += ' danger';
break;
case STEP_STATE.hidden:
stepClass += ' hidden';
break;
}
switch (selectedStep.status) {
case STEP_STATUS.done:
stepClass += ' done';
break;
case STEP_STATUS.active:
stepClass += ' active';
break;
}
return stepClass;
}
_showSelectedStep(event, selectedStep) {
event.preventDefault();
if (!this.config.anchorSettings.anchorClickable) {
return;
}
if (!this.config.anchorSettings.enableAnchorOnDoneStep && selectedStep.status == STEP_STATUS.done) {
return true;
}
if (selectedStep.index != this.currentStepIndex) {
if (this.config.anchorSettings.enableAllAnchors && this.config.anchorSettings.anchorClickable) {
this._showStep(selectedStep.index);
}
else {
if (selectedStep.status == STEP_STATUS.done) {
this._showStep(selectedStep.index);
}
}
}
}
_showNextStep(event) {
if (event) {
event.preventDefault();
}
// Find the next not disabled & hidden step
let filteredSteps = this.steps.filter(step => {
return step.index > (this.currentStepIndex == null ? -1 : this.currentStepIndex)
&& step.state != STEP_STATE.disabled
&& step.state != STEP_STATE.hidden;
});
if (filteredSteps.length == 0) {
if (!this.config.cycleSteps) {
return;
}
this._showStep(0);
}
else {
this._showStep(filteredSteps.shift().index);
}
}
_showPreviousStep(event) {
if (event) {
event.preventDefault();
}
// Find the previous not disabled & hidden step
let filteredSteps = this.steps.filter(step => {
return step.index < (this.currentStepIndex == null && this.config.cycleSteps ? this.steps.length : this.currentStepIndex)
&& step.state != STEP_STATE.disabled
&& step.state != STEP_STATE.hidden;
});
if (filteredSteps.length == 0) {
if (!this.config.cycleSteps) {
return;
}
this._showStep(this.steps.length - 1);
}
else {
this._showStep(filteredSteps.pop().index);
}
}
_showStep(selectedStepIndex) {
// If step not found, skip
if (selectedStepIndex >= this.steps.length || selectedStepIndex < 0) {
return;
}
// If current step is requested again, skip
if (selectedStepIndex == this.currentStepIndex) {
return;
}
let selectedStep = this.steps.toArray()[selectedStepIndex];
// If it is a disabled or hidden step, skip
if (selectedStep.state == STEP_STATE.disabled || selectedStep.state == STEP_STATE.hidden) {
return;
}
this._showLoader();
return this._isStepChangeValid(selectedStep, this.currentStep && this.currentStep.canExit).toPromise()
.then(isValid => {
if (isValid) {
return this._isStepChangeValid(selectedStep, selectedStep.canEnter).toPromise();
}
return of(isValid).toPromise();
})
.then(isValid => {
if (isValid) {
// Load step content
this._loadStepContent(selectedStep);
}
})
.finally(() => this._hideLoader());
}
_isStepChangeValid(selectedStep, condition) {
if (typeof condition === typeof true) {
return of(condition);
}
else if (condition instanceof Function) {
let direction = this._getStepDirection(selectedStep.index);
let result = condition({ direction: direction, fromStep: this.currentStep, toStep: selectedStep });
if (isObservable(result)) {
return result;
}
else if (typeof result === typeof true) {
return of(result);
}
else {
return of(false);
}
}
return of(true);
}
_loadStepContent(selectedStep) {
// Update controls
this._setAnchor(selectedStep);
// Set the buttons based on the step
this._setButtons(selectedStep.index);
// Trigger "stepChanged" event
const args = {
step: selectedStep,
previousStep: this.currentStep,
direction: this._getStepDirection(selectedStep.index),
position: this._getStepPosition(selectedStep.index)
};
this.stepChanged.emit(args);
this.ngWizardDataService.stepChanged(args);
// Update the current index
this.currentStepIndex = selectedStep.index;
this.currentStep = selectedStep;
}
_setAnchor(selectedStep) {
// Current step anchor > Remove other classes and add done class
if (this.currentStep) {
this.currentStep.status = STEP_STATUS.untouched;
if (this.config.anchorSettings.markDoneStep) {
this.currentStep.status = STEP_STATUS.done;
if (this.config.anchorSettings.removeDoneStepOnNavigateBack) {
this.steps.forEach(step => {
if (step.index > selectedStep.index) {
step.status = STEP_STATUS.untouched;
}
});
}
}
}
// Next step anchor > Remove other classes and add active class
selectedStep.status = STEP_STATUS.active;
}
_setButtons(index) {
// Previous/Next Button enable/disable based on step
if (!this.config.cycleSteps) {
if (0 >= index) {
this.styles.previousButton = 'btn btn-secondary ng-wizard-btn-prev disabled';
}
else {
this.styles.previousButton = 'btn btn-secondary ng-wizard-btn-prev';
}
if (this.steps.length - 1 <= index) {
this.styles.nextButton = 'btn btn-secondary ng-wizard-btn-next disabled';
}
else {
this.styles.nextButton = 'btn btn-secondary ng-wizard-btn-next';
}
}
}
_extraButtonClicked(button) {
if (button.event) {
button.event();
}
}
// HELPER FUNCTIONS
_keyNav(event) {
// Keyboard navigation
switch (event.which) {
case 37:
// left
this._showPreviousStep(event);
event.preventDefault();
break;
case 39:
// right
this._showNextStep(event);
event.preventDefault();
break;
default:
return; // exit this handler for other keys
}
}
_showLoader() {
this.styles.main = 'ng-wizard-main ng-wizard-theme-' + this.config.theme + ' ng-wizard-loading';
}
_hideLoader() {
this.styles.main = 'ng-wizard-main ng-wizard-theme-' + this.config.theme;
}
_getStepDirection(selectedStepIndex) {
return (this.currentStepIndex != null && this.currentStepIndex != selectedStepIndex) ?
(this.currentStepIndex < selectedStepIndex ? STEP_DIRECTIN.forward : STEP_DIRECTIN.backward) : null;
}
_getStepPosition(selectedStepIndex) {
return (selectedStepIndex == 0) ? STEP_POSITION.first : (selectedStepIndex == this.steps.length - 1 ? STEP_POSITION.final : STEP_POSITION.middle);
}
// PUBLIC FUNCTIONS
_setTheme(theme) {
if (this.config.theme == theme) {
return false;
}
this.config.theme = theme;
this.styles.main = 'ng-wizard-main ng-wizard-theme-' + this.config.theme;
// Trigger "themeChanged" event
this.themeChanged.emit(this.config.theme);
}
_reset() {
// Reset all elements and classes
this.currentStepIndex = null;
this.currentStep = null;
this._restoreStepStates();
this._init();
// Trigger "reseted" event
this.reseted.emit();
}
ngOnDestroy() {
if (this.resetWizardWatcher) {
this.resetWizardWatcher.unsubscribe();
}
if (this.showNextStepWatcher) {
this.showNextStepWatcher.unsubscribe();
}
if (this.showPreviousStepWatcher) {
this.showPreviousStepWatcher.unsubscribe();
}
if (this.showStepWatcher) {
this.showStepWatcher.unsubscribe();
}
if (this.setThemeWatcher) {
this.setThemeWatcher.unsubscribe();
}
}
}
NgWizardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: NgWizardComponent, deps: [{ token: i1.NgWizardDataService }], target: i0.ɵɵFactoryTarget.Component });
NgWizardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.2", type: NgWizardComponent, selector: "ng-wizard", inputs: { pConfig: ["config", "pConfig"] }, outputs: { stepChanged: "stepChanged", themeChanged: "themeChanged", reseted: "reseted" }, queries: [{ propertyName: "steps", predicate: NgWizardStep }], ngImport: i0, template: "<div id=\"ngwizard\" [ngClass]=\"styles.main\">\r\n <ul class=\"nav nav-tabs step-anchor\">\r\n <li *ngFor=\"let step of steps; let i = index\" [ngClass]=\"_getStepCssClass(step)\">\r\n <a href=\"#step-{{ i }}\" (click)=\"_showSelectedStep($event, step)\" *ngIf=\"!step.isHidden\"\r\n class=\"nav-link\">{{ step.title }}<br /><small>{{ step.description }}</small></a>\r\n </li>\r\n </ul>\r\n\r\n <div *ngIf=\"showToolbarTop\" [ngClass]=\"styles.toolbarTop\">\r\n <div class=\"btn-group mr-2 ng-wizard-btn-group\" role=\"group\">\r\n <button *ngIf=\"showPreviousButton\" [ngClass]=\"styles.previousButton\" type=\"button\"\r\n (click)=\"_showPreviousStep($event)\">{{ config!.lang!.previous }}</button>\r\n <button *ngIf=\"showNextButton\" [ngClass]=\"styles.nextButton\" type=\"button\"\r\n (click)=\"_showNextStep($event)\">{{ config!.lang!.next }}</button>\r\n </div>\r\n\r\n <div *ngIf=\"showExtraButtons\" class=\"btn-group mr-2 ng-wizard-btn-group-extra\" role=\"group\">\r\n <button *ngFor=\"let button of config!.toolbarSettings!.toolbarExtraButtons; let j = index\"\r\n [ngClass]=\"button.class\" type=\"button\" (click)=\"_extraButtonClicked(button)\">{{ button.text }}</button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"ng-wizard-container tab-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n <div *ngIf=\"showToolbarBottom\" [ngClass]=\"styles.toolbarBottom\">\r\n <div class=\"btn-group mr-2 ng-wizard-btn-group\" role=\"group\">\r\n <button *ngIf=\"showPreviousButton\" [ngClass]=\"styles.previousButton\" type=\"button\"\r\n (click)=\"_showPreviousStep($event)\">{{ config!.lang!.previous }}</button>\r\n <button *ngIf=\"showNextButton\" [ngClass]=\"styles.nextButton\" type=\"button\"\r\n (click)=\"_showNextStep($event)\">{{ config!.lang!.next }}</button>\r\n </div>\r\n\r\n <div *ngIf=\"showExtraButtons\" class=\"btn-group mr-2 ng-wizard-btn-group-extra\" role=\"group\">\r\n <button *ngFor=\"let button of config!.toolbarSettings!.toolbarExtraButtons; let j = index\"\r\n [ngClass]=\"button.class\" type=\"button\" (click)=\"_extraButtonClicked(button)\">{{ button.text }}</button>\r\n </div>\r\n </div>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.2", ngImport: i0, type: NgWizardComponent, decorators: [{
type: Component,
args: [{ selector: 'ng-wizard', template: "<div id=\"ngwizard\" [ngClass]=\"styles.main\">\r\n <ul class=\"nav nav-tabs step-anchor\">\r\n <li *ngFor=\"let step of steps; let i = index\" [ngClass]=\"_getStepCssClass(step)\">\r\n <a href=\"#step-{{ i }}\" (click)=\"_showSelectedStep($event, step)\" *ngIf=\"!step.isHidden\"\r\n class=\"nav-link\">{{ step.title }}<br /><small>{{ step.description }}</small></a>\r\n </li>\r\n </ul>\r\n\r\n <div *ngIf=\"showToolbarTop\" [ngClass]=\"styles.toolbarTop\">\r\n <div class=\"btn-group mr-2 ng-wizard-btn-group\" role=\"group\">\r\n <button *ngIf=\"showPreviousButton\" [ngClass]=\"styles.previousButton\" type=\"button\"\r\n (click)=\"_showPreviousStep($event)\">{{ config!.lang!.previous }}</button>\r\n <button *ngIf=\"showNextButton\" [ngClass]=\"styles.nextButton\" type=\"button\"\r\n (click)=\"_showNextStep($event)\">{{ config!.lang!.next }}</button>\r\n </div>\r\n\r\n <div *ngIf=\"showExtraButtons\" class=\"btn-group mr-2 ng-wizard-btn-group-extra\" role=\"group\">\r\n <button *ngFor=\"let button of config!.toolbarSettings!.toolbarExtraButtons; let j = index\"\r\n [ngClass]=\"button.class\" type=\"button\" (click)=\"_extraButtonClicked(button)\">{{ button.text }}</button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"ng-wizard-container tab-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n <div *ngIf=\"showToolbarBottom\" [ngClass]=\"styles.toolbarBottom\">\r\n <div class=\"btn-group mr-2 ng-wizard-btn-group\" role=\"group\">\r\n <button *ngIf=\"showPreviousButton\" [ngClass]=\"styles.previousButton\" type=\"button\"\r\n (click)=\"_showPreviousStep($event)\">{{ config!.lang!.previous }}</button>\r\n <button *ngIf=\"showNextButton\" [ngClass]=\"styles.nextButton\" type=\"button\"\r\n (click)=\"_showNextStep($event)\">{{ config!.lang!.next }}</button>\r\n </div>\r\n\r\n <div *ngIf=\"showExtraButtons\" class=\"btn-group mr-2 ng-wizard-btn-group-extra\" role=\"group\">\r\n <button *ngFor=\"let button of config!.toolbarSettings!.toolbarExtraButtons; let j = index\"\r\n [ngClass]=\"button.class\" type=\"button\" (click)=\"_extraButtonClicked(button)\">{{ button.text }}</button>\r\n </div>\r\n </div>\r\n</div>" }]
}], ctorParameters: function () { return [{ type: i1.NgWizardDataService }]; }, propDecorators: { steps: [{
type: ContentChildren,
args: [NgWizardStep]
}], pConfig: [{
type: Input,
args: ['config']
}], stepChanged: [{
type: Output
}], themeChanged: [{
type: Output
}], reseted: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-wizard.component.js","sourceRoot":"","sources":["../../../../../../src/ng-wizard/lib/core/wizard/ng-wizard.component.ts","../../../../../../src/ng-wizard/lib/core/wizard/ng-wizard.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, AfterContentInit, Input, OnDestroy, EventEmitter, Output, ContentChildren, QueryList } from '@angular/core';\r\nimport { isObservable, observable, Observable, of, Subscription } from 'rxjs';\r\n\r\nimport { NgWizardDataService } from '../ng-wizard-data.service';\r\nimport { NgWizardConfig, NgWizardStep, ToolbarButton, StepChangedArgs, StepValidationArgs } from '../../utils/interfaces';\r\nimport { TOOLBAR_POSITION, STEP_STATE, STEP_STATUS, THEME, STEP_DIRECTIN, STEP_POSITION } from '../../utils/enums';\r\nimport { merge } from '../../utils/functions';\r\n\r\n@Component({\r\n  selector: 'ng-wizard',\r\n  templateUrl: './ng-wizard.component.html',\r\n  styleUrls: ['./ng-wizard.component.css'],\r\n})\r\nexport class NgWizardComponent implements OnDestroy, AfterContentInit {\r\n\r\n  @ContentChildren(NgWizardStep)\r\n  public steps: QueryList<NgWizardStep>;\r\n\r\n  _pConfig: NgWizardConfig;\r\n  get pConfig(): NgWizardConfig {\r\n    return this._pConfig || {};\r\n  }\r\n\r\n  @Input('config')\r\n  set pConfig(config: NgWizardConfig) {\r\n    this._pConfig = config;\r\n  }\r\n\r\n  config: NgWizardConfig;\r\n\r\n  @Output() stepChanged = new EventEmitter<StepChangedArgs>();\r\n  @Output() themeChanged = new EventEmitter<THEME>();\r\n  @Output() reseted = new EventEmitter<void>();\r\n\r\n  styles: {\r\n    main?: string;\r\n    step?: string;\r\n    previousButton?: string;\r\n    nextButton?: string;\r\n    toolbarTop?: string;\r\n    toolbarBottom?: string;\r\n  } = {};\r\n\r\n  showToolbarTop: boolean = false;\r\n  showPreviousButton: boolean = false;\r\n  showNextButton: boolean = false;\r\n  showToolbarBottom: boolean = false;\r\n  showExtraButtons: boolean = false;\r\n  currentStepIndex: number = null; // Active step index\r\n  currentStep: NgWizardStep; // Active step\r\n\r\n  resetWizardWatcher: Subscription;\r\n  showNextStepWatcher: Subscription;\r\n  showPreviousStepWatcher: Subscription;\r\n  showStepWatcher: Subscription;\r\n  setThemeWatcher: Subscription;\r\n\r\n  constructor(private ngWizardDataService: NgWizardDataService) {\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    this._backupStepStates();\r\n\r\n    this._init();\r\n\r\n    // Set toolbar\r\n    this._setToolbar();\r\n\r\n    // Assign plugin events\r\n    this._setEvents();\r\n\r\n    this.resetWizardWatcher = this.ngWizardDataService.resetWizard$.subscribe(() => this._reset());\r\n    this.showNextStepWatcher = this.ngWizardDataService.showNextStep$.subscribe(() => this._showNextStep());\r\n    this.showPreviousStepWatcher = this.ngWizardDataService.showPreviousStep$.subscribe(() => this._showPreviousStep());\r\n    this.showStepWatcher = this.ngWizardDataService.showStep$.subscribe(index => this._showStep(index));\r\n    this.setThemeWatcher = this.ngWizardDataService.setTheme$.subscribe(theme => this._setTheme(theme));\r\n  }\r\n\r\n  _init() {\r\n    // set config\r\n    let defaultConfig = this.ngWizardDataService.getDefaultConfig();\r\n    this.config = merge(defaultConfig, this.pConfig);\r\n\r\n    // set step states\r\n    this._initSteps();\r\n\r\n    // Set the elements\r\n    this._initStyles();\r\n\r\n    // Show the initial step\r\n    this._showStep(this.config.selected);\r\n  }\r\n\r\n  _initSteps() {\r\n    this.steps.forEach((step, index) => {\r\n      step.index = index;\r\n      step.status = step.status || STEP_STATUS.untouched;\r\n      step.state = step.state || STEP_STATE.normal;\r\n    });\r\n\r\n    // Mark previous steps of the active step as done\r\n    if (this.config.selected > 0\r\n      && this.config.anchorSettings.markDoneStep\r\n      && this.config.anchorSettings.markAllPreviousStepsAsDone) {\r\n\r\n      this.steps.forEach(step => {\r\n        if (step.state != STEP_STATE.disabled && step.state != STEP_STATE.hidden) {\r\n          step.status = step.index < this.config.selected ? STEP_STATUS.done : step.status;\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  _backupStepStates() {\r\n    this.steps.forEach(step => {\r\n      step.initialStatus = step.status;\r\n      step.initialState = step.state;\r\n    });\r\n  }\r\n\r\n  _restoreStepStates() {\r\n    this.steps.forEach(step => {\r\n      step.status = step.initialStatus;\r\n      step.state = step.initialState;\r\n    });\r\n  }\r\n\r\n  // PRIVATE FUNCTIONS\r\n  _initStyles() {\r\n    // Set the main element\r\n    this.styles.main = 'ng-wizard-main ng-wizard-theme-' + this.config.theme;\r\n\r\n    // Set anchor elements\r\n    this.styles.step = 'nav-item'; // li\r\n\r\n    // Make the anchor clickable\r\n    if (this.config.anchorSettings.enableAllAnchors && this.config.anchorSettings.anchorClickable) {\r\n      this.styles.step += ' clickable';\r\n    }\r\n\r\n    // Set the toolbar styles\r\n    this.styles.toolbarTop = 'btn-toolbar ng-wizard-toolbar ng-wizard-toolbar-top justify-content-' + this.config.toolbarSettings.toolbarButtonPosition;\r\n    this.styles.toolbarBottom = 'btn-toolbar ng-wizard-toolbar ng-wizard-toolbar-bottom justify-content-' + this.config.toolbarSettings.toolbarButtonPosition;\r\n\r\n    // Set previous&next buttons \r\n    this.styles.previousButton = 'btn btn-secondary ng-wizard-btn-prev';\r\n    this.styles.nextButton = 'btn btn-secondary ng-wizard-btn-next';\r\n  }\r\n\r\n  _setToolbar() {\r\n    this.showToolbarTop = this.config.toolbarSettings.toolbarPosition == TOOLBAR_POSITION.top ||\r\n      this.config.toolbarSettings.toolbarPosition == TOOLBAR_POSITION.both;\r\n\r\n    this.showToolbarBottom = this.config.toolbarSettings.toolbarPosition == TOOLBAR_POSITION.bottom ||\r\n      this.config.toolbarSettings.toolbarPosition == TOOLBAR_POSITION.both;\r\n\r\n    this.showPreviousButton = this.config.toolbarSettings.showPreviousButton;\r\n    this.showNextButton = this.config.toolbarSettings.showNextButton;\r\n\r\n    this.showExtraButtons = this.config.toolbarSettings.toolbarExtraButtons && this.config.toolbarSettings.toolbarExtraButtons.length > 0;\r\n  }\r\n\r\n  _setEvents() {\r\n    //TODO: keyNavigation\r\n    // Keyboard navigation event\r\n    if (this.config.keyNavigation) {\r\n      // $(document).keyup(function (e) {\r\n      //   mi._keyNav(e);\r\n      // });\r\n    }\r\n  }\r\n\r\n  _getStepCssClass(selectedStep: NgWizardStep) {\r\n    let stepClass = this.styles.step;\r\n\r\n    switch (selectedStep.state) {\r\n      case STEP_STATE.disabled:\r\n        stepClass += ' disabled';\r\n        break;\r\n      case STEP_STATE.error:\r\n        stepClass += ' danger';\r\n        break;\r\n      case STEP_STATE.hidden:\r\n        stepClass += ' hidden';\r\n        break;\r\n    }\r\n\r\n    switch (selectedStep.status) {\r\n      case STEP_STATUS.done:\r\n        stepClass += ' done';\r\n        break;\r\n      case STEP_STATUS.active:\r\n        stepClass += ' active';\r\n        break;\r\n    }\r\n\r\n    return stepClass;\r\n  }\r\n\r\n  _showSelectedStep(event: Event, selectedStep: NgWizardStep) {\r\n    event.preventDefault();\r\n\r\n    if (!this.config.anchorSettings.anchorClickable) {\r\n      return;\r\n    }\r\n\r\n    if (!this.config.anchorSettings.enableAnchorOnDoneStep && selectedStep.status == STEP_STATUS.done) {\r\n      return true;\r\n    }\r\n\r\n    if (selectedStep.index != this.currentStepIndex) {\r\n      if (this.config.anchorSettings.enableAllAnchors && this.config.anchorSettings.anchorClickable) {\r\n        this._showStep(selectedStep.index);\r\n      }\r\n      else {\r\n        if (selectedStep.status == STEP_STATUS.done) {\r\n          this._showStep(selectedStep.index);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  _showNextStep(event?: Event) {\r\n    if (event) {\r\n      event.preventDefault();\r\n    }\r\n    // Find the next not disabled & hidden step\r\n    let filteredSteps = this.steps.filter(step => {\r\n      return step.index > (this.currentStepIndex == null ? -1 : this.currentStepIndex)\r\n        && step.state != STEP_STATE.disabled\r\n        && step.state != STEP_STATE.hidden;\r\n    });\r\n\r\n    if (filteredSteps.length == 0) {\r\n      if (!this.config.cycleSteps) {\r\n        return;\r\n      }\r\n\r\n      this._showStep(0)\r\n    }\r\n    else {\r\n      this._showStep(filteredSteps.shift().index)\r\n    }\r\n  }\r\n\r\n  _showPreviousStep(event?: Event) {\r\n    if (event) {\r\n      event.preventDefault();\r\n    }\r\n    // Find the previous not disabled & hidden step\r\n    let filteredSteps = this.steps.filter(step => {\r\n      return step.index < (this.currentStepIndex == null && this.config.cycleSteps ? this.steps.length : this.currentStepIndex)\r\n        && step.state != STEP_STATE.disabled\r\n        && step.state != STEP_STATE.hidden;\r\n    });\r\n\r\n    if (filteredSteps.length == 0) {\r\n      if (!this.config.cycleSteps) {\r\n        return;\r\n   