diff --git a/projects/demo/src/app/home.component.html b/projects/demo/src/app/home.component.html index 9a5f7df..0d91f1d 100644 --- a/projects/demo/src/app/home.component.html +++ b/projects/demo/src/app/home.component.html @@ -2,6 +2,7 @@ diff --git a/projects/demo/src/app/home.component.ts b/projects/demo/src/app/home.component.ts index 966008e..968ea8f 100644 --- a/projects/demo/src/app/home.component.ts +++ b/projects/demo/src/app/home.component.ts @@ -1,7 +1,8 @@ import { Component, OnInit, ViewChild } from '@angular/core' import { FormControl, FormGroup, Validators } from '@angular/forms' -import {WizardStep} from "../../../lib/src/form/form-wizard/models"; -import {FormWizardComponent} from "../../../lib/src/form/form-wizard/form-wizard.component"; +import { WizardStep } from '../../../lib/src/form/form-wizard/models' +import { FormWizardComponent, ValidationResult } from '../../../lib/src/form/form-wizard/form-wizard.component' +import { of } from 'rxjs' @Component({ selector: 'app-home', @@ -52,6 +53,10 @@ export class HomeComponent implements OnInit { }, ] + preNavigationValidator = (firstName: string) => { + return of(this.validateName(firstName)) + } + ngOnInit() { this.submittedData = null } @@ -62,15 +67,33 @@ export class HomeComponent implements OnInit { } } - onBeforeNavigateForward() {} + onBeforeNavigateForward() { + } - onNavigateForward(e: WizardStep) {} + onNavigateForward(e: WizardStep) { + } - onNavigateBackward(e: WizardStep) {} + onNavigateBackward(e: WizardStep) { + } - onNavigationFailed() {} + onNavigationFailed(e: string) { + window.alert('error: ' + e) + } isStep(index: number): boolean { return this.formWizardComponent != null ? this.formWizardComponent.isStep(this.steps[index]) : index === 0 } + + private validateName(name: string): ValidationResult { + return name?.indexOf('super') > -1 ? + { + isValid: true, + } + : + { + errorLabel: 'firstname should contain "super"', + isValid: false, + } + + } } diff --git a/projects/lib/src/form/form-wizard/form-wizard.component.ts b/projects/lib/src/form/form-wizard/form-wizard.component.ts index 36d59f3..7145c08 100644 --- a/projects/lib/src/form/form-wizard/form-wizard.component.ts +++ b/projects/lib/src/form/form-wizard/form-wizard.component.ts @@ -13,7 +13,7 @@ import { } from '@angular/core' import { FormGroup } from '@angular/forms' import { NavigationEnd, Router, RouterEvent } from '@angular/router' -import { first, Subscription } from 'rxjs' +import { first, Observable, Subscription } from 'rxjs' import { parse } from 'query-string' import { isNumber } from 'lodash' import { BalFormWrapper } from '../form-wrapper' @@ -22,6 +22,12 @@ import { WizardStepComponent } from './wizard-step/wizard-step.component' const URL_PARAM_STEP = 'step' +export interface ValidationResult { + errorLabel?: string; + isValid: boolean; +} + + @Component({ selector: 'bal-form-wizard', templateUrl: 'form-wizard.component.html', @@ -40,11 +46,12 @@ export class FormWizardComponent implements OnInit, OnChanges, AfterContentInit, } @Input() disableStepsAfterActiveStep = false @Input() enableDirectNavigationBackward = false + @Input() beforeNavigateForwardValidation: Observable | undefined @Output() beforeNavigateForward = new EventEmitter() @Output() navigateForward = new EventEmitter() @Output() navigateBackward = new EventEmitter() - @Output() navigationFailed = new EventEmitter() + @Output() navigationFailed = new EventEmitter() @Output() submitForm = new EventEmitter() @Output() clickOnStep: EventEmitter = new EventEmitter() @@ -130,13 +137,26 @@ export class FormWizardComponent implements OnInit, OnChanges, AfterContentInit, // wait for async validators activeForm.statusChanges .pipe(first()) - .subscribe(() => this.checkValidationResultAndPerformAction(activeForm, formWrapper)) + .subscribe(() => this.beforeValidateCheckValidationResultAndPerformAction(activeForm, formWrapper)) + } else { + this.beforeValidateCheckValidationResultAndPerformAction(activeForm, formWrapper) + } + } + + private beforeValidateCheckValidationResultAndPerformAction(activeForm: FormGroup | undefined, formWrapper: BalFormWrapper) { + if (this.beforeNavigateForwardValidation) { + this.subscriptions.push(this.beforeNavigateForwardValidation.subscribe( + (validationResult) => validationResult.isValid ? + this.checkValidationResultAndPerformAction(activeForm, formWrapper) : + this.navigationFailed.emit(validationResult.errorLabel), + (e) => this.navigationFailed.emit(e), + )) } else { this.checkValidationResultAndPerformAction(activeForm, formWrapper) } } - private checkValidationResultAndPerformAction(activeForm: FormGroup | undefined, formWrapper: BalFormWrapper) { + private checkValidationResultAndPerformAction(activeForm: FormGroup | undefined, formWrapper: BalFormWrapper) { if (activeForm && activeForm.valid) { this.beforeNavigateForward.emit(this.activeStep) this.goForwardWithoutValidation()