diff --git a/README.md b/README.md index ec20096..93ef286 100644 --- a/README.md +++ b/README.md @@ -70,6 +70,13 @@ var app = angular.module('myApp', ['vcRecaptcha']); Here, the `key` attribute is passed to the directive's scope, so you can use either a property in your scope or just a hardcoded string. Be careful to use your public key, not your private one. +Form Validation +--------------- +**By default**, if placed in a [form](https://docs.angularjs.org/api/ng/directive/form) using [formControl](https://docs.angularjs.org/api/ng/type/form.FormController) the captcha will need to be checked for the form to be valid. +If the captcha is not checked (if the user has not checked the box or the check has expired) the form will be marked as invalid. The validation key is `recaptcha`. +You can **opt out** of this feature by setting the `required` attribute to `false` or a scoped variable +that will evaluate to `false`. Any other value, or omitting the attribute will opt in to this feature. + Response Validation ------------------- diff --git a/src/directive.js b/src/directive.js index 38b281e..7ac0a58 100644 --- a/src/directive.js +++ b/src/directive.js @@ -20,6 +20,7 @@ theme: '=?', size: '=?', tabindex: '=?', + required: '=?', onCreate: '&', onSuccess: '&', onExpire: '&' @@ -31,6 +32,10 @@ scope.widgetId = null; + if(ctrl && angular.isDefined(attrs.required)){ + scope.$watch('required', validate); + } + var removeCreationListener = scope.$watch('key', function (key) { if (!key) { return; @@ -43,10 +48,9 @@ var callback = function (gRecaptchaResponse) { // Safe $apply $timeout(function () { - if(ctrl){ - ctrl.$setValidity('recaptcha',true); - } scope.response = gRecaptchaResponse; + validate(); + // Notify about the response availability scope.onSuccess({response: gRecaptchaResponse, widgetId: scope.widgetId}); }); @@ -62,9 +66,7 @@ }).then(function (widgetId) { // The widget has been created - if(ctrl){ - ctrl.$setValidity('recaptcha',false); - } + validate(); scope.widgetId = widgetId; scope.onCreate({widgetId: widgetId}); @@ -86,14 +88,19 @@ } function expired(){ - if(ctrl){ - ctrl.$setValidity('recaptcha',false); - } scope.response = ""; + validate(); + // Notify about the response availability scope.onExpire({widgetId: scope.widgetId}); } + function validate(){ + if(ctrl){ + ctrl.$setValidity('recaptcha', scope.required === false ? null : Boolean(scope.response)); + } + } + function cleanup(){ // removes elements reCaptcha added. angular.element($document[0].querySelectorAll('.pls-container')).parent().remove();