UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

126 lines 15.5 kB
'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 lang_2 = require("angular2/src/facade/lang"); var REQUIRED_VALIDATOR = lang_1.CONST_EXPR(new core_1.Provider(validators_1.NG_VALIDATORS, { useValue: validators_1.Validators.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_2.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_2.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":["angular2/src/common/forms/directives/validators.ts"],"names":["RequiredValidator","RequiredValidator.constructor","MinLengthValidator","MinLengthValidator.constructor","MinLengthValidator.validate","MaxLengthValidator","MaxLengthValidator.constructor","MaxLengthValidator.validate","PatternValidator","PatternValidator.constructor","PatternValidator.validate"],"mappings":";;;;;;;;;;;;AAAA,qBAAsE,eAAe,CAAC,CAAA;AACtF,qBAAyB,0BAA0B,CAAC,CAAA;AACpD,2BAAwC,eAAe,CAAC,CAAA;AAGxD,qBAA4B,0BAA0B,CAAC,CAAA;AAsBvD,IAAM,kBAAkB,GACpB,iBAAU,CAAC,IAAI,eAAQ,CAAC,0BAAa,EAAE,EAAC,QAAQ,EAAE,uBAAU,CAAC,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC,CAAC;AAE1F;;;;;;;;;GASG;AACH;IAAAA;IAKAC,CAACA;IALDD;QAACA,gBAASA,CAACA;YACTA,QAAQA,EAAEA,qEAAqEA;YAC/EA,SAASA,EAAEA,CAACA,kBAAkBA,CAACA;SAChCA,CAACA;;0BAEDA;IAADA,wBAACA;AAADA,CAACA,AALD,IAKC;AADY,yBAAiB,oBAC7B,CAAA;AAED;;;;;;GAMG;AACH,IAAM,oBAAoB,GAAG,iBAAU,CACnC,IAAI,eAAQ,CAAC,0BAAa,EAAE,EAAC,WAAW,EAAE,iBAAU,CAAC,cAAM,OAAA,kBAAkB,EAAlB,CAAkB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC,CAAC;AAEnG;;;GAGG;AACH;IAOEE,4BAAoCA,SAAiBA;QACnDC,IAAIA,CAACA,UAAUA,GAAGA,uBAAUA,CAACA,SAASA,CAACA,oBAAaA,CAACA,QAAQA,CAACA,SAASA,EAAEA,EAAEA,CAACA,CAACA,CAACA;IAChFA,CAACA;IAEDD,qCAAQA,GAARA,UAASA,CAAUA,IAA0BE,MAAMA,CAACA,IAAIA,CAACA,UAAUA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA;IAX3EF;QAACA,gBAASA,CAACA;YACTA,QAAQA,EAAEA,wEAAwEA;YAClFA,SAASA,EAAEA,CAACA,oBAAoBA,CAACA;SAClCA,CAACA;QAIYA,WAACA,gBAASA,CAACA,WAAWA,CAACA,CAAAA;;2BAKpCA;IAADA,yBAACA;AAADA,CAACA,AAZD,IAYC;AARY,0BAAkB,qBAQ9B,CAAA;AAED;;;;;;GAMG;AACH,IAAM,oBAAoB,GAAG,iBAAU,CACnC,IAAI,eAAQ,CAAC,0BAAa,EAAE,EAAC,WAAW,EAAE,iBAAU,CAAC,cAAM,OAAA,kBAAkB,EAAlB,CAAkB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC,CAAC;AAEnG;;;GAGG;AACH;IAOEG,4BAAoCA,SAAiBA;QACnDC,IAAIA,CAACA,UAAUA,GAAGA,uBAAUA,CAACA,SAASA,CAACA,oBAAaA,CAACA,QAAQA,CAACA,SAASA,EAAEA,EAAEA,CAACA,CAACA,CAACA;IAChFA,CAACA;IAEDD,qCAAQA,GAARA,UAASA,CAAUA,IAA0BE,MAAMA,CAACA,IAAIA,CAACA,UAAUA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA;IAX3EF;QAACA,gBAASA,CAACA;YACTA,QAAQA,EAAEA,wEAAwEA;YAClFA,SAASA,EAAEA,CAACA,oBAAoBA,CAACA;SAClCA,CAACA;QAIYA,WAACA,gBAASA,CAACA,WAAWA,CAACA,CAAAA;;2BAKpCA;IAADA,yBAACA;AAADA,CAACA,AAZD,IAYC;AARY,0BAAkB,qBAQ9B,CAAA;AAGD;;;;;;;;;;;GAWG;AACH,IAAM,iBAAiB,GAAG,iBAAU,CAChC,IAAI,eAAQ,CAAC,0BAAa,EAAE,EAAC,WAAW,EAAE,iBAAU,CAAC,cAAM,OAAA,gBAAgB,EAAhB,CAAgB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC,CAAC;AACjG;IAOEG,0BAAkCA,OAAeA;QAC/CC,IAAIA,CAACA,UAAUA,GAAGA,uBAAUA,CAACA,OAAOA,CAACA,OAAOA,CAACA,CAACA;IAChDA,CAACA;IAEDD,mCAAQA,GAARA,UAASA,CAAUA,IAA0BE,MAAMA,CAACA,IAAIA,CAACA,UAAUA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA;IAX3EF;QAACA,gBAASA,CAACA;YACTA,QAAQA,EAAEA,kEAAkEA;YAC5EA,SAASA,EAAEA,CAACA,iBAAiBA,CAACA;SAC/BA,CAACA;QAIYA,WAACA,gBAASA,CAACA,SAASA,CAACA,CAAAA;;yBAKlCA;IAADA,uBAACA;AAADA,CAACA,AAZD,IAYC;AARY,wBAAgB,mBAQ5B,CAAA","sourcesContent":["import {forwardRef, Provider, OpaqueToken, Attribute, Directive} from 'angular2/core';\nimport {CONST_EXPR} from 'angular2/src/facade/lang';\nimport {Validators, NG_VALIDATORS} from '../validators';\nimport {Control} from '../model';\nimport * as modelModule from '../model';\nimport {NumberWrapper} from \"angular2/src/facade/lang\";\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.Control): {[key: string]: any}; }\n\nconst REQUIRED_VALIDATOR =\n    CONST_EXPR(new Provider(NG_VALIDATORS, {useValue: Validators.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\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: Function;\n\n  constructor(@Attribute(\"minlength\") minLength: string) {\n    this._validator = Validators.minLength(NumberWrapper.parseInt(minLength, 10));\n  }\n\n  validate(c: Control): {[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: Function;\n\n  constructor(@Attribute(\"maxlength\") maxLength: string) {\n    this._validator = Validators.maxLength(NumberWrapper.parseInt(maxLength, 10));\n  }\n\n  validate(c: Control): {[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: Function;\n\n  constructor(@Attribute(\"pattern\") pattern: string) {\n    this._validator = Validators.pattern(pattern);\n  }\n\n  validate(c: Control): {[key: string]: any} { return this._validator(c); }\n}\n"]}