File

projects/common/lib/components/city/validate-city.directive.ts

Implements

Validator

Metadata

Providers { provide: NG_VALIDATORS, useExisting: ValidateCityDirective, multi: true }
Selector [commonValidateCity]

Index

Methods

Methods

validate
validate(control: AbstractControl)
Parameters :
Name Type Optional
control AbstractControl No
Returns : literal type | null
import { Directive } from '@angular/core';
import { ValidatorFn, AbstractControl, ValidationErrors, NG_VALIDATORS, Validator } from '@angular/forms';

export const commonValidateCity: ValidatorFn = (control: AbstractControl): ValidationErrors | null => {

  /**
   * Valid characters for  city names
   */
 const criteria: RegExp = RegExp( '^(?=.*[a-zA-Z])[a-zA-Z0-9\-.\' ]*$' );

 if ( control.value ) {
    const result = criteria.test( control.value );
    return result ? null : { 'invalidChar': true };
 }
 return null;
};

@Directive({
  selector: '[commonValidateCity]',
  providers: [
    {provide: NG_VALIDATORS, useExisting: ValidateCityDirective, multi: true}
  ]
})
export class ValidateCityDirective implements Validator {

  validate( control: AbstractControl ): {[key: string]: any} | null {

    return commonValidateCity( control );
  }

}

result-matching ""

    No results matching ""