From 5645bc7d995dd1933b8d2ea8ea273f03ac548cf1 Mon Sep 17 00:00:00 2001 From: Ghislain B Date: Wed, 24 Jun 2015 01:58:53 -0400 Subject: [PATCH] Merge pull #41 and fixed it - Merge pull request #41 and fixed some errors found inside it. - Updated Protractor tests --- bower.json | 2 +- dist/angular-validation.min.js | 8 +++---- package.json | 4 ++-- protractor/full_tests_spec.js | 43 ++++++++++++++++------------------ readme.md | 4 ++-- src/validation-rules.js | 32 ++++++++++++------------- 6 files changed, 45 insertions(+), 48 deletions(-) diff --git a/bower.json b/bower.json index 15a1c92..4a4bd33 100644 --- a/bower.json +++ b/bower.json @@ -1,6 +1,6 @@ { "name": "angular-validation-ghiscoding", - "version": "1.3.31", + "version": "1.3.32", "author": "Ghislain B.", "description": "Angular-Validation Directive and Service (ghiscoding)", "main": [ diff --git a/dist/angular-validation.min.js b/dist/angular-validation.min.js index 13e3a7f..42853e5 100644 --- a/dist/angular-validation.min.js +++ b/dist/angular-validation.min.js @@ -2,11 +2,11 @@ * Angular-Validation Directive and Service (ghiscoding) * http://github.com/ghiscoding/angular-validation * @author: Ghislain B. - * @version: 1.3.31 + * @version: 1.3.32 * @license: MIT - * @build: Tue Jun 23 2015 14:03:22 GMT+0200 (W. Europe Daylight Time) + * @build: Wed Jun 24 2015 01:32:09 GMT-0400 (Eastern Daylight Time) */ angular.module("ghiscoding.validation",["pascalprecht.translate"]).directive("validation",["$timeout","validationCommon",function(e,i){return{restrict:"A",require:"ngModel",link:function(t,a,n,d){function l(){var i=s.getFormElementByName(d.$name);i.isValidationCancelled=!0,e.cancel(r),s.updateErrorMsg(""),d.$setValidity("validation",!0),"function"==typeof u&&a.unbind("blur",u)}function o(i,n){var o="undefined"!=typeof n?n:s.typingLimit,u=s.getFormElementByName(d.$name);return s.validate(i,!1),s.isFieldRequired()||""!==i&&null!==i&&"undefined"!=typeof i?(u&&(u.isValidationCancelled=!1),(i||s.isFieldRequired())&&d.$setValidity("validation",!1),""!==i&&"undefined"!=typeof i||"NUMBER"!==a.prop("type").toUpperCase()?"SELECT"===a.prop("tagName").toUpperCase()?(d.$setValidity("validation",s.validate(i,!0)),i):("undefined"!=typeof i&&(s.updateErrorMsg(""),e.cancel(r),r=e(function(){t.$evalAsync(d.$setValidity("validation",s.validate(i,!0)))},o)),i):(e.cancel(r),d.$setValidity("validation",s.validate(i,!0)),i)):(l(),i)}var r,u,s=new i(t,a,n,d);d.$formatters.unshift(o),d.$parsers.unshift(o),n.$observe("disabled",function(e){if(e)l(),s.removeFromValidationSummary(n.name);else{"function"==typeof d.$setTouched&&d.$setTouched();var i=d.$viewValue||"";d.$setValidity("validation",s.validate(i,!0))}}),t.$watch(function(){return a.attr("validation")},function(e){("undefined"==typeof e||""===e)&&(d.$formatters.shift(),d.$parsers.shift(),l())}),a.bind("blur",u=function(e){var i=s.getFormElementByName(d.$name);i.isValidationCancelled?d.$setValidity("validation",!0):o(e.target.value,0)})}}}]); -angular.module("ghiscoding.validation").factory("validationCommon",["$rootScope","$timeout","$translate","validationRules",function(t,e,a,r){function i(){var t=this,e={};t.validators=[],t.typingLimit=F,t.validatorAttrs.hasOwnProperty("debounce")?t.typingLimit=parseInt(t.validatorAttrs.debounce,10):t.validatorAttrs.hasOwnProperty("typingLimit")?t.typingLimit=parseInt(t.validatorAttrs.typingLimit,10):U&&U.hasOwnProperty("debounce")&&(t.typingLimit=parseInt(U.debounce,10));var a=t.validatorAttrs.hasOwnProperty("rules")?t.validatorAttrs.rules:t.validatorAttrs.validation;if(a.indexOf("regex:")>=0){var i=a.match("regex:(.*?):regex");if(i.length<2)throw'Regex validator within the validation needs to be define with an opening "regex:" and a closing ":regex", please review your validator.';var n=i[1].split(":=");e={message:n[0],pattern:n[1]},a=a.replace(i[0],"regex:")}var s=a.split("|");if(s){t.bFieldRequired=a.indexOf("required")>=0?!0:!1;for(var o=0,l=s.length;l>o;o++){var p=s[o].split(":"),d=s[o].indexOf("alt=")>=0?!0:!1;t.validators[o]=r.getElementValidators({altText:d===!0?2===p.length?p[1]:p[2]:"",customRegEx:e,rule:p[0],ruleParams:d&&2===p.length?null:p[1]})}}return t}function n(t){return O(L,"fieldName",t)}function s(t){return t?$(L,"formName",t):L}function o(t,e,a,r){this.scope=t,this.elm=e,this.ctrl=r,this.validatorAttrs=a,h(e,a,r,t),this.defineValidation()}function l(){var t=this;return t.bFieldRequired}function p(t,e){var a={};for(var r in t)a[r]=t[r];for(var r in e)a[r]=e[r];return a}function d(t){var e=S(L,"fieldName",t);e>=0&&L.splice(e,1)}function u(t,e){var a=this,r=A(t,a),i=e?e:q,n=S(i,"field",t);return n>=0&&i.splice(n,1),n=S(q,"field",t),n>=0&&q.splice(n,1),a.scope.$validationSummary=q,r&&(r.$validationSummary=$(q,"formName",r.$name)),q}function c(t){w=t}function m(t){U.displayOnlyLastErrorMsg=t}function f(t){var e=this;return U=p(U,t),e}function g(t,e){var r=this;e&&e.obj&&(r=e.obj,r.validatorAttrs=e.obj.attrs);var i=e&&e.elm?e.elm:r.elm,n=i&&i.attr("name")?i.attr("name"):null;if("undefined"==typeof n||null===n){var s=i?i.attr("ng-model"):"unknown";throw'Angular-Validation Service requires you to have a (name="") attribute on the element to validate... Your element is: ng-model="'+s+'"'}var o=e&&e.translate?a.instant(t):t,l=n.replace(/[|&;$%@"<>()+,\[\]\{\}]/g,""),p=null;if(r.validatorAttrs&&r.validatorAttrs.hasOwnProperty("validationErrorTo")){var d=r.validatorAttrs.validationErrorTo.charAt(0),u="."===d||"#"===d?r.validatorAttrs.validationErrorTo:"#"+r.validatorAttrs.validationErrorTo;p=angular.element(document.querySelector(u))}p&&0!==p.length||(p=angular.element(document.querySelector(".validation-"+l)));var c=e&&e.isSubmitted?e.isSubmitted:!1;e&&!e.isValid&&(c||r.ctrl.$dirty||r.ctrl.$touched)?p.length>0?p.text(o):i.after(''+o+""):p.text("")}function v(t,e){var r,i,s=this,o=!0,l=!0,p="";"undefined"==typeof t&&(t="");for(var d=s.ctrl&&s.ctrl.$name?s.ctrl.$name:s.attrs&&s.attrs.name?s.attrs.name:s.elm.attr("name"),u=n(d),c=s.validatorAttrs.hasOwnProperty("rules")?s.validatorAttrs.rules:s.validatorAttrs.validation,m=0,f=s.validators.length;f>m;m++){if(i=s.validators[m],"conditionalDate"===i.type){if(r=new RegExp(i.pattern,"i"),o=("\\S+"===i.pattern||c&&"required"===i.pattern)&&null===t?!1:r.test(t)){var g=i.dateType,v=E(t,g).getTime();if(2==i.params.length){var h=E(i.params[0],g).getTime(),O=E(i.params[1],g).getTime(),$=N(i.condition[0],v,h),S=N(i.condition[1],v,O);o=$&&S?!0:!1}else{var A=E(i.params[0],g).getTime();o=N(i.condition,v,A)}}}else if("conditionalNumber"===i.type)if(2==i.params.length){var $=N(i.condition[0],parseFloat(t),parseFloat(i.params[0])),S=N(i.condition[1],parseFloat(t),parseFloat(i.params[1]));o=$&&S?!0:!1}else o=N(i.condition,parseFloat(t),parseFloat(i.params[0]));else if("match"===i.type){var x=i.params[0],R=s.scope.$eval(x);o=R===t&&!!t}else if("remote"===i.type){if(t&&e){s.ctrl.$processing=!0;var V=null,T=i.params[0];if(-1===T.indexOf("."))V=s.scope[T];else{var w=T.split(".");V=s.scope;for(var F=0,L=w.length;L>F;F++)V=V[w[F]]}var q="function"==typeof V?V():null;if(k.length>1)for(;k.length>0;){var M=k.pop();"function"==typeof M.abort&&M.abort()}if(k.push(q),!q||"function"!=typeof q.then)throw"Remote Validation requires a declared function (in your Controller) which also needs to return a Promise, please review your code.";s.ctrl.$setValidity("remote",!1),function(t){q.then(function(a){a=a.data||a,k.pop(),s.ctrl.$processing=!1;var r=p+" ";"boolean"==typeof a?o=a?!0:!1:"object"==typeof a&&(o=a.isValid?!0:!1),o===!1&&(u.isValid=!1,r+=a.message?a.message:t,y(s,u,r,!1,e)),o===!0&&l===!0&&(u.isValid=!0,s.ctrl.$setValidity("remote",!0),y(s,u,"",!0,e))})}(i.altText)}}else{var P="undefined"!=typeof s.attrs?s.attrs.ngDisabled:s.validatorAttrs.ngDisabled;s.elm.prop("disabled")||s.scope.$eval(P)?o=!0:"string"==typeof t&&""===t&&"NUMBER"===s.elm.prop("type").toUpperCase()?o=!1:(r=new RegExp(i.pattern,"i"),o=("\\S+"===i.pattern||c&&"required"===i.pattern)&&null===t?!1:r.test(t))}(!s.bFieldRequired&&!t||s.elm.prop("disabled")||s.scope.$eval(P))&&(o=!0),o||(l=!1,function(t,r,i){var n=i.message;i.altText&&i.altText.length>0&&(n=i.altText.replace("alt=","")),a(n).then(function(a){p.length>0&&U.displayOnlyLastErrorMsg?p=" "+(i&&i.params?String.format(a,i.params):a):p+=" "+(i&&i.params?String.format(a,i.params):a),y(s,t,p,l,e)})["catch"](function(a){i.altText&&i.altText.length>0&&(p.length>0&&U.displayOnlyLastErrorMsg?p=" "+n:p+=" "+n,y(s,t,p,l,e))})}(u,o,i))}return o&&(b(s,""),s.updateErrorMsg("",{isValid:o})),u&&(u.isValid=l,l&&(u.message="")),l}function h(t,e,r,i){var n=e.name?e.name:t.attr("name"),s=A(n,{scope:i}),o=e&&e.friendlyName?a.instant(e.friendlyName):"",l={fieldName:n,friendlyName:o,elm:t,attrs:e,ctrl:r,scope:i,isValid:!1,message:"",formName:s?s.$name:null},p=S(L,"fieldName",t.attr("name"));return p>=0?L[p]=l:L.push(l),L}function y(t,e,a,r,i){a=a.trim(),b(e,a),e&&(e.message=a),(t.validatorAttrs.preValidateFormElements||U.preValidateFormElements)&&(e&&"function"==typeof t.ctrl.$setTouched&&e.ctrl.$setTouched(),t.ctrl.$dirty===!1&&g(a,{isSubmitted:!0,isValid:r,obj:e})),i&&e&&!e.isValid?t.updateErrorMsg(a,{isValid:r}):e&&e.isValid&&b(e,"")}function b(t,e){if("undefined"!=typeof t&&null!=t){var r=t.ctrl&&t.ctrl.$name?t.ctrl.$name:t.attrs&&t.attrs.name?t.attrs.name:t.elm.attr("name"),i=A(r,t),n=S(q,"field",r);if(n>=0&&""===e)q.splice(n,1);else if(""!==e){var s=t.attrs&&t.friendlyName?a.instant(t.friendlyName):"",o={field:r,friendlyName:s,message:e,formName:i?i.$name:null};n>=0?q[n]=o:q.push(o)}return t.scope.$validationSummary=q,i&&(i.$validationSummary=$(q,"formName",i.$name)),q}}function O(t,e,a){if(t)for(var r=0;r8?t.substring(9).split(":"):null;break;case"UK":case"EURO":case"EURO_SHORT":case"EURO-SHORT":case"EUROPE":a=t.substring(0,8),r=t.substring(2,3),i=x(a,r),l=i[0],o=i[1],s=parseInt(i[2])<50?"20"+i[2]:"19"+i[2],n=t.length>8?t.substring(9).split(":"):null;break;case"US_LONG":case"US-LONG":a=t.substring(0,10),r=t.substring(2,3),i=x(a,r),o=i[0],l=i[1],s=i[2],n=t.length>8?t.substring(9).split(":"):null;break;case"US":case"US_SHORT":case"US-SHORT":a=t.substring(0,8),r=t.substring(2,3),i=x(a,r),o=i[0],l=i[1],s=parseInt(i[2])<50?"20"+i[2]:"19"+i[2],n=t.length>8?t.substring(9).split(":"):null;break;case"ISO":default:a=t.substring(0,10),r=t.substring(4,5),i=x(a,r),s=i[0],o=i[1],l=i[2],n=t.length>10?t.substring(11).split(":"):null}var p=n&&3===n.length?n[0]:0,d=n&&3===n.length?n[1]:0,u=n&&3===n.length?n[2]:0;return new Date(s,o-1,l,p,d,u)}function x(t,e){var a=[];switch(e){case"/":a=t.split("/");break;case".":a=t.split(".");break;case"-":default:a=t.split("-")}return a}function N(t,e,a){var r=!1;switch(t){case"<":r=a>e?!0:!1;break;case"<=":r=a>=e?!0:!1;break;case">":r=e>a?!0:!1;break;case">=":r=e>=a?!0:!1;break;case"!=":case"<>":r=e!=a?!0:!1;break;case"=":case"==":r=e==a?!0:!1;break;default:r=!1}return r}function R(){return this.replace(/^\s+|\s+$/g,"")}function V(){var t=Array.isArray(arguments[0])?arguments[0]:arguments;return this.replace(/{(\d+)}/g,function(e,a){return"undefined"!=typeof t[a]?t[a]:e})}function T(t){var e=Array.isArray(arguments[1])?arguments[1]:Array.prototype.slice.call(arguments,1);return t.replace(/{(\d+)}/g,function(t,a){return"undefined"!=typeof e[a]?e[a]:t})}var w=!1,F=1e3,L=[],U={},k=[],q=[];t.$on("$routeChangeStart",function(t,e,a){w||(U.displayOnlyLastErrorMsg=!1,L=[],q=[])});var M=function(t,e,a,r){this.bFieldRequired=!1,this.validators=[],this.typingLimit=F,this.scope=t,this.elm=e,this.ctrl=r,this.validatorAttrs=a,t&&t.$validationOptions&&(U=t.$validationOptions),t&&(U.isolatedScope||U.scope)&&(this.scope=U.isolatedScope?U.isolatedScope:U.scope,U=p(t.$validationOptions,U)),this.elm&&this.validatorAttrs&&this.ctrl&&this.scope&&(h(this.elm,this.validatorAttrs,this.ctrl,this.scope),this.defineValidation())};return M.prototype.arrayFindObject=O,M.prototype.defineValidation=i,M.prototype.getFormElementByName=n,M.prototype.getFormElements=s,M.prototype.isFieldRequired=l,M.prototype.initialize=o,M.prototype.mergeObjects=p,M.prototype.removeFromValidationSummary=u,M.prototype.removeFromFormElementObjectList=d,M.prototype.setBypassRootScopeReset=c,M.prototype.setDisplayOnlyLastErrorMsg=m,M.prototype.setGlobalOptions=f,M.prototype.updateErrorMsg=g,M.prototype.validate=v,String.prototype.trim=R,String.prototype.format=V,String.format=T,M}]); -angular.module("ghiscoding.validation").factory("validationRules",[function(){function e(e){var a="undefined"!=typeof e.altText?e.altText.replace("alt=",""):null,t=e.hasOwnProperty("customRegEx")?e.customRegEx:null,s=e.hasOwnProperty("rule")?e.rule:null,r=e.hasOwnProperty("ruleParams")?e.ruleParams:null,n={};switch(s){case"alpha":n={pattern:"^([a-zÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÒÓÔÕÖØÙÚÛÜÝàáâãäåæçèéêëìíîïðòóôõöøùúûüýÿ])+$",message:"INVALID_ALPHA",type:"regex"};break;case"alphaSpaces":case"alpha_spaces":n={pattern:"^([a-zÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÒÓÔÕÖØÙÚÛÜÝàáâãäåæçèéêëìíîïðòóôõöøùúûüýÿ\\s])+$",message:"INVALID_ALPHA_SPACE",type:"regex"};break;case"alphaNum":case"alpha_num":n={pattern:"^([a-z0-9ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÒÓÔÕÖØÙÚÛÜÝàáâãäåæçèéêëìíîïðòóôõöøùúûüýÿ])+$",message:"INVALID_ALPHA_NUM",type:"regex"};break;case"alphaNumSpaces":case"alpha_num_spaces":n={pattern:"^([a-z0-9ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÒÓÔÕÖØÙÚÛÜÝàáâãäåæçèéêëìíîïðòóôõöøùúûüýÿ\\s])+$",message:"INVALID_ALPHA_NUM_SPACE",type:"regex"};break;case"alphaDash":case"alpha_dash":n={pattern:"^([a-z0-9ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÒÓÔÕÖØÙÚÛÜÝàáâãäåæçèéêëìíîïðòóôõöøùúûüýÿ_-])+$",message:"INVALID_ALPHA_DASH",type:"regex"};break;case"alphaDashSpaces":case"alpha_dash_spaces":n={pattern:"^([a-z0-9ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÒÓÔÕÖØÙÚÛÜÝàáâãäåæçèéêëìíîïðòóôõöøùúûüýÿ\\s_-])+$",message:"INVALID_ALPHA_DASH_SPACE",type:"regex"};break;case"betweenLen":case"between_len":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_len:1,5";n={pattern:"^.{"+_[0]+","+_[1]+"}$",message:"INVALID_BETWEEN_CHAR",params:[_[0],_[1]],type:"regex"};break;case"betweenNum":case"between_num":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_num:1,5";n={condition:[">=","<="],message:"INVALID_BETWEEN_NUM",params:[_[0],_[1]],type:"conditionalNumber"};break;case"boolean":n={pattern:"^(true|True|false|False|0|1)$",message:"INVALID_BOOLEAN",type:"regex"};break;case"checked":n={pattern:"^true$",message:"INVALID_CHECKBOX_SELECTED",type:"regex"};break;case"creditCard":case"credit_card":n={pattern:"^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|6(?:011|5[0-9]{2})[0-9]{12}|(?:2131|1800|35\\d{3})\\d{11})$",message:"INVALID_CREDIT_CARD",type:"regex"};break;case"dateEuroLong":case"date_euro_long":n={pattern:"^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/](19|20)\\d\\d$",message:"INVALID_DATE_EURO_LONG",type:"regex"};break;case"dateEuroLongBetween":case"date_euro_long_between":case"betweenDateEuroLong":case"between_date_euro_long":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_date_euro_long:01-01-1990,31-12-2015";n={condition:[">=","<="],dateType:"EURO_LONG",params:[_[0],_[1]],pattern:"^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/](19|20)\\d\\d$",message:"INVALID_DATE_EURO_LONG_BETWEEN",type:"conditionalDate"};break;case"dateEuroLongMax":case"date_euro_long_max":case"maxDateEuroLong":case"max_date_euro_long":n={condition:"<=",dateType:"EURO_LONG",params:[r],pattern:"^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/](19|20)\\d\\d$",message:"INVALID_DATE_EURO_LONG_MAX",type:"conditionalDate"};break;case"dateEuroLongMin":case"date_euro_long_min":case"minDateEuroLong":case"min_date_euro_long":n={condition:">=",dateType:"EURO_LONG",params:[r],pattern:"^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/](19|20)\\d\\d$",message:"INVALID_DATE_EURO_LONG_MIN",type:"conditionalDate"};break;case"dateEuroShort":case"date_euro_short":n={pattern:"^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/]\\d\\d$",message:"INVALID_DATE_EURO_SHORT",type:"regex"};break;case"dateEuroShortBetween":case"date_euro_short_between":case"betweenDateEuroShort":case"between_date_euro_short":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_date_euro_short:01-01-90,31-12-15";n={condition:[">=","<="],dateType:"EURO_SHORT",params:[_[0],_[1]],pattern:"^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/]\\d\\d$",message:"INVALID_DATE_EURO_SHORT_BETWEEN",type:"conditionalDate"};break;case"dateEuroShortMax":case"date_euro_short_max":case"maxDateEuroShort":case"max_date_euro_short":n={condition:"<=",dateType:"EURO_SHORT",params:[r],pattern:"^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/]\\d\\d$",message:"INVALID_DATE_EURO_SHORT_MAX",type:"conditionalDate"};break;case"dateEuroShortMin":case"date_euro_short_min":case"minDateEuroShort":case"min_date_euro_short":n={condition:">=",dateType:"EURO_SHORT",params:[r],pattern:"^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/]\\d\\d$",message:"INVALID_DATE_EURO_SHORT_MIN",type:"conditionalDate"};break;case"dateIso":case"date_iso":n={pattern:"^(19|20)\\d\\d([-])(0[1-9]|1[012])\\2(0[1-9]|[12][0-9]|3[01])$",message:"INVALID_DATE_ISO",type:"regex"};break;case"dateIsoBetween":case"date_iso_between":case"betweenDateIso":case"between_date_iso":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_date_iso:1990-01-01,2000-12-31";n={condition:[">=","<="],dateType:"ISO",params:[_[0],_[1]],pattern:"^(19|20)\\d\\d([-])(0[1-9]|1[012])\\2(0[1-9]|[12][0-9]|3[01])$",message:"INVALID_DATE_ISO_BETWEEN",type:"conditionalDate"};break;case"dateIsoMax":case"date_iso_max":case"maxDateIso":case"max_date_iso":n={condition:"<=",dateType:"ISO",params:[r],pattern:"^(19|20)\\d\\d([-])(0[1-9]|1[012])\\2(0[1-9]|[12][0-9]|3[01])$",message:"INVALID_DATE_ISO_MAX",type:"conditionalDate"};break;case"dateIsoMin":case"date_iso_min":case"minDateIso":case"min_date_iso":n={condition:">=",dateType:"ISO",params:[r],pattern:"^(19|20)\\d\\d([-])(0[1-9]|1[012])\\2(0[1-9]|[12][0-9]|3[01])$",message:"INVALID_DATE_ISO_MIN",type:"conditionalDate"};break;case"dateUsLong":case"date_us_long":n={pattern:"^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/](19|20)\\d\\d$",message:"INVALID_DATE_US_LONG",type:"regex"};break;case"dateUsLongBetween":case"date_us_long_between":case"betweenDateUsLong":case"between_date_us_long":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_date_us_long:01/01/1990,12/31/2015";n={condition:[">=","<="],dateType:"US_LONG",params:[_[0],_[1]],pattern:"^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/](19|20)\\d\\d$",message:"INVALID_DATE_US_LONG_BETWEEN",type:"conditionalDate"};break;case"dateUsLongMax":case"date_us_long_max":case"maxDateUsLong":case"max_date_us_long":n={condition:"<=",dateType:"US_LONG",params:[r],pattern:"^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/](19|20)\\d\\d$",message:"INVALID_DATE_US_LONG_MAX",type:"conditionalDate"};break;case"dateUsLongMin":case"date_us_long_min":case"minDateUsLong":case"min_date_us_long":n={condition:">=",dateType:"US_LONG",params:[r],pattern:"^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/](19|20)\\d\\d$",message:"INVALID_DATE_US_LONG_MIN",type:"conditionalDate"};break;case"dateUsShort":case"date_us_short":n={pattern:"^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/]\\d\\d$",message:"INVALID_DATE_US_SHORT",type:"regex"};break;case"dateUsShortBetween":case"date_us_short_between":case"betweenDateUsShort":case"between_date_us_short":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_date_us_short:01/01/90,12/31/15";n={condition:[">=","<="],dateType:"US_SHORT",params:[_[0],_[1]],pattern:"^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/]\\d\\d$",message:"INVALID_DATE_US_SHORT_BETWEEN",type:"conditionalDate"};break;case"dateUsShortMax":case"date_us_short_max":case"maxDateUsShort":case"max_date_us_short":n={condition:"<=",dateType:"US_SHORT",params:[r],pattern:"^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/]\\d\\d$",message:"INVALID_DATE_US_SHORT_MAX",type:"conditionalDate"};break;case"dateUsShortMin":case"date_us_short_min":case"minDateUsShort":case"min_date_us_short":n={condition:">=",dateType:"US_SHORT",params:[r],pattern:"^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/]\\d\\d$",message:"INVALID_DATE_US_SHORT_MIN",type:"conditionalDate"};break;case"email":n={pattern:"(?:[\\wа-я0-9!#$%&'*+/=?^_`{|}~-]+(?:\\.?[\\wа-я0-9!#$%&'*+/=?^_`{|}~-]+)*|\"(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21\\x23-\\x5b\\x5d-\\x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])*\")@(?:(?:[\\wа-я0-9](?:[\\wа-я0-9-]*[\\wа-я0-9])?\\.?)+[\\wа-я0-9](?:[\\wа-я0-9-]*[\\wа-я0-9])?|\\[(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.?){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?|[\\wа-я0-9-]*[\\wа-я0-9]:(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21-\\x5a\\x53-\\x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])+)\\])",message:"INVALID_EMAIL",type:"regex"};break;case"exactLen":case"exact_len":n={pattern:"^.{"+r+"}$",message:"INVALID_EXACT_LEN",params:[r],type:"regex"};break;case"float":n={pattern:"^\\d*\\.{1}\\d+$",message:"INVALID_FLOAT",type:"regex"};break;case"floatSigned":case"float_signed":n={pattern:"^[-+]?\\d*\\.{1}\\d+$",message:"INVALID_FLOAT_SIGNED",type:"regex"};break;case"iban":n={pattern:"^[a-zA-Z]{2}\\d{2}\\s?([0-9a-zA-Z]{4}\\s?){4}[0-9a-zA-Z]{2}$",message:"INVALID_IBAN",type:"regex"};break;case"int":case"integer":n={pattern:"^\\d+$",message:"INVALID_INTEGER",type:"regex"};break;case"intSigned":case"integerSigned":case"int_signed":case"integer_signed":n={pattern:"^[+-]?\\d+$",message:"INVALID_INTEGER_SIGNED",type:"regex"};break;case"ipv4":n={pattern:"^(25[0-5]|2[0-4]\\d|[0-1]?\\d?\\d)(\\.(25[0-5]|2[0-4]\\d|[0-1]?\\d?\\d)){3}$",message:"INVALID_IPV4",type:"regex"};break;case"ipv6":n={pattern:"^(?:[0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}$",message:"INVALID_IPV6",type:"regex"};break;case"match":var e=r.split(",");n={message:"INVALID_INPUT_MATCH",params:e,type:"match"};break;case"maxLen":case"max_len":n={pattern:"^.{0,"+r+"}$",message:"INVALID_MAX_CHAR",params:[r],type:"regex"};break;case"maxNum":case"max_num":n={condition:"<=",message:"INVALID_MAX_NUM",params:[r],type:"conditionalNumber"};break;case"minLen":case"min_len":n={pattern:"^.{"+r+",}$",message:"INVALID_MIN_CHAR",params:[r],type:"regex"};break;case"minNum":case"min_num":n={condition:">=",message:"INVALID_MIN_NUM",params:[r],type:"conditionalNumber"};break;case"numeric":n={pattern:"^\\d*\\.?\\d+$",message:"INVALID_NUMERIC",type:"regex"};break;case"numericSigned":case"numeric_signed":n={pattern:"^[-+]?\\d*\\.?\\d+$",message:"INVALID_NUMERIC_SIGNED",type:"regex"};break;case"regex":n={pattern:t.pattern,message:"INVALID_PATTERN",params:[t.message],type:"regex"};break;case"remote":n={message:"",params:[r],type:"remote"};break;case"required":n={pattern:"\\S+",message:"INVALID_REQUIRED",type:"regex"};break;case"url":n={pattern:"(http|ftp|https):\\/\\/[\\w\\-_]+(\\.[\\w\\-_]+)+([\\w\\-\\.,@?^=%&:/~\\+#]*[\\w\\-\\@?^=%&/~\\+#])?",message:"INVALID_URL",type:"regex"};break;case"time":n={pattern:"^([01]?[0-9]|2[0-3]):[0-5][0-9](:[0-5][0-9])?$",message:"INVALID_TIME",type:"regex"}}return n.altText=a,n}var a={getElementValidators:e};return a}]); +angular.module("ghiscoding.validation").factory("validationCommon",["$rootScope","$timeout","$translate","validationRules",function(t,e,a,r){function i(){var t=this,e={};t.validators=[],t.typingLimit=F,t.validatorAttrs.hasOwnProperty("debounce")?t.typingLimit=parseInt(t.validatorAttrs.debounce,10):t.validatorAttrs.hasOwnProperty("typingLimit")?t.typingLimit=parseInt(t.validatorAttrs.typingLimit,10):U&&U.hasOwnProperty("debounce")&&(t.typingLimit=parseInt(U.debounce,10));var a=t.validatorAttrs.hasOwnProperty("rules")?t.validatorAttrs.rules:t.validatorAttrs.validation;if(a.indexOf("regex:")>=0){var i=a.match("regex:(.*?):regex");if(i.length<2)throw'Regex validator within the validation needs to be define with an opening "regex:" and a closing ":regex", please review your validator.';var n=i[1].split(":=");e={message:n[0],pattern:n[1]},a=a.replace(i[0],"regex:")}var s=a.split("|");if(s){t.bFieldRequired=a.indexOf("required")>=0?!0:!1;for(var o=0,l=s.length;l>o;o++){var p=s[o].split(":"),d=s[o].indexOf("alt=")>=0?!0:!1;t.validators[o]=r.getElementValidators({altText:d===!0?2===p.length?p[1]:p[2]:"",customRegEx:e,rule:p[0],ruleParams:d&&2===p.length?null:p[1]})}}return t}function n(t){return O(L,"fieldName",t)}function s(t){return t?$(L,"formName",t):L}function o(t,e,a,r){this.scope=t,this.elm=e,this.ctrl=r,this.validatorAttrs=a,h(e,a,r,t),this.defineValidation()}function l(){var t=this;return t.bFieldRequired}function p(t,e){var a={};for(var r in t)a[r]=t[r];for(var r in e)a[r]=e[r];return a}function d(t){var e=S(L,"fieldName",t);e>=0&&L.splice(e,1)}function u(t,e){var a=this,r=A(t,a),i=e?e:q,n=S(i,"field",t);return n>=0&&i.splice(n,1),n=S(q,"field",t),n>=0&&q.splice(n,1),a.scope.$validationSummary=q,r&&(r.$validationSummary=$(q,"formName",r.$name)),q}function c(t){w=t}function m(t){U.displayOnlyLastErrorMsg=t}function f(t){var e=this;return U=p(U,t),e}function g(t,e){var r=this;e&&e.obj&&(r=e.obj,r.validatorAttrs=e.obj.attrs);var i=e&&e.elm?e.elm:r.elm,n=i&&i.attr("name")?i.attr("name"):null;if("undefined"==typeof n||null===n){var s=i?i.attr("ng-model"):"unknown";throw'Angular-Validation Service requires you to have a (name="") attribute on the element to validate... Your element is: ng-model="'+s+'"'}var o=e&&e.translate?a.instant(t):t,l=n.replace(/[|&;$%@"<>()+,\[\]\{\}]/g,""),p=null;if(r.validatorAttrs&&r.validatorAttrs.hasOwnProperty("validationErrorTo")){var d=r.validatorAttrs.validationErrorTo.charAt(0),u="."===d||"#"===d?r.validatorAttrs.validationErrorTo:"#"+r.validatorAttrs.validationErrorTo;p=angular.element(document.querySelector(u))}p&&0!==p.length||(p=angular.element(document.querySelector(".validation-"+l)));var c=e&&e.isSubmitted?e.isSubmitted:!1;e&&!e.isValid&&(c||r.ctrl.$dirty||r.ctrl.$touched)?p.length>0?p.text(o):i.after(''+o+""):p.text("")}function v(t,e){var r,i,s=this,o=!0,l=!0,p="";"undefined"==typeof t&&(t="");for(var d=s.ctrl&&s.ctrl.$name?s.ctrl.$name:s.attrs&&s.attrs.name?s.attrs.name:s.elm.attr("name"),u=n(d),c=s.validatorAttrs.hasOwnProperty("rules")?s.validatorAttrs.rules:s.validatorAttrs.validation,m=0,f=s.validators.length;f>m;m++){if(i=s.validators[m],"conditionalDate"===i.type){if(r=new RegExp(i.pattern,"i"),o=("\\S+"===i.pattern||c&&"required"===i.pattern)&&null===t?!1:r.test(t)){var g=i.dateType,v=E(t,g).getTime();if(2==i.params.length){var h=E(i.params[0],g).getTime(),O=E(i.params[1],g).getTime(),$=N(i.condition[0],v,h),S=N(i.condition[1],v,O);o=$&&S?!0:!1}else{var A=E(i.params[0],g).getTime();o=N(i.condition,v,A)}}}else if("conditionalNumber"===i.type)if(2==i.params.length){var $=N(i.condition[0],parseFloat(t),parseFloat(i.params[0])),S=N(i.condition[1],parseFloat(t),parseFloat(i.params[1]));o=$&&S?!0:!1}else o=N(i.condition,parseFloat(t),parseFloat(i.params[0]));else if("match"===i.type){var x=i.params[0],R=s.scope.$eval(x);o=R===t&&!!t}else if("remote"===i.type){if(t&&e){s.ctrl.$processing=!0;var V=null,T=i.params[0];if(-1===T.indexOf("."))V=s.scope[T];else{var w=T.split(".");V=s.scope;for(var F=0,L=w.length;L>F;F++)V=V[w[F]]}var q="function"==typeof V?V():null;if(k.length>1)for(;k.length>0;){var M=k.pop();"function"==typeof M.abort&&M.abort()}if(k.push(q),!q||"function"!=typeof q.then)throw"Remote Validation requires a declared function (in your Controller) which also needs to return a Promise, please review your code.";s.ctrl.$setValidity("remote",!1),function(t){q.then(function(a){a=a.data||a,k.pop(),s.ctrl.$processing=!1;var r=p+" ";"boolean"==typeof a?o=a?!0:!1:"object"==typeof a&&(o=a.isValid?!0:!1),o===!1&&(u.isValid=!1,r+=a.message?a.message:t,y(s,u,r,!1,e)),o===!0&&l===!0&&(u.isValid=!0,s.ctrl.$setValidity("remote",!0),y(s,u,"",!0,e))})}(i.altText)}}else{var P="undefined"!=typeof s.attrs?s.attrs.ngDisabled:s.validatorAttrs.ngDisabled;s.elm.prop("disabled")||s.scope.$eval(P)?o=!0:"string"==typeof t&&""===t&&"NUMBER"===s.elm.prop("type").toUpperCase()?o=!1:(r=new RegExp(i.pattern,"i"),o=("\\S+"===i.pattern||c&&"required"===i.pattern)&&null===t?!1:r.test(t))}(!s.bFieldRequired&&!t||s.elm.prop("disabled")||s.scope.$eval(P))&&(o=!0),o||(l=!1,function(t,r,i){var n=i.message;i.altText&&i.altText.length>0&&(n=i.altText.replace("alt=","")),a(n).then(function(a){p.length>0&&U.displayOnlyLastErrorMsg?p=" "+(i&&i.params?String.format(a,i.params):a):p+=" "+(i&&i.params?String.format(a,i.params):a),y(s,t,p,l,e)})["catch"](function(){i.altText&&i.altText.length>0&&(p.length>0&&U.displayOnlyLastErrorMsg?p=" "+n:p+=" "+n,y(s,t,p,l,e))})}(u,o,i))}return o&&(b(s,""),s.updateErrorMsg("",{isValid:o})),u&&(u.isValid=l,l&&(u.message="")),l}function h(t,e,r,i){var n=e.name?e.name:t.attr("name"),s=A(n,{scope:i}),o=e&&e.friendlyName?a.instant(e.friendlyName):"",l={fieldName:n,friendlyName:o,elm:t,attrs:e,ctrl:r,scope:i,isValid:!1,message:"",formName:s?s.$name:null},p=S(L,"fieldName",t.attr("name"));return p>=0?L[p]=l:L.push(l),L}function y(t,e,a,r,i){a=a.trim(),b(e,a),e&&(e.message=a),(t.validatorAttrs.preValidateFormElements||U.preValidateFormElements)&&(e&&"function"==typeof t.ctrl.$setTouched&&e.ctrl.$setTouched(),t.ctrl.$dirty===!1&&g(a,{isSubmitted:!0,isValid:r,obj:e})),i&&e&&!e.isValid?t.updateErrorMsg(a,{isValid:r}):e&&e.isValid&&b(e,"")}function b(t,e){if("undefined"!=typeof t&&null!=t){var r=t.ctrl&&t.ctrl.$name?t.ctrl.$name:t.attrs&&t.attrs.name?t.attrs.name:t.elm.attr("name"),i=A(r,t),n=S(q,"field",r);if(n>=0&&""===e)q.splice(n,1);else if(""!==e){var s=t.attrs&&t.friendlyName?a.instant(t.friendlyName):"",o={field:r,friendlyName:s,message:e,formName:i?i.$name:null};n>=0?q[n]=o:q.push(o)}return t.scope.$validationSummary=q,i&&(i.$validationSummary=$(q,"formName",i.$name)),q}}function O(t,e,a){if(t)for(var r=0;r8?t.substring(9).split(":"):null;break;case"UK":case"EURO":case"EURO_SHORT":case"EURO-SHORT":case"EUROPE":a=t.substring(0,8),r=t.substring(2,3),i=x(a,r),l=i[0],o=i[1],s=parseInt(i[2])<50?"20"+i[2]:"19"+i[2],n=t.length>8?t.substring(9).split(":"):null;break;case"US_LONG":case"US-LONG":a=t.substring(0,10),r=t.substring(2,3),i=x(a,r),o=i[0],l=i[1],s=i[2],n=t.length>8?t.substring(9).split(":"):null;break;case"US":case"US_SHORT":case"US-SHORT":a=t.substring(0,8),r=t.substring(2,3),i=x(a,r),o=i[0],l=i[1],s=parseInt(i[2])<50?"20"+i[2]:"19"+i[2],n=t.length>8?t.substring(9).split(":"):null;break;case"ISO":default:a=t.substring(0,10),r=t.substring(4,5),i=x(a,r),s=i[0],o=i[1],l=i[2],n=t.length>10?t.substring(11).split(":"):null}var p=n&&3===n.length?n[0]:0,d=n&&3===n.length?n[1]:0,u=n&&3===n.length?n[2]:0;return new Date(s,o-1,l,p,d,u)}function x(t,e){var a=[];switch(e){case"/":a=t.split("/");break;case".":a=t.split(".");break;case"-":default:a=t.split("-")}return a}function N(t,e,a){var r=!1;switch(t){case"<":r=a>e?!0:!1;break;case"<=":r=a>=e?!0:!1;break;case">":r=e>a?!0:!1;break;case">=":r=e>=a?!0:!1;break;case"!=":case"<>":r=e!=a?!0:!1;break;case"=":case"==":r=e==a?!0:!1;break;default:r=!1}return r}function R(){return this.replace(/^\s+|\s+$/g,"")}function V(){var t=Array.isArray(arguments[0])?arguments[0]:arguments;return this.replace(/{(\d+)}/g,function(e,a){return"undefined"!=typeof t[a]?t[a]:e})}function T(t){var e=Array.isArray(arguments[1])?arguments[1]:Array.prototype.slice.call(arguments,1);return t.replace(/{(\d+)}/g,function(t,a){return"undefined"!=typeof e[a]?e[a]:t})}var w=!1,F=1e3,L=[],U={},k=[],q=[];t.$on("$routeChangeStart",function(){w||(U.displayOnlyLastErrorMsg=!1,L=[],q=[])});var M=function(t,e,a,r){this.bFieldRequired=!1,this.validators=[],this.typingLimit=F,this.scope=t,this.elm=e,this.ctrl=r,this.validatorAttrs=a,t&&t.$validationOptions&&(U=t.$validationOptions),t&&(U.isolatedScope||U.scope)&&(this.scope=U.isolatedScope?U.isolatedScope:U.scope,U=p(t.$validationOptions,U)),this.elm&&this.validatorAttrs&&this.ctrl&&this.scope&&(h(this.elm,this.validatorAttrs,this.ctrl,this.scope),this.defineValidation())};return M.prototype.arrayFindObject=O,M.prototype.defineValidation=i,M.prototype.getFormElementByName=n,M.prototype.getFormElements=s,M.prototype.isFieldRequired=l,M.prototype.initialize=o,M.prototype.mergeObjects=p,M.prototype.removeFromValidationSummary=u,M.prototype.removeFromFormElementObjectList=d,M.prototype.setBypassRootScopeReset=c,M.prototype.setDisplayOnlyLastErrorMsg=m,M.prototype.setGlobalOptions=f,M.prototype.updateErrorMsg=g,M.prototype.validate=v,String.prototype.trim=R,String.prototype.format=V,String.format=T,M}]); +angular.module("ghiscoding.validation").factory("validationRules",[function(){function e(e){var a="undefined"!=typeof e.altText?e.altText.replace("alt=",""):null,t=e.hasOwnProperty("customRegEx")?e.customRegEx:null,s=e.hasOwnProperty("rule")?e.rule:null,r=e.hasOwnProperty("ruleParams")?e.ruleParams:null,n={};switch(s){case"alpha":n={pattern:"^([a-zÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÒÓÔÕÖØÙÚÛÜÝàáâãäåæçèéêëìíîïðòóôõöøùúûüýÿ])+$",message:"INVALID_ALPHA",type:"regex"};break;case"alphaSpaces":case"alpha_spaces":n={pattern:"^([a-zÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÒÓÔÕÖØÙÚÛÜÝàáâãäåæçèéêëìíîïðòóôõöøùúûüýÿ\\s])+$",message:"INVALID_ALPHA_SPACE",type:"regex"};break;case"alphaNum":case"alpha_num":n={pattern:"^([a-z0-9ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÒÓÔÕÖØÙÚÛÜÝàáâãäåæçèéêëìíîïðòóôõöøùúûüýÿ])+$",message:"INVALID_ALPHA_NUM",type:"regex"};break;case"alphaNumSpaces":case"alpha_num_spaces":n={pattern:"^([a-z0-9ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÒÓÔÕÖØÙÚÛÜÝàáâãäåæçèéêëìíîïðòóôõöøùúûüýÿ\\s])+$",message:"INVALID_ALPHA_NUM_SPACE",type:"regex"};break;case"alphaDash":case"alpha_dash":n={pattern:"^([a-z0-9ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÒÓÔÕÖØÙÚÛÜÝàáâãäåæçèéêëìíîïðòóôõöøùúûüýÿ_-])+$",message:"INVALID_ALPHA_DASH",type:"regex"};break;case"alphaDashSpaces":case"alpha_dash_spaces":n={pattern:"^([a-z0-9ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÒÓÔÕÖØÙÚÛÜÝàáâãäåæçèéêëìíîïðòóôõöøùúûüýÿ\\s_-])+$",message:"INVALID_ALPHA_DASH_SPACE",type:"regex"};break;case"betweenLen":case"between_len":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_len:1,5";n={pattern:"^.{"+_[0]+","+_[1]+"}$",message:"INVALID_BETWEEN_CHAR",params:[_[0],_[1]],type:"regex"};break;case"betweenNum":case"between_num":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_num:1,5";n={condition:[">=","<="],message:"INVALID_BETWEEN_NUM",params:[_[0],_[1]],type:"conditionalNumber"};break;case"boolean":n={pattern:"^(true|True|false|False|0|1)$",message:"INVALID_BOOLEAN",type:"regex"};break;case"checked":n={pattern:"^true$",message:"INVALID_CHECKBOX_SELECTED",type:"regex"};break;case"creditCard":case"credit_card":n={pattern:"^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|6(?:011|5[0-9]{2})[0-9]{12}|(?:2131|1800|35\\d{3})\\d{11})$",message:"INVALID_CREDIT_CARD",type:"regex"};break;case"dateEuroLong":case"date_euro_long":n={pattern:"^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.](19|20)\\d\\d$",message:"INVALID_DATE_EURO_LONG",type:"regex"};break;case"dateEuroLongBetween":case"date_euro_long_between":case"betweenDateEuroLong":case"between_date_euro_long":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_date_euro_long:01-01-1990,31-12-2015";n={condition:[">=","<="],dateType:"EURO_LONG",params:[_[0],_[1]],pattern:"^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.](19|20)\\d\\d$",message:"INVALID_DATE_EURO_LONG_BETWEEN",type:"conditionalDate"};break;case"dateEuroLongMax":case"date_euro_long_max":case"maxDateEuroLong":case"max_date_euro_long":n={condition:"<=",dateType:"EURO_LONG",params:[r],pattern:"^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.](19|20)\\d\\d$",message:"INVALID_DATE_EURO_LONG_MAX",type:"conditionalDate"};break;case"dateEuroLongMin":case"date_euro_long_min":case"minDateEuroLong":case"min_date_euro_long":n={condition:">=",dateType:"EURO_LONG",params:[r],pattern:"^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.](19|20)\\d\\d$",message:"INVALID_DATE_EURO_LONG_MIN",type:"conditionalDate"};break;case"dateEuroShort":case"date_euro_short":n={pattern:"^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.]\\d\\d$",message:"INVALID_DATE_EURO_SHORT",type:"regex"};break;case"dateEuroShortBetween":case"date_euro_short_between":case"betweenDateEuroShort":case"between_date_euro_short":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_date_euro_short:01-01-90,31-12-15";n={condition:[">=","<="],dateType:"EURO_SHORT",params:[_[0],_[1]],pattern:"^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.]\\d\\d$",message:"INVALID_DATE_EURO_SHORT_BETWEEN",type:"conditionalDate"};break;case"dateEuroShortMax":case"date_euro_short_max":case"maxDateEuroShort":case"max_date_euro_short":n={condition:"<=",dateType:"EURO_SHORT",params:[r],pattern:"^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.]\\d\\d$",message:"INVALID_DATE_EURO_SHORT_MAX",type:"conditionalDate"};break;case"dateEuroShortMin":case"date_euro_short_min":case"minDateEuroShort":case"min_date_euro_short":n={condition:">=",dateType:"EURO_SHORT",params:[r],pattern:"^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.]\\d\\d$",message:"INVALID_DATE_EURO_SHORT_MIN",type:"conditionalDate"};break;case"dateIso":case"date_iso":n={pattern:"^(19|20)\\d\\d([-])(0[1-9]|1[012])\\2(0[1-9]|[12][0-9]|3[01])$",message:"INVALID_DATE_ISO",type:"regex"};break;case"dateIsoBetween":case"date_iso_between":case"betweenDateIso":case"between_date_iso":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_date_iso:1990-01-01,2000-12-31";n={condition:[">=","<="],dateType:"ISO",params:[_[0],_[1]],pattern:"^(19|20)\\d\\d([-])(0[1-9]|1[012])\\2(0[1-9]|[12][0-9]|3[01])$",message:"INVALID_DATE_ISO_BETWEEN",type:"conditionalDate"};break;case"dateIsoMax":case"date_iso_max":case"maxDateIso":case"max_date_iso":n={condition:"<=",dateType:"ISO",params:[r],pattern:"^(19|20)\\d\\d([-])(0[1-9]|1[012])\\2(0[1-9]|[12][0-9]|3[01])$",message:"INVALID_DATE_ISO_MAX",type:"conditionalDate"};break;case"dateIsoMin":case"date_iso_min":case"minDateIso":case"min_date_iso":n={condition:">=",dateType:"ISO",params:[r],pattern:"^(19|20)\\d\\d([-])(0[1-9]|1[012])\\2(0[1-9]|[12][0-9]|3[01])$",message:"INVALID_DATE_ISO_MIN",type:"conditionalDate"};break;case"dateUsLong":case"date_us_long":n={pattern:"^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.](19|20)\\d\\d$",message:"INVALID_DATE_US_LONG",type:"regex"};break;case"dateUsLongBetween":case"date_us_long_between":case"betweenDateUsLong":case"between_date_us_long":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_date_us_long:01/01/1990,12/31/2015";n={condition:[">=","<="],dateType:"US_LONG",params:[_[0],_[1]],pattern:"^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.](19|20)\\d\\d$",message:"INVALID_DATE_US_LONG_BETWEEN",type:"conditionalDate"};break;case"dateUsLongMax":case"date_us_long_max":case"maxDateUsLong":case"max_date_us_long":n={condition:"<=",dateType:"US_LONG",params:[r],pattern:"^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.](19|20)\\d\\d$",message:"INVALID_DATE_US_LONG_MAX",type:"conditionalDate"};break;case"dateUsLongMin":case"date_us_long_min":case"minDateUsLong":case"min_date_us_long":n={condition:">=",dateType:"US_LONG",params:[r],pattern:"^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.](19|20)\\d\\d$",message:"INVALID_DATE_US_LONG_MIN",type:"conditionalDate"};break;case"dateUsShort":case"date_us_short":n={pattern:"^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.]\\d\\d$",message:"INVALID_DATE_US_SHORT",type:"regex"};break;case"dateUsShortBetween":case"date_us_short_between":case"betweenDateUsShort":case"between_date_us_short":var _=r.split(",");if(2!==_.length)throw"This validation must include exactly 2 params separated by a comma (,) ex.: between_date_us_short:01/01/90,12/31/15";n={condition:[">=","<="],dateType:"US_SHORT",params:[_[0],_[1]],pattern:"^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.]\\d\\d$",message:"INVALID_DATE_US_SHORT_BETWEEN",type:"conditionalDate"};break;case"dateUsShortMax":case"date_us_short_max":case"maxDateUsShort":case"max_date_us_short":n={condition:"<=",dateType:"US_SHORT",params:[r],pattern:"^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.]\\d\\d$",message:"INVALID_DATE_US_SHORT_MAX",type:"conditionalDate"};break;case"dateUsShortMin":case"date_us_short_min":case"minDateUsShort":case"min_date_us_short":n={condition:">=",dateType:"US_SHORT",params:[r],pattern:"^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.]\\d\\d$",message:"INVALID_DATE_US_SHORT_MIN",type:"conditionalDate"};break;case"email":n={pattern:"(?:[\\wа-я0-9!#$%&'*+/=?^_`{|}~-]+(?:\\.?[\\wа-я0-9!#$%&'*+/=?^_`{|}~-]+)*|\"(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21\\x23-\\x5b\\x5d-\\x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])*\")@(?:(?:[\\wа-я0-9](?:[\\wа-я0-9-]*[\\wа-я0-9])?\\.?)+[\\wа-я0-9](?:[\\wа-я0-9-]*[\\wа-я0-9])?|\\[(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.?){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?|[\\wа-я0-9-]*[\\wа-я0-9]:(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21-\\x5a\\x53-\\x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])+)\\])",message:"INVALID_EMAIL",type:"regex"};break;case"exactLen":case"exact_len":n={pattern:"^.{"+r+"}$",message:"INVALID_EXACT_LEN",params:[r],type:"regex"};break;case"float":n={pattern:"^\\d*\\.{1}\\d+$",message:"INVALID_FLOAT",type:"regex"};break;case"floatSigned":case"float_signed":n={pattern:"^[-+]?\\d*\\.{1}\\d+$",message:"INVALID_FLOAT_SIGNED",type:"regex"};break;case"iban":n={pattern:"^[a-zA-Z]{2}\\d{2}\\s?([0-9a-zA-Z]{4}\\s?){4}[0-9a-zA-Z]{2}$",message:"INVALID_IBAN",type:"regex"};break;case"int":case"integer":n={pattern:"^\\d+$",message:"INVALID_INTEGER",type:"regex"};break;case"intSigned":case"integerSigned":case"int_signed":case"integer_signed":n={pattern:"^[+-]?\\d+$",message:"INVALID_INTEGER_SIGNED",type:"regex"};break;case"ipv4":n={pattern:"^(25[0-5]|2[0-4]\\d|[0-1]?\\d?\\d)(\\.(25[0-5]|2[0-4]\\d|[0-1]?\\d?\\d)){3}$",message:"INVALID_IPV4",type:"regex"};break;case"ipv6":n={pattern:"^(?:[0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}$",message:"INVALID_IPV6",type:"regex"};break;case"match":var e=r.split(",");n={message:"INVALID_INPUT_MATCH",params:e,type:"match"};break;case"maxLen":case"max_len":n={pattern:"^.{0,"+r+"}$",message:"INVALID_MAX_CHAR",params:[r],type:"regex"};break;case"maxNum":case"max_num":n={condition:"<=",message:"INVALID_MAX_NUM",params:[r],type:"conditionalNumber"};break;case"minLen":case"min_len":n={pattern:"^.{"+r+",}$",message:"INVALID_MIN_CHAR",params:[r],type:"regex"};break;case"minNum":case"min_num":n={condition:">=",message:"INVALID_MIN_NUM",params:[r],type:"conditionalNumber"};break;case"numeric":n={pattern:"^\\d*\\.?\\d+$",message:"INVALID_NUMERIC",type:"regex"};break;case"numericSigned":case"numeric_signed":n={pattern:"^[-+]?\\d*\\.?\\d+$",message:"INVALID_NUMERIC_SIGNED",type:"regex"};break;case"regex":n={pattern:t.pattern,message:"INVALID_PATTERN",params:[t.message],type:"regex"};break;case"remote":n={message:"",params:[r],type:"remote"};break;case"required":n={pattern:"\\S+",message:"INVALID_REQUIRED",type:"regex"};break;case"url":n={pattern:"(http|ftp|https):\\/\\/[\\w\\-_]+(\\.[\\w\\-_]+)+([\\w\\-\\.,@?^=%&:/~\\+#]*[\\w\\-\\@?^=%&/~\\+#])?",message:"INVALID_URL",type:"regex"};break;case"time":n={pattern:"^([01]?[0-9]|2[0-3]):[0-5][0-9](:[0-5][0-9])?$",message:"INVALID_TIME",type:"regex"}}return n.altText=a,n}var a={getElementValidators:e};return a}]); angular.module("ghiscoding.validation").service("validationService",["$interpolate","$timeout","validationCommon",function(e,o,t){function a(t,a,n){var i=this,r={};if("string"==typeof t&&"string"==typeof a?(r.elmName=t,r.rules=a,r.friendlyName="string"==typeof n?n:""):r=t,"object"!=typeof r||!r.hasOwnProperty("elmName")||!r.hasOwnProperty("rules")||!r.hasOwnProperty("scope")&&"undefined"==typeof i.validationAttrs.scope)throw"Angular-Validation-Service requires at least the following 3 attributes: {elmName, rules, scope}";var l=r.scope?r.scope:i.validationAttrs.scope;if(r.elm=angular.element(document.querySelector('[name="'+r.elmName+'"]')),"object"!=typeof r.elm||0===r.elm.length)return i;if(new RegExp("{{(.*?)}}").test(r.elmName)&&(r.elmName=e(r.elmName)(l)),r.name=r.elmName,i.validationAttrs.isolatedScope){var m=l.$validationOptions||null;l=i.validationAttrs.isolatedScope,m&&(l.$validationOptions=m)}r.elm.bind("blur",v=function(e){var o=i.commonObj.getFormElementByName(r.elmName);o.isValidationCancelled||(i.commonObj.initialize(l,r.elm,r,r.ctrl),s(i,e.target.value,0))}),r=i.commonObj.mergeObjects(i.validationAttrs,r),f(i,l,r);var c=l.$watch(r.elmName,function(e,t){return void 0===e&&void 0!==t?(o.cancel(i.timer),void i.commonObj.ctrl.$setValidity("validation",i.commonObj.validate("",!0))):(r.ctrl=angular.element(r.elm).controller("ngModel"),r.value=e,i.commonObj.initialize(l,r.elm,r,r.ctrl),void s(i,e))},!0);return y.push({elmName:r.elmName,watcherHandler:c}),i}function n(e){var o=this,t="",a=!0;if("undefined"==typeof e||"undefined"==typeof e.$validationSummary)throw"checkFormValidity() requires a valid Angular Form or $scope object passed as argument to work properly (ex.: $scope.form1 OR $scope).";for(var n=0,i=e.$validationSummary.length;i>n;n++)if(a=!1,t=e.$validationSummary[n].field){var r=o.commonObj.getFormElementByName(t);r.elm&&r.elm.length>0&&("function"==typeof r.ctrl.$setTouched&&r.ctrl.$setTouched(),o.commonObj.updateErrorMsg(e.$validationSummary[n].message,{isSubmitted:!0,isValid:r.isValid,obj:r}))}return a}function i(e){var o=this;if("undefined"==typeof e||"undefined"==typeof e.$validationSummary)throw"clearInvalidValidatorsInSummary() requires a valid Angular Form or $scope object passed as argument to work properly (ex.: $scope.form1 OR $scope).";for(var t=[],a=0,n=e.$validationSummary.length;n>a;a++)t.push(e.$validationSummary[a].field);for(a=0,n=t.length;n>a;a++)t[a]&&(o.commonObj.removeFromFormElementObjectList(t[a]),o.commonObj.removeFromValidationSummary(t[a],e.$validationSummary))}function r(e,o){var t,a=this;if("undefined"==typeof e||"undefined"==typeof e.$validationSummary)throw"removeValidator() only works with Validation that were defined by the Service (not by the Directive) and requires a valid Angular Form or $scope object passed as argument to work properly (ex.: $scope.form1 OR $scope).";if(o instanceof Array)for(var n=0,i=o.length;i>n;n++)t=a.commonObj.getFormElementByName(o[n]),t.elm.removeAttr("validation"),p(a,t,e.$validationSummary);else o instanceof Object&&o.formElmObj?(t=o.formElmObj,t.elm.removeAttr("validation"),p(o.self,t,e.$validationSummary)):(t=a.commonObj.getFormElementByName(o),t.elm.removeAttr("validation"),p(a,t,e.$validationSummary));return a}function l(e,o){var t,a=this,o=o||{},n="undefined"!=typeof o.removeAllValidators?o.removeAllValidators:!1,i="undefined"!=typeof o.emptyAllInputValues?o.emptyAllInputValues:!1;if("undefined"==typeof e||"undefined"==typeof e.$name)throw"resetForm() requires a valid Angular Form object passed as argument to work properly (ex.: $scope.form1).";var l=a.commonObj.getFormElements(e.$name);if(l instanceof Array)for(var m=0,c=l.length;c>m;m++)t=l[m],i&&t.elm.val(null),n?r(e,{self:a,formElmObj:t}):("function"==typeof t.ctrl.$setUntouched&&t.ctrl.$setUntouched(),t.ctrl.$setPristine(),a.commonObj.updateErrorMsg("",{isValid:!1,obj:t}))}function m(e){var o=this,t="boolean"==typeof e?e:!0;o.commonObj.setBypassRootScopeReset(t)}function c(e){var o=this,t="boolean"==typeof e?e:!0;o.commonObj.setDisplayOnlyLastErrorMsg(t)}function d(e){var o=this;return o.validationAttrs=e,o.commonObj.setGlobalOptions(e),o}function s(e,t,a){var n="undefined"!=typeof a?a:e.commonObj.typingLimit,i=e.commonObj.getFormElementByName(e.commonObj.ctrl.$name);return e.commonObj.validate(t,!1),e.commonObj.isFieldRequired()||""!==t&&null!==t&&"undefined"!=typeof t?(i.isValidationCancelled=!1,(e.commonObj.isFieldRequired()||t)&&e.commonObj.ctrl.$setValidity("validation",!1),""!==t&&"undefined"!=typeof t||"NUMBER"!==e.commonObj.elm.prop("type").toUpperCase()?"SELECT"===e.commonObj.elm.prop("tagName").toUpperCase()?(e.commonObj.ctrl.$setValidity("validation",e.commonObj.validate(t,!0)),t):("undefined"!=typeof t&&(e.commonObj.updateErrorMsg(""),o.cancel(e.timer),e.timer=o(function(){e.commonObj.scope.$evalAsync(e.commonObj.ctrl.$setValidity("validation",e.commonObj.validate(t,!0)))},n)),t):(o.cancel(e.timer),e.commonObj.ctrl.$setValidity("validation",e.commonObj.validate(t,!0)),t)):(u(e,i),t)}function u(e,t){var a=t.ctrl?t.ctrl:e.commonObj.ctrl;if(o.cancel(self.timer),t.isValidationCancelled=!0,a.$setValidity("validation",!0),e.commonObj.updateErrorMsg("",{isValid:!0,obj:t}),"function"==typeof v){var n=t.elm?t.elm:e.commonObj.elm;n.unbind("blur",v)}}function p(e,o,t){var a=e.commonObj.scope?e.commonObj.scope:o.scope?o.scope:null;if("undefined"==typeof a)throw"removeValidator() requires a valid $scope object passed but unfortunately could not find it.";var n=e.commonObj.arrayFindObject(y,"elmName",o.fieldName);n&&n.watcherHandler(),o.isValidationCancelled=!0,o.isValid=!0,o.attrs.validation="",u(e,o),"function"==typeof o.ctrl.$setUntouched&&o.ctrl.$setUntouched(),e.commonObj.scope=a,o.ctrl.$setPristine(),e.commonObj.removeFromValidationSummary(o.fieldName,t)}function f(e,t,a){t.$watch(function(){return"undefined"==typeof a.elm.attr("ng-disabled")?null:t.$eval(a.elm.attr("ng-disabled"))},function(n){if("undefined"==typeof n||null===n)return null;a.ctrl=angular.element(a.elm).controller("ngModel"),e.commonObj.initialize(t,a.elm,a,a.ctrl);var i=e.commonObj.getFormElementByName(a.name);o(function(){if(n)a.ctrl.$setValidity("validation",!0),e.commonObj.updateErrorMsg("",{isValid:!0,obj:i}),e.commonObj.removeFromValidationSummary(a.name);else{"function"==typeof a.ctrl.$setTouched&&a.ctrl.$setTouched();var o=a.ctrl.$viewValue||"";e.commonObj.initialize(t,a.elm,a,a.ctrl),a.ctrl.$setValidity("validation",e.commonObj.validate(o,!0))}},0,!1),n&&("function"==typeof a.ctrl.$setUntouched&&a.ctrl.$setUntouched(),a.ctrl.$setValidity("validation",!0),e.commonObj.removeFromValidationSummary(a.name))})}var v,y=[],b=function(){this.isValidationCancelled=!1,this.timer=null,this.validationAttrs={},this.commonObj=new t};return b.prototype.addValidator=a,b.prototype.checkFormValidity=n,b.prototype.removeValidator=r,b.prototype.resetForm=l,b.prototype.setBypassRootScopeReset=m,b.prototype.setDisplayOnlyLastErrorMsg=c,b.prototype.setGlobalOptions=d,b.prototype.clearInvalidValidatorsInSummary=i,b}]); \ No newline at end of file diff --git a/package.json b/package.json index c3242b3..9e1daec 100644 --- a/package.json +++ b/package.json @@ -1,13 +1,13 @@ { "name": "angular-validation-ghiscoding", - "version": "1.3.31", + "version": "1.3.32", "author": "Ghislain B.", "description": "Angular-Validation Directive and Service (ghiscoding)", "main": "app.js", "dependencies": {}, "devDependencies": { "del": "^1.1.1", - "gulp": "^3.8.11", + "gulp": "^3.9.0", "gulp-bump": "^0.3.0", "gulp-concat": "^2.5.2", "gulp-if": "^1.2.5", diff --git a/protractor/full_tests_spec.js b/protractor/full_tests_spec.js index be38ecd..c304673 100644 --- a/protractor/full_tests_spec.js +++ b/protractor/full_tests_spec.js @@ -67,10 +67,7 @@ for (var i = 0, ln = validations.length; i < ln; i++) { var elmInput = $('[name=input' + i + ']'); elmInput.click(); - for(var j = 0, jln = 2; j < jln; j++) { - if(jln > validations[i].length) { - break; - } + for(var j = 0, jln = validations[i].valid_data.length; j < jln; j++) { var data = validations[i].valid_data[j]; (function(elmInput, data, i) { elmInput.clear().then(function() { @@ -287,7 +284,7 @@ function loadData() { 'validator': 'dateEuroLong', 'aliases': ['date_euro_long'], 'invalid_data': ['abc', '32-12-2000', '00-01-2001', '30-13-2012'], - 'valid_data': ['01-01-2001', '30-12-2001', '28-02-2001'], + 'valid_data': ['30-12-2001', '28-02-2001', '05.05.2005'], 'error_message': { 'en': "Must be a valid date format (dd-mm-yyyy) OR (dd/mm/yyyy).", 'es': "Debe contener una fecha valida con formato (dd-mm-yyyy) ó (dd/mm/yyyy).", @@ -301,7 +298,7 @@ function loadData() { 'aliases': ['date_euro_long_between', 'betweenDateEuroLong', 'between_date_euro_long'], 'params': '01-01-2001,28-02-2001', 'invalid_data': ['abc', '32-12-2000', '00-01-2001', '30-13-2012', '31-12-2000', '01-03-2001'], - 'valid_data': ['01-01-2001', '01-02-2001', '28-02-2001'], + 'valid_data': ['01-02-2001', '28-02-2001', '05.02.2001'], 'error_message': { 'en': "Needs to be a valid date format (dd-mm-yyyy) OR (dd/mm/yyyy) between 01-01-2001 and 28-02-2001.", 'es': "Debe contener una fecha valida entre 01-01-2001 y 28-02-2001 con formato (dd-mm-yyyy) ó (dd/mm/yyyy).", @@ -315,7 +312,7 @@ function loadData() { 'aliases': ['date_euro_long_max', 'maxDateEuroLong', 'max_date_euro_long'], 'params': '30-05-2012', 'invalid_data': ['abc', '32-12-2000', '00-01-2001', '30-13-2012', '01-06-2012'], - 'valid_data': ['01-01-2001', '01/01/2001', '30-05-2012'], + 'valid_data': ['01/01/2001', '30-05-2012', '05.05.2005'], 'error_message': { 'en': "Needs to be a valid date format (dd-mm-yyyy) OR (dd/mm/yyyy), equal to, or lower than 30-05-2012.", 'es': "Debe contener una fecha valida igual ó menor que 30-05-2012 con formato (dd-mm-yyyy) ó (dd/mm/yyyy).", @@ -329,7 +326,7 @@ function loadData() { 'aliases': ['date_euro_long_min', 'minDateEuroLong', 'min_date_euro_long'], 'params': '25-05-2012', 'invalid_data': ['abc', '24-05-2012', '32-12-2000', '00-01-2001', '30-13-2012'], - 'valid_data': ['25-05-2012', '25/05/2012', '30-05-2012'], + 'valid_data': ['25/05/2012', '30-05-2012', '05.05.2015'], 'error_message': { 'en': "Needs to be a valid date format (dd-mm-yyyy) OR (dd/mm/yyyy), equal to, or higher than 25-05-2012.", 'es': "Debe contener una fecha valida igual ó mayor que 25-05-2012 con formato (dd-mm-yyyy) ó (dd/mm/yyyy).", @@ -343,7 +340,7 @@ function loadData() { 'aliases': ['date_euro_short'], 'params': '25-05-12', 'invalid_data': ['32-12-00', '00-01-01', '30-13-12', '01-06-2012'], - 'valid_data': ['25-05-12', '25/05/12', '30-05-12'], + 'valid_data': ['25/05/12', '30-05-12', '05.05.05'], 'error_message': { 'en': "Must be a valid date format (dd-mm-yy) OR (dd/mm/yy).", 'es': "Debe contener una fecha valida con formato (dd-mm-yy) o (dd/mm/yy).", @@ -357,7 +354,7 @@ function loadData() { 'aliases': ['date_euro_short_between', 'betweenDateEuroShort', 'between_date_euro_short'], 'params': '25-05-12,04-06-12', 'invalid_data': ['24-05-12', '32-12-00', '00-01-01', '30-13-12', '24-05-12', '05-06-12', '01-06-2012'], - 'valid_data': ['25-05-12', '25/05/12', '30-05-12', '04-06-12'], + 'valid_data': ['25/05/12', '30.05.12', '04-06-12'], 'error_message': { 'en': "Needs to be a valid date format (dd-mm-yy) OR (dd/mm/yy) between 25-05-12 and 04-06-12.", 'es': "Debe contener una fecha valida entre 25-05-12 y 04-06-12 con formato (dd-mm-yy) o (dd/mm/yy).", @@ -371,7 +368,7 @@ function loadData() { 'aliases': ['date_euro_short_max', 'maxDateEuroShort', 'max_date_euro_short'], 'params': '04-06-12', 'invalid_data': ['32-12-00', '00-01-01', '30-13-12', '05-06-12', '01-06-2012'], - 'valid_data': ['25-05-12', '25/05/12', '04-06-12'], + 'valid_data': ['25/05/12', '04-06-12', '05.05.05'], 'error_message': { 'en': "Needs to be a valid date format (dd-mm-yy) OR (dd/mm/yy), equal to, or lower than 04-06-12.", 'es': "Debe contener una fecha valida igual ó menor que 04-06-12 con formato (dd-mm-yy) ó (dd/mm/yy).", @@ -385,7 +382,7 @@ function loadData() { 'aliases': ['date_euro_short_min', 'minDateEuroShort', 'min_date_euro_short'], 'params': '04-06-12', 'invalid_data': ['32-12-00', '00-01-01', '30-13-12', '03-06-12', '01-06-2012'], - 'valid_data': ['25-07-12', '25/07/12', '04-06-12'], + 'valid_data': ['25/07/12', '04-06-12', '05.05.15'], 'error_message': { 'en': "Needs to be a valid date format (dd-mm-yy) OR (dd/mm/yy), equal to, or higher than 04-06-12.", 'es': "Debe contener una fecha valida igual ó mayor que 04-06-12 con formato (dd-mm-yy) ó (dd/mm/yy).", @@ -453,7 +450,7 @@ function loadData() { 'validator': 'dateUsLong', 'aliases': ['date_us_long'], 'invalid_data': ['32-12-2000', '00-01-2001', '13-30-2012'], - 'valid_data': ['01-01-2001', '01/01/2001', '12/30/2001', '28/02/2001'], + 'valid_data': ['01-01-2001', '12/30/2001', '05.15.2005'], 'error_message': { 'en': "Must be a valid date format (mm/dd/yyyy) OR (mm-dd-yyyy).", 'es': "Debe contener una fecha valida con formato (mm/dd/yyyy) ó (mm-dd-yyyy).", @@ -467,7 +464,7 @@ function loadData() { 'aliases': ['date_us_long_between', 'betweenDateUsLong', 'between_date_us_long'], 'params': '01/01/1990,12/31/2015', 'invalid_data': ['00/02/1990', '01/01/2016', '12/31/15'], - 'valid_data': ['01-01-1990', '01/01/1990', '12/31/2015', '01/12/2000'], + 'valid_data': ['01-01-1990', '12/31/2015', '05.15.2015'], 'error_message': { 'en': "Needs to be a valid date format (mm/dd/yyyy) OR (mm-dd-yyyy) between 01/01/1990 and 12/31/2015.", 'es': "Debe contener una fecha valida entre 01/01/1990 y 12/31/2015 con formato (mm/dd/yyyy) ó (mm/dd/yyyy).", @@ -481,7 +478,7 @@ function loadData() { 'aliases': ['date_us_long_max', 'maxDateUsLong', 'max_date_us_long'], 'params': '01/01/1990', 'invalid_data': ['00/02/1990', '02/01/1990', '12/31/15'], - 'valid_data': ['01-01-1990', '01/01/1990', '12/31/1989', '01/12/1900'], + 'valid_data': ['01-01-1990', '12/31/1989', '01.12.1900'], 'error_message': { 'en': "Needs to be a valid date format (mm/dd/yyyy) OR (mm-dd-yyyy), equal to, or lower than 01/01/1990.", 'es': "Debe contener una fecha valida igual ó menor que 01/01/1990 con formato (mm/dd/yyyy) ó (mm/dd/yyyy).", @@ -495,7 +492,7 @@ function loadData() { 'aliases': ['date_us_long_min', 'minDateUsLong', 'min_date_us_long'], 'params': '01/01/1990', 'invalid_data': ['00/02/1990', '12/31/1989', '12/31/15'], - 'valid_data': ['01-01-1990', '01/01/1990', '12/31/1999'], + 'valid_data': ['01-01-1990', '12/31/1990', '12.31.1999'], 'error_message': { 'en': "Needs to be a valid date format (mm/dd/yyyy) OR (mm-dd-yyyy), equal to, or higher than 01/01/1990.", 'es': "Debe contener una fecha valida igual ó mayor que 01/01/1990 con formato (mm/dd/yyyy) ó (mm/dd/yyyy).", @@ -508,7 +505,7 @@ function loadData() { 'validator': 'dateUsShort', 'aliases': ['date_us_short'], 'invalid_data': ['32-12-00', '00-01-01', '13-30-12'], - 'valid_data': ['01-01-01', '01/01/01', '12/30/01', '28/02/01'], + 'valid_data': ['01-01-01', '12/30/01', '05.15.05'], 'error_message': { 'en': "Must be a valid date format (mm/dd/yy) OR (mm-dd-yy).", 'es': "Debe contener una fecha valida con formato (mm/dd/yy) ó (mm-dd-yy).", @@ -522,7 +519,7 @@ function loadData() { 'aliases': ['date_us_short_between', 'betweenDateUsShort', 'between_date_us_short'], 'params': '01/01/90,12/31/15', 'invalid_data': ['00/02/90', '01/01/16', '12/31/15', '12/31/2015'], - 'valid_data': ['01-01-90', '01/01/90', '12/31/15', '01/12/00'], + 'valid_data': ['01-01-90', '12/31/15', '05.15.15'], 'error_message': { 'en': "Needs to be a valid date format (mm/dd/yy) OR (mm-dd-yy) between 01/01/90 and 12/31/15.", 'es': "Debe contener una fecha valida entre 01/01/90 y 12/31/15 con formato (mm/dd/yy) ó (mm/dd/yy).", @@ -536,7 +533,7 @@ function loadData() { 'aliases': ['date_us_short_max', 'maxDateUsShort', 'max_date_us_short'], 'params': '01/01/90', 'invalid_data': ['00/02/90', '02/01/90', '12/31/15', '12/31/2015'], - 'valid_data': ['01-01-90', '01/01/90', '12/31/89', '01/12/00'], + 'valid_data': ['01-01-90', '12/31/89', '01.12.89'], 'error_message': { 'en': "Needs to be a valid date format (mm/dd/yy) OR (mm-dd-yy), equal to, or lower than 01/01/90.", 'es': "Debe contener una fecha valida igual ó menor que 01/01/90 con formato (mm/dd/yy) ó (mm/dd/yy).", @@ -550,7 +547,7 @@ function loadData() { 'aliases': ['date_us_short_min', 'minDateUsShort', 'min_date_us_short'], 'params': '01/01/90', 'invalid_data': ['00/02/90', '12/31/89', '31/12/15', '12/31/2015'], - 'valid_data': ['01-01-90', '01/01/90', '02/01/90', '12/31/89'], + 'valid_data': ['01-01-90', '02/28/90', '05.15.05'], 'error_message': { 'en': "Needs to be a valid date format (mm/dd/yy) OR (mm-dd-yy), equal to, or higher than 01/01/90.", 'es': "Debe contener una fecha valida igual ó mayor que 01/01/90 con formato (mm/dd/yy) ó (mm/dd/yy).", @@ -639,7 +636,7 @@ function loadData() { 'validator': 'intSigned', 'aliases': ['integerSigned', 'int_signed', 'integer_signed'], 'invalid_data': ['12.5', '.5', 'abc', '12,4'], - 'valid_data': ['12', '100', '-12.3', '+12.3'], + 'valid_data': ['12', '100', '-12', '+12'], 'error_message': { 'en': "Must be a positive or negative integer.", 'es': "Debe contener un número entero positivo ó negativo.", @@ -779,8 +776,8 @@ function loadData() { }, { 'validator': 'time', - 'invalid_data': ['1010', '61:61', '00:00', '59:59:60'], - 'valid_data': ['10:10', '00:01', '59:59:59'], + 'invalid_data': ['1010', '61:61', '00:00', '59:59:59'], + 'valid_data': ['10:10', '00:01', '23:59:59'], 'error_message': { 'en': "Must be a valid time format (hh:mm) OR (hh:mm:ss).", 'es': "Debe contener un formato de tiempo valido (hh:mm) ó (hh:mm:ss).", diff --git a/readme.md b/readme.md index a49ccd7..10945cb 100644 --- a/readme.md +++ b/readme.md @@ -1,5 +1,5 @@ #Angular Validation (Directive / Service) -`Version: 1.3.31` +`Version: 1.3.32` ### Form validation after user inactivity of default 1sec. (customizable timeout) Forms Validation with Angular made easy! Angular-Validation is an angular directive/service with locales (languages) with a very simple approach of defining your `validation=""` directly within your element to validate (input, textarea, etc) and...that's it!!! The directive/service will take care of the rest! @@ -24,7 +24,7 @@ If you do use Angular-Validation, please click on the **Star** and add it as a f [Plunker](http://plnkr.co/jADq7H) ## Tested with Protractor -Angular-validation now has a full set of End-to-End tests with Protractor, there is over 1400+ assertions, it starts by testing the original live demo page and then goes on with a complete test suite of All Validators in both the Angular-Validation Directive and Service. +Angular-validation now has a full set of End-to-End tests with Protractor, there is over 1600+ assertions, it starts by testing the original live demo page and then goes on with a complete test suite of All Validators in both the Angular-Validation Directive and Service. Why use angular-validation? diff --git a/src/validation-rules.js b/src/validation-rules.js index afaccd2..42bb335 100644 --- a/src/validation-rules.js +++ b/src/validation-rules.js @@ -135,7 +135,7 @@ angular case "dateEuroLong" : case "date_euro_long" : validator = { - pattern: "^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/](19|20)\\d\\d$", + pattern: "^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.](19|20)\\d\\d$", message: "INVALID_DATE_EURO_LONG", type: "regex" }; @@ -152,7 +152,7 @@ angular condition: [">=","<="], dateType: "EURO_LONG", params: [ranges[0], ranges[1]], - pattern: "^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/](19|20)\\d\\d$", + pattern: "^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.](19|20)\\d\\d$", message: "INVALID_DATE_EURO_LONG_BETWEEN", type: "conditionalDate" }; @@ -165,7 +165,7 @@ angular condition: "<=", dateType: "EURO_LONG", params: [ruleParams], - pattern: "^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/](19|20)\\d\\d$", + pattern: "^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.](19|20)\\d\\d$", message: "INVALID_DATE_EURO_LONG_MAX", type: "conditionalDate" }; @@ -178,7 +178,7 @@ angular condition: ">=", dateType: "EURO_LONG", params: [ruleParams], - pattern: "^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/](19|20)\\d\\d$", + pattern: "^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.](19|20)\\d\\d$", message: "INVALID_DATE_EURO_LONG_MIN", type: "conditionalDate" }; @@ -186,7 +186,7 @@ angular case "dateEuroShort" : case "date_euro_short" : validator = { - pattern: "^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/]\\d\\d$", + pattern: "^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.]\\d\\d$", message: "INVALID_DATE_EURO_SHORT", type: "regex" }; @@ -203,7 +203,7 @@ angular condition: [">=","<="], dateType: "EURO_SHORT", params: [ranges[0], ranges[1]], - pattern: "^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/]\\d\\d$", + pattern: "^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.]\\d\\d$", message: "INVALID_DATE_EURO_SHORT_BETWEEN", type: "conditionalDate" }; @@ -216,7 +216,7 @@ angular condition: "<=", dateType: "EURO_SHORT", params: [ruleParams], - pattern: "^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/]\\d\\d$", + pattern: "^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.]\\d\\d$", message: "INVALID_DATE_EURO_SHORT_MAX", type: "conditionalDate" }; @@ -229,7 +229,7 @@ angular condition: ">=", dateType: "EURO_SHORT", params: [ruleParams], - pattern: "^(0[1-9]|[12][0-9]|3[01])[.-/](0[1-9]|1[012])[.-/]\\d\\d$", + pattern: "^(0[1-9]|[12][0-9]|3[01])[-/.](0[1-9]|1[012])[-/.]\\d\\d$", message: "INVALID_DATE_EURO_SHORT_MIN", type: "conditionalDate" }; @@ -288,7 +288,7 @@ angular case "dateUsLong" : case "date_us_long" : validator = { - pattern: "^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/](19|20)\\d\\d$", + pattern: "^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.](19|20)\\d\\d$", message: "INVALID_DATE_US_LONG", type: "regex" }; @@ -305,7 +305,7 @@ angular condition: [">=","<="], dateType: "US_LONG", params: [ranges[0], ranges[1]], - pattern: "^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/](19|20)\\d\\d$", + pattern: "^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.](19|20)\\d\\d$", message: "INVALID_DATE_US_LONG_BETWEEN", type: "conditionalDate" }; @@ -318,7 +318,7 @@ angular condition: "<=", dateType: "US_LONG", params: [ruleParams], - pattern: "^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/](19|20)\\d\\d$", + pattern: "^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.](19|20)\\d\\d$", message: "INVALID_DATE_US_LONG_MAX", type: "conditionalDate" }; @@ -331,7 +331,7 @@ angular condition: ">=", dateType: "US_LONG", params: [ruleParams], - pattern: "^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/](19|20)\\d\\d$", + pattern: "^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.](19|20)\\d\\d$", message: "INVALID_DATE_US_LONG_MIN", type: "conditionalDate" }; @@ -339,7 +339,7 @@ angular case "dateUsShort" : case "date_us_short" : validator = { - pattern: "^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/]\\d\\d$", + pattern: "^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.]\\d\\d$", message: "INVALID_DATE_US_SHORT", type: "regex" }; @@ -356,7 +356,7 @@ angular condition: [">=","<="], dateType: "US_SHORT", params: [ranges[0], ranges[1]], - pattern: "^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/]\\d\\d$", + pattern: "^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.]\\d\\d$", message: "INVALID_DATE_US_SHORT_BETWEEN", type: "conditionalDate" }; @@ -369,7 +369,7 @@ angular condition: "<=", dateType: "US_SHORT", params: [ruleParams], - pattern: "^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/]\\d\\d$", + pattern: "^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.]\\d\\d$", message: "INVALID_DATE_US_SHORT_MAX", type: "conditionalDate" }; @@ -382,7 +382,7 @@ angular condition: ">=", dateType: "US_SHORT", params: [ruleParams], - pattern: "^(0[1-9]|1[012])[-/](0[1-9]|[12][0-9]|3[01])[-/]\\d\\d$", + pattern: "^(0[1-9]|1[012])[-/.](0[1-9]|[12][0-9]|3[01])[-/.]\\d\\d$", message: "INVALID_DATE_US_SHORT_MIN", type: "conditionalDate" };