UNPKG

@kronscht/ng-wizard

Version:

Angular ng-wizard - Angular wizard | stepper

393 lines 62.2 kB
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":"AAAA,OAAO,EAAE,SAAS,EAAoB,KAAK,EAAa,YAAY,EAAE,MAAM,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAChI,OAAO,EAAE,YAAY,EAA0B,EAAE,EAAgB,MAAM,MAAM,CAAC;AAE9E,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,EAAkB,YAAY,EAAsD,MAAM,wBAAwB,CAAC;AAC1H,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,WAAW,EAAS,aAAa,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACnH,OAAO,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;;;;AAO9C,MAAM,OAAO,iBAAiB;IA4C5B,YAAoB,mBAAwC;QAAxC,wBAAmB,GAAnB,mBAAmB,CAAqB;QA3BlD,gBAAW,GAAG,IAAI,YAAY,EAAmB,CAAC;QAClD,iBAAY,GAAG,IAAI,YAAY,EAAS,CAAC;QACzC,YAAO,GAAG,IAAI,YAAY,EAAQ,CAAC;QAE7C,WAAM,GAOF,EAAE,CAAC;QAEP,mBAAc,GAAY,KAAK,CAAC;QAChC,uBAAkB,GAAY,KAAK,CAAC;QACpC,mBAAc,GAAY,KAAK,CAAC;QAChC,sBAAiB,GAAY,KAAK,CAAC;QACnC,qBAAgB,GAAY,KAAK,CAAC;QAClC,qBAAgB,GAAW,IAAI,CAAC,CAAC,oBAAoB;IAUrD,CAAC;IAvCD,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC;IAC7B,CAAC;IAED,IACI,OAAO,CAAC,MAAsB;QAChC,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC;IACzB,CAAC;IAkCD,kBAAkB;QAChB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,IAAI,CAAC,KAAK,EAAE,CAAC;QAEb,cAAc;QACd,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,uBAAuB;QACvB,IAAI,CAAC,UAAU,EAAE,CAAC;QAElB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QAC/F,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QACxG,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,mBAAmB,CAAC,iBAAiB,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;QACpH,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;QACpG,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;IACtG,CAAC;IAED,KAAK;QACH,aAAa;QACb,IAAI,aAAa,GAAG,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,CAAC;QAChE,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,aAAa,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAEjD,kBAAkB;QAClB,IAAI,CAAC,UAAU,EAAE,CAAC;QAElB,mBAAmB;QACnB,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,wBAAwB;QACxB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACvC,CAAC;IAED,UAAU;QACR,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YACjC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,WAAW,CAAC,SAAS,CAAC;YACnD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,UAAU,CAAC,MAAM,CAAC;QAC/C,CAAC,CAAC,CAAC;QAEH,iDAAiD;QACjD,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,GAAG,CAAC;eACvB,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,YAAY;eACvC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,0BAA0B,EAAE;YAE1D,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBACxB,IAAI,IAAI,CAAC,KAAK,IAAI,UAAU,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,IAAI,UAAU,CAAC,MAAM,EAAE;oBACxE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;iBAClF;YACH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACxB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC;YACjC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC;QACjC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACxB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC;YACjC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC;QACjC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,oBAAoB;IACpB,WAAW;QACT,uBAAuB;QACvB,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,iCAAiC,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;QAEzE,sBAAsB;QACtB,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,UAAU,CAAC,CAAC,KAAK;QAEpC,4BAA4B;QAC5B,IAAI,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,gBAAgB,IAAI,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,eAAe,EAAE;YAC7F,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,YAAY,CAAC;SAClC;QAED,yBAAyB;QACzB,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,sEAAsE,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,qBAAqB,CAAC;QACpJ,IAAI,CAAC,MAAM,CAAC,aAAa,GAAG,yEAAyE,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,qBAAqB,CAAC;QAE1J,6BAA6B;QAC7B,IAAI,CAAC,MAAM,CAAC,cAAc,GAAG,sCAAsC,CAAC;QACpE,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,sCAAsC,CAAC;IAClE,CAAC;IAED,WAAW;QACT,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,eAAe,IAAI,gBAAgB,CAAC,GAAG;YACvF,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,eAAe,IAAI,gBAAgB,CAAC,IAAI,CAAC;QAEvE,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,eAAe,IAAI,gBAAgB,CAAC,MAAM;YAC7F,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,eAAe,IAAI,gBAAgB,CAAC,IAAI,CAAC;QAEvE,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,kBAAkB,CAAC;QACzE,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,cAAc,CAAC;QAEjE,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,mBAAmB,IAAI,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,mBAAmB,CAAC,MAAM,GAAG,CAAC,CAAC;IACxI,CAAC;IAED,UAAU;QACR,qBAAqB;QACrB,4BAA4B;QAC5B,IAAI,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE;YAC7B,mCAAmC;YACnC,mBAAmB;YACnB,MAAM;SACP;IACH,CAAC;IAED,gBAAgB,CAAC,YAA0B;QACzC,IAAI,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;QAEjC,QAAQ,YAAY,CAAC,KAAK,EAAE;YAC1B,KAAK,UAAU,CAAC,QAAQ;gBACtB,SAAS,IAAI,WAAW,CAAC;gBACzB,MAAM;YACR,KAAK,UAAU,CAAC,KAAK;gBACnB,SAAS,IAAI,SAAS,CAAC;gBACvB,MAAM;YACR,KAAK,UAAU,CAAC,MAAM;gBACpB,SAAS,IAAI,SAAS,CAAC;gBACvB,MAAM;SACT;QAED,QAAQ,YAAY,CAAC,MAAM,EAAE;YAC3B,KAAK,WAAW,CAAC,IAAI;gBACnB,SAAS,IAAI,OAAO,CAAC;gBACrB,MAAM;YACR,KAAK,WAAW,CAAC,MAAM;gBACrB,SAAS,IAAI,SAAS,CAAC;gBACvB,MAAM;SACT;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,iBAAiB,CAAC,KAAY,EAAE,YAA0B;QACxD,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,eAAe,EAAE;YAC/C,OAAO;SACR;QAED,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,sBAAsB,IAAI,YAAY,CAAC,MAAM,IAAI,WAAW,CAAC,IAAI,EAAE;YACjG,OAAO,IAAI,CAAC;SACb;QAED,IAAI,YAAY,CAAC,KAAK,IAAI,IAAI,CAAC,gBAAgB,EAAE;YAC/C,IAAI,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,gBAAgB,IAAI,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,eAAe,EAAE;gBAC7F,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;aACpC;iBACI;gBACH,IAAI,YAAY,CAAC,MAAM,IAAI,WAAW,CAAC,IAAI,EAAE;oBAC3C,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;iBACpC;aACF;SACF;IACH,CAAC;IAED,aAAa,CAAC,KAAa;QACzB,IAAI,KAAK,EAAE;YACT,KAAK,CAAC,cAAc,EAAE,CAAC;SACxB;QACD,2CAA2C;QAC3C,IAAI,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;YAC3C,OAAO,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC;mBAC3E,IAAI,CAAC,KAAK,IAAI,UAAU,CAAC,QAAQ;mBACjC,IAAI,CAAC,KAAK,IAAI,UAAU,CAAC,MAAM,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,IAAI,aAAa,CAAC,MAAM,IAAI,CAAC,EAAE;YAC7B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;gBAC3B,OAAO;aACR;YAED,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAA;SAClB;aACI;YACH,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,CAAA;SAC5C;IACH,CAAC;IAED,iBAAiB,CAAC,KAAa;QAC7B,IAAI,KAAK,EAAE;YACT,KAAK,CAAC,cAAc,EAAE,CAAC;SACxB;QACD,+CAA+C;QAC/C,IAAI,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;YAC3C,OAAO,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,gBAAgB,IAAI,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC;mBACpH,IAAI,CAAC,KAAK,IAAI,UAAU,CAAC,QAAQ;mBACjC,IAAI,CAAC,KAAK,IAAI,UAAU,CAAC,MAAM,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,IAAI,aAAa,CAAC,MAAM,IAAI,CAAC,EAAE;YAC7B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;gBAC3B,OAAO;aACR;YAED,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;SACtC;aACI;YACH,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAA;SAC1C;IACH,CAAC;IAED,SAAS,CAAC,iBAAyB;QACjC,0BAA0B;QAC1B,IAAI,iBAAiB,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,IAAI,iBAAiB,GAAG,CAAC,EAAE;YACnE,OAAO;SACR;QAED,2CAA2C;QAC3C,IAAI,iBAAiB,IAAI,IAAI,CAAC,gBAAgB,EAAE;YAC9C,OAAO;SACR;QAED,IAAI,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,iBAAiB,CAAC,CAAC;QAE3D,2CAA2C;QAC3C,IAAI,YAAY,CAAC,KAAK,IAAI,UAAU,CAAC,QAAQ,IAAI,YAAY,CAAC,KAAK,IAAI,UAAU,CAAC,MAAM,EAAE;YACxF,OAAO;SACR;QAED,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,OAAO,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE;aACnG,IAAI,CAAC,OAAO,CAAC,EAAE;YACd,IAAI,OAAO,EAAE;gBACX,OAAO,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,YAAY,CAAC,QAAQ,CAAC,CAAC,SAAS,EAAE,CAAC;aACjF;YAED,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,CAAC;QACjC,CAAC,CAAC;aACD,IAAI,CAAC,OAAO,CAAC,EAAE;YACd,IAAI,OAAO,EAAE;gBACX,oBAAoB;gBACpB,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;aACrC;QACH,CAAC,CAAC;aACD,OAAO,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IACvC,CAAC;IAEO,kBAAkB,CAAC,YAAY,EAAE,SAAkH;QACzJ,IAAI,OAAO,SAAS,KAAK,OAAO,IAAI,EAAE;YACpC,OAAO,EAAE,CAAU,SAAS,CAAC,CAAC;SAC/B;aAEI,IAAI,SAAS,YAAY,QAAQ,EAAE;YACtC,IAAI,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YAC3D,IAAI,MAAM,GAAG,SAAS,CAAC,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,CAAC,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC,CAAC;YAEnG,IAAI,YAAY,CAAU,MAAM,CAAC,EAAE;gBACjC,OAAO,MAAM,CAAC;aACf;iBACI,IAAI,OAAO,MAAM,KAAK,OAAO,IAAI,EAAE;gBACtC,OAAO,EAAE,CAAU,MAAM,CAAC,CAAC;aAC5B;iBACI;gBACH,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;aAClB;SACF;QAED,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;IAClB,CAAC;IAED,gBAAgB,CAAC,YAA0B;QACzC,kBAAkB;QAClB,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;QAC9B,oCAAoC;QACpC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAErC,8BAA8B;QAC9B,MAAM,IAAI,GAAoB;YAC5B,IAAI,EAAE,YAAY;YAClB,YAAY,EAAE,IAAI,CAAC,WAAW;YAC9B,SAAS,EAAE,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,KAAK,CAAC;YACrD,QAAQ,EAAE,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,KAAK,CAAC;SACpD,CAAC;QACF,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAE3C,2BAA2B;QAC3B,IAAI,CAAC,gBAAgB,GAAG,YAAY,CAAC,KAAK,CAAC;QAC3C,IAAI,CAAC,WAAW,GAAG,YAAY,CAAC;IAClC,CAAC;IAED,UAAU,CAAC,YAA0B;QACnC,gEAAgE;QAChE,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,WAAW,CAAC,SAAS,CAAC;YAEhD,IAAI,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,YAAY,EAAE;gBAC3C,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,WAAW,CAAC,IAAI,CAAC;gBAE3C,IAAI,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,4BAA4B,EAAE;oBAC3D,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;wBACxB,IAAI,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,KAAK,EAAE;4BACnC,IAAI,CAAC,MAAM,GAAG,WAAW,CAAC,SAAS,CAAC;yBACrC;oBACH,CAAC,CAAC,CAAC;iBACJ;aACF;SACF;QAED,+DAA+D;QAC/D,YAAY,CAAC,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC;IAC3C,CAAC;IAED,WAAW,CAAC,KAAa;QACvB,oDAAoD;QACpD,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC3B,IAAI,CAAC,IAAI,KAAK,EAAE;gBACd,IAAI,CAAC,MAAM,CAAC,cAAc,GAAG,+CAA+C,CAAC;aAC9E;iBACI;gBACH,IAAI,CAAC,MAAM,CAAC,cAAc,GAAG,sCAAsC,CAAC;aACrE;YAED,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,KAAK,EAAE;gBAClC,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,+CAA+C,CAAC;aAC1E;iBACI;gBACH,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,sCAAsC,CAAC;aACjE;SACF;IACH,CAAC;IAED,mBAAmB,CAAC,MAAqB;QACvC,IAAI,MAAM,CAAC,KAAK,EAAE;YAChB,MAAM,CAAC,KAAK,EAAE,CAAC;SAChB;IACH,CAAC;IAED,mBAAmB;IACnB,OAAO,CAAC,KAAoB;QAC1B,sBAAsB;QACtB,QAAQ,KAAK,CAAC,KAAK,EAAE;YACnB,KAAK,EAAE;gBACL,OAAO;gBACP,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;gBAC9B,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;YACR,KAAK,EAAE;gBACL,QAAQ;gBACR,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBAC1B,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;YACR;gBACE,OAAO,CAAC,mCAAmC;SAC9C;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,iCAAiC,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,oBAAoB,CAAC;IAClG,CAAC;IAED,WAAW;QACT,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,iCAAiC,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;IAC3E,CAAC;IAED,iBAAiB,CAAC,iBAAyB;QACzC,OAAO,CAAC,IAAI,CAAC,gBAAgB,IAAI,IAAI,IAAI,IAAI,CAAC,gBAAgB,IAAI,iBAAiB,CAAC,CAAC,CAAC;YACpF,CAAC,IAAI,CAAC,gBAAgB,GAAG,iBAAiB,CAAC,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACxG,CAAC;IAED,gBAAgB,CAAC,iBAAyB;QACxC,OAAO,CAAC,iBAAiB,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,iBAAiB,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;IACpJ,CAAC;IAED,mBAAmB;IACnB,SAAS,CAAC,KAAY;QACpB,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,KAAK,EAAE;YAC9B,OAAO,KAAK,CAAC;SACd;QAED,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,iCAAiC,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;QAEzE,+BAA+B;QAC/B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC5C,CAAC;IAED,MAAM;QACJ,iCAAiC;QACjC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;QAC7B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,KAAK,EAAE,CAAC;QAEb,0BAA0B;QAC1B,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE,CAAC;SACvC;QAED,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC5B,IAAI,CAAC,mBAAmB,CAAC,WAAW,EAAE,CAAC;SACxC;QAED,IAAI,IAAI,CAAC,uBAAuB,EAAE;YAChC,IAAI,CAAC,uBAAuB,CAAC,WAAW,EAAE,CAAC;SAC5C;QAED,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,CAAC;SACpC;QAED,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,CAAC;SACpC;IACH,CAAC;;8GA/cU,iBAAiB;kGAAjB,iBAAiB,8MAEX,YAAY,6BCf/B,63EAuCM;2FD1BO,iBAAiB;kBAL7B,SAAS;+BACE,WAAW;0GAOd,KAAK;sBADX,eAAe;uBAAC,YAAY;gBASzB,OAAO;sBADV,KAAK;uBAAC,QAAQ;gBAOL,WAAW;sBAApB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBACG,OAAO;sBAAhB,MAAM","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   