UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

116 lines 14 kB
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var __param = (this && this.__param) || function (paramIndex, decorator) { return function (target, key) { decorator(target, key, paramIndex); } }; import { forwardRef, Provider, Attribute, Directive } from 'angular2/core'; import { CONST_EXPR, NumberWrapper } from 'angular2/src/facade/lang'; import { Validators, NG_VALIDATORS } from '../validators'; const REQUIRED = Validators.required; const REQUIRED_VALIDATOR = CONST_EXPR(new Provider(NG_VALIDATORS, { useValue: REQUIRED, multi: true })); /** * A Directive that adds the `required` validator to any controls marked with the * `required` attribute, via the {@link NG_VALIDATORS} binding. * * ### Example * * ``` * <input ngControl="fullName" required> * ``` */ export let RequiredValidator = class RequiredValidator { }; RequiredValidator = __decorate([ Directive({ selector: '[required][ngControl],[required][ngFormControl],[required][ngModel]', providers: [REQUIRED_VALIDATOR] }), __metadata('design:paramtypes', []) ], RequiredValidator); /** * Provivder which adds {@link MinLengthValidator} to {@link NG_VALIDATORS}. * * ## Example: * * {@example common/forms/ts/validators/validators.ts region='min'} */ const MIN_LENGTH_VALIDATOR = CONST_EXPR(new Provider(NG_VALIDATORS, { useExisting: forwardRef(() => MinLengthValidator), multi: true })); /** * A directive which installs the {@link MinLengthValidator} for any `ngControl`, * `ngFormControl`, or control with `ngModel` that also has a `minlength` attribute. */ export let MinLengthValidator = class MinLengthValidator { constructor(minLength) { this._validator = Validators.minLength(NumberWrapper.parseInt(minLength, 10)); } validate(c) { return this._validator(c); } }; MinLengthValidator = __decorate([ Directive({ selector: '[minlength][ngControl],[minlength][ngFormControl],[minlength][ngModel]', providers: [MIN_LENGTH_VALIDATOR] }), __param(0, Attribute("minlength")), __metadata('design:paramtypes', [String]) ], MinLengthValidator); /** * Provider which adds {@link MaxLengthValidator} to {@link NG_VALIDATORS}. * * ## Example: * * {@example common/forms/ts/validators/validators.ts region='max'} */ const MAX_LENGTH_VALIDATOR = CONST_EXPR(new Provider(NG_VALIDATORS, { useExisting: forwardRef(() => MaxLengthValidator), multi: true })); /** * A directive which installs the {@link MaxLengthValidator} for any `ngControl, `ngFormControl`, * or control with `ngModel` that also has a `maxlength` attribute. */ export let MaxLengthValidator = class MaxLengthValidator { constructor(maxLength) { this._validator = Validators.maxLength(NumberWrapper.parseInt(maxLength, 10)); } validate(c) { return this._validator(c); } }; MaxLengthValidator = __decorate([ Directive({ selector: '[maxlength][ngControl],[maxlength][ngFormControl],[maxlength][ngModel]', providers: [MAX_LENGTH_VALIDATOR] }), __param(0, Attribute("maxlength")), __metadata('design:paramtypes', [String]) ], MaxLengthValidator); /** * A Directive that adds the `pattern` validator to any controls marked with the * `pattern` attribute, via the {@link NG_VALIDATORS} binding. Uses attribute value * as the regex to validate Control value against. Follows pattern attribute * semantics; i.e. regex must match entire Control value. * * ### Example * * ``` * <input [ngControl]="fullName" pattern="[a-zA-Z ]*"> * ``` */ const PATTERN_VALIDATOR = CONST_EXPR(new Provider(NG_VALIDATORS, { useExisting: forwardRef(() => PatternValidator), multi: true })); export let PatternValidator = class PatternValidator { constructor(pattern) { this._validator = Validators.pattern(pattern); } validate(c) { return this._validator(c); } }; PatternValidator = __decorate([ Directive({ selector: '[pattern][ngControl],[pattern][ngFormControl],[pattern][ngModel]', providers: [PATTERN_VALIDATOR] }), __param(0, Attribute("pattern")), __metadata('design:paramtypes', [String]) ], PatternValidator); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.js","sourceRoot":"","sources":["diffing_plugin_wrapper-output_path-xBLIBrVR.tmp/angular2/src/common/forms/directives/validators.ts"],"names":[],"mappings":";;;;;;;;;;;;OAAO,EAAC,UAAU,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAC,MAAM,eAAe;OACjE,EAAC,UAAU,EAAE,aAAa,EAAC,MAAM,0BAA0B;OAC3D,EAAC,UAAU,EAAE,aAAa,EAAC,MAAM,eAAe;AAyBvD,MAAM,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC;AAErC,MAAM,kBAAkB,GACpB,UAAU,CAAC,IAAI,QAAQ,CAAC,aAAa,EAAE,EAAC,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC,CAAC;AAE/E;;;;;;;;;GASG;AAKH;AACA,CAAC;AALD;IAAC,SAAS,CAAC;QACT,QAAQ,EAAE,qEAAqE;QAC/E,SAAS,EAAE,CAAC,kBAAkB,CAAC;KAChC,CAAC;;qBAAA;AASF;;;;;;GAMG;AACH,MAAM,oBAAoB,GAAG,UAAU,CACnC,IAAI,QAAQ,CAAC,aAAa,EAAE,EAAC,WAAW,EAAE,UAAU,CAAC,MAAM,kBAAkB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC,CAAC;AAEnG;;;GAGG;AAKH;IAGE,YAAoC,SAAiB;QACnD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,SAAS,CAAC,aAAa,CAAC,QAAQ,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;IAChF,CAAC;IAED,QAAQ,CAAC,CAAkB,IAA0B,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACnF,CAAC;AAZD;IAAC,SAAS,CAAC;QACT,QAAQ,EAAE,wEAAwE;QAClF,SAAS,EAAE,CAAC,oBAAoB,CAAC;KAClC,CAAC;eAIa,SAAS,CAAC,WAAW,CAAC;;sBAJnC;AAWF;;;;;;GAMG;AACH,MAAM,oBAAoB,GAAG,UAAU,CACnC,IAAI,QAAQ,CAAC,aAAa,EAAE,EAAC,WAAW,EAAE,UAAU,CAAC,MAAM,kBAAkB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC,CAAC;AAEnG;;;GAGG;AAKH;IAGE,YAAoC,SAAiB;QACnD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,SAAS,CAAC,aAAa,CAAC,QAAQ,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;IAChF,CAAC;IAED,QAAQ,CAAC,CAAkB,IAA0B,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACnF,CAAC;AAZD;IAAC,SAAS,CAAC;QACT,QAAQ,EAAE,wEAAwE;QAClF,SAAS,EAAE,CAAC,oBAAoB,CAAC;KAClC,CAAC;eAIa,SAAS,CAAC,WAAW,CAAC;;sBAJnC;AAYF;;;;;;;;;;;GAWG;AACH,MAAM,iBAAiB,GAAG,UAAU,CAChC,IAAI,QAAQ,CAAC,aAAa,EAAE,EAAC,WAAW,EAAE,UAAU,CAAC,MAAM,gBAAgB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC,CAAC;AAKjG;IAGE,YAAkC,OAAe;QAC/C,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IAChD,CAAC;IAED,QAAQ,CAAC,CAAkB,IAA0B,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACnF,CAAC;AAZD;IAAC,SAAS,CAAC;QACT,QAAQ,EAAE,kEAAkE;QAC5E,SAAS,EAAE,CAAC,iBAAiB,CAAC;KAC/B,CAAC;eAIa,SAAS,CAAC,SAAS,CAAC;;oBAJjC;AASD","sourcesContent":["import {forwardRef, Provider, Attribute, Directive} from 'angular2/core';\nimport {CONST_EXPR, NumberWrapper} from 'angular2/src/facade/lang';\nimport {Validators, NG_VALIDATORS} from '../validators';\nimport {AbstractControl} from '../model';\nimport * as modelModule from '../model';\n\n\n\n/**\n * An interface that can be implemented by classes that can act as validators.\n *\n * ## Usage\n *\n * ```typescript\n * @Directive({\n *   selector: '[custom-validator]',\n *   providers: [provide(NG_VALIDATORS, {useExisting: CustomValidatorDirective, multi: true})]\n * })\n * class CustomValidatorDirective implements Validator {\n *   validate(c: Control): {[key: string]: any} {\n *     return {\"custom\": true};\n *   }\n * }\n * ```\n */\nexport interface Validator { validate(c: modelModule.AbstractControl): {[key: string]: any}; }\n\nconst REQUIRED = Validators.required;\n\nconst REQUIRED_VALIDATOR =\n    CONST_EXPR(new Provider(NG_VALIDATORS, {useValue: REQUIRED, multi: true}));\n\n/**\n * A Directive that adds the `required` validator to any controls marked with the\n * `required` attribute, via the {@link NG_VALIDATORS} binding.\n *\n * ### Example\n *\n * ```\n * <input ngControl=\"fullName\" required>\n * ```\n */\n@Directive({\n  selector: '[required][ngControl],[required][ngFormControl],[required][ngModel]',\n  providers: [REQUIRED_VALIDATOR]\n})\nexport class RequiredValidator {\n}\n\nexport interface ValidatorFn { (c: AbstractControl): {[key: string]: any}; }\nexport interface AsyncValidatorFn {\n  (c: AbstractControl): any /*Promise<{[key: string]: any}>|Observable<{[key: string]: any}>*/;\n}\n\n/**\n * Provivder which adds {@link MinLengthValidator} to {@link NG_VALIDATORS}.\n *\n * ## Example:\n *\n * {@example common/forms/ts/validators/validators.ts region='min'}\n */\nconst MIN_LENGTH_VALIDATOR = CONST_EXPR(\n    new Provider(NG_VALIDATORS, {useExisting: forwardRef(() => MinLengthValidator), multi: true}));\n\n/**\n * A directive which installs the {@link MinLengthValidator} for any `ngControl`,\n * `ngFormControl`, or control with `ngModel` that also has a `minlength` attribute.\n */\n@Directive({\n  selector: '[minlength][ngControl],[minlength][ngFormControl],[minlength][ngModel]',\n  providers: [MIN_LENGTH_VALIDATOR]\n})\nexport class MinLengthValidator implements Validator {\n  private _validator: ValidatorFn;\n\n  constructor(@Attribute(\"minlength\") minLength: string) {\n    this._validator = Validators.minLength(NumberWrapper.parseInt(minLength, 10));\n  }\n\n  validate(c: AbstractControl): {[key: string]: any} { return this._validator(c); }\n}\n\n/**\n * Provider which adds {@link MaxLengthValidator} to {@link NG_VALIDATORS}.\n *\n * ## Example:\n *\n * {@example common/forms/ts/validators/validators.ts region='max'}\n */\nconst MAX_LENGTH_VALIDATOR = CONST_EXPR(\n    new Provider(NG_VALIDATORS, {useExisting: forwardRef(() => MaxLengthValidator), multi: true}));\n\n/**\n * A directive which installs the {@link MaxLengthValidator} for any `ngControl, `ngFormControl`,\n * or control with `ngModel` that also has a `maxlength` attribute.\n */\n@Directive({\n  selector: '[maxlength][ngControl],[maxlength][ngFormControl],[maxlength][ngModel]',\n  providers: [MAX_LENGTH_VALIDATOR]\n})\nexport class MaxLengthValidator implements Validator {\n  private _validator: ValidatorFn;\n\n  constructor(@Attribute(\"maxlength\") maxLength: string) {\n    this._validator = Validators.maxLength(NumberWrapper.parseInt(maxLength, 10));\n  }\n\n  validate(c: AbstractControl): {[key: string]: any} { return this._validator(c); }\n}\n\n\n/**\n * A Directive that adds the `pattern` validator to any controls marked with the\n * `pattern` attribute, via the {@link NG_VALIDATORS} binding. Uses attribute value\n * as the regex to validate Control value against.  Follows pattern attribute\n * semantics; i.e. regex must match entire Control value.\n *\n * ### Example\n *\n * ```\n * <input [ngControl]=\"fullName\" pattern=\"[a-zA-Z ]*\">\n * ```\n */\nconst PATTERN_VALIDATOR = CONST_EXPR(\n    new Provider(NG_VALIDATORS, {useExisting: forwardRef(() => PatternValidator), multi: true}));\n@Directive({\n  selector: '[pattern][ngControl],[pattern][ngFormControl],[pattern][ngModel]',\n  providers: [PATTERN_VALIDATOR]\n})\nexport class PatternValidator implements Validator {\n  private _validator: ValidatorFn;\n\n  constructor(@Attribute(\"pattern\") pattern: string) {\n    this._validator = Validators.pattern(pattern);\n  }\n\n  validate(c: AbstractControl): {[key: string]: any} { return this._validator(c); }\n}\n"]}