UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

127 lines 15.1 kB
'use strict';"use strict"; 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); } }; var core_1 = require('angular2/core'); var lang_1 = require('angular2/src/facade/lang'); var validators_1 = require('../validators'); var REQUIRED = validators_1.Validators.required; var REQUIRED_VALIDATOR = lang_1.CONST_EXPR(new core_1.Provider(validators_1.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> * ``` */ var RequiredValidator = (function () { function RequiredValidator() { } RequiredValidator = __decorate([ core_1.Directive({ selector: '[required][ngControl],[required][ngFormControl],[required][ngModel]', providers: [REQUIRED_VALIDATOR] }), __metadata('design:paramtypes', []) ], RequiredValidator); return RequiredValidator; }()); exports.RequiredValidator = RequiredValidator; /** * Provivder which adds {@link MinLengthValidator} to {@link NG_VALIDATORS}. * * ## Example: * * {@example common/forms/ts/validators/validators.ts region='min'} */ var MIN_LENGTH_VALIDATOR = lang_1.CONST_EXPR(new core_1.Provider(validators_1.NG_VALIDATORS, { useExisting: core_1.forwardRef(function () { return MinLengthValidator; }), multi: true })); /** * A directive which installs the {@link MinLengthValidator} for any `ngControl`, * `ngFormControl`, or control with `ngModel` that also has a `minlength` attribute. */ var MinLengthValidator = (function () { function MinLengthValidator(minLength) { this._validator = validators_1.Validators.minLength(lang_1.NumberWrapper.parseInt(minLength, 10)); } MinLengthValidator.prototype.validate = function (c) { return this._validator(c); }; MinLengthValidator = __decorate([ core_1.Directive({ selector: '[minlength][ngControl],[minlength][ngFormControl],[minlength][ngModel]', providers: [MIN_LENGTH_VALIDATOR] }), __param(0, core_1.Attribute("minlength")), __metadata('design:paramtypes', [String]) ], MinLengthValidator); return MinLengthValidator; }()); exports.MinLengthValidator = MinLengthValidator; /** * Provider which adds {@link MaxLengthValidator} to {@link NG_VALIDATORS}. * * ## Example: * * {@example common/forms/ts/validators/validators.ts region='max'} */ var MAX_LENGTH_VALIDATOR = lang_1.CONST_EXPR(new core_1.Provider(validators_1.NG_VALIDATORS, { useExisting: core_1.forwardRef(function () { return MaxLengthValidator; }), multi: true })); /** * A directive which installs the {@link MaxLengthValidator} for any `ngControl, `ngFormControl`, * or control with `ngModel` that also has a `maxlength` attribute. */ var MaxLengthValidator = (function () { function MaxLengthValidator(maxLength) { this._validator = validators_1.Validators.maxLength(lang_1.NumberWrapper.parseInt(maxLength, 10)); } MaxLengthValidator.prototype.validate = function (c) { return this._validator(c); }; MaxLengthValidator = __decorate([ core_1.Directive({ selector: '[maxlength][ngControl],[maxlength][ngFormControl],[maxlength][ngModel]', providers: [MAX_LENGTH_VALIDATOR] }), __param(0, core_1.Attribute("maxlength")), __metadata('design:paramtypes', [String]) ], MaxLengthValidator); return MaxLengthValidator; }()); exports.MaxLengthValidator = 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 ]*"> * ``` */ var PATTERN_VALIDATOR = lang_1.CONST_EXPR(new core_1.Provider(validators_1.NG_VALIDATORS, { useExisting: core_1.forwardRef(function () { return PatternValidator; }), multi: true })); var PatternValidator = (function () { function PatternValidator(pattern) { this._validator = validators_1.Validators.pattern(pattern); } PatternValidator.prototype.validate = function (c) { return this._validator(c); }; PatternValidator = __decorate([ core_1.Directive({ selector: '[pattern][ngControl],[pattern][ngFormControl],[pattern][ngModel]', providers: [PATTERN_VALIDATOR] }), __param(0, core_1.Attribute("pattern")), __metadata('design:paramtypes', [String]) ], PatternValidator); return PatternValidator; }()); exports.PatternValidator = PatternValidator; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.js","sourceRoot":"","sources":["diffing_plugin_wrapper-output_path-BRJer1J9.tmp/angular2/src/common/forms/directives/validators.ts"],"names":[],"mappings":"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","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"]}