angular2
Version:
Angular 2 - a web framework for modern web apps
127 lines • 15.1 kB
JavaScript
"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"]}
;