ngx-captcha
Advanced tools
Comparing version 3.1.2 to 4.0.0
@@ -1,2 +0,2 @@ | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-captcha",["exports","@angular/core","@angular/common"],e):e(t["ngx-captcha"]={},t.ng.core,t.ng.common)}(this,function(t,i,a){"use strict";var r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var a in e)e.hasOwnProperty(a)&&(t[a]=e[a])};function e(t,e){function a(){this.constructor=t}r(t,e),t.prototype=null===e?Object.create(e):(a.prototype=e.prototype,new a)}var o={InvisibleReCaptcha:0,ReCaptcha2:1};o[o.InvisibleReCaptcha]="InvisibleReCaptcha",o[o.ReCaptcha2]="ReCaptcha2";var n=function(){function t(t,e,a){this.renderer=t,this.zone=e,this.globalConfig=a,this.setupAfterLoad=!1,this.windowOnLoadCallbackProperty="ngx_onload_callback_"+this.getPseudoUniqueNumber(),this.globalReCaptchaProperty="grecaptcha",this.captchaElemPrefix="ngx_captcha_id_",this.type="image",this.tabIndex=0,this.success=new i.EventEmitter,this.load=new i.EventEmitter,this.ready=new i.EventEmitter,this.resetCaptchaAfterSuccess=!1,this.isLoaded=!1}return t.prototype.getGlobalSiteKey=function(){if(this.globalConfig){if(this.recaptchaType===o.InvisibleReCaptcha){if(!this.globalConfig.invisibleCaptchaSiteKey)throw Error("SiteKey for invisible reCaptcha is not set!");return this.globalConfig.invisibleCaptchaSiteKey instanceof Function?this.globalConfig.invisibleCaptchaSiteKey():this.globalConfig.invisibleCaptchaSiteKey}if(this.recaptchaType===o.ReCaptcha2){if(!this.globalConfig.reCaptcha2SiteKey)throw Error("SiteKey for reCaptcha2 is not set!");return this.globalConfig.reCaptcha2SiteKey instanceof Function?this.globalConfig.reCaptcha2SiteKey():this.globalConfig.reCaptcha2SiteKey}throw Error("Unsupported captcha type '"+this.recaptchaType+"'!")}},t.prototype.ngOnChanges=function(t){this.siteKey?this.siteKey instanceof Function?this._siteKey=this.siteKey():this._siteKey=this.siteKey:this._siteKey=this.getGlobalSiteKey(),this.setupComponent()},t.prototype.ngOnDestroy=function(){window[this.windowOnLoadCallbackProperty]={},window[this.globalReCaptchaProperty]={}},t.prototype.getResponse=function(){return this.reCaptchaApi.getResponse(this.captchaId)},t.prototype.getCaptchaId=function(){return this.captchaId},t.prototype.resetCaptcha=function(){this.reCaptchaApi.reset(this.captchaId)},t.prototype.getCurrentResponse=function(){return this.currentResponse},t.prototype.reloadCaptcha=function(){this.setupComponent()},t.prototype.ensureCaptchaElem=function(t){var e=document.getElementById(t);if(!e)throw Error("Captcha element with id '"+t+"' was not found");this.captchaElem=e},t.prototype.renderReCaptcha=function(){this.captchaId=this.reCaptchaApi.render(this.captchaElemId,this.getCaptchaProperties()),this.ready.next()},t.prototype.handleCallback=function(t){this.currentResponse=t,this.success.next(t),this.resetCaptchaAfterSuccess&&this.resetCaptcha()},t.prototype.ensureReCaptchaScript=function(){window[this.globalReCaptchaProperty]={},this.reCaptchaApi={},this.registerReCaptchaScript()},t.prototype.registerReCaptchaScript=function(){var t=document.createElement("script");t.innerHTML="",t.src="https://www.google.com/recaptcha/api.js?onload="+this.windowOnLoadCallbackProperty+"&render=explicit"+this.getLanguageParam(),t.async=!0,t.defer=!0,this.captchaScriptElem.nativeElement.appendChild(t)},t.prototype.getLanguageParam=function(){return this.hl?"&hl="+this.hl:""},t.prototype.getPseudoUniqueNumber=function(){return(new Date).getUTCMilliseconds()+Math.floor(9999*Math.random())},t.prototype.isReCaptchaApiDefined=function(){return!!window[this.globalReCaptchaProperty]},t.prototype.setupComponent=function(){var t=this;this.captchaSpecificSetup(),this.createAndSetCaptchaElem(),window[this.windowOnLoadCallbackProperty]=function(){return t.zone.run(t.onloadCallback.bind(t))},this.ensureReCaptchaScript()},t.prototype.onloadCallback=function(){if(this.reCaptchaApi=grecaptcha,!this.reCaptchaApi)throw Error("ReCaptcha Api was not initialized correctly");this.isLoaded=!0,this.load.next(),this.renderReCaptcha(),this.setupAfterLoad&&(this.setupAfterLoad=!1,this.setupComponent())},t.prototype.generateNewElemId=function(){return this.captchaElemPrefix+this.getPseudoUniqueNumber()},t.prototype.createAndSetCaptchaElem=function(){if(this.captchaElemId=this.generateNewElemId(),!this.captchaElemId)throw Error("Captcha elem Id is not set");this.captchaWrapperElem.nativeElement.innerHTML="";var t=this.renderer.createElement("div");t.id=this.captchaElemId,this.renderer.appendChild(this.captchaWrapperElem.nativeElement,t),this.ensureCaptchaElem(this.captchaElemId)},t.propDecorators={siteKey:[{type:i.Input}],type:[{type:i.Input}],hl:[{type:i.Input}],tabIndex:[{type:i.Input}],success:[{type:i.Output}],load:[{type:i.Output}],ready:[{type:i.Output}],captchaWrapperElem:[{type:i.ViewChild,args:["captchaWrapperElem"]}],captchaScriptElem:[{type:i.ViewChild,args:["captchaScriptElem"]}]},t}(),p=function(){},c=function(n){function t(t,e,a){var r=n.call(this,t,e,a)||this;return r.renderer=t,r.zone=e,r.globalConfig=a,r.windowOnErrorCallbackProperty="ngx_captcha_error_callback",r.windowOnExpireCallbackProperty="ngx_captcha_expire_callback",r.theme="light",r.size="normal",r.expire=new i.EventEmitter,r.error=new i.EventEmitter,r.recaptchaType=o.ReCaptcha2,r}return e(t,n),t.prototype.ngOnChanges=function(t){n.prototype.ngOnChanges.call(this,t)},t.prototype.ngOnDestroy=function(){n.prototype.ngOnDestroy.call(this),window[this.windowOnErrorCallbackProperty]={},window[this.windowOnExpireCallbackProperty]={}},t.prototype.captchaSpecificSetup=function(){this.registerCallbacks()},t.prototype.getCaptchaProperties=function(){var e=this;return{sitekey:this._siteKey,callback:function(t){return e.zone.run(function(){return e.handleCallback(t)})},"expired-callback":function(){return e.zone.run(function(){return e.handleExpireCallback()})},"error-callback":function(){return e.zone.run(function(){return e.handleErrorCallback()})},theme:this.theme,type:this.type,size:this.size,tabindex:this.tabIndex}},t.prototype.registerCallbacks=function(){window[this.windowOnErrorCallbackProperty]=this.handleErrorCallback.bind(this),window[this.windowOnExpireCallbackProperty]=this.handleExpireCallback.bind(this)},t.prototype.handleErrorCallback=function(){this.error.next()},t.prototype.handleExpireCallback=function(){this.expire.next(),this.resetCaptcha()},t.decorators=[{type:i.Component,args:[{selector:"ngx-recaptcha2",template:"\n <div #captchaScriptElem></div>\n <div #captchaWrapperElem></div>"}]}],t.ctorParameters=function(){return[{type:i.Renderer2},{type:i.NgZone},{type:p,decorators:[{type:i.Optional}]}]},t.propDecorators={theme:[{type:i.Input}],size:[{type:i.Input}],hl:[{type:i.Input}],expire:[{type:i.Output}],error:[{type:i.Output}]},t}(n),s=function(n){function t(t,e,a){var r=n.call(this,t,e,a)||this;return r.renderer=t,r.zone=e,r.globalConfig=a,r.size="invisible",r.badge="bottomright",r.recaptchaType=o.InvisibleReCaptcha,r}return e(t,n),t.prototype.ngOnChanges=function(t){n.prototype.ngOnChanges.call(this,t)},t.prototype.execute=function(){this.reCaptchaApi.execute(this.captchaId)},t.prototype.captchaSpecificSetup=function(){},t.prototype.getCaptchaProperties=function(){var e=this;return{sitekey:this._siteKey,callback:function(t){return e.zone.run(function(){return e.handleCallback(t)})},badge:this.badge,type:this.type,tabindex:this.tabIndex,size:this.size}},t.decorators=[{type:i.Component,args:[{selector:"ngx-invisible-recaptcha",template:"\n <div #captchaScriptElem></div>\n <div #captchaWrapperElem></div>"}]}],t.ctorParameters=function(){return[{type:i.Renderer2},{type:i.NgZone},{type:p,decorators:[{type:i.Optional}]}]},t.propDecorators={badge:[{type:i.Input}],hl:[{type:i.Input}]},t}(n),h=function(){function e(){}return e.forRoot=function(t){return{ngModule:e,providers:[{provide:p,useValue:t}]}},e.decorators=[{type:i.NgModule,args:[{imports:[a.CommonModule],declarations:[c,s],exports:[c,s]}]}],e}();t.ReCaptcha2Component=c,t.InvisibleReCaptchaComponent=s,t.NgxCaptchaConfig=p,t.NgxCaptchaModule=h,t.ɵa=n,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/forms"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-captcha",["exports","@angular/core","@angular/forms","@angular/common"],e):e(t["ngx-captcha"]={},t.ng.core,t.ng.forms,t.ng.common)}(this,function(t,o,e,n){"use strict";var r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)e.hasOwnProperty(n)&&(t[n]=e[n])};function i(t,e){function n(){this.constructor=t}r(t,e),t.prototype=null===e?Object.create(e):(n.prototype=e.prototype,new n)}var p={InvisibleReCaptcha:0,ReCaptcha2:1};p[p.InvisibleReCaptcha]="InvisibleReCaptcha",p[p.ReCaptcha2]="ReCaptcha2";var a=function(){function t(t,e,n,r){this.renderer=t,this.zone=e,this.injector=n,this.globalConfig=r,this.setupAfterLoad=!1,this.windowOnLoadCallbackProperty="ngx_onload_callback_"+this.getPseudoUniqueNumber(),this.globalReCaptchaProperty="grecaptcha",this.captchaElemPrefix="ngx_captcha_id_",this.type="image",this.tabIndex=0,this.success=new o.EventEmitter,this.load=new o.EventEmitter,this.ready=new o.EventEmitter,this.resetCaptchaAfterSuccess=!1,this.isLoaded=!1}return t.prototype.ngAfterViewInit=function(){this.control=this.injector.get(e.NgControl).control},t.prototype.getGlobalSiteKey=function(){if(this.globalConfig){if(this.recaptchaType===p.InvisibleReCaptcha){if(!this.globalConfig.invisibleCaptchaSiteKey)throw Error("SiteKey for invisible reCaptcha is not set!");return this.globalConfig.invisibleCaptchaSiteKey instanceof Function?this.globalConfig.invisibleCaptchaSiteKey():this.globalConfig.invisibleCaptchaSiteKey}if(this.recaptchaType===p.ReCaptcha2){if(!this.globalConfig.reCaptcha2SiteKey)throw Error("SiteKey for reCaptcha2 is not set!");return this.globalConfig.reCaptcha2SiteKey instanceof Function?this.globalConfig.reCaptcha2SiteKey():this.globalConfig.reCaptcha2SiteKey}throw Error("Unsupported captcha type '"+this.recaptchaType+"'!")}},t.prototype.ngOnChanges=function(t){this.siteKey?this.siteKey instanceof Function?this._siteKey=this.siteKey():this._siteKey=this.siteKey:this._siteKey=this.getGlobalSiteKey(),this.setupComponent()},t.prototype.ngOnDestroy=function(){window[this.windowOnLoadCallbackProperty]={},window[this.globalReCaptchaProperty]={}},t.prototype.getResponse=function(){return this.reCaptchaApi.getResponse(this.captchaId)},t.prototype.getCaptchaId=function(){return this.captchaId},t.prototype.resetCaptcha=function(){var t=this;this.zone.run(function(){t.onChange(null),t.onTouched(null)}),this.reCaptchaApi.reset(this.captchaId)},t.prototype.getCurrentResponse=function(){return this.currentResponse},t.prototype.reloadCaptcha=function(){this.setupComponent()},t.prototype.ensureCaptchaElem=function(t){var e=document.getElementById(t);if(!e)throw Error("Captcha element with id '"+t+"' was not found");this.captchaElem=e},t.prototype.renderReCaptcha=function(){this.captchaId=this.reCaptchaApi.render(this.captchaElemId,this.getCaptchaProperties()),this.ready.next()},t.prototype.handleCallback=function(t){var e=this;this.currentResponse=t,this.success.next(t),this.zone.run(function(){e.onChange(t),e.onTouched(t)}),this.resetCaptchaAfterSuccess&&this.resetCaptcha()},t.prototype.ensureReCaptchaScript=function(){window[this.globalReCaptchaProperty]={},this.reCaptchaApi={},this.registerReCaptchaScript()},t.prototype.registerReCaptchaScript=function(){var t=document.createElement("script");t.innerHTML="",t.src="https://www.google.com/recaptcha/api.js?onload="+this.windowOnLoadCallbackProperty+"&render=explicit"+this.getLanguageParam(),t.async=!0,t.defer=!0,this.captchaScriptElem.nativeElement.appendChild(t)},t.prototype.getLanguageParam=function(){return this.hl?"&hl="+this.hl:""},t.prototype.getPseudoUniqueNumber=function(){return(new Date).getUTCMilliseconds()+Math.floor(9999*Math.random())},t.prototype.isReCaptchaApiDefined=function(){return!!window[this.globalReCaptchaProperty]},t.prototype.setupComponent=function(){var t=this;this.captchaSpecificSetup(),this.createAndSetCaptchaElem(),window[this.windowOnLoadCallbackProperty]=function(){return t.zone.run(t.onloadCallback.bind(t))},this.ensureReCaptchaScript()},t.prototype.onloadCallback=function(){if(this.reCaptchaApi=grecaptcha,!this.reCaptchaApi)throw Error("ReCaptcha Api was not initialized correctly");this.isLoaded=!0,this.load.next(),this.renderReCaptcha(),this.setupAfterLoad&&(this.setupAfterLoad=!1,this.setupComponent())},t.prototype.generateNewElemId=function(){return this.captchaElemPrefix+this.getPseudoUniqueNumber()},t.prototype.createAndSetCaptchaElem=function(){if(this.captchaElemId=this.generateNewElemId(),!this.captchaElemId)throw Error("Captcha elem Id is not set");this.captchaWrapperElem.nativeElement.innerHTML="";var t=this.renderer.createElement("div");t.id=this.captchaElemId,this.renderer.appendChild(this.captchaWrapperElem.nativeElement,t),this.ensureCaptchaElem(this.captchaElemId)},t.prototype.writeValue=function(t){},t.prototype.registerOnChange=function(t){this.onChange=t},t.prototype.registerOnTouched=function(t){this.onTouched=t},t.propDecorators={siteKey:[{type:o.Input}],type:[{type:o.Input}],hl:[{type:o.Input}],tabIndex:[{type:o.Input}],success:[{type:o.Output}],load:[{type:o.Output}],ready:[{type:o.Output}],captchaWrapperElem:[{type:o.ViewChild,args:["captchaWrapperElem"]}],captchaScriptElem:[{type:o.ViewChild,args:["captchaScriptElem"]}]},t}(),c=function(){},s=function(a){function t(t,e,n,r){var i=a.call(this,t,e,n,r)||this;return i.renderer=t,i.zone=e,i.injector=n,i.globalConfig=r,i.windowOnErrorCallbackProperty="ngx_captcha_error_callback",i.windowOnExpireCallbackProperty="ngx_captcha_expire_callback",i.theme="light",i.size="normal",i.expire=new o.EventEmitter,i.error=new o.EventEmitter,i.recaptchaType=p.ReCaptcha2,i}return i(t,a),t.prototype.ngOnChanges=function(t){a.prototype.ngOnChanges.call(this,t)},t.prototype.ngOnDestroy=function(){a.prototype.ngOnDestroy.call(this),window[this.windowOnErrorCallbackProperty]={},window[this.windowOnExpireCallbackProperty]={}},t.prototype.captchaSpecificSetup=function(){this.registerCallbacks()},t.prototype.getCaptchaProperties=function(){var e=this;return{sitekey:this._siteKey,callback:function(t){return e.zone.run(function(){return e.handleCallback(t)})},"expired-callback":function(){return e.zone.run(function(){return e.handleExpireCallback()})},"error-callback":function(){return e.zone.run(function(){return e.handleErrorCallback()})},theme:this.theme,type:this.type,size:this.size,tabindex:this.tabIndex}},t.prototype.registerCallbacks=function(){window[this.windowOnErrorCallbackProperty]=this.handleErrorCallback.bind(this),window[this.windowOnExpireCallbackProperty]=this.handleExpireCallback.bind(this)},t.prototype.handleErrorCallback=function(){var t=this;this.zone.run(function(){t.onChange(null),t.onTouched(null)}),this.error.next()},t.prototype.handleExpireCallback=function(){this.expire.next(),this.resetCaptcha()},t.decorators=[{type:o.Component,args:[{selector:"ngx-recaptcha2",template:"\n <div #captchaScriptElem></div>\n <div #captchaWrapperElem></div>",providers:[{provide:e.NG_VALUE_ACCESSOR,useExisting:o.forwardRef(function(){return t}),multi:!0}]}]}],t.ctorParameters=function(){return[{type:o.Renderer2},{type:o.NgZone},{type:o.Injector},{type:c,decorators:[{type:o.Optional}]}]},t.propDecorators={theme:[{type:o.Input}],size:[{type:o.Input}],hl:[{type:o.Input}],expire:[{type:o.Output}],error:[{type:o.Output}]},t}(a),h=function(a){function t(t,e,n,r){var i=a.call(this,t,e,n,r)||this;return i.renderer=t,i.zone=e,i.injector=n,i.globalConfig=r,i.size="invisible",i.badge="bottomright",i.recaptchaType=p.InvisibleReCaptcha,i}return i(t,a),t.prototype.ngOnChanges=function(t){a.prototype.ngOnChanges.call(this,t)},t.prototype.execute=function(){this.reCaptchaApi.execute(this.captchaId)},t.prototype.captchaSpecificSetup=function(){},t.prototype.getCaptchaProperties=function(){var e=this;return{sitekey:this._siteKey,callback:function(t){return e.zone.run(function(){return e.handleCallback(t)})},badge:this.badge,type:this.type,tabindex:this.tabIndex,size:this.size}},t.decorators=[{type:o.Component,args:[{selector:"ngx-invisible-recaptcha",template:"\n <div #captchaScriptElem></div>\n <div #captchaWrapperElem></div>",providers:[{provide:e.NG_VALUE_ACCESSOR,useExisting:o.forwardRef(function(){return t}),multi:!0}]}]}],t.ctorParameters=function(){return[{type:o.Renderer2},{type:o.NgZone},{type:o.Injector},{type:c,decorators:[{type:o.Optional}]}]},t.propDecorators={badge:[{type:o.Input}],hl:[{type:o.Input}]},t}(a),l=function(){function e(){}return e.forRoot=function(t){return{ngModule:e,providers:[{provide:c,useValue:t}]}},e.decorators=[{type:o.NgModule,args:[{imports:[n.CommonModule],declarations:[s,h],exports:[s,h]}]}],e}();t.ReCaptcha2Component=s,t.InvisibleReCaptchaComponent=h,t.NgxCaptchaConfig=c,t.NgxCaptchaModule=l,t.ɵa=a,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
//# sourceMappingURL=ngx-captcha.umd.min.js.map |
@@ -7,2 +7,3 @@ /** | ||
import { ReCaptchaType } from './recaptcha-type.enum'; | ||
import { NgControl } from '@angular/forms'; | ||
/** | ||
@@ -15,7 +16,9 @@ * @abstract | ||
* @param {?} zone | ||
* @param {?} injector | ||
* @param {?=} globalConfig | ||
*/ | ||
constructor(renderer, zone, globalConfig) { | ||
constructor(renderer, zone, injector, globalConfig) { | ||
this.renderer = renderer; | ||
this.zone = zone; | ||
this.injector = injector; | ||
this.globalConfig = globalConfig; | ||
@@ -69,2 +72,8 @@ this.setupAfterLoad = false; | ||
*/ | ||
ngAfterViewInit() { | ||
this.control = this.injector.get(NgControl).control; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
getGlobalSiteKey() { | ||
@@ -147,2 +156,6 @@ if (this.globalConfig) { | ||
resetCaptcha() { | ||
this.zone.run(() => { | ||
this.onChange(null); | ||
this.onTouched(null); | ||
}); | ||
this.reCaptchaApi.reset(this.captchaId); | ||
@@ -192,2 +205,6 @@ } | ||
this.success.next(callback); | ||
this.zone.run(() => { | ||
this.onChange(callback); | ||
this.onTouched(callback); | ||
}); | ||
if (this.resetCaptchaAfterSuccess) { | ||
@@ -276,3 +293,3 @@ this.resetCaptcha(); | ||
this.renderReCaptcha(); | ||
// setup component if it was flagges as such | ||
// setup component if it was flagged as such | ||
if (this.setupAfterLoad) { | ||
@@ -307,2 +324,25 @@ this.setupAfterLoad = false; | ||
} | ||
/** | ||
* To be aligned with the ControlValueAccessor interface we need to implement this method | ||
* However as we don't want to update the recaptcha, this doesn't need to be implemented | ||
* @param {?} obj | ||
* @return {?} | ||
*/ | ||
writeValue(obj) { } | ||
/** | ||
* This method helps us tie together recaptcha and our formControl values | ||
* @param {?} fn | ||
* @return {?} | ||
*/ | ||
registerOnChange(fn) { | ||
this.onChange = fn; | ||
} | ||
/** | ||
* At some point we might be interested whether the user has touched our component | ||
* @param {?} fn | ||
* @return {?} | ||
*/ | ||
registerOnTouched(fn) { | ||
this.onTouched = fn; | ||
} | ||
} | ||
@@ -321,2 +361,7 @@ BaseReCaptchaComponent.propDecorators = { | ||
function BaseReCaptchaComponent_tsickle_Closure_declarations() { | ||
/** | ||
* Form Control to be enable usage in reactive forms | ||
* @type {?} | ||
*/ | ||
BaseReCaptchaComponent.prototype.control; | ||
/** @type {?} */ | ||
@@ -426,3 +471,10 @@ BaseReCaptchaComponent.prototype.setupAfterLoad; | ||
BaseReCaptchaComponent.prototype.recaptchaType; | ||
/** | ||
* Required by ControlValueAccessor | ||
* @type {?} | ||
*/ | ||
BaseReCaptchaComponent.prototype.onChange; | ||
/** @type {?} */ | ||
BaseReCaptchaComponent.prototype.onTouched; | ||
/** @type {?} */ | ||
BaseReCaptchaComponent.prototype.renderer; | ||
@@ -432,2 +484,4 @@ /** @type {?} */ | ||
/** @type {?} */ | ||
BaseReCaptchaComponent.prototype.injector; | ||
/** @type {?} */ | ||
BaseReCaptchaComponent.prototype.globalConfig; | ||
@@ -448,2 +502,2 @@ /** | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-recaptcha.component.js","sourceRoot":"ng://ngx-captcha/","sources":["lib/base-recaptcha.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ElementRef,\r\n    EventEmitter,\r\n    Input,\r\n    NgZone,\r\n    OnChanges,\r\n    OnDestroy,\r\n    Output,\r\n    Renderer2,\r\n    SimpleChanges,\r\n    ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { ReCaptchaType } from './recaptcha-type.enum';\r\nimport { NgxCaptchaConfig } from './recaptcha.config';\r\n\r\ndeclare var grecaptcha: any;\r\n\r\nexport abstract class BaseReCaptchaComponent implements OnChanges, OnDestroy {\r\n\r\n    private setupAfterLoad = false;\r\n\r\n    /**\r\n    * Name of the global callback\r\n    */\r\n    protected readonly windowOnLoadCallbackProperty = 'ngx_onload_callback_' + this.getPseudoUniqueNumber();\r\n\r\n    /**\r\n     * Name of the global reCaptcha property\r\n     */\r\n    protected readonly globalReCaptchaProperty = 'grecaptcha';\r\n\r\n    /**\r\n     * Prefix of the captcha element\r\n     */\r\n    protected readonly captchaElemPrefix = 'ngx_captcha_id_';\r\n\r\n    /**\r\n      * Google's site key.\r\n      * You can find this under https://www.google.com/recaptcha\r\n      */\r\n    protected _siteKey?: string;\r\n\r\n    /**\r\n    * Config to use\r\n    */\r\n    @Input() siteKey: string | (() => string);\r\n\r\n    /**\r\n     * Type\r\n     */\r\n    @Input() type: 'audio' | 'image' = 'image';\r\n\r\n    /**\r\n     * Language code. Auto-detects the user's language if unspecified.\r\n     */\r\n    @Input() hl: string;\r\n\r\n    /**\r\n    * Tab index\r\n    */\r\n    @Input() tabIndex = 0;\r\n\r\n    /**\r\n     * Called when captcha receives successful response.\r\n     * Captcha response token is passed to event.\r\n     */\r\n    @Output() success = new EventEmitter<string>();\r\n\r\n    /**\r\n    * Called when captcha is loaded. Event receives id of the captcha\r\n    */\r\n    @Output() load = new EventEmitter<number>();\r\n\r\n    /**\r\n    * Called when captcha is loaded & ready. I.e. when you need to execute captcha on component load.\r\n    */\r\n    @Output() ready = new EventEmitter<void>();\r\n\r\n    @ViewChild('captchaWrapperElem') captchaWrapperElem: ElementRef;\r\n    @ViewChild('captchaScriptElem') captchaScriptElem: ElementRef;\r\n\r\n    /**\r\n     * Captcha element\r\n     */\r\n    protected captchaElem?: HTMLElement;\r\n\r\n    /**\r\n     * Id of the captcha elem\r\n     */\r\n    protected captchaId?: number;\r\n\r\n    /**\r\n     * Holds last response value\r\n     */\r\n    protected currentResponse?: string;\r\n\r\n    /**\r\n     * If enabled, captcha will reset after receiving success response. This is useful\r\n     * when invisible captcha need to be resolved multiple times on same page\r\n     */\r\n    protected resetCaptchaAfterSuccess = false;\r\n\r\n    /**\r\n     * Indicates if captcha is loaded\r\n     */\r\n    public isLoaded = false;\r\n\r\n    /**\r\n    * Reference to global reCaptcha API\r\n    */\r\n    public reCaptchaApi?: any;\r\n\r\n    /**\r\n     * Id of the DOM element wrapping captcha\r\n     */\r\n    public captchaElemId?: string;\r\n\r\n    /**\r\n     * Captcha type\r\n     */\r\n    protected abstract recaptchaType: ReCaptchaType;\r\n\r\n    constructor(\r\n        protected renderer: Renderer2,\r\n        protected zone: NgZone,\r\n        protected globalConfig?: NgxCaptchaConfig,\r\n    ) {\r\n    }\r\n\r\n    /**\r\n    * Gets reCaptcha properties\r\n    */\r\n    protected abstract getCaptchaProperties(): any;\r\n\r\n    /**\r\n     * Used for captcha specific setup\r\n    */\r\n    protected abstract captchaSpecificSetup(): void;\r\n\r\n    private getGlobalSiteKey(): string {\r\n        if (this.globalConfig) {\r\n            // Invisible captcha\r\n            if (this.recaptchaType === ReCaptchaType.InvisibleReCaptcha) {\r\n                if (!this.globalConfig.invisibleCaptchaSiteKey) {\r\n                    throw Error(`SiteKey for invisible reCaptcha is not set!`);\r\n                }\r\n\r\n                if (this.globalConfig.invisibleCaptchaSiteKey instanceof Function) {\r\n                    return this.globalConfig.invisibleCaptchaSiteKey();\r\n                } else {\r\n                    return this.globalConfig.invisibleCaptchaSiteKey;\r\n                }\r\n\r\n                // recaptcha 2\r\n            } else if (this.recaptchaType === ReCaptchaType.ReCaptcha2) {\r\n                if (!this.globalConfig.reCaptcha2SiteKey) {\r\n                    throw Error(`SiteKey for reCaptcha2 is not set!`);\r\n                }\r\n\r\n                if (this.globalConfig.reCaptcha2SiteKey instanceof Function) {\r\n                    return this.globalConfig.reCaptcha2SiteKey();\r\n                } else {\r\n                    return this.globalConfig.reCaptcha2SiteKey;\r\n                }\r\n\r\n            } else {\r\n                throw Error(`Unsupported captcha type '${this.recaptchaType}'!`);\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if (!this.siteKey) {\r\n            // use global site key if key is not available\r\n            this._siteKey = this.getGlobalSiteKey();\r\n        } else {\r\n            // use comnponent site key\r\n            if (this.siteKey instanceof Function) {\r\n                this._siteKey = this.siteKey();\r\n            } else {\r\n                this._siteKey = this.siteKey;\r\n            }\r\n        }\r\n        this.setupComponent();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        window[this.windowOnLoadCallbackProperty] = {};\r\n        window[this.globalReCaptchaProperty] = {};\r\n    }\r\n\r\n    /**\r\n     * Gets captcha response as per reCaptcha docs\r\n    */\r\n    getResponse(): string {\r\n        return this.reCaptchaApi.getResponse(this.captchaId);\r\n    }\r\n\r\n    /**\r\n     * Gets Id of captcha widget\r\n    */\r\n    getCaptchaId(): number {\r\n        return this.captchaId;\r\n    }\r\n\r\n    /**\r\n    * Resets captcha\r\n    */\r\n    resetCaptcha(): void {\r\n        this.reCaptchaApi.reset(this.captchaId);\r\n    }\r\n\r\n    /**\r\n     * Gets last submitted captcha response\r\n    */\r\n    getCurrentResponse(): string | undefined {\r\n        return this.currentResponse;\r\n    }\r\n\r\n    /**\r\n     * Reload captcha. Useful when properties (i.e. theme) changed and captcha need to reflect them\r\n    */\r\n    reloadCaptcha(): void {\r\n        this.setupComponent();\r\n    }\r\n\r\n    protected ensureCaptchaElem(captchaElemId: string): void {\r\n        const captchaElem = document.getElementById(captchaElemId);\r\n\r\n        if (!captchaElem) {\r\n            throw Error(`Captcha element with id '${captchaElemId}' was not found`);\r\n        }\r\n\r\n        // assign captcha alem\r\n        this.captchaElem = captchaElem;\r\n    }\r\n\r\n    /**\r\n     * Responsible for instantiating captcha element\r\n    */\r\n    protected renderReCaptcha(): void {\r\n        this.captchaId = this.reCaptchaApi.render(this.captchaElemId, this.getCaptchaProperties());\r\n        this.ready.next();\r\n    }\r\n\r\n    /**\r\n     * Called when captcha receives response\r\n     * @param callback Callback\r\n     */\r\n    protected handleCallback(callback: any): void {\r\n        this.currentResponse = callback;\r\n        this.success.next(callback);\r\n\r\n        if (this.resetCaptchaAfterSuccess) {\r\n            this.resetCaptcha();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Registers reCaptcha script if its not available\r\n    */\r\n    protected ensureReCaptchaScript(): void {\r\n        window[this.globalReCaptchaProperty] = {};\r\n        this.reCaptchaApi = {};\r\n\r\n        this.registerReCaptchaScript();\r\n    }\r\n\r\n    /**\r\n     * Add script to page with reference to captcha API. This has to be done manually\r\n     * as we want to avoid adding script to main index.html\r\n    */\r\n    protected registerReCaptchaScript(): void {\r\n        const script = document.createElement('script');\r\n        script.innerHTML = '';\r\n        script.src =\r\n            `https://www.google.com/recaptcha/api.js?onload=${this.windowOnLoadCallbackProperty}&render=explicit${this.getLanguageParam()}`;\r\n        script.async = true;\r\n        script.defer = true;\r\n\r\n        this.captchaScriptElem.nativeElement.appendChild(script);\r\n    }\r\n\r\n    protected getLanguageParam(): string {\r\n        if (!this.hl) {\r\n            return '';\r\n        }\r\n\r\n        return `&hl=${this.hl}`;\r\n    }\r\n\r\n    private getPseudoUniqueNumber(): number {\r\n        return new Date().getUTCMilliseconds() + Math.floor(Math.random() * 9999);\r\n    }\r\n\r\n    /**\r\n     * Checks if reCaptcha Api is defined. It may happen that when navigating from angular component to another\r\n     * via router, the Api was already loaded previously. In such cases, do not render script again.\r\n    */\r\n    private isReCaptchaApiDefined(): boolean {\r\n        if (!window[this.globalReCaptchaProperty]) {\r\n            return false;\r\n        }\r\n        return true;\r\n    }\r\n\r\n    private setupComponent(): void {\r\n        // captcha specific setup\r\n        this.captchaSpecificSetup();\r\n\r\n        // create captcha wrapper\r\n        this.createAndSetCaptchaElem();\r\n\r\n        // we need to patch the callback through global variable, otherwise callback is not accessible\r\n        // note: https://github.com/Enngage/ngx-captcha/issues/2\r\n        window[this.windowOnLoadCallbackProperty] = <any>(() => this.zone.run(\r\n            this.onloadCallback.bind(this)\r\n        ));\r\n\r\n        // create and put reCaptcha script to page\r\n        this.ensureReCaptchaScript();\r\n    }\r\n\r\n    /**\r\n    * Called when google's recaptcha script is ready\r\n    */\r\n    private onloadCallback(): void {\r\n        // assign reference to reCaptcha Api once its loaded\r\n        this.reCaptchaApi = grecaptcha;\r\n\r\n        if (!this.reCaptchaApi) {\r\n            throw Error(`ReCaptcha Api was not initialized correctly`);\r\n        }\r\n\r\n        // loaded flag\r\n        this.isLoaded = true;\r\n\r\n        // fire load event\r\n        this.load.next();\r\n\r\n        // render captcha\r\n        this.renderReCaptcha();\r\n\r\n        // setup component if it was flagges as such\r\n        if (this.setupAfterLoad) {\r\n            this.setupAfterLoad = false;\r\n            this.setupComponent();\r\n        }\r\n    }\r\n\r\n    private generateNewElemId(): string {\r\n        return this.captchaElemPrefix + this.getPseudoUniqueNumber();\r\n    }\r\n\r\n    private createAndSetCaptchaElem(): void {\r\n        // generate new captcha id\r\n        this.captchaElemId = this.generateNewElemId();\r\n\r\n        if (!this.captchaElemId) {\r\n            throw Error(`Captcha elem Id is not set`);\r\n        }\r\n\r\n        // remove old html\r\n        this.captchaWrapperElem.nativeElement.innerHTML = '';\r\n\r\n        // create new wrapper for captcha\r\n        const newElem = this.renderer.createElement('div');\r\n        newElem.id = this.captchaElemId;\r\n\r\n        this.renderer.appendChild(this.captchaWrapperElem.nativeElement, newElem);\r\n\r\n        // update captcha elem\r\n        this.ensureCaptchaElem(this.captchaElemId);\r\n    }\r\n\r\n}\r\n\r\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-recaptcha.component.js","sourceRoot":"ng://ngx-captcha/","sources":["lib/base-recaptcha.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ElementRef,\r\n  EventEmitter, Injector,\r\n  Input,\r\n  NgZone,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Output,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { ReCaptchaType } from './recaptcha-type.enum';\r\nimport { NgxCaptchaConfig } from './recaptcha.config';\r\nimport { ControlValueAccessor, FormControl, NgControl } from '@angular/forms';\r\n\r\ndeclare var grecaptcha: any;\r\n\r\nexport abstract class BaseReCaptchaComponent implements OnChanges, OnDestroy, ControlValueAccessor, AfterViewInit {\r\n    /**\r\n     * Form Control to be enable usage in reactive forms\r\n     */\r\n    private control: FormControl;\r\n\r\n    private setupAfterLoad = false;\r\n\r\n    /**\r\n    * Name of the global callback\r\n    */\r\n    protected readonly windowOnLoadCallbackProperty = 'ngx_onload_callback_' + this.getPseudoUniqueNumber();\r\n\r\n    /**\r\n     * Name of the global reCaptcha property\r\n     */\r\n    protected readonly globalReCaptchaProperty = 'grecaptcha';\r\n\r\n    /**\r\n     * Prefix of the captcha element\r\n     */\r\n    protected readonly captchaElemPrefix = 'ngx_captcha_id_';\r\n\r\n    /**\r\n      * Google's site key.\r\n      * You can find this under https://www.google.com/recaptcha\r\n      */\r\n    protected _siteKey?: string;\r\n\r\n    /**\r\n    * Config to use\r\n    */\r\n    @Input() siteKey: string | (() => string);\r\n\r\n    /**\r\n     * Type\r\n     */\r\n    @Input() type: 'audio' | 'image' = 'image';\r\n\r\n    /**\r\n     * Language code. Auto-detects the user's language if unspecified.\r\n     */\r\n    @Input() hl: string;\r\n\r\n    /**\r\n    * Tab index\r\n    */\r\n    @Input() tabIndex = 0;\r\n\r\n    /**\r\n     * Called when captcha receives successful response.\r\n     * Captcha response token is passed to event.\r\n     */\r\n    @Output() success = new EventEmitter<string>();\r\n\r\n    /**\r\n    * Called when captcha is loaded. Event receives id of the captcha\r\n    */\r\n    @Output() load = new EventEmitter<number>();\r\n\r\n    /**\r\n    * Called when captcha is loaded & ready. I.e. when you need to execute captcha on component load.\r\n    */\r\n    @Output() ready = new EventEmitter<void>();\r\n\r\n    @ViewChild('captchaWrapperElem') captchaWrapperElem: ElementRef;\r\n    @ViewChild('captchaScriptElem') captchaScriptElem: ElementRef;\r\n\r\n    /**\r\n     * Captcha element\r\n     */\r\n    protected captchaElem?: HTMLElement;\r\n\r\n    /**\r\n     * Id of the captcha elem\r\n     */\r\n    protected captchaId?: number;\r\n\r\n    /**\r\n     * Holds last response value\r\n     */\r\n    protected currentResponse?: string;\r\n\r\n    /**\r\n     * If enabled, captcha will reset after receiving success response. This is useful\r\n     * when invisible captcha need to be resolved multiple times on same page\r\n     */\r\n    protected resetCaptchaAfterSuccess = false;\r\n\r\n    /**\r\n     * Indicates if captcha is loaded\r\n     */\r\n    public isLoaded = false;\r\n\r\n    /**\r\n    * Reference to global reCaptcha API\r\n    */\r\n    public reCaptchaApi?: any;\r\n\r\n    /**\r\n     * Id of the DOM element wrapping captcha\r\n     */\r\n    public captchaElemId?: string;\r\n\r\n    /**\r\n     * Captcha type\r\n     */\r\n    protected abstract recaptchaType: ReCaptchaType;\r\n\r\n  /**\r\n   * Required by ControlValueAccessor\r\n   */\r\n    protected onChange: (value: string ) => void;\r\n    protected onTouched: (value: string ) => void;\r\n\r\n    protected constructor(\r\n        protected renderer: Renderer2,\r\n        protected zone: NgZone,\r\n        protected injector: Injector,\r\n        protected globalConfig?: NgxCaptchaConfig,\r\n    ) {}\r\n\r\n    ngAfterViewInit() {\r\n      this.control = this.injector.get(NgControl).control;\r\n    }\r\n\r\n    /**\r\n    * Gets reCaptcha properties\r\n    */\r\n    protected abstract getCaptchaProperties(): any;\r\n\r\n    /**\r\n     * Used for captcha specific setup\r\n    */\r\n    protected abstract captchaSpecificSetup(): void;\r\n\r\n    private getGlobalSiteKey(): string {\r\n        if (this.globalConfig) {\r\n            // Invisible captcha\r\n            if (this.recaptchaType === ReCaptchaType.InvisibleReCaptcha) {\r\n                if (!this.globalConfig.invisibleCaptchaSiteKey) {\r\n                    throw Error(`SiteKey for invisible reCaptcha is not set!`);\r\n                }\r\n\r\n                if (this.globalConfig.invisibleCaptchaSiteKey instanceof Function) {\r\n                    return this.globalConfig.invisibleCaptchaSiteKey();\r\n                } else {\r\n                    return this.globalConfig.invisibleCaptchaSiteKey;\r\n                }\r\n\r\n                // recaptcha 2\r\n            } else if (this.recaptchaType === ReCaptchaType.ReCaptcha2) {\r\n                if (!this.globalConfig.reCaptcha2SiteKey) {\r\n                    throw Error(`SiteKey for reCaptcha2 is not set!`);\r\n                }\r\n\r\n                if (this.globalConfig.reCaptcha2SiteKey instanceof Function) {\r\n                    return this.globalConfig.reCaptcha2SiteKey();\r\n                } else {\r\n                    return this.globalConfig.reCaptcha2SiteKey;\r\n                }\r\n\r\n            } else {\r\n                throw Error(`Unsupported captcha type '${this.recaptchaType}'!`);\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if (!this.siteKey) {\r\n            // use global site key if key is not available\r\n            this._siteKey = this.getGlobalSiteKey();\r\n        } else {\r\n            // use comnponent site key\r\n            if (this.siteKey instanceof Function) {\r\n                this._siteKey = this.siteKey();\r\n            } else {\r\n                this._siteKey = this.siteKey;\r\n            }\r\n        }\r\n        this.setupComponent();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        window[this.windowOnLoadCallbackProperty] = {};\r\n        window[this.globalReCaptchaProperty] = {};\r\n    }\r\n\r\n    /**\r\n     * Gets captcha response as per reCaptcha docs\r\n    */\r\n    getResponse(): string {\r\n        return this.reCaptchaApi.getResponse(this.captchaId);\r\n    }\r\n\r\n    /**\r\n     * Gets Id of captcha widget\r\n    */\r\n    getCaptchaId(): number {\r\n        return this.captchaId;\r\n    }\r\n\r\n    /**\r\n    * Resets captcha\r\n    */\r\n    resetCaptcha(): void {\r\n      this.zone.run(() => {\r\n        this.onChange(null);\r\n        this.onTouched(null);\r\n      });\r\n\r\n      this.reCaptchaApi.reset(this.captchaId);\r\n    }\r\n\r\n    /**\r\n     * Gets last submitted captcha response\r\n    */\r\n    getCurrentResponse(): string | undefined {\r\n        return this.currentResponse;\r\n    }\r\n\r\n    /**\r\n     * Reload captcha. Useful when properties (i.e. theme) changed and captcha need to reflect them\r\n    */\r\n    reloadCaptcha(): void {\r\n        this.setupComponent();\r\n    }\r\n\r\n    protected ensureCaptchaElem(captchaElemId: string): void {\r\n        const captchaElem = document.getElementById(captchaElemId);\r\n\r\n        if (!captchaElem) {\r\n            throw Error(`Captcha element with id '${captchaElemId}' was not found`);\r\n        }\r\n\r\n        // assign captcha alem\r\n        this.captchaElem = captchaElem;\r\n    }\r\n\r\n    /**\r\n     * Responsible for instantiating captcha element\r\n    */\r\n    protected renderReCaptcha(): void {\r\n        this.captchaId = this.reCaptchaApi.render(this.captchaElemId, this.getCaptchaProperties());\r\n        this.ready.next();\r\n    }\r\n\r\n    /**\r\n     * Called when captcha receives response\r\n     * @param callback Callback\r\n     */\r\n    protected handleCallback(callback: any): void {\r\n        this.currentResponse = callback;\r\n        this.success.next(callback);\r\n\r\n        this.zone.run(() => {\r\n          this.onChange(callback);\r\n          this.onTouched(callback);\r\n        });\r\n\r\n        if (this.resetCaptchaAfterSuccess) {\r\n            this.resetCaptcha();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Registers reCaptcha script if its not available\r\n    */\r\n    protected ensureReCaptchaScript(): void {\r\n        window[this.globalReCaptchaProperty] = {};\r\n        this.reCaptchaApi = {};\r\n\r\n        this.registerReCaptchaScript();\r\n    }\r\n\r\n    /**\r\n     * Add script to page with reference to captcha API. This has to be done manually\r\n     * as we want to avoid adding script to main index.html\r\n    */\r\n    protected registerReCaptchaScript(): void {\r\n        const script = document.createElement('script');\r\n        script.innerHTML = '';\r\n        script.src =\r\n            `https://www.google.com/recaptcha/api.js?onload=${this.windowOnLoadCallbackProperty}&render=explicit${this.getLanguageParam()}`;\r\n        script.async = true;\r\n        script.defer = true;\r\n\r\n        this.captchaScriptElem.nativeElement.appendChild(script);\r\n    }\r\n\r\n    protected getLanguageParam(): string {\r\n        if (!this.hl) {\r\n            return '';\r\n        }\r\n\r\n        return `&hl=${this.hl}`;\r\n    }\r\n\r\n    private getPseudoUniqueNumber(): number {\r\n        return new Date().getUTCMilliseconds() + Math.floor(Math.random() * 9999);\r\n    }\r\n\r\n    /**\r\n     * Checks if reCaptcha Api is defined. It may happen that when navigating from angular component to another\r\n     * via router, the Api was already loaded previously. In such cases, do not render script again.\r\n    */\r\n    private isReCaptchaApiDefined(): boolean {\r\n        if (!window[this.globalReCaptchaProperty]) {\r\n            return false;\r\n        }\r\n        return true;\r\n    }\r\n\r\n    private setupComponent(): void {\r\n        // captcha specific setup\r\n        this.captchaSpecificSetup();\r\n\r\n        // create captcha wrapper\r\n        this.createAndSetCaptchaElem();\r\n\r\n        // we need to patch the callback through global variable, otherwise callback is not accessible\r\n        // note: https://github.com/Enngage/ngx-captcha/issues/2\r\n        window[this.windowOnLoadCallbackProperty] = <any>(() => this.zone.run(\r\n            this.onloadCallback.bind(this)\r\n        ));\r\n\r\n        // create and put reCaptcha script to page\r\n        this.ensureReCaptchaScript();\r\n    }\r\n\r\n    /**\r\n    * Called when google's recaptcha script is ready\r\n    */\r\n    private onloadCallback(): void {\r\n        // assign reference to reCaptcha Api once its loaded\r\n        this.reCaptchaApi = grecaptcha;\r\n\r\n        if (!this.reCaptchaApi) {\r\n            throw Error(`ReCaptcha Api was not initialized correctly`);\r\n        }\r\n\r\n        // loaded flag\r\n        this.isLoaded = true;\r\n\r\n        // fire load event\r\n        this.load.next();\r\n\r\n        // render captcha\r\n        this.renderReCaptcha();\r\n\r\n        // setup component if it was flagged as such\r\n        if (this.setupAfterLoad) {\r\n            this.setupAfterLoad = false;\r\n            this.setupComponent();\r\n        }\r\n    }\r\n\r\n    private generateNewElemId(): string {\r\n        return this.captchaElemPrefix + this.getPseudoUniqueNumber();\r\n    }\r\n\r\n    private createAndSetCaptchaElem(): void {\r\n        // generate new captcha id\r\n        this.captchaElemId = this.generateNewElemId();\r\n\r\n        if (!this.captchaElemId) {\r\n            throw Error(`Captcha elem Id is not set`);\r\n        }\r\n\r\n        // remove old html\r\n        this.captchaWrapperElem.nativeElement.innerHTML = '';\r\n\r\n        // create new wrapper for captcha\r\n        const newElem = this.renderer.createElement('div');\r\n        newElem.id = this.captchaElemId;\r\n\r\n        this.renderer.appendChild(this.captchaWrapperElem.nativeElement, newElem);\r\n\r\n        // update captcha elem\r\n        this.ensureCaptchaElem(this.captchaElemId);\r\n    }\r\n\r\n    /**\r\n     * To be aligned with the ControlValueAccessor interface we need to implement this method\r\n     * However as we don't want to update the recaptcha, this doesn't need to be implemented\r\n     */\r\n    public writeValue(obj: any): void {}\r\n\r\n    /**\r\n     * This method helps us tie together recaptcha and our formControl values\r\n     */\r\n    public registerOnChange(fn: any): void {\r\n      this.onChange = fn;\r\n    }\r\n\r\n    /**\r\n    * At some point we might be interested whether the user has touched our component\r\n    */\r\n    public registerOnTouched(fn: any): void {\r\n      this.onTouched = fn;\r\n    }\r\n}\r\n\r\n"]} |
@@ -5,6 +5,7 @@ /** | ||
*/ | ||
import { Component, Input, Optional, Renderer2, NgZone } from '@angular/core'; | ||
import { Component, Input, Optional, Renderer2, NgZone, Injector, forwardRef } from '@angular/core'; | ||
import { BaseReCaptchaComponent } from './base-recaptcha.component'; | ||
import { ReCaptchaType } from './recaptcha-type.enum'; | ||
import { NgxCaptchaConfig } from './recaptcha.config'; | ||
import { NG_VALUE_ACCESSOR } from '@angular/forms'; | ||
export class InvisibleReCaptchaComponent extends BaseReCaptchaComponent { | ||
@@ -14,8 +15,10 @@ /** | ||
* @param {?} zone | ||
* @param {?} injector | ||
* @param {?} globalConfig | ||
*/ | ||
constructor(renderer, zone, globalConfig) { | ||
super(renderer, zone, globalConfig); | ||
constructor(renderer, zone, injector, globalConfig) { | ||
super(renderer, zone, injector, globalConfig); | ||
this.renderer = renderer; | ||
this.zone = zone; | ||
this.injector = injector; | ||
this.globalConfig = globalConfig; | ||
@@ -72,3 +75,10 @@ /** | ||
<div #captchaScriptElem></div> | ||
<div #captchaWrapperElem></div>` | ||
<div #captchaWrapperElem></div>`, | ||
providers: [ | ||
{ | ||
provide: NG_VALUE_ACCESSOR, | ||
useExisting: forwardRef(() => InvisibleReCaptchaComponent), | ||
multi: true, | ||
} | ||
] | ||
},] }, | ||
@@ -80,2 +90,3 @@ ]; | ||
{ type: NgZone }, | ||
{ type: Injector }, | ||
{ type: NgxCaptchaConfig, decorators: [{ type: Optional }] } | ||
@@ -110,5 +121,7 @@ ]; | ||
/** @type {?} */ | ||
InvisibleReCaptchaComponent.prototype.injector; | ||
/** @type {?} */ | ||
InvisibleReCaptchaComponent.prototype.globalConfig; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW52aXNpYmxlLXJlY2FwdGNoYS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtY2FwdGNoYS8iLCJzb3VyY2VzIjpbImxpYi9pbnZpc2libGUtcmVjYXB0Y2hhLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQWEsUUFBUSxFQUFFLFNBQVMsRUFBaUIsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXhHLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQVN0RCxNQUFNLGtDQUFtQyxTQUFRLHNCQUFzQjs7Ozs7O0lBbUJyRSxZQUNZLFFBQW1CLEVBQ25CLElBQVksRUFDQSxZQUE4QjtRQUVwRCxLQUFLLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxZQUFZLENBQUMsQ0FBQztRQUoxQixhQUFRLEdBQVIsUUFBUSxDQUFXO1FBQ25CLFNBQUksR0FBSixJQUFJLENBQVE7UUFDQSxpQkFBWSxHQUFaLFlBQVksQ0FBa0I7Ozs7b0JBakI1QixXQUFXOzs7O3FCQUtxQixhQUFhOzZCQU85QixhQUFhLENBQUMsa0JBQWtCO0tBUXhFOzs7OztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxLQUFLLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0tBQzVCOzs7OztJQUtELE9BQU87O1FBRUwsSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0tBQzNDOzs7O0lBRVMsb0JBQW9CO0tBQzdCOzs7OztJQUtTLG9CQUFvQjtRQUM1QixNQUFNLENBQUM7WUFDTCxTQUFTLEVBQUUsSUFBSSxDQUFDLFFBQVE7WUFDeEIsVUFBVSxFQUFFLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQzVFLE9BQU8sRUFBRSxJQUFJLENBQUMsS0FBSztZQUNuQixNQUFNLEVBQUUsSUFBSSxDQUFDLElBQUk7WUFDakIsVUFBVSxFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ3pCLE1BQU0sRUFBRSxJQUFJLENBQUMsSUFBSTtTQUNsQixDQUFDO0tBQ0g7OztZQTVERixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLHlCQUF5QjtnQkFDbkMsUUFBUSxFQUFFOztrQ0FFc0I7YUFDakM7Ozs7WUFaK0MsU0FBUztZQUFpQixNQUFNO1lBSXZFLGdCQUFnQix1QkErQnBCLFFBQVE7OztvQkFaVixLQUFLO2lCQUtMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkNoYW5nZXMsIE9wdGlvbmFsLCBSZW5kZXJlcjIsIFNpbXBsZUNoYW5nZXMsIE5nWm9uZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgQmFzZVJlQ2FwdGNoYUNvbXBvbmVudCB9IGZyb20gJy4vYmFzZS1yZWNhcHRjaGEuY29tcG9uZW50JztcclxuaW1wb3J0IHsgUmVDYXB0Y2hhVHlwZSB9IGZyb20gJy4vcmVjYXB0Y2hhLXR5cGUuZW51bSc7XHJcbmltcG9ydCB7IE5neENhcHRjaGFDb25maWcgfSBmcm9tICcuL3JlY2FwdGNoYS5jb25maWcnO1xyXG5cclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbmd4LWludmlzaWJsZS1yZWNhcHRjaGEnLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgPGRpdiAjY2FwdGNoYVNjcmlwdEVsZW0+PC9kaXY+XHJcbiAgPGRpdiAjY2FwdGNoYVdyYXBwZXJFbGVtPjwvZGl2PmBcclxufSlcclxuZXhwb3J0IGNsYXNzIEludmlzaWJsZVJlQ2FwdGNoYUNvbXBvbmVudCBleHRlbmRzIEJhc2VSZUNhcHRjaGFDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xyXG5cclxuICAvKipcclxuICAgKiBUaGlzIHNpemUgcmVwcmVzZW50aW5nIGludmlzaWJsZSBjYXB0Y2hhXHJcbiAgICovXHJcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IHNpemUgPSAnaW52aXNpYmxlJztcclxuXHJcbiAgLyoqXHJcbiAgICogQmFkZ2VcclxuICAgKi9cclxuICBASW5wdXQoKSBiYWRnZTogJ2JvdHRvbXJpZ2h0JyB8ICdib3R0b21sZWZ0JyB8ICdpbmxpbmUnID0gJ2JvdHRvbXJpZ2h0JztcclxuXHJcbiAgLyoqXHJcbiAgICogTGFuZ3VhZ2UgY29kZS4gQXV0by1kZXRlY3RzIHRoZSB1c2VyJ3MgbGFuZ3VhZ2UgaWYgdW5zcGVjaWZpZWQuXHJcbiAgICovXHJcbiAgQElucHV0KCkgaGw6IHN0cmluZztcclxuXHJcbiAgcHJvdGVjdGVkIHJlY2FwdGNoYVR5cGU6IFJlQ2FwdGNoYVR5cGUgPSBSZUNhcHRjaGFUeXBlLkludmlzaWJsZVJlQ2FwdGNoYTtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcm90ZWN0ZWQgcmVuZGVyZXI6IFJlbmRlcmVyMixcclxuICAgIHByb3RlY3RlZCB6b25lOiBOZ1pvbmUsXHJcbiAgICBAT3B0aW9uYWwoKSBwcm90ZWN0ZWQgZ2xvYmFsQ29uZmlnOiBOZ3hDYXB0Y2hhQ29uZmlnLFxyXG4gICkge1xyXG4gICAgc3VwZXIocmVuZGVyZXIsIHpvbmUsIGdsb2JhbENvbmZpZyk7XHJcbiAgfVxyXG5cclxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XHJcbiAgICBzdXBlci5uZ09uQ2hhbmdlcyhjaGFuZ2VzKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFByb2dyYW1hdGljYWxseSBpbnZva2UgdGhlIHJlQ0FQVENIQSBjaGVjay4gVXNlZCBpZiB0aGUgaW52aXNpYmxlIHJlQ0FQVENIQSBpcyBvbiBhIGRpdiBpbnN0ZWFkIG9mIGEgYnV0dG9uLlxyXG4gICAqL1xyXG4gIGV4ZWN1dGUoKTogdm9pZCB7XHJcbiAgICAvLyBleGVjdXRlIGNhcHRjaGFcclxuICAgIHRoaXMucmVDYXB0Y2hhQXBpLmV4ZWN1dGUodGhpcy5jYXB0Y2hhSWQpO1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIGNhcHRjaGFTcGVjaWZpY1NldHVwKCk6IHZvaWQge1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgKiBHZXRzIHJlQ2FwdGNoYSBwcm9wZXJ0aWVzXHJcbiAgKi9cclxuICBwcm90ZWN0ZWQgZ2V0Q2FwdGNoYVByb3BlcnRpZXMoKTogYW55IHtcclxuICAgIHJldHVybiB7XHJcbiAgICAgICdzaXRla2V5JzogdGhpcy5fc2l0ZUtleSxcclxuICAgICAgJ2NhbGxiYWNrJzogKHJlc3BvbnNlKSA9PiB0aGlzLnpvbmUucnVuKCgpID0+IHRoaXMuaGFuZGxlQ2FsbGJhY2socmVzcG9uc2UpKSxcclxuICAgICAgJ2JhZGdlJzogdGhpcy5iYWRnZSxcclxuICAgICAgJ3R5cGUnOiB0aGlzLnR5cGUsXHJcbiAgICAgICd0YWJpbmRleCc6IHRoaXMudGFiSW5kZXgsXHJcbiAgICAgICdzaXplJzogdGhpcy5zaXplXHJcbiAgICB9O1xyXG4gIH1cclxufVxyXG5cclxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW52aXNpYmxlLXJlY2FwdGNoYS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtY2FwdGNoYS8iLCJzb3VyY2VzIjpbImxpYi9pbnZpc2libGUtcmVjYXB0Y2hhLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQWEsUUFBUSxFQUFFLFNBQVMsRUFBaUIsTUFBTSxFQUFFLFFBQVEsRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFOUgsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDcEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBZ0JuRCxNQUFNLGtDQUFtQyxTQUFRLHNCQUFzQjs7Ozs7OztJQW1CckUsWUFDWSxRQUFtQixFQUNuQixJQUFZLEVBQ1osUUFBa0IsRUFDTixZQUE4QjtRQUVwRCxLQUFLLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsWUFBWSxDQUFDLENBQUM7UUFMcEMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQUNuQixTQUFJLEdBQUosSUFBSSxDQUFRO1FBQ1osYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUNOLGlCQUFZLEdBQVosWUFBWSxDQUFrQjs7OztvQkFsQjVCLFdBQVc7Ozs7cUJBS3FCLGFBQWE7NkJBTzlCLGFBQWEsQ0FBQyxrQkFBa0I7S0FTeEU7Ozs7O0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLEtBQUssQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7S0FDNUI7Ozs7O0lBS0QsT0FBTzs7UUFFTCxJQUFJLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7S0FDM0M7Ozs7SUFFUyxvQkFBb0I7S0FDN0I7Ozs7O0lBS1Msb0JBQW9CO1FBQzVCLE1BQU0sQ0FBQztZQUNMLFNBQVMsRUFBRSxJQUFJLENBQUMsUUFBUTtZQUN4QixVQUFVLEVBQUUsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDNUUsT0FBTyxFQUFFLElBQUksQ0FBQyxLQUFLO1lBQ25CLE1BQU0sRUFBRSxJQUFJLENBQUMsSUFBSTtZQUNqQixVQUFVLEVBQUUsSUFBSSxDQUFDLFFBQVE7WUFDekIsTUFBTSxFQUFFLElBQUksQ0FBQyxJQUFJO1NBQ2xCLENBQUM7S0FDSDs7O1lBcEVGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUseUJBQXlCO2dCQUNuQyxRQUFRLEVBQUU7O2tDQUVzQjtnQkFDaEMsU0FBUyxFQUFFO29CQUNUO3dCQUNFLE9BQU8sRUFBRSxpQkFBaUI7d0JBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsMkJBQTJCLENBQUM7d0JBQzFELEtBQUssRUFBRSxJQUFJO3FCQUNaO2lCQUNGO2FBQ0Y7Ozs7WUFwQitDLFNBQVM7WUFBaUIsTUFBTTtZQUFFLFFBQVE7WUFJakYsZ0JBQWdCLHVCQXdDcEIsUUFBUTs7O29CQWJWLEtBQUs7aUJBS0wsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uQ2hhbmdlcywgT3B0aW9uYWwsIFJlbmRlcmVyMiwgU2ltcGxlQ2hhbmdlcywgTmdab25lLCBJbmplY3RvciwgZm9yd2FyZFJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgQmFzZVJlQ2FwdGNoYUNvbXBvbmVudCB9IGZyb20gJy4vYmFzZS1yZWNhcHRjaGEuY29tcG9uZW50JztcclxuaW1wb3J0IHsgUmVDYXB0Y2hhVHlwZSB9IGZyb20gJy4vcmVjYXB0Y2hhLXR5cGUuZW51bSc7XHJcbmltcG9ydCB7IE5neENhcHRjaGFDb25maWcgfSBmcm9tICcuL3JlY2FwdGNoYS5jb25maWcnO1xyXG5pbXBvcnQgeyBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuXHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ25neC1pbnZpc2libGUtcmVjYXB0Y2hhJyxcclxuICB0ZW1wbGF0ZTogYFxyXG4gIDxkaXYgI2NhcHRjaGFTY3JpcHRFbGVtPjwvZGl2PlxyXG4gIDxkaXYgI2NhcHRjaGFXcmFwcGVyRWxlbT48L2Rpdj5gLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAge1xyXG4gICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcclxuICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gSW52aXNpYmxlUmVDYXB0Y2hhQ29tcG9uZW50KSxcclxuICAgICAgbXVsdGk6IHRydWUsXHJcbiAgICB9XHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgSW52aXNpYmxlUmVDYXB0Y2hhQ29tcG9uZW50IGV4dGVuZHMgQmFzZVJlQ2FwdGNoYUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XHJcblxyXG4gIC8qKlxyXG4gICAqIFRoaXMgc2l6ZSByZXByZXNlbnRpbmcgaW52aXNpYmxlIGNhcHRjaGFcclxuICAgKi9cclxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgc2l6ZSA9ICdpbnZpc2libGUnO1xyXG5cclxuICAvKipcclxuICAgKiBCYWRnZVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIGJhZGdlOiAnYm90dG9tcmlnaHQnIHwgJ2JvdHRvbWxlZnQnIHwgJ2lubGluZScgPSAnYm90dG9tcmlnaHQnO1xyXG5cclxuICAvKipcclxuICAgKiBMYW5ndWFnZSBjb2RlLiBBdXRvLWRldGVjdHMgdGhlIHVzZXIncyBsYW5ndWFnZSBpZiB1bnNwZWNpZmllZC5cclxuICAgKi9cclxuICBASW5wdXQoKSBobDogc3RyaW5nO1xyXG5cclxuICBwcm90ZWN0ZWQgcmVjYXB0Y2hhVHlwZTogUmVDYXB0Y2hhVHlwZSA9IFJlQ2FwdGNoYVR5cGUuSW52aXNpYmxlUmVDYXB0Y2hhO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByb3RlY3RlZCByZW5kZXJlcjogUmVuZGVyZXIyLFxyXG4gICAgcHJvdGVjdGVkIHpvbmU6IE5nWm9uZSxcclxuICAgIHByb3RlY3RlZCBpbmplY3RvcjogSW5qZWN0b3IsXHJcbiAgICBAT3B0aW9uYWwoKSBwcm90ZWN0ZWQgZ2xvYmFsQ29uZmlnOiBOZ3hDYXB0Y2hhQ29uZmlnLFxyXG4gICkge1xyXG4gICAgc3VwZXIocmVuZGVyZXIsIHpvbmUsIGluamVjdG9yLCBnbG9iYWxDb25maWcpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xyXG4gICAgc3VwZXIubmdPbkNoYW5nZXMoY2hhbmdlcyk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBQcm9ncmFtYXRpY2FsbHkgaW52b2tlIHRoZSByZUNBUFRDSEEgY2hlY2suIFVzZWQgaWYgdGhlIGludmlzaWJsZSByZUNBUFRDSEEgaXMgb24gYSBkaXYgaW5zdGVhZCBvZiBhIGJ1dHRvbi5cclxuICAgKi9cclxuICBleGVjdXRlKCk6IHZvaWQge1xyXG4gICAgLy8gZXhlY3V0ZSBjYXB0Y2hhXHJcbiAgICB0aGlzLnJlQ2FwdGNoYUFwaS5leGVjdXRlKHRoaXMuY2FwdGNoYUlkKTtcclxuICB9XHJcblxyXG4gIHByb3RlY3RlZCBjYXB0Y2hhU3BlY2lmaWNTZXR1cCgpOiB2b2lkIHtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICogR2V0cyByZUNhcHRjaGEgcHJvcGVydGllc1xyXG4gICovXHJcbiAgcHJvdGVjdGVkIGdldENhcHRjaGFQcm9wZXJ0aWVzKCk6IGFueSB7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICAnc2l0ZWtleSc6IHRoaXMuX3NpdGVLZXksXHJcbiAgICAgICdjYWxsYmFjayc6IChyZXNwb25zZSkgPT4gdGhpcy56b25lLnJ1bigoKSA9PiB0aGlzLmhhbmRsZUNhbGxiYWNrKHJlc3BvbnNlKSksXHJcbiAgICAgICdiYWRnZSc6IHRoaXMuYmFkZ2UsXHJcbiAgICAgICd0eXBlJzogdGhpcy50eXBlLFxyXG4gICAgICAndGFiaW5kZXgnOiB0aGlzLnRhYkluZGV4LFxyXG4gICAgICAnc2l6ZSc6IHRoaXMuc2l6ZVxyXG4gICAgfTtcclxuICB9XHJcbn1cclxuXHJcbiJdfQ== |
@@ -5,6 +5,7 @@ /** | ||
*/ | ||
import { Component, EventEmitter, Input, Optional, Output, Renderer2, NgZone, } from '@angular/core'; | ||
import { Component, EventEmitter, Input, Optional, Output, Renderer2, NgZone, Injector, forwardRef, } from '@angular/core'; | ||
import { BaseReCaptchaComponent } from './base-recaptcha.component'; | ||
import { ReCaptchaType } from './recaptcha-type.enum'; | ||
import { NgxCaptchaConfig } from './recaptcha.config'; | ||
import { NG_VALUE_ACCESSOR } from '@angular/forms'; | ||
export class ReCaptcha2Component extends BaseReCaptchaComponent { | ||
@@ -14,8 +15,10 @@ /** | ||
* @param {?} zone | ||
* @param {?} injector | ||
* @param {?} globalConfig | ||
*/ | ||
constructor(renderer, zone, globalConfig) { | ||
super(renderer, zone, globalConfig); | ||
constructor(renderer, zone, injector, globalConfig) { | ||
super(renderer, zone, injector, globalConfig); | ||
this.renderer = renderer; | ||
this.zone = zone; | ||
this.injector = injector; | ||
this.globalConfig = globalConfig; | ||
@@ -98,2 +101,6 @@ /** | ||
handleErrorCallback() { | ||
this.zone.run(() => { | ||
this.onChange(null); | ||
this.onTouched(null); | ||
}); | ||
this.error.next(); | ||
@@ -116,3 +123,10 @@ } | ||
<div #captchaScriptElem></div> | ||
<div #captchaWrapperElem></div>` | ||
<div #captchaWrapperElem></div>`, | ||
providers: [ | ||
{ | ||
provide: NG_VALUE_ACCESSOR, | ||
useExisting: forwardRef(() => ReCaptcha2Component), | ||
multi: true, | ||
} | ||
] | ||
},] }, | ||
@@ -124,2 +138,3 @@ ]; | ||
{ type: NgZone }, | ||
{ type: Injector }, | ||
{ type: NgxCaptchaConfig, decorators: [{ type: Optional }] } | ||
@@ -177,5 +192,7 @@ ]; | ||
/** @type {?} */ | ||
ReCaptcha2Component.prototype.injector; | ||
/** @type {?} */ | ||
ReCaptcha2Component.prototype.globalConfig; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjYXB0Y2hhLTIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWNhcHRjaGEvIiwic291cmNlcyI6WyJsaWIvcmVjYXB0Y2hhLTIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBR0wsUUFBUSxFQUNSLE1BQU0sRUFDTixTQUFTLEVBRVQsTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQVF0RCxNQUFNLDBCQUEyQixTQUFRLHNCQUFzQjs7Ozs7O0lBdUM3RCxZQUNZLFFBQW1CLEVBQ25CLElBQVksRUFDQSxZQUE4QjtRQUVwRCxLQUFLLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxZQUFZLENBQUMsQ0FBQztRQUoxQixhQUFRLEdBQVIsUUFBUSxDQUFXO1FBQ25CLFNBQUksR0FBSixJQUFJLENBQVE7UUFDQSxpQkFBWSxHQUFaLFlBQVksQ0FBa0I7Ozs7NkNBckNILDRCQUE0Qjs7Ozs4Q0FLM0IsNkJBQTZCOzs7O3FCQUs5QyxPQUFPOzs7O29CQUtKLFFBQVE7Ozs7c0JBVTNCLElBQUksWUFBWSxFQUFROzs7O3FCQUt6QixJQUFJLFlBQVksRUFBUTs2QkFFRCxhQUFhLENBQUMsVUFBVTtLQVFoRTs7Ozs7SUFFRCxXQUFXLENBQUMsT0FBc0I7UUFDaEMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztLQUM1Qjs7OztJQUVELFdBQVc7UUFDVCxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUM7UUFFcEIsTUFBTSxDQUFDLElBQUksQ0FBQyw2QkFBNkIsQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUNoRCxNQUFNLENBQUMsSUFBSSxDQUFDLDhCQUE4QixDQUFDLEdBQUcsRUFBRSxDQUFDO0tBQ2xEOzs7O0lBRVMsb0JBQW9CO1FBQzVCLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO0tBQzFCOzs7OztJQUtTLG9CQUFvQjtRQUM1QixNQUFNLENBQUM7WUFDTCxTQUFTLEVBQUUsSUFBSSxDQUFDLFFBQVE7WUFDeEIsVUFBVSxFQUFFLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQzVFLGtCQUFrQixFQUFFLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDO1lBQzFFLGdCQUFnQixFQUFFLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO1lBQ3ZFLE9BQU8sRUFBRSxJQUFJLENBQUMsS0FBSztZQUNuQixNQUFNLEVBQUUsSUFBSSxDQUFDLElBQUk7WUFDakIsTUFBTSxFQUFFLElBQUksQ0FBQyxJQUFJO1lBQ2pCLFVBQVUsRUFBRSxJQUFJLENBQUMsUUFBUTtTQUMxQixDQUFDO0tBQ0g7Ozs7O0lBS08saUJBQWlCO1FBQ3ZCLE1BQU0sQ0FBQyxJQUFJLENBQUMsNkJBQTZCLENBQUMsR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2pGLE1BQU0sQ0FBQyxJQUFJLENBQUMsOEJBQThCLENBQUMsR0FBRyxJQUFJLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDOzs7Ozs7SUFNN0UsbUJBQW1CO1FBQ3pCLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7Ozs7OztJQU1aLG9CQUFvQjtRQUMxQixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRSxDQUFDOztRQUduQixJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7Ozs7WUExR3ZCLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsZ0JBQWdCO2dCQUMxQixRQUFRLEVBQUU7O2tDQUVzQjthQUNqQzs7OztZQWRDLFNBQVM7WUFFVCxNQUFNO1lBS0MsZ0JBQWdCLHVCQWtEcEIsUUFBUTs7O29CQTNCVixLQUFLO21CQUtMLEtBQUs7aUJBS0wsS0FBSztxQkFLTCxNQUFNO29CQUtOLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENvbXBvbmVudCxcclxuICBFdmVudEVtaXR0ZXIsXHJcbiAgSW5wdXQsXHJcbiAgT25DaGFuZ2VzLFxyXG4gIE9uRGVzdHJveSxcclxuICBPcHRpb25hbCxcclxuICBPdXRwdXQsXHJcbiAgUmVuZGVyZXIyLFxyXG4gIFNpbXBsZUNoYW5nZXMsXHJcbiAgTmdab25lLFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgQmFzZVJlQ2FwdGNoYUNvbXBvbmVudCB9IGZyb20gJy4vYmFzZS1yZWNhcHRjaGEuY29tcG9uZW50JztcclxuaW1wb3J0IHsgUmVDYXB0Y2hhVHlwZSB9IGZyb20gJy4vcmVjYXB0Y2hhLXR5cGUuZW51bSc7XHJcbmltcG9ydCB7IE5neENhcHRjaGFDb25maWcgfSBmcm9tICcuL3JlY2FwdGNoYS5jb25maWcnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICduZ3gtcmVjYXB0Y2hhMicsXHJcbiAgdGVtcGxhdGU6IGBcclxuICA8ZGl2ICNjYXB0Y2hhU2NyaXB0RWxlbT48L2Rpdj5cclxuICA8ZGl2ICNjYXB0Y2hhV3JhcHBlckVsZW0+PC9kaXY+YFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUmVDYXB0Y2hhMkNvbXBvbmVudCBleHRlbmRzIEJhc2VSZUNhcHRjaGFDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMsIE9uRGVzdHJveSB7XHJcblxyXG4gIC8qKlxyXG4gICogTmFtZSBvZiB0aGUgZ2xvYmFsIGV4cGlyZSBjYWxsYmFja1xyXG4gICovXHJcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IHdpbmRvd09uRXJyb3JDYWxsYmFja1Byb3BlcnR5ID0gJ25neF9jYXB0Y2hhX2Vycm9yX2NhbGxiYWNrJztcclxuXHJcbiAgLyoqXHJcbiAgKiBOYW1lIG9mIHRoZSBnbG9iYWwgZXJyb3IgY2FsbGJhY2tcclxuICAqL1xyXG4gIHByb3RlY3RlZCByZWFkb25seSB3aW5kb3dPbkV4cGlyZUNhbGxiYWNrUHJvcGVydHkgPSAnbmd4X2NhcHRjaGFfZXhwaXJlX2NhbGxiYWNrJztcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlbWVcclxuICAgKi9cclxuICBASW5wdXQoKSB0aGVtZTogJ2RhcmsnIHwgJ2xpZ2h0JyA9ICdsaWdodCc7XHJcblxyXG4gIC8qKlxyXG4gICogU2l6ZVxyXG4gICovXHJcbiAgQElucHV0KCkgc2l6ZTogJ2NvbXBhY3QnIHwgJ25vcm1hbCcgPSAnbm9ybWFsJztcclxuXHJcbiAgLyoqXHJcbiAgICogTGFuZ3VhZ2UgY29kZS4gQXV0by1kZXRlY3RzIHRoZSB1c2VyJ3MgbGFuZ3VhZ2UgaWYgdW5zcGVjaWZpZWQuXHJcbiAgICovXHJcbiAgQElucHV0KCkgaGw6IHN0cmluZztcclxuXHJcbiAgLyoqXHJcbiAgKiBFeHBpcmVkIGNhbGxiYWNrXHJcbiAgKi9cclxuICBAT3V0cHV0KCkgZXhwaXJlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xyXG5cclxuICAvKipcclxuICAqIEVycm9yIGNhbGxiYWNrXHJcbiAgKi9cclxuICBAT3V0cHV0KCkgZXJyb3IgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XHJcblxyXG4gIHByb3RlY3RlZCByZWNhcHRjaGFUeXBlOiBSZUNhcHRjaGFUeXBlID0gUmVDYXB0Y2hhVHlwZS5SZUNhcHRjaGEyO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByb3RlY3RlZCByZW5kZXJlcjogUmVuZGVyZXIyLFxyXG4gICAgcHJvdGVjdGVkIHpvbmU6IE5nWm9uZSxcclxuICAgIEBPcHRpb25hbCgpIHByb3RlY3RlZCBnbG9iYWxDb25maWc6IE5neENhcHRjaGFDb25maWcsXHJcbiAgKSB7XHJcbiAgICBzdXBlcihyZW5kZXJlciwgem9uZSwgZ2xvYmFsQ29uZmlnKTtcclxuICB9XHJcblxyXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcclxuICAgIHN1cGVyLm5nT25DaGFuZ2VzKGNoYW5nZXMpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICBzdXBlci5uZ09uRGVzdHJveSgpO1xyXG5cclxuICAgIHdpbmRvd1t0aGlzLndpbmRvd09uRXJyb3JDYWxsYmFja1Byb3BlcnR5XSA9IHt9O1xyXG4gICAgd2luZG93W3RoaXMud2luZG93T25FeHBpcmVDYWxsYmFja1Byb3BlcnR5XSA9IHt9O1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIGNhcHRjaGFTcGVjaWZpY1NldHVwKCk6IHZvaWQge1xyXG4gICAgdGhpcy5yZWdpc3RlckNhbGxiYWNrcygpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogR2V0cyByZUNhcHRjaGEgcHJvcGVydGllc1xyXG4gICovXHJcbiAgcHJvdGVjdGVkIGdldENhcHRjaGFQcm9wZXJ0aWVzKCk6IGFueSB7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICAnc2l0ZWtleSc6IHRoaXMuX3NpdGVLZXksXHJcbiAgICAgICdjYWxsYmFjayc6IChyZXNwb25zZSkgPT4gdGhpcy56b25lLnJ1bigoKSA9PiB0aGlzLmhhbmRsZUNhbGxiYWNrKHJlc3BvbnNlKSksXHJcbiAgICAgICdleHBpcmVkLWNhbGxiYWNrJzogKCkgPT4gdGhpcy56b25lLnJ1bigoKSA9PiB0aGlzLmhhbmRsZUV4cGlyZUNhbGxiYWNrKCkpLFxyXG4gICAgICAnZXJyb3ItY2FsbGJhY2snOiAoKSA9PiB0aGlzLnpvbmUucnVuKCgpID0+IHRoaXMuaGFuZGxlRXJyb3JDYWxsYmFjaygpKSxcclxuICAgICAgJ3RoZW1lJzogdGhpcy50aGVtZSxcclxuICAgICAgJ3R5cGUnOiB0aGlzLnR5cGUsXHJcbiAgICAgICdzaXplJzogdGhpcy5zaXplLFxyXG4gICAgICAndGFiaW5kZXgnOiB0aGlzLnRhYkluZGV4XHJcbiAgICB9O1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogUmVnaXN0ZXJzIGdsb2JhbCBjYWxsYmFja3NcclxuICAqL1xyXG4gIHByaXZhdGUgcmVnaXN0ZXJDYWxsYmFja3MoKTogdm9pZCB7XHJcbiAgICB3aW5kb3dbdGhpcy53aW5kb3dPbkVycm9yQ2FsbGJhY2tQcm9wZXJ0eV0gPSB0aGlzLmhhbmRsZUVycm9yQ2FsbGJhY2suYmluZCh0aGlzKTtcclxuICAgIHdpbmRvd1t0aGlzLndpbmRvd09uRXhwaXJlQ2FsbGJhY2tQcm9wZXJ0eV0gPSB0aGlzLmhhbmRsZUV4cGlyZUNhbGxiYWNrLmJpbmQodGhpcyk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBIYW5kbGVzIGVycm9yIGNhbGxiYWNrXHJcbiAgKi9cclxuICBwcml2YXRlIGhhbmRsZUVycm9yQ2FsbGJhY2soKTogdm9pZCB7XHJcbiAgICB0aGlzLmVycm9yLm5leHQoKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEhhbmRsZXMgZXhwaXJlZCBjYWxsYmFja1xyXG4gICAqL1xyXG4gIHByaXZhdGUgaGFuZGxlRXhwaXJlQ2FsbGJhY2soKTogdm9pZCB7XHJcbiAgICB0aGlzLmV4cGlyZS5uZXh0KCk7XHJcblxyXG4gICAgLy8gcmVzZXQgY2FwdGNoYSBvbiBleHBpcmUgY2FsbGJhY2tcclxuICAgIHRoaXMucmVzZXRDYXB0Y2hhKCk7XHJcbiAgfVxyXG59XHJcblxyXG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recaptcha-2.component.js","sourceRoot":"ng://ngx-captcha/","sources":["lib/recaptcha-2.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Optional,\r\n  Output,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  NgZone, Injector, forwardRef,\r\n} from '@angular/core';\r\n\r\nimport { BaseReCaptchaComponent } from './base-recaptcha.component';\r\nimport { ReCaptchaType } from './recaptcha-type.enum';\r\nimport { NgxCaptchaConfig } from './recaptcha.config';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'ngx-recaptcha2',\r\n  template: `\r\n  <div #captchaScriptElem></div>\r\n  <div #captchaWrapperElem></div>`,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ReCaptcha2Component),\r\n      multi: true,\r\n    }\r\n  ]\r\n})\r\nexport class ReCaptcha2Component extends BaseReCaptchaComponent implements OnChanges, OnDestroy {\r\n\r\n  /**\r\n  * Name of the global expire callback\r\n  */\r\n  protected readonly windowOnErrorCallbackProperty = 'ngx_captcha_error_callback';\r\n\r\n  /**\r\n  * Name of the global error callback\r\n  */\r\n  protected readonly windowOnExpireCallbackProperty = 'ngx_captcha_expire_callback';\r\n\r\n  /**\r\n   * Theme\r\n   */\r\n  @Input() theme: 'dark' | 'light' = 'light';\r\n\r\n  /**\r\n  * Size\r\n  */\r\n  @Input() size: 'compact' | 'normal' = 'normal';\r\n\r\n  /**\r\n   * Language code. Auto-detects the user's language if unspecified.\r\n   */\r\n  @Input() hl: string;\r\n\r\n  /**\r\n  * Expired callback\r\n  */\r\n  @Output() expire = new EventEmitter<void>();\r\n\r\n  /**\r\n  * Error callback\r\n  */\r\n  @Output() error = new EventEmitter<void>();\r\n\r\n  protected recaptchaType: ReCaptchaType = ReCaptchaType.ReCaptcha2;\r\n\r\n  constructor(\r\n    protected renderer: Renderer2,\r\n    protected zone: NgZone,\r\n    protected injector: Injector,\r\n    @Optional() protected globalConfig: NgxCaptchaConfig,\r\n  ) {\r\n    super(renderer, zone, injector, globalConfig);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    super.ngOnChanges(changes);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    super.ngOnDestroy();\r\n\r\n    window[this.windowOnErrorCallbackProperty] = {};\r\n    window[this.windowOnExpireCallbackProperty] = {};\r\n  }\r\n\r\n  protected captchaSpecificSetup(): void {\r\n    this.registerCallbacks();\r\n  }\r\n\r\n  /**\r\n   * Gets reCaptcha properties\r\n  */\r\n  protected getCaptchaProperties(): any {\r\n    return {\r\n      'sitekey': this._siteKey,\r\n      'callback': (response) => this.zone.run(() => this.handleCallback(response)),\r\n      'expired-callback': () => this.zone.run(() => this.handleExpireCallback()),\r\n      'error-callback': () => this.zone.run(() => this.handleErrorCallback()),\r\n      'theme': this.theme,\r\n      'type': this.type,\r\n      'size': this.size,\r\n      'tabindex': this.tabIndex\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Registers global callbacks\r\n  */\r\n  private registerCallbacks(): void {\r\n    window[this.windowOnErrorCallbackProperty] = this.handleErrorCallback.bind(this);\r\n    window[this.windowOnExpireCallbackProperty] = this.handleExpireCallback.bind(this);\r\n  }\r\n\r\n  /**\r\n   * Handles error callback\r\n  */\r\n  private handleErrorCallback(): void {\r\n    this.zone.run(() => {\r\n      this.onChange(null);\r\n      this.onTouched(null);\r\n    });\r\n\r\n    this.error.next();\r\n  }\r\n\r\n  /**\r\n   * Handles expired callback\r\n   */\r\n  private handleExpireCallback(): void {\r\n    this.expire.next();\r\n\r\n    // reset captcha on expire callback\r\n    this.resetCaptcha();\r\n  }\r\n}\r\n\r\n"]} |
@@ -7,2 +7,3 @@ /** | ||
import { ReCaptchaType } from './recaptcha-type.enum'; | ||
import { NgControl } from '@angular/forms'; | ||
/** | ||
@@ -12,5 +13,6 @@ * @abstract | ||
var BaseReCaptchaComponent = /** @class */ (function () { | ||
function BaseReCaptchaComponent(renderer, zone, globalConfig) { | ||
function BaseReCaptchaComponent(renderer, zone, injector, globalConfig) { | ||
this.renderer = renderer; | ||
this.zone = zone; | ||
this.injector = injector; | ||
this.globalConfig = globalConfig; | ||
@@ -64,2 +66,11 @@ this.setupAfterLoad = false; | ||
*/ | ||
BaseReCaptchaComponent.prototype.ngAfterViewInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
this.control = this.injector.get(NgControl).control; | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
BaseReCaptchaComponent.prototype.getGlobalSiteKey = /** | ||
@@ -173,2 +184,7 @@ * @return {?} | ||
function () { | ||
var _this = this; | ||
this.zone.run(function () { | ||
_this.onChange(null); | ||
_this.onTouched(null); | ||
}); | ||
this.reCaptchaApi.reset(this.captchaId); | ||
@@ -250,4 +266,9 @@ }; | ||
function (callback) { | ||
var _this = this; | ||
this.currentResponse = callback; | ||
this.success.next(callback); | ||
this.zone.run(function () { | ||
_this.onChange(callback); | ||
_this.onTouched(callback); | ||
}); | ||
if (this.resetCaptchaAfterSuccess) { | ||
@@ -371,3 +392,3 @@ this.resetCaptcha(); | ||
this.renderReCaptcha(); | ||
// setup component if it was flagges as such | ||
// setup component if it was flagged as such | ||
if (this.setupAfterLoad) { | ||
@@ -408,2 +429,41 @@ this.setupAfterLoad = false; | ||
}; | ||
/** | ||
* To be aligned with the ControlValueAccessor interface we need to implement this method | ||
* However as we don't want to update the recaptcha, this doesn't need to be implemented | ||
* @param {?} obj | ||
* @return {?} | ||
*/ | ||
BaseReCaptchaComponent.prototype.writeValue = /** | ||
* To be aligned with the ControlValueAccessor interface we need to implement this method | ||
* However as we don't want to update the recaptcha, this doesn't need to be implemented | ||
* @param {?} obj | ||
* @return {?} | ||
*/ | ||
function (obj) { }; | ||
/** | ||
* This method helps us tie together recaptcha and our formControl values | ||
* @param {?} fn | ||
* @return {?} | ||
*/ | ||
BaseReCaptchaComponent.prototype.registerOnChange = /** | ||
* This method helps us tie together recaptcha and our formControl values | ||
* @param {?} fn | ||
* @return {?} | ||
*/ | ||
function (fn) { | ||
this.onChange = fn; | ||
}; | ||
/** | ||
* At some point we might be interested whether the user has touched our component | ||
* @param {?} fn | ||
* @return {?} | ||
*/ | ||
BaseReCaptchaComponent.prototype.registerOnTouched = /** | ||
* At some point we might be interested whether the user has touched our component | ||
* @param {?} fn | ||
* @return {?} | ||
*/ | ||
function (fn) { | ||
this.onTouched = fn; | ||
}; | ||
BaseReCaptchaComponent.propDecorators = { | ||
@@ -424,2 +484,7 @@ siteKey: [{ type: Input }], | ||
function BaseReCaptchaComponent_tsickle_Closure_declarations() { | ||
/** | ||
* Form Control to be enable usage in reactive forms | ||
* @type {?} | ||
*/ | ||
BaseReCaptchaComponent.prototype.control; | ||
/** @type {?} */ | ||
@@ -529,3 +594,10 @@ BaseReCaptchaComponent.prototype.setupAfterLoad; | ||
BaseReCaptchaComponent.prototype.recaptchaType; | ||
/** | ||
* Required by ControlValueAccessor | ||
* @type {?} | ||
*/ | ||
BaseReCaptchaComponent.prototype.onChange; | ||
/** @type {?} */ | ||
BaseReCaptchaComponent.prototype.onTouched; | ||
/** @type {?} */ | ||
BaseReCaptchaComponent.prototype.renderer; | ||
@@ -535,2 +607,4 @@ /** @type {?} */ | ||
/** @type {?} */ | ||
BaseReCaptchaComponent.prototype.injector; | ||
/** @type {?} */ | ||
BaseReCaptchaComponent.prototype.globalConfig; | ||
@@ -551,2 +625,2 @@ /** | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-recaptcha.component.js","sourceRoot":"ng://ngx-captcha/","sources":["lib/base-recaptcha.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ElementRef,\r\n    EventEmitter,\r\n    Input,\r\n    NgZone,\r\n    OnChanges,\r\n    OnDestroy,\r\n    Output,\r\n    Renderer2,\r\n    SimpleChanges,\r\n    ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { ReCaptchaType } from './recaptcha-type.enum';\r\nimport { NgxCaptchaConfig } from './recaptcha.config';\r\n\r\ndeclare var grecaptcha: any;\r\n\r\nexport abstract class BaseReCaptchaComponent implements OnChanges, OnDestroy {\r\n\r\n    private setupAfterLoad = false;\r\n\r\n    /**\r\n    * Name of the global callback\r\n    */\r\n    protected readonly windowOnLoadCallbackProperty = 'ngx_onload_callback_' + this.getPseudoUniqueNumber();\r\n\r\n    /**\r\n     * Name of the global reCaptcha property\r\n     */\r\n    protected readonly globalReCaptchaProperty = 'grecaptcha';\r\n\r\n    /**\r\n     * Prefix of the captcha element\r\n     */\r\n    protected readonly captchaElemPrefix = 'ngx_captcha_id_';\r\n\r\n    /**\r\n      * Google's site key.\r\n      * You can find this under https://www.google.com/recaptcha\r\n      */\r\n    protected _siteKey?: string;\r\n\r\n    /**\r\n    * Config to use\r\n    */\r\n    @Input() siteKey: string | (() => string);\r\n\r\n    /**\r\n     * Type\r\n     */\r\n    @Input() type: 'audio' | 'image' = 'image';\r\n\r\n    /**\r\n     * Language code. Auto-detects the user's language if unspecified.\r\n     */\r\n    @Input() hl: string;\r\n\r\n    /**\r\n    * Tab index\r\n    */\r\n    @Input() tabIndex = 0;\r\n\r\n    /**\r\n     * Called when captcha receives successful response.\r\n     * Captcha response token is passed to event.\r\n     */\r\n    @Output() success = new EventEmitter<string>();\r\n\r\n    /**\r\n    * Called when captcha is loaded. Event receives id of the captcha\r\n    */\r\n    @Output() load = new EventEmitter<number>();\r\n\r\n    /**\r\n    * Called when captcha is loaded & ready. I.e. when you need to execute captcha on component load.\r\n    */\r\n    @Output() ready = new EventEmitter<void>();\r\n\r\n    @ViewChild('captchaWrapperElem') captchaWrapperElem: ElementRef;\r\n    @ViewChild('captchaScriptElem') captchaScriptElem: ElementRef;\r\n\r\n    /**\r\n     * Captcha element\r\n     */\r\n    protected captchaElem?: HTMLElement;\r\n\r\n    /**\r\n     * Id of the captcha elem\r\n     */\r\n    protected captchaId?: number;\r\n\r\n    /**\r\n     * Holds last response value\r\n     */\r\n    protected currentResponse?: string;\r\n\r\n    /**\r\n     * If enabled, captcha will reset after receiving success response. This is useful\r\n     * when invisible captcha need to be resolved multiple times on same page\r\n     */\r\n    protected resetCaptchaAfterSuccess = false;\r\n\r\n    /**\r\n     * Indicates if captcha is loaded\r\n     */\r\n    public isLoaded = false;\r\n\r\n    /**\r\n    * Reference to global reCaptcha API\r\n    */\r\n    public reCaptchaApi?: any;\r\n\r\n    /**\r\n     * Id of the DOM element wrapping captcha\r\n     */\r\n    public captchaElemId?: string;\r\n\r\n    /**\r\n     * Captcha type\r\n     */\r\n    protected abstract recaptchaType: ReCaptchaType;\r\n\r\n    constructor(\r\n        protected renderer: Renderer2,\r\n        protected zone: NgZone,\r\n        protected globalConfig?: NgxCaptchaConfig,\r\n    ) {\r\n    }\r\n\r\n    /**\r\n    * Gets reCaptcha properties\r\n    */\r\n    protected abstract getCaptchaProperties(): any;\r\n\r\n    /**\r\n     * Used for captcha specific setup\r\n    */\r\n    protected abstract captchaSpecificSetup(): void;\r\n\r\n    private getGlobalSiteKey(): string {\r\n        if (this.globalConfig) {\r\n            // Invisible captcha\r\n            if (this.recaptchaType === ReCaptchaType.InvisibleReCaptcha) {\r\n                if (!this.globalConfig.invisibleCaptchaSiteKey) {\r\n                    throw Error(`SiteKey for invisible reCaptcha is not set!`);\r\n                }\r\n\r\n                if (this.globalConfig.invisibleCaptchaSiteKey instanceof Function) {\r\n                    return this.globalConfig.invisibleCaptchaSiteKey();\r\n                } else {\r\n                    return this.globalConfig.invisibleCaptchaSiteKey;\r\n                }\r\n\r\n                // recaptcha 2\r\n            } else if (this.recaptchaType === ReCaptchaType.ReCaptcha2) {\r\n                if (!this.globalConfig.reCaptcha2SiteKey) {\r\n                    throw Error(`SiteKey for reCaptcha2 is not set!`);\r\n                }\r\n\r\n                if (this.globalConfig.reCaptcha2SiteKey instanceof Function) {\r\n                    return this.globalConfig.reCaptcha2SiteKey();\r\n                } else {\r\n                    return this.globalConfig.reCaptcha2SiteKey;\r\n                }\r\n\r\n            } else {\r\n                throw Error(`Unsupported captcha type '${this.recaptchaType}'!`);\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if (!this.siteKey) {\r\n            // use global site key if key is not available\r\n            this._siteKey = this.getGlobalSiteKey();\r\n        } else {\r\n            // use comnponent site key\r\n            if (this.siteKey instanceof Function) {\r\n                this._siteKey = this.siteKey();\r\n            } else {\r\n                this._siteKey = this.siteKey;\r\n            }\r\n        }\r\n        this.setupComponent();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        window[this.windowOnLoadCallbackProperty] = {};\r\n        window[this.globalReCaptchaProperty] = {};\r\n    }\r\n\r\n    /**\r\n     * Gets captcha response as per reCaptcha docs\r\n    */\r\n    getResponse(): string {\r\n        return this.reCaptchaApi.getResponse(this.captchaId);\r\n    }\r\n\r\n    /**\r\n     * Gets Id of captcha widget\r\n    */\r\n    getCaptchaId(): number {\r\n        return this.captchaId;\r\n    }\r\n\r\n    /**\r\n    * Resets captcha\r\n    */\r\n    resetCaptcha(): void {\r\n        this.reCaptchaApi.reset(this.captchaId);\r\n    }\r\n\r\n    /**\r\n     * Gets last submitted captcha response\r\n    */\r\n    getCurrentResponse(): string | undefined {\r\n        return this.currentResponse;\r\n    }\r\n\r\n    /**\r\n     * Reload captcha. Useful when properties (i.e. theme) changed and captcha need to reflect them\r\n    */\r\n    reloadCaptcha(): void {\r\n        this.setupComponent();\r\n    }\r\n\r\n    protected ensureCaptchaElem(captchaElemId: string): void {\r\n        const captchaElem = document.getElementById(captchaElemId);\r\n\r\n        if (!captchaElem) {\r\n            throw Error(`Captcha element with id '${captchaElemId}' was not found`);\r\n        }\r\n\r\n        // assign captcha alem\r\n        this.captchaElem = captchaElem;\r\n    }\r\n\r\n    /**\r\n     * Responsible for instantiating captcha element\r\n    */\r\n    protected renderReCaptcha(): void {\r\n        this.captchaId = this.reCaptchaApi.render(this.captchaElemId, this.getCaptchaProperties());\r\n        this.ready.next();\r\n    }\r\n\r\n    /**\r\n     * Called when captcha receives response\r\n     * @param callback Callback\r\n     */\r\n    protected handleCallback(callback: any): void {\r\n        this.currentResponse = callback;\r\n        this.success.next(callback);\r\n\r\n        if (this.resetCaptchaAfterSuccess) {\r\n            this.resetCaptcha();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Registers reCaptcha script if its not available\r\n    */\r\n    protected ensureReCaptchaScript(): void {\r\n        window[this.globalReCaptchaProperty] = {};\r\n        this.reCaptchaApi = {};\r\n\r\n        this.registerReCaptchaScript();\r\n    }\r\n\r\n    /**\r\n     * Add script to page with reference to captcha API. This has to be done manually\r\n     * as we want to avoid adding script to main index.html\r\n    */\r\n    protected registerReCaptchaScript(): void {\r\n        const script = document.createElement('script');\r\n        script.innerHTML = '';\r\n        script.src =\r\n            `https://www.google.com/recaptcha/api.js?onload=${this.windowOnLoadCallbackProperty}&render=explicit${this.getLanguageParam()}`;\r\n        script.async = true;\r\n        script.defer = true;\r\n\r\n        this.captchaScriptElem.nativeElement.appendChild(script);\r\n    }\r\n\r\n    protected getLanguageParam(): string {\r\n        if (!this.hl) {\r\n            return '';\r\n        }\r\n\r\n        return `&hl=${this.hl}`;\r\n    }\r\n\r\n    private getPseudoUniqueNumber(): number {\r\n        return new Date().getUTCMilliseconds() + Math.floor(Math.random() * 9999);\r\n    }\r\n\r\n    /**\r\n     * Checks if reCaptcha Api is defined. It may happen that when navigating from angular component to another\r\n     * via router, the Api was already loaded previously. In such cases, do not render script again.\r\n    */\r\n    private isReCaptchaApiDefined(): boolean {\r\n        if (!window[this.globalReCaptchaProperty]) {\r\n            return false;\r\n        }\r\n        return true;\r\n    }\r\n\r\n    private setupComponent(): void {\r\n        // captcha specific setup\r\n        this.captchaSpecificSetup();\r\n\r\n        // create captcha wrapper\r\n        this.createAndSetCaptchaElem();\r\n\r\n        // we need to patch the callback through global variable, otherwise callback is not accessible\r\n        // note: https://github.com/Enngage/ngx-captcha/issues/2\r\n        window[this.windowOnLoadCallbackProperty] = <any>(() => this.zone.run(\r\n            this.onloadCallback.bind(this)\r\n        ));\r\n\r\n        // create and put reCaptcha script to page\r\n        this.ensureReCaptchaScript();\r\n    }\r\n\r\n    /**\r\n    * Called when google's recaptcha script is ready\r\n    */\r\n    private onloadCallback(): void {\r\n        // assign reference to reCaptcha Api once its loaded\r\n        this.reCaptchaApi = grecaptcha;\r\n\r\n        if (!this.reCaptchaApi) {\r\n            throw Error(`ReCaptcha Api was not initialized correctly`);\r\n        }\r\n\r\n        // loaded flag\r\n        this.isLoaded = true;\r\n\r\n        // fire load event\r\n        this.load.next();\r\n\r\n        // render captcha\r\n        this.renderReCaptcha();\r\n\r\n        // setup component if it was flagges as such\r\n        if (this.setupAfterLoad) {\r\n            this.setupAfterLoad = false;\r\n            this.setupComponent();\r\n        }\r\n    }\r\n\r\n    private generateNewElemId(): string {\r\n        return this.captchaElemPrefix + this.getPseudoUniqueNumber();\r\n    }\r\n\r\n    private createAndSetCaptchaElem(): void {\r\n        // generate new captcha id\r\n        this.captchaElemId = this.generateNewElemId();\r\n\r\n        if (!this.captchaElemId) {\r\n            throw Error(`Captcha elem Id is not set`);\r\n        }\r\n\r\n        // remove old html\r\n        this.captchaWrapperElem.nativeElement.innerHTML = '';\r\n\r\n        // create new wrapper for captcha\r\n        const newElem = this.renderer.createElement('div');\r\n        newElem.id = this.captchaElemId;\r\n\r\n        this.renderer.appendChild(this.captchaWrapperElem.nativeElement, newElem);\r\n\r\n        // update captcha elem\r\n        this.ensureCaptchaElem(this.captchaElemId);\r\n    }\r\n\r\n}\r\n\r\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-recaptcha.component.js","sourceRoot":"ng://ngx-captcha/","sources":["lib/base-recaptcha.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ElementRef,\r\n  EventEmitter, Injector,\r\n  Input,\r\n  NgZone,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Output,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { ReCaptchaType } from './recaptcha-type.enum';\r\nimport { NgxCaptchaConfig } from './recaptcha.config';\r\nimport { ControlValueAccessor, FormControl, NgControl } from '@angular/forms';\r\n\r\ndeclare var grecaptcha: any;\r\n\r\nexport abstract class BaseReCaptchaComponent implements OnChanges, OnDestroy, ControlValueAccessor, AfterViewInit {\r\n    /**\r\n     * Form Control to be enable usage in reactive forms\r\n     */\r\n    private control: FormControl;\r\n\r\n    private setupAfterLoad = false;\r\n\r\n    /**\r\n    * Name of the global callback\r\n    */\r\n    protected readonly windowOnLoadCallbackProperty = 'ngx_onload_callback_' + this.getPseudoUniqueNumber();\r\n\r\n    /**\r\n     * Name of the global reCaptcha property\r\n     */\r\n    protected readonly globalReCaptchaProperty = 'grecaptcha';\r\n\r\n    /**\r\n     * Prefix of the captcha element\r\n     */\r\n    protected readonly captchaElemPrefix = 'ngx_captcha_id_';\r\n\r\n    /**\r\n      * Google's site key.\r\n      * You can find this under https://www.google.com/recaptcha\r\n      */\r\n    protected _siteKey?: string;\r\n\r\n    /**\r\n    * Config to use\r\n    */\r\n    @Input() siteKey: string | (() => string);\r\n\r\n    /**\r\n     * Type\r\n     */\r\n    @Input() type: 'audio' | 'image' = 'image';\r\n\r\n    /**\r\n     * Language code. Auto-detects the user's language if unspecified.\r\n     */\r\n    @Input() hl: string;\r\n\r\n    /**\r\n    * Tab index\r\n    */\r\n    @Input() tabIndex = 0;\r\n\r\n    /**\r\n     * Called when captcha receives successful response.\r\n     * Captcha response token is passed to event.\r\n     */\r\n    @Output() success = new EventEmitter<string>();\r\n\r\n    /**\r\n    * Called when captcha is loaded. Event receives id of the captcha\r\n    */\r\n    @Output() load = new EventEmitter<number>();\r\n\r\n    /**\r\n    * Called when captcha is loaded & ready. I.e. when you need to execute captcha on component load.\r\n    */\r\n    @Output() ready = new EventEmitter<void>();\r\n\r\n    @ViewChild('captchaWrapperElem') captchaWrapperElem: ElementRef;\r\n    @ViewChild('captchaScriptElem') captchaScriptElem: ElementRef;\r\n\r\n    /**\r\n     * Captcha element\r\n     */\r\n    protected captchaElem?: HTMLElement;\r\n\r\n    /**\r\n     * Id of the captcha elem\r\n     */\r\n    protected captchaId?: number;\r\n\r\n    /**\r\n     * Holds last response value\r\n     */\r\n    protected currentResponse?: string;\r\n\r\n    /**\r\n     * If enabled, captcha will reset after receiving success response. This is useful\r\n     * when invisible captcha need to be resolved multiple times on same page\r\n     */\r\n    protected resetCaptchaAfterSuccess = false;\r\n\r\n    /**\r\n     * Indicates if captcha is loaded\r\n     */\r\n    public isLoaded = false;\r\n\r\n    /**\r\n    * Reference to global reCaptcha API\r\n    */\r\n    public reCaptchaApi?: any;\r\n\r\n    /**\r\n     * Id of the DOM element wrapping captcha\r\n     */\r\n    public captchaElemId?: string;\r\n\r\n    /**\r\n     * Captcha type\r\n     */\r\n    protected abstract recaptchaType: ReCaptchaType;\r\n\r\n  /**\r\n   * Required by ControlValueAccessor\r\n   */\r\n    protected onChange: (value: string ) => void;\r\n    protected onTouched: (value: string ) => void;\r\n\r\n    protected constructor(\r\n        protected renderer: Renderer2,\r\n        protected zone: NgZone,\r\n        protected injector: Injector,\r\n        protected globalConfig?: NgxCaptchaConfig,\r\n    ) {}\r\n\r\n    ngAfterViewInit() {\r\n      this.control = this.injector.get(NgControl).control;\r\n    }\r\n\r\n    /**\r\n    * Gets reCaptcha properties\r\n    */\r\n    protected abstract getCaptchaProperties(): any;\r\n\r\n    /**\r\n     * Used for captcha specific setup\r\n    */\r\n    protected abstract captchaSpecificSetup(): void;\r\n\r\n    private getGlobalSiteKey(): string {\r\n        if (this.globalConfig) {\r\n            // Invisible captcha\r\n            if (this.recaptchaType === ReCaptchaType.InvisibleReCaptcha) {\r\n                if (!this.globalConfig.invisibleCaptchaSiteKey) {\r\n                    throw Error(`SiteKey for invisible reCaptcha is not set!`);\r\n                }\r\n\r\n                if (this.globalConfig.invisibleCaptchaSiteKey instanceof Function) {\r\n                    return this.globalConfig.invisibleCaptchaSiteKey();\r\n                } else {\r\n                    return this.globalConfig.invisibleCaptchaSiteKey;\r\n                }\r\n\r\n                // recaptcha 2\r\n            } else if (this.recaptchaType === ReCaptchaType.ReCaptcha2) {\r\n                if (!this.globalConfig.reCaptcha2SiteKey) {\r\n                    throw Error(`SiteKey for reCaptcha2 is not set!`);\r\n                }\r\n\r\n                if (this.globalConfig.reCaptcha2SiteKey instanceof Function) {\r\n                    return this.globalConfig.reCaptcha2SiteKey();\r\n                } else {\r\n                    return this.globalConfig.reCaptcha2SiteKey;\r\n                }\r\n\r\n            } else {\r\n                throw Error(`Unsupported captcha type '${this.recaptchaType}'!`);\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if (!this.siteKey) {\r\n            // use global site key if key is not available\r\n            this._siteKey = this.getGlobalSiteKey();\r\n        } else {\r\n            // use comnponent site key\r\n            if (this.siteKey instanceof Function) {\r\n                this._siteKey = this.siteKey();\r\n            } else {\r\n                this._siteKey = this.siteKey;\r\n            }\r\n        }\r\n        this.setupComponent();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        window[this.windowOnLoadCallbackProperty] = {};\r\n        window[this.globalReCaptchaProperty] = {};\r\n    }\r\n\r\n    /**\r\n     * Gets captcha response as per reCaptcha docs\r\n    */\r\n    getResponse(): string {\r\n        return this.reCaptchaApi.getResponse(this.captchaId);\r\n    }\r\n\r\n    /**\r\n     * Gets Id of captcha widget\r\n    */\r\n    getCaptchaId(): number {\r\n        return this.captchaId;\r\n    }\r\n\r\n    /**\r\n    * Resets captcha\r\n    */\r\n    resetCaptcha(): void {\r\n      this.zone.run(() => {\r\n        this.onChange(null);\r\n        this.onTouched(null);\r\n      });\r\n\r\n      this.reCaptchaApi.reset(this.captchaId);\r\n    }\r\n\r\n    /**\r\n     * Gets last submitted captcha response\r\n    */\r\n    getCurrentResponse(): string | undefined {\r\n        return this.currentResponse;\r\n    }\r\n\r\n    /**\r\n     * Reload captcha. Useful when properties (i.e. theme) changed and captcha need to reflect them\r\n    */\r\n    reloadCaptcha(): void {\r\n        this.setupComponent();\r\n    }\r\n\r\n    protected ensureCaptchaElem(captchaElemId: string): void {\r\n        const captchaElem = document.getElementById(captchaElemId);\r\n\r\n        if (!captchaElem) {\r\n            throw Error(`Captcha element with id '${captchaElemId}' was not found`);\r\n        }\r\n\r\n        // assign captcha alem\r\n        this.captchaElem = captchaElem;\r\n    }\r\n\r\n    /**\r\n     * Responsible for instantiating captcha element\r\n    */\r\n    protected renderReCaptcha(): void {\r\n        this.captchaId = this.reCaptchaApi.render(this.captchaElemId, this.getCaptchaProperties());\r\n        this.ready.next();\r\n    }\r\n\r\n    /**\r\n     * Called when captcha receives response\r\n     * @param callback Callback\r\n     */\r\n    protected handleCallback(callback: any): void {\r\n        this.currentResponse = callback;\r\n        this.success.next(callback);\r\n\r\n        this.zone.run(() => {\r\n          this.onChange(callback);\r\n          this.onTouched(callback);\r\n        });\r\n\r\n        if (this.resetCaptchaAfterSuccess) {\r\n            this.resetCaptcha();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Registers reCaptcha script if its not available\r\n    */\r\n    protected ensureReCaptchaScript(): void {\r\n        window[this.globalReCaptchaProperty] = {};\r\n        this.reCaptchaApi = {};\r\n\r\n        this.registerReCaptchaScript();\r\n    }\r\n\r\n    /**\r\n     * Add script to page with reference to captcha API. This has to be done manually\r\n     * as we want to avoid adding script to main index.html\r\n    */\r\n    protected registerReCaptchaScript(): void {\r\n        const script = document.createElement('script');\r\n        script.innerHTML = '';\r\n        script.src =\r\n            `https://www.google.com/recaptcha/api.js?onload=${this.windowOnLoadCallbackProperty}&render=explicit${this.getLanguageParam()}`;\r\n        script.async = true;\r\n        script.defer = true;\r\n\r\n        this.captchaScriptElem.nativeElement.appendChild(script);\r\n    }\r\n\r\n    protected getLanguageParam(): string {\r\n        if (!this.hl) {\r\n            return '';\r\n        }\r\n\r\n        return `&hl=${this.hl}`;\r\n    }\r\n\r\n    private getPseudoUniqueNumber(): number {\r\n        return new Date().getUTCMilliseconds() + Math.floor(Math.random() * 9999);\r\n    }\r\n\r\n    /**\r\n     * Checks if reCaptcha Api is defined. It may happen that when navigating from angular component to another\r\n     * via router, the Api was already loaded previously. In such cases, do not render script again.\r\n    */\r\n    private isReCaptchaApiDefined(): boolean {\r\n        if (!window[this.globalReCaptchaProperty]) {\r\n            return false;\r\n        }\r\n        return true;\r\n    }\r\n\r\n    private setupComponent(): void {\r\n        // captcha specific setup\r\n        this.captchaSpecificSetup();\r\n\r\n        // create captcha wrapper\r\n        this.createAndSetCaptchaElem();\r\n\r\n        // we need to patch the callback through global variable, otherwise callback is not accessible\r\n        // note: https://github.com/Enngage/ngx-captcha/issues/2\r\n        window[this.windowOnLoadCallbackProperty] = <any>(() => this.zone.run(\r\n            this.onloadCallback.bind(this)\r\n        ));\r\n\r\n        // create and put reCaptcha script to page\r\n        this.ensureReCaptchaScript();\r\n    }\r\n\r\n    /**\r\n    * Called when google's recaptcha script is ready\r\n    */\r\n    private onloadCallback(): void {\r\n        // assign reference to reCaptcha Api once its loaded\r\n        this.reCaptchaApi = grecaptcha;\r\n\r\n        if (!this.reCaptchaApi) {\r\n            throw Error(`ReCaptcha Api was not initialized correctly`);\r\n        }\r\n\r\n        // loaded flag\r\n        this.isLoaded = true;\r\n\r\n        // fire load event\r\n        this.load.next();\r\n\r\n        // render captcha\r\n        this.renderReCaptcha();\r\n\r\n        // setup component if it was flagged as such\r\n        if (this.setupAfterLoad) {\r\n            this.setupAfterLoad = false;\r\n            this.setupComponent();\r\n        }\r\n    }\r\n\r\n    private generateNewElemId(): string {\r\n        return this.captchaElemPrefix + this.getPseudoUniqueNumber();\r\n    }\r\n\r\n    private createAndSetCaptchaElem(): void {\r\n        // generate new captcha id\r\n        this.captchaElemId = this.generateNewElemId();\r\n\r\n        if (!this.captchaElemId) {\r\n            throw Error(`Captcha elem Id is not set`);\r\n        }\r\n\r\n        // remove old html\r\n        this.captchaWrapperElem.nativeElement.innerHTML = '';\r\n\r\n        // create new wrapper for captcha\r\n        const newElem = this.renderer.createElement('div');\r\n        newElem.id = this.captchaElemId;\r\n\r\n        this.renderer.appendChild(this.captchaWrapperElem.nativeElement, newElem);\r\n\r\n        // update captcha elem\r\n        this.ensureCaptchaElem(this.captchaElemId);\r\n    }\r\n\r\n    /**\r\n     * To be aligned with the ControlValueAccessor interface we need to implement this method\r\n     * However as we don't want to update the recaptcha, this doesn't need to be implemented\r\n     */\r\n    public writeValue(obj: any): void {}\r\n\r\n    /**\r\n     * This method helps us tie together recaptcha and our formControl values\r\n     */\r\n    public registerOnChange(fn: any): void {\r\n      this.onChange = fn;\r\n    }\r\n\r\n    /**\r\n    * At some point we might be interested whether the user has touched our component\r\n    */\r\n    public registerOnTouched(fn: any): void {\r\n      this.onTouched = fn;\r\n    }\r\n}\r\n\r\n"]} |
@@ -6,12 +6,14 @@ /** | ||
import * as tslib_1 from "tslib"; | ||
import { Component, Input, Optional, Renderer2, NgZone } from '@angular/core'; | ||
import { Component, Input, Optional, Renderer2, NgZone, Injector, forwardRef } from '@angular/core'; | ||
import { BaseReCaptchaComponent } from './base-recaptcha.component'; | ||
import { ReCaptchaType } from './recaptcha-type.enum'; | ||
import { NgxCaptchaConfig } from './recaptcha.config'; | ||
import { NG_VALUE_ACCESSOR } from '@angular/forms'; | ||
var InvisibleReCaptchaComponent = /** @class */ (function (_super) { | ||
tslib_1.__extends(InvisibleReCaptchaComponent, _super); | ||
function InvisibleReCaptchaComponent(renderer, zone, globalConfig) { | ||
var _this = _super.call(this, renderer, zone, globalConfig) || this; | ||
function InvisibleReCaptchaComponent(renderer, zone, injector, globalConfig) { | ||
var _this = _super.call(this, renderer, zone, injector, globalConfig) || this; | ||
_this.renderer = renderer; | ||
_this.zone = zone; | ||
_this.injector = injector; | ||
_this.globalConfig = globalConfig; | ||
@@ -88,3 +90,10 @@ /** | ||
selector: 'ngx-invisible-recaptcha', | ||
template: "\n <div #captchaScriptElem></div>\n <div #captchaWrapperElem></div>" | ||
template: "\n <div #captchaScriptElem></div>\n <div #captchaWrapperElem></div>", | ||
providers: [ | ||
{ | ||
provide: NG_VALUE_ACCESSOR, | ||
useExisting: forwardRef(function () { return InvisibleReCaptchaComponent; }), | ||
multi: true, | ||
} | ||
] | ||
},] }, | ||
@@ -96,2 +105,3 @@ ]; | ||
{ type: NgZone }, | ||
{ type: Injector }, | ||
{ type: NgxCaptchaConfig, decorators: [{ type: Optional }] } | ||
@@ -129,5 +139,7 @@ ]; }; | ||
/** @type {?} */ | ||
InvisibleReCaptchaComponent.prototype.injector; | ||
/** @type {?} */ | ||
InvisibleReCaptchaComponent.prototype.globalConfig; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW52aXNpYmxlLXJlY2FwdGNoYS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtY2FwdGNoYS8iLCJzb3VyY2VzIjpbImxpYi9pbnZpc2libGUtcmVjYXB0Y2hhLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFhLFFBQVEsRUFBRSxTQUFTLEVBQWlCLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV4RyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNwRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7O0lBU0wsdURBQXNCO0lBbUJyRSxxQ0FDWSxRQUFtQixFQUNuQixJQUFZLEVBQ0EsWUFBOEI7UUFIdEQsWUFLRSxrQkFBTSxRQUFRLEVBQUUsSUFBSSxFQUFFLFlBQVksQ0FBQyxTQUNwQztRQUxXLGNBQVEsR0FBUixRQUFRLENBQVc7UUFDbkIsVUFBSSxHQUFKLElBQUksQ0FBUTtRQUNBLGtCQUFZLEdBQVosWUFBWSxDQUFrQjs7OztxQkFqQjVCLFdBQVc7Ozs7c0JBS3FCLGFBQWE7OEJBTzlCLGFBQWEsQ0FBQyxrQkFBa0I7O0tBUXhFOzs7OztJQUVELGlEQUFXOzs7O0lBQVgsVUFBWSxPQUFzQjtRQUNoQyxpQkFBTSxXQUFXLFlBQUMsT0FBTyxDQUFDLENBQUM7S0FDNUI7SUFFRDs7T0FFRzs7Ozs7SUFDSCw2Q0FBTzs7OztJQUFQOztRQUVFLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztLQUMzQzs7OztJQUVTLDBEQUFvQjs7O0lBQTlCO0tBQ0M7SUFFRDs7TUFFRTs7Ozs7SUFDUSwwREFBb0I7Ozs7SUFBOUI7UUFBQSxpQkFTQztRQVJDLE1BQU0sQ0FBQztZQUNMLFNBQVMsRUFBRSxJQUFJLENBQUMsUUFBUTtZQUN4QixVQUFVLEVBQUUsVUFBQyxRQUFRLElBQUssT0FBQSxLQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxjQUFNLE9BQUEsS0FBSSxDQUFDLGNBQWMsQ0FBQyxRQUFRLENBQUMsRUFBN0IsQ0FBNkIsQ0FBQyxFQUFsRCxDQUFrRDtZQUM1RSxPQUFPLEVBQUUsSUFBSSxDQUFDLEtBQUs7WUFDbkIsTUFBTSxFQUFFLElBQUksQ0FBQyxJQUFJO1lBQ2pCLFVBQVUsRUFBRSxJQUFJLENBQUMsUUFBUTtZQUN6QixNQUFNLEVBQUUsSUFBSSxDQUFDLElBQUk7U0FDbEIsQ0FBQztLQUNIOztnQkE1REYsU0FBUyxTQUFDO29CQUNULFFBQVEsRUFBRSx5QkFBeUI7b0JBQ25DLFFBQVEsRUFBRSx1RUFFc0I7aUJBQ2pDOzs7O2dCQVorQyxTQUFTO2dCQUFpQixNQUFNO2dCQUl2RSxnQkFBZ0IsdUJBK0JwQixRQUFROzs7d0JBWlYsS0FBSztxQkFLTCxLQUFLOztzQ0E1QlI7RUFhaUQsc0JBQXNCO1NBQTFELDJCQUEyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uQ2hhbmdlcywgT3B0aW9uYWwsIFJlbmRlcmVyMiwgU2ltcGxlQ2hhbmdlcywgTmdab25lIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBCYXNlUmVDYXB0Y2hhQ29tcG9uZW50IH0gZnJvbSAnLi9iYXNlLXJlY2FwdGNoYS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBSZUNhcHRjaGFUeXBlIH0gZnJvbSAnLi9yZWNhcHRjaGEtdHlwZS5lbnVtJztcclxuaW1wb3J0IHsgTmd4Q2FwdGNoYUNvbmZpZyB9IGZyb20gJy4vcmVjYXB0Y2hhLmNvbmZpZyc7XHJcblxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICduZ3gtaW52aXNpYmxlLXJlY2FwdGNoYScsXHJcbiAgdGVtcGxhdGU6IGBcclxuICA8ZGl2ICNjYXB0Y2hhU2NyaXB0RWxlbT48L2Rpdj5cclxuICA8ZGl2ICNjYXB0Y2hhV3JhcHBlckVsZW0+PC9kaXY+YFxyXG59KVxyXG5leHBvcnQgY2xhc3MgSW52aXNpYmxlUmVDYXB0Y2hhQ29tcG9uZW50IGV4dGVuZHMgQmFzZVJlQ2FwdGNoYUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XHJcblxyXG4gIC8qKlxyXG4gICAqIFRoaXMgc2l6ZSByZXByZXNlbnRpbmcgaW52aXNpYmxlIGNhcHRjaGFcclxuICAgKi9cclxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgc2l6ZSA9ICdpbnZpc2libGUnO1xyXG5cclxuICAvKipcclxuICAgKiBCYWRnZVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIGJhZGdlOiAnYm90dG9tcmlnaHQnIHwgJ2JvdHRvbWxlZnQnIHwgJ2lubGluZScgPSAnYm90dG9tcmlnaHQnO1xyXG5cclxuICAvKipcclxuICAgKiBMYW5ndWFnZSBjb2RlLiBBdXRvLWRldGVjdHMgdGhlIHVzZXIncyBsYW5ndWFnZSBpZiB1bnNwZWNpZmllZC5cclxuICAgKi9cclxuICBASW5wdXQoKSBobDogc3RyaW5nO1xyXG5cclxuICBwcm90ZWN0ZWQgcmVjYXB0Y2hhVHlwZTogUmVDYXB0Y2hhVHlwZSA9IFJlQ2FwdGNoYVR5cGUuSW52aXNpYmxlUmVDYXB0Y2hhO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByb3RlY3RlZCByZW5kZXJlcjogUmVuZGVyZXIyLFxyXG4gICAgcHJvdGVjdGVkIHpvbmU6IE5nWm9uZSxcclxuICAgIEBPcHRpb25hbCgpIHByb3RlY3RlZCBnbG9iYWxDb25maWc6IE5neENhcHRjaGFDb25maWcsXHJcbiAgKSB7XHJcbiAgICBzdXBlcihyZW5kZXJlciwgem9uZSwgZ2xvYmFsQ29uZmlnKTtcclxuICB9XHJcblxyXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcclxuICAgIHN1cGVyLm5nT25DaGFuZ2VzKGNoYW5nZXMpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogUHJvZ3JhbWF0aWNhbGx5IGludm9rZSB0aGUgcmVDQVBUQ0hBIGNoZWNrLiBVc2VkIGlmIHRoZSBpbnZpc2libGUgcmVDQVBUQ0hBIGlzIG9uIGEgZGl2IGluc3RlYWQgb2YgYSBidXR0b24uXHJcbiAgICovXHJcbiAgZXhlY3V0ZSgpOiB2b2lkIHtcclxuICAgIC8vIGV4ZWN1dGUgY2FwdGNoYVxyXG4gICAgdGhpcy5yZUNhcHRjaGFBcGkuZXhlY3V0ZSh0aGlzLmNhcHRjaGFJZCk7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgY2FwdGNoYVNwZWNpZmljU2V0dXAoKTogdm9pZCB7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAqIEdldHMgcmVDYXB0Y2hhIHByb3BlcnRpZXNcclxuICAqL1xyXG4gIHByb3RlY3RlZCBnZXRDYXB0Y2hhUHJvcGVydGllcygpOiBhbnkge1xyXG4gICAgcmV0dXJuIHtcclxuICAgICAgJ3NpdGVrZXknOiB0aGlzLl9zaXRlS2V5LFxyXG4gICAgICAnY2FsbGJhY2snOiAocmVzcG9uc2UpID0+IHRoaXMuem9uZS5ydW4oKCkgPT4gdGhpcy5oYW5kbGVDYWxsYmFjayhyZXNwb25zZSkpLFxyXG4gICAgICAnYmFkZ2UnOiB0aGlzLmJhZGdlLFxyXG4gICAgICAndHlwZSc6IHRoaXMudHlwZSxcclxuICAgICAgJ3RhYmluZGV4JzogdGhpcy50YWJJbmRleCxcclxuICAgICAgJ3NpemUnOiB0aGlzLnNpemVcclxuICAgIH07XHJcbiAgfVxyXG59XHJcblxyXG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW52aXNpYmxlLXJlY2FwdGNoYS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtY2FwdGNoYS8iLCJzb3VyY2VzIjpbImxpYi9pbnZpc2libGUtcmVjYXB0Y2hhLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFhLFFBQVEsRUFBRSxTQUFTLEVBQWlCLE1BQU0sRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTlILE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUN0RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7SUFnQkYsdURBQXNCO0lBbUJyRSxxQ0FDWSxRQUFtQixFQUNuQixJQUFZLEVBQ1osUUFBa0IsRUFDTixZQUE4QjtRQUp0RCxZQU1FLGtCQUFNLFFBQVEsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLFlBQVksQ0FBQyxTQUM5QztRQU5XLGNBQVEsR0FBUixRQUFRLENBQVc7UUFDbkIsVUFBSSxHQUFKLElBQUksQ0FBUTtRQUNaLGNBQVEsR0FBUixRQUFRLENBQVU7UUFDTixrQkFBWSxHQUFaLFlBQVksQ0FBa0I7Ozs7cUJBbEI1QixXQUFXOzs7O3NCQUtxQixhQUFhOzhCQU85QixhQUFhLENBQUMsa0JBQWtCOztLQVN4RTs7Ozs7SUFFRCxpREFBVzs7OztJQUFYLFVBQVksT0FBc0I7UUFDaEMsaUJBQU0sV0FBVyxZQUFDLE9BQU8sQ0FBQyxDQUFDO0tBQzVCO0lBRUQ7O09BRUc7Ozs7O0lBQ0gsNkNBQU87Ozs7SUFBUDs7UUFFRSxJQUFJLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7S0FDM0M7Ozs7SUFFUywwREFBb0I7OztJQUE5QjtLQUNDO0lBRUQ7O01BRUU7Ozs7O0lBQ1EsMERBQW9COzs7O0lBQTlCO1FBQUEsaUJBU0M7UUFSQyxNQUFNLENBQUM7WUFDTCxTQUFTLEVBQUUsSUFBSSxDQUFDLFFBQVE7WUFDeEIsVUFBVSxFQUFFLFVBQUMsUUFBUSxJQUFLLE9BQUEsS0FBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsY0FBTSxPQUFBLEtBQUksQ0FBQyxjQUFjLENBQUMsUUFBUSxDQUFDLEVBQTdCLENBQTZCLENBQUMsRUFBbEQsQ0FBa0Q7WUFDNUUsT0FBTyxFQUFFLElBQUksQ0FBQyxLQUFLO1lBQ25CLE1BQU0sRUFBRSxJQUFJLENBQUMsSUFBSTtZQUNqQixVQUFVLEVBQUUsSUFBSSxDQUFDLFFBQVE7WUFDekIsTUFBTSxFQUFFLElBQUksQ0FBQyxJQUFJO1NBQ2xCLENBQUM7S0FDSDs7Z0JBcEVGLFNBQVMsU0FBQztvQkFDVCxRQUFRLEVBQUUseUJBQXlCO29CQUNuQyxRQUFRLEVBQUUsdUVBRXNCO29CQUNoQyxTQUFTLEVBQUU7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxjQUFNLE9BQUEsMkJBQTJCLEVBQTNCLENBQTJCLENBQUM7NEJBQzFELEtBQUssRUFBRSxJQUFJO3lCQUNaO3FCQUNGO2lCQUNGOzs7O2dCQXBCK0MsU0FBUztnQkFBaUIsTUFBTTtnQkFBRSxRQUFRO2dCQUlqRixnQkFBZ0IsdUJBd0NwQixRQUFROzs7d0JBYlYsS0FBSztxQkFLTCxLQUFLOztzQ0FwQ1I7RUFxQmlELHNCQUFzQjtTQUExRCwyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkNoYW5nZXMsIE9wdGlvbmFsLCBSZW5kZXJlcjIsIFNpbXBsZUNoYW5nZXMsIE5nWm9uZSwgSW5qZWN0b3IsIGZvcndhcmRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IEJhc2VSZUNhcHRjaGFDb21wb25lbnQgfSBmcm9tICcuL2Jhc2UtcmVjYXB0Y2hhLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFJlQ2FwdGNoYVR5cGUgfSBmcm9tICcuL3JlY2FwdGNoYS10eXBlLmVudW0nO1xyXG5pbXBvcnQgeyBOZ3hDYXB0Y2hhQ29uZmlnIH0gZnJvbSAnLi9yZWNhcHRjaGEuY29uZmlnJztcclxuaW1wb3J0IHsgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcblxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICduZ3gtaW52aXNpYmxlLXJlY2FwdGNoYScsXHJcbiAgdGVtcGxhdGU6IGBcclxuICA8ZGl2ICNjYXB0Y2hhU2NyaXB0RWxlbT48L2Rpdj5cclxuICA8ZGl2ICNjYXB0Y2hhV3JhcHBlckVsZW0+PC9kaXY+YCxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIHtcclxuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXHJcbiAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IEludmlzaWJsZVJlQ2FwdGNoYUNvbXBvbmVudCksXHJcbiAgICAgIG11bHRpOiB0cnVlLFxyXG4gICAgfVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEludmlzaWJsZVJlQ2FwdGNoYUNvbXBvbmVudCBleHRlbmRzIEJhc2VSZUNhcHRjaGFDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xyXG5cclxuICAvKipcclxuICAgKiBUaGlzIHNpemUgcmVwcmVzZW50aW5nIGludmlzaWJsZSBjYXB0Y2hhXHJcbiAgICovXHJcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IHNpemUgPSAnaW52aXNpYmxlJztcclxuXHJcbiAgLyoqXHJcbiAgICogQmFkZ2VcclxuICAgKi9cclxuICBASW5wdXQoKSBiYWRnZTogJ2JvdHRvbXJpZ2h0JyB8ICdib3R0b21sZWZ0JyB8ICdpbmxpbmUnID0gJ2JvdHRvbXJpZ2h0JztcclxuXHJcbiAgLyoqXHJcbiAgICogTGFuZ3VhZ2UgY29kZS4gQXV0by1kZXRlY3RzIHRoZSB1c2VyJ3MgbGFuZ3VhZ2UgaWYgdW5zcGVjaWZpZWQuXHJcbiAgICovXHJcbiAgQElucHV0KCkgaGw6IHN0cmluZztcclxuXHJcbiAgcHJvdGVjdGVkIHJlY2FwdGNoYVR5cGU6IFJlQ2FwdGNoYVR5cGUgPSBSZUNhcHRjaGFUeXBlLkludmlzaWJsZVJlQ2FwdGNoYTtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcm90ZWN0ZWQgcmVuZGVyZXI6IFJlbmRlcmVyMixcclxuICAgIHByb3RlY3RlZCB6b25lOiBOZ1pvbmUsXHJcbiAgICBwcm90ZWN0ZWQgaW5qZWN0b3I6IEluamVjdG9yLFxyXG4gICAgQE9wdGlvbmFsKCkgcHJvdGVjdGVkIGdsb2JhbENvbmZpZzogTmd4Q2FwdGNoYUNvbmZpZyxcclxuICApIHtcclxuICAgIHN1cGVyKHJlbmRlcmVyLCB6b25lLCBpbmplY3RvciwgZ2xvYmFsQ29uZmlnKTtcclxuICB9XHJcblxyXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcclxuICAgIHN1cGVyLm5nT25DaGFuZ2VzKGNoYW5nZXMpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogUHJvZ3JhbWF0aWNhbGx5IGludm9rZSB0aGUgcmVDQVBUQ0hBIGNoZWNrLiBVc2VkIGlmIHRoZSBpbnZpc2libGUgcmVDQVBUQ0hBIGlzIG9uIGEgZGl2IGluc3RlYWQgb2YgYSBidXR0b24uXHJcbiAgICovXHJcbiAgZXhlY3V0ZSgpOiB2b2lkIHtcclxuICAgIC8vIGV4ZWN1dGUgY2FwdGNoYVxyXG4gICAgdGhpcy5yZUNhcHRjaGFBcGkuZXhlY3V0ZSh0aGlzLmNhcHRjaGFJZCk7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgY2FwdGNoYVNwZWNpZmljU2V0dXAoKTogdm9pZCB7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAqIEdldHMgcmVDYXB0Y2hhIHByb3BlcnRpZXNcclxuICAqL1xyXG4gIHByb3RlY3RlZCBnZXRDYXB0Y2hhUHJvcGVydGllcygpOiBhbnkge1xyXG4gICAgcmV0dXJuIHtcclxuICAgICAgJ3NpdGVrZXknOiB0aGlzLl9zaXRlS2V5LFxyXG4gICAgICAnY2FsbGJhY2snOiAocmVzcG9uc2UpID0+IHRoaXMuem9uZS5ydW4oKCkgPT4gdGhpcy5oYW5kbGVDYWxsYmFjayhyZXNwb25zZSkpLFxyXG4gICAgICAnYmFkZ2UnOiB0aGlzLmJhZGdlLFxyXG4gICAgICAndHlwZSc6IHRoaXMudHlwZSxcclxuICAgICAgJ3RhYmluZGV4JzogdGhpcy50YWJJbmRleCxcclxuICAgICAgJ3NpemUnOiB0aGlzLnNpemVcclxuICAgIH07XHJcbiAgfVxyXG59XHJcblxyXG4iXX0= |
@@ -6,12 +6,14 @@ /** | ||
import * as tslib_1 from "tslib"; | ||
import { Component, EventEmitter, Input, Optional, Output, Renderer2, NgZone, } from '@angular/core'; | ||
import { Component, EventEmitter, Input, Optional, Output, Renderer2, NgZone, Injector, forwardRef, } from '@angular/core'; | ||
import { BaseReCaptchaComponent } from './base-recaptcha.component'; | ||
import { ReCaptchaType } from './recaptcha-type.enum'; | ||
import { NgxCaptchaConfig } from './recaptcha.config'; | ||
import { NG_VALUE_ACCESSOR } from '@angular/forms'; | ||
var ReCaptcha2Component = /** @class */ (function (_super) { | ||
tslib_1.__extends(ReCaptcha2Component, _super); | ||
function ReCaptcha2Component(renderer, zone, globalConfig) { | ||
var _this = _super.call(this, renderer, zone, globalConfig) || this; | ||
function ReCaptcha2Component(renderer, zone, injector, globalConfig) { | ||
var _this = _super.call(this, renderer, zone, injector, globalConfig) || this; | ||
_this.renderer = renderer; | ||
_this.zone = zone; | ||
_this.injector = injector; | ||
_this.globalConfig = globalConfig; | ||
@@ -121,2 +123,7 @@ /** | ||
function () { | ||
var _this = this; | ||
this.zone.run(function () { | ||
_this.onChange(null); | ||
_this.onTouched(null); | ||
}); | ||
this.error.next(); | ||
@@ -140,3 +147,10 @@ }; | ||
selector: 'ngx-recaptcha2', | ||
template: "\n <div #captchaScriptElem></div>\n <div #captchaWrapperElem></div>" | ||
template: "\n <div #captchaScriptElem></div>\n <div #captchaWrapperElem></div>", | ||
providers: [ | ||
{ | ||
provide: NG_VALUE_ACCESSOR, | ||
useExisting: forwardRef(function () { return ReCaptcha2Component; }), | ||
multi: true, | ||
} | ||
] | ||
},] }, | ||
@@ -148,2 +162,3 @@ ]; | ||
{ type: NgZone }, | ||
{ type: Injector }, | ||
{ type: NgxCaptchaConfig, decorators: [{ type: Optional }] } | ||
@@ -204,5 +219,7 @@ ]; }; | ||
/** @type {?} */ | ||
ReCaptcha2Component.prototype.injector; | ||
/** @type {?} */ | ||
ReCaptcha2Component.prototype.globalConfig; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjYXB0Y2hhLTIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWNhcHRjaGEvIiwic291cmNlcyI6WyJsaWIvcmVjYXB0Y2hhLTIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUdMLFFBQVEsRUFDUixNQUFNLEVBQ04sU0FBUyxFQUVULE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNwRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7O0lBUWIsK0NBQXNCO0lBdUM3RCw2QkFDWSxRQUFtQixFQUNuQixJQUFZLEVBQ0EsWUFBOEI7UUFIdEQsWUFLRSxrQkFBTSxRQUFRLEVBQUUsSUFBSSxFQUFFLFlBQVksQ0FBQyxTQUNwQztRQUxXLGNBQVEsR0FBUixRQUFRLENBQVc7UUFDbkIsVUFBSSxHQUFKLElBQUksQ0FBUTtRQUNBLGtCQUFZLEdBQVosWUFBWSxDQUFrQjs7Ozs4Q0FyQ0gsNEJBQTRCOzs7OytDQUszQiw2QkFBNkI7Ozs7c0JBSzlDLE9BQU87Ozs7cUJBS0osUUFBUTs7Ozt1QkFVM0IsSUFBSSxZQUFZLEVBQVE7Ozs7c0JBS3pCLElBQUksWUFBWSxFQUFROzhCQUVELGFBQWEsQ0FBQyxVQUFVOztLQVFoRTs7Ozs7SUFFRCx5Q0FBVzs7OztJQUFYLFVBQVksT0FBc0I7UUFDaEMsaUJBQU0sV0FBVyxZQUFDLE9BQU8sQ0FBQyxDQUFDO0tBQzVCOzs7O0lBRUQseUNBQVc7OztJQUFYO1FBQ0UsaUJBQU0sV0FBVyxXQUFFLENBQUM7UUFFcEIsTUFBTSxDQUFDLElBQUksQ0FBQyw2QkFBNkIsQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUNoRCxNQUFNLENBQUMsSUFBSSxDQUFDLDhCQUE4QixDQUFDLEdBQUcsRUFBRSxDQUFDO0tBQ2xEOzs7O0lBRVMsa0RBQW9COzs7SUFBOUI7UUFDRSxJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztLQUMxQjtJQUVEOztNQUVFOzs7OztJQUNRLGtEQUFvQjs7OztJQUE5QjtRQUFBLGlCQVdDO1FBVkMsTUFBTSxDQUFDO1lBQ0wsU0FBUyxFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ3hCLFVBQVUsRUFBRSxVQUFDLFFBQVEsSUFBSyxPQUFBLEtBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLGNBQU0sT0FBQSxLQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxFQUE3QixDQUE2QixDQUFDLEVBQWxELENBQWtEO1lBQzVFLGtCQUFrQixFQUFFLGNBQU0sT0FBQSxLQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxjQUFNLE9BQUEsS0FBSSxDQUFDLG9CQUFvQixFQUFFLEVBQTNCLENBQTJCLENBQUMsRUFBaEQsQ0FBZ0Q7WUFDMUUsZ0JBQWdCLEVBQUUsY0FBTSxPQUFBLEtBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLGNBQU0sT0FBQSxLQUFJLENBQUMsbUJBQW1CLEVBQUUsRUFBMUIsQ0FBMEIsQ0FBQyxFQUEvQyxDQUErQztZQUN2RSxPQUFPLEVBQUUsSUFBSSxDQUFDLEtBQUs7WUFDbkIsTUFBTSxFQUFFLElBQUksQ0FBQyxJQUFJO1lBQ2pCLE1BQU0sRUFBRSxJQUFJLENBQUMsSUFBSTtZQUNqQixVQUFVLEVBQUUsSUFBSSxDQUFDLFFBQVE7U0FDMUIsQ0FBQztLQUNIOzs7OztJQUtPLCtDQUFpQjs7Ozs7UUFDdkIsTUFBTSxDQUFDLElBQUksQ0FBQyw2QkFBNkIsQ0FBQyxHQUFHLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDakYsTUFBTSxDQUFDLElBQUksQ0FBQyw4QkFBOEIsQ0FBQyxHQUFHLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7Ozs7OztJQU03RSxpREFBbUI7Ozs7O1FBQ3pCLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7Ozs7OztJQU1aLGtEQUFvQjs7Ozs7UUFDMUIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQzs7UUFHbkIsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDOzs7Z0JBMUd2QixTQUFTLFNBQUM7b0JBQ1QsUUFBUSxFQUFFLGdCQUFnQjtvQkFDMUIsUUFBUSxFQUFFLHVFQUVzQjtpQkFDakM7Ozs7Z0JBZEMsU0FBUztnQkFFVCxNQUFNO2dCQUtDLGdCQUFnQix1QkFrRHBCLFFBQVE7Ozt3QkEzQlYsS0FBSzt1QkFLTCxLQUFLO3FCQUtMLEtBQUs7eUJBS0wsTUFBTTt3QkFLTixNQUFNOzs4QkExRFQ7RUF1QnlDLHNCQUFzQjtTQUFsRCxtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENvbXBvbmVudCxcclxuICBFdmVudEVtaXR0ZXIsXHJcbiAgSW5wdXQsXHJcbiAgT25DaGFuZ2VzLFxyXG4gIE9uRGVzdHJveSxcclxuICBPcHRpb25hbCxcclxuICBPdXRwdXQsXHJcbiAgUmVuZGVyZXIyLFxyXG4gIFNpbXBsZUNoYW5nZXMsXHJcbiAgTmdab25lLFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgQmFzZVJlQ2FwdGNoYUNvbXBvbmVudCB9IGZyb20gJy4vYmFzZS1yZWNhcHRjaGEuY29tcG9uZW50JztcclxuaW1wb3J0IHsgUmVDYXB0Y2hhVHlwZSB9IGZyb20gJy4vcmVjYXB0Y2hhLXR5cGUuZW51bSc7XHJcbmltcG9ydCB7IE5neENhcHRjaGFDb25maWcgfSBmcm9tICcuL3JlY2FwdGNoYS5jb25maWcnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICduZ3gtcmVjYXB0Y2hhMicsXHJcbiAgdGVtcGxhdGU6IGBcclxuICA8ZGl2ICNjYXB0Y2hhU2NyaXB0RWxlbT48L2Rpdj5cclxuICA8ZGl2ICNjYXB0Y2hhV3JhcHBlckVsZW0+PC9kaXY+YFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUmVDYXB0Y2hhMkNvbXBvbmVudCBleHRlbmRzIEJhc2VSZUNhcHRjaGFDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMsIE9uRGVzdHJveSB7XHJcblxyXG4gIC8qKlxyXG4gICogTmFtZSBvZiB0aGUgZ2xvYmFsIGV4cGlyZSBjYWxsYmFja1xyXG4gICovXHJcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IHdpbmRvd09uRXJyb3JDYWxsYmFja1Byb3BlcnR5ID0gJ25neF9jYXB0Y2hhX2Vycm9yX2NhbGxiYWNrJztcclxuXHJcbiAgLyoqXHJcbiAgKiBOYW1lIG9mIHRoZSBnbG9iYWwgZXJyb3IgY2FsbGJhY2tcclxuICAqL1xyXG4gIHByb3RlY3RlZCByZWFkb25seSB3aW5kb3dPbkV4cGlyZUNhbGxiYWNrUHJvcGVydHkgPSAnbmd4X2NhcHRjaGFfZXhwaXJlX2NhbGxiYWNrJztcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlbWVcclxuICAgKi9cclxuICBASW5wdXQoKSB0aGVtZTogJ2RhcmsnIHwgJ2xpZ2h0JyA9ICdsaWdodCc7XHJcblxyXG4gIC8qKlxyXG4gICogU2l6ZVxyXG4gICovXHJcbiAgQElucHV0KCkgc2l6ZTogJ2NvbXBhY3QnIHwgJ25vcm1hbCcgPSAnbm9ybWFsJztcclxuXHJcbiAgLyoqXHJcbiAgICogTGFuZ3VhZ2UgY29kZS4gQXV0by1kZXRlY3RzIHRoZSB1c2VyJ3MgbGFuZ3VhZ2UgaWYgdW5zcGVjaWZpZWQuXHJcbiAgICovXHJcbiAgQElucHV0KCkgaGw6IHN0cmluZztcclxuXHJcbiAgLyoqXHJcbiAgKiBFeHBpcmVkIGNhbGxiYWNrXHJcbiAgKi9cclxuICBAT3V0cHV0KCkgZXhwaXJlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xyXG5cclxuICAvKipcclxuICAqIEVycm9yIGNhbGxiYWNrXHJcbiAgKi9cclxuICBAT3V0cHV0KCkgZXJyb3IgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XHJcblxyXG4gIHByb3RlY3RlZCByZWNhcHRjaGFUeXBlOiBSZUNhcHRjaGFUeXBlID0gUmVDYXB0Y2hhVHlwZS5SZUNhcHRjaGEyO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByb3RlY3RlZCByZW5kZXJlcjogUmVuZGVyZXIyLFxyXG4gICAgcHJvdGVjdGVkIHpvbmU6IE5nWm9uZSxcclxuICAgIEBPcHRpb25hbCgpIHByb3RlY3RlZCBnbG9iYWxDb25maWc6IE5neENhcHRjaGFDb25maWcsXHJcbiAgKSB7XHJcbiAgICBzdXBlcihyZW5kZXJlciwgem9uZSwgZ2xvYmFsQ29uZmlnKTtcclxuICB9XHJcblxyXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcclxuICAgIHN1cGVyLm5nT25DaGFuZ2VzKGNoYW5nZXMpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICBzdXBlci5uZ09uRGVzdHJveSgpO1xyXG5cclxuICAgIHdpbmRvd1t0aGlzLndpbmRvd09uRXJyb3JDYWxsYmFja1Byb3BlcnR5XSA9IHt9O1xyXG4gICAgd2luZG93W3RoaXMud2luZG93T25FeHBpcmVDYWxsYmFja1Byb3BlcnR5XSA9IHt9O1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIGNhcHRjaGFTcGVjaWZpY1NldHVwKCk6IHZvaWQge1xyXG4gICAgdGhpcy5yZWdpc3RlckNhbGxiYWNrcygpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogR2V0cyByZUNhcHRjaGEgcHJvcGVydGllc1xyXG4gICovXHJcbiAgcHJvdGVjdGVkIGdldENhcHRjaGFQcm9wZXJ0aWVzKCk6IGFueSB7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICAnc2l0ZWtleSc6IHRoaXMuX3NpdGVLZXksXHJcbiAgICAgICdjYWxsYmFjayc6IChyZXNwb25zZSkgPT4gdGhpcy56b25lLnJ1bigoKSA9PiB0aGlzLmhhbmRsZUNhbGxiYWNrKHJlc3BvbnNlKSksXHJcbiAgICAgICdleHBpcmVkLWNhbGxiYWNrJzogKCkgPT4gdGhpcy56b25lLnJ1bigoKSA9PiB0aGlzLmhhbmRsZUV4cGlyZUNhbGxiYWNrKCkpLFxyXG4gICAgICAnZXJyb3ItY2FsbGJhY2snOiAoKSA9PiB0aGlzLnpvbmUucnVuKCgpID0+IHRoaXMuaGFuZGxlRXJyb3JDYWxsYmFjaygpKSxcclxuICAgICAgJ3RoZW1lJzogdGhpcy50aGVtZSxcclxuICAgICAgJ3R5cGUnOiB0aGlzLnR5cGUsXHJcbiAgICAgICdzaXplJzogdGhpcy5zaXplLFxyXG4gICAgICAndGFiaW5kZXgnOiB0aGlzLnRhYkluZGV4XHJcbiAgICB9O1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogUmVnaXN0ZXJzIGdsb2JhbCBjYWxsYmFja3NcclxuICAqL1xyXG4gIHByaXZhdGUgcmVnaXN0ZXJDYWxsYmFja3MoKTogdm9pZCB7XHJcbiAgICB3aW5kb3dbdGhpcy53aW5kb3dPbkVycm9yQ2FsbGJhY2tQcm9wZXJ0eV0gPSB0aGlzLmhhbmRsZUVycm9yQ2FsbGJhY2suYmluZCh0aGlzKTtcclxuICAgIHdpbmRvd1t0aGlzLndpbmRvd09uRXhwaXJlQ2FsbGJhY2tQcm9wZXJ0eV0gPSB0aGlzLmhhbmRsZUV4cGlyZUNhbGxiYWNrLmJpbmQodGhpcyk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBIYW5kbGVzIGVycm9yIGNhbGxiYWNrXHJcbiAgKi9cclxuICBwcml2YXRlIGhhbmRsZUVycm9yQ2FsbGJhY2soKTogdm9pZCB7XHJcbiAgICB0aGlzLmVycm9yLm5leHQoKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEhhbmRsZXMgZXhwaXJlZCBjYWxsYmFja1xyXG4gICAqL1xyXG4gIHByaXZhdGUgaGFuZGxlRXhwaXJlQ2FsbGJhY2soKTogdm9pZCB7XHJcbiAgICB0aGlzLmV4cGlyZS5uZXh0KCk7XHJcblxyXG4gICAgLy8gcmVzZXQgY2FwdGNoYSBvbiBleHBpcmUgY2FsbGJhY2tcclxuICAgIHRoaXMucmVzZXRDYXB0Y2hhKCk7XHJcbiAgfVxyXG59XHJcblxyXG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recaptcha-2.component.js","sourceRoot":"ng://ngx-captcha/","sources":["lib/recaptcha-2.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Optional,\r\n  Output,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  NgZone, Injector, forwardRef,\r\n} from '@angular/core';\r\n\r\nimport { BaseReCaptchaComponent } from './base-recaptcha.component';\r\nimport { ReCaptchaType } from './recaptcha-type.enum';\r\nimport { NgxCaptchaConfig } from './recaptcha.config';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'ngx-recaptcha2',\r\n  template: `\r\n  <div #captchaScriptElem></div>\r\n  <div #captchaWrapperElem></div>`,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ReCaptcha2Component),\r\n      multi: true,\r\n    }\r\n  ]\r\n})\r\nexport class ReCaptcha2Component extends BaseReCaptchaComponent implements OnChanges, OnDestroy {\r\n\r\n  /**\r\n  * Name of the global expire callback\r\n  */\r\n  protected readonly windowOnErrorCallbackProperty = 'ngx_captcha_error_callback';\r\n\r\n  /**\r\n  * Name of the global error callback\r\n  */\r\n  protected readonly windowOnExpireCallbackProperty = 'ngx_captcha_expire_callback';\r\n\r\n  /**\r\n   * Theme\r\n   */\r\n  @Input() theme: 'dark' | 'light' = 'light';\r\n\r\n  /**\r\n  * Size\r\n  */\r\n  @Input() size: 'compact' | 'normal' = 'normal';\r\n\r\n  /**\r\n   * Language code. Auto-detects the user's language if unspecified.\r\n   */\r\n  @Input() hl: string;\r\n\r\n  /**\r\n  * Expired callback\r\n  */\r\n  @Output() expire = new EventEmitter<void>();\r\n\r\n  /**\r\n  * Error callback\r\n  */\r\n  @Output() error = new EventEmitter<void>();\r\n\r\n  protected recaptchaType: ReCaptchaType = ReCaptchaType.ReCaptcha2;\r\n\r\n  constructor(\r\n    protected renderer: Renderer2,\r\n    protected zone: NgZone,\r\n    protected injector: Injector,\r\n    @Optional() protected globalConfig: NgxCaptchaConfig,\r\n  ) {\r\n    super(renderer, zone, injector, globalConfig);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    super.ngOnChanges(changes);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    super.ngOnDestroy();\r\n\r\n    window[this.windowOnErrorCallbackProperty] = {};\r\n    window[this.windowOnExpireCallbackProperty] = {};\r\n  }\r\n\r\n  protected captchaSpecificSetup(): void {\r\n    this.registerCallbacks();\r\n  }\r\n\r\n  /**\r\n   * Gets reCaptcha properties\r\n  */\r\n  protected getCaptchaProperties(): any {\r\n    return {\r\n      'sitekey': this._siteKey,\r\n      'callback': (response) => this.zone.run(() => this.handleCallback(response)),\r\n      'expired-callback': () => this.zone.run(() => this.handleExpireCallback()),\r\n      'error-callback': () => this.zone.run(() => this.handleErrorCallback()),\r\n      'theme': this.theme,\r\n      'type': this.type,\r\n      'size': this.size,\r\n      'tabindex': this.tabIndex\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Registers global callbacks\r\n  */\r\n  private registerCallbacks(): void {\r\n    window[this.windowOnErrorCallbackProperty] = this.handleErrorCallback.bind(this);\r\n    window[this.windowOnExpireCallbackProperty] = this.handleExpireCallback.bind(this);\r\n  }\r\n\r\n  /**\r\n   * Handles error callback\r\n  */\r\n  private handleErrorCallback(): void {\r\n    this.zone.run(() => {\r\n      this.onChange(null);\r\n      this.onTouched(null);\r\n    });\r\n\r\n    this.error.next();\r\n  }\r\n\r\n  /**\r\n   * Handles expired callback\r\n   */\r\n  private handleExpireCallback(): void {\r\n    this.expire.next();\r\n\r\n    // reset captcha on expire callback\r\n    this.resetCaptcha();\r\n  }\r\n}\r\n\r\n"]} |
@@ -1,2 +0,3 @@ | ||
import { EventEmitter, Input, Output, ViewChild, Component, Optional, Renderer2, NgZone, NgModule } from '@angular/core'; | ||
import { EventEmitter, Input, Output, ViewChild, Component, Optional, Renderer2, NgZone, Injector, forwardRef, NgModule } from '@angular/core'; | ||
import { NgControl, NG_VALUE_ACCESSOR } from '@angular/forms'; | ||
import { CommonModule } from '@angular/common'; | ||
@@ -27,7 +28,9 @@ | ||
* @param {?} zone | ||
* @param {?} injector | ||
* @param {?=} globalConfig | ||
*/ | ||
constructor(renderer, zone, globalConfig) { | ||
constructor(renderer, zone, injector, globalConfig) { | ||
this.renderer = renderer; | ||
this.zone = zone; | ||
this.injector = injector; | ||
this.globalConfig = globalConfig; | ||
@@ -81,2 +84,8 @@ this.setupAfterLoad = false; | ||
*/ | ||
ngAfterViewInit() { | ||
this.control = this.injector.get(NgControl).control; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
getGlobalSiteKey() { | ||
@@ -159,2 +168,6 @@ if (this.globalConfig) { | ||
resetCaptcha() { | ||
this.zone.run(() => { | ||
this.onChange(null); | ||
this.onTouched(null); | ||
}); | ||
this.reCaptchaApi.reset(this.captchaId); | ||
@@ -204,2 +217,6 @@ } | ||
this.success.next(callback); | ||
this.zone.run(() => { | ||
this.onChange(callback); | ||
this.onTouched(callback); | ||
}); | ||
if (this.resetCaptchaAfterSuccess) { | ||
@@ -288,3 +305,3 @@ this.resetCaptcha(); | ||
this.renderReCaptcha(); | ||
// setup component if it was flagges as such | ||
// setup component if it was flagged as such | ||
if (this.setupAfterLoad) { | ||
@@ -319,2 +336,25 @@ this.setupAfterLoad = false; | ||
} | ||
/** | ||
* To be aligned with the ControlValueAccessor interface we need to implement this method | ||
* However as we don't want to update the recaptcha, this doesn't need to be implemented | ||
* @param {?} obj | ||
* @return {?} | ||
*/ | ||
writeValue(obj) { } | ||
/** | ||
* This method helps us tie together recaptcha and our formControl values | ||
* @param {?} fn | ||
* @return {?} | ||
*/ | ||
registerOnChange(fn) { | ||
this.onChange = fn; | ||
} | ||
/** | ||
* At some point we might be interested whether the user has touched our component | ||
* @param {?} fn | ||
* @return {?} | ||
*/ | ||
registerOnTouched(fn) { | ||
this.onTouched = fn; | ||
} | ||
} | ||
@@ -348,8 +388,10 @@ BaseReCaptchaComponent.propDecorators = { | ||
* @param {?} zone | ||
* @param {?} injector | ||
* @param {?} globalConfig | ||
*/ | ||
constructor(renderer, zone, globalConfig) { | ||
super(renderer, zone, globalConfig); | ||
constructor(renderer, zone, injector, globalConfig) { | ||
super(renderer, zone, injector, globalConfig); | ||
this.renderer = renderer; | ||
this.zone = zone; | ||
this.injector = injector; | ||
this.globalConfig = globalConfig; | ||
@@ -432,2 +474,6 @@ /** | ||
handleErrorCallback() { | ||
this.zone.run(() => { | ||
this.onChange(null); | ||
this.onTouched(null); | ||
}); | ||
this.error.next(); | ||
@@ -450,3 +496,10 @@ } | ||
<div #captchaScriptElem></div> | ||
<div #captchaWrapperElem></div>` | ||
<div #captchaWrapperElem></div>`, | ||
providers: [ | ||
{ | ||
provide: NG_VALUE_ACCESSOR, | ||
useExisting: forwardRef(() => ReCaptcha2Component), | ||
multi: true, | ||
} | ||
] | ||
},] }, | ||
@@ -458,2 +511,3 @@ ]; | ||
{ type: NgZone }, | ||
{ type: Injector }, | ||
{ type: NgxCaptchaConfig, decorators: [{ type: Optional }] } | ||
@@ -477,8 +531,10 @@ ]; | ||
* @param {?} zone | ||
* @param {?} injector | ||
* @param {?} globalConfig | ||
*/ | ||
constructor(renderer, zone, globalConfig) { | ||
super(renderer, zone, globalConfig); | ||
constructor(renderer, zone, injector, globalConfig) { | ||
super(renderer, zone, injector, globalConfig); | ||
this.renderer = renderer; | ||
this.zone = zone; | ||
this.injector = injector; | ||
this.globalConfig = globalConfig; | ||
@@ -535,3 +591,10 @@ /** | ||
<div #captchaScriptElem></div> | ||
<div #captchaWrapperElem></div>` | ||
<div #captchaWrapperElem></div>`, | ||
providers: [ | ||
{ | ||
provide: NG_VALUE_ACCESSOR, | ||
useExisting: forwardRef(() => InvisibleReCaptchaComponent), | ||
multi: true, | ||
} | ||
] | ||
},] }, | ||
@@ -543,2 +606,3 @@ ]; | ||
{ type: NgZone }, | ||
{ type: Injector }, | ||
{ type: NgxCaptchaConfig, decorators: [{ type: Optional }] } | ||
@@ -605,2 +669,2 @@ ]; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-captcha.js.map","sources":["ng://ngx-captcha/lib/base-recaptcha.component.ts","ng://ngx-captcha/lib/recaptcha.config.ts","ng://ngx-captcha/lib/recaptcha-2.component.ts","ng://ngx-captcha/lib/invisible-recaptcha.component.ts","ng://ngx-captcha/lib/ngx-captcha.module.ts"],"sourcesContent":["import {\r\n    ElementRef,\r\n    EventEmitter,\r\n    Input,\r\n    NgZone,\r\n    OnChanges,\r\n    OnDestroy,\r\n    Output,\r\n    Renderer2,\r\n    SimpleChanges,\r\n    ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { ReCaptchaType } from './recaptcha-type.enum';\r\nimport { NgxCaptchaConfig } from './recaptcha.config';\r\n\r\ndeclare var grecaptcha: any;\r\n\r\nexport abstract class BaseReCaptchaComponent implements OnChanges, OnDestroy {\r\n\r\n    private setupAfterLoad = false;\r\n\r\n    /**\r\n    * Name of the global callback\r\n    */\r\n    protected readonly windowOnLoadCallbackProperty = 'ngx_onload_callback_' + this.getPseudoUniqueNumber();\r\n\r\n    /**\r\n     * Name of the global reCaptcha property\r\n     */\r\n    protected readonly globalReCaptchaProperty = 'grecaptcha';\r\n\r\n    /**\r\n     * Prefix of the captcha element\r\n     */\r\n    protected readonly captchaElemPrefix = 'ngx_captcha_id_';\r\n\r\n    /**\r\n      * Google's site key.\r\n      * You can find this under https://www.google.com/recaptcha\r\n      */\r\n    protected _siteKey?: string;\r\n\r\n    /**\r\n    * Config to use\r\n    */\r\n    @Input() siteKey: string | (() => string);\r\n\r\n    /**\r\n     * Type\r\n     */\r\n    @Input() type: 'audio' | 'image' = 'image';\r\n\r\n    /**\r\n     * Language code. Auto-detects the user's language if unspecified.\r\n     */\r\n    @Input() hl: string;\r\n\r\n    /**\r\n    * Tab index\r\n    */\r\n    @Input() tabIndex = 0;\r\n\r\n    /**\r\n     * Called when captcha receives successful response.\r\n     * Captcha response token is passed to event.\r\n     */\r\n    @Output() success = new EventEmitter<string>();\r\n\r\n    /**\r\n    * Called when captcha is loaded. Event receives id of the captcha\r\n    */\r\n    @Output() load = new EventEmitter<number>();\r\n\r\n    /**\r\n    * Called when captcha is loaded & ready. I.e. when you need to execute captcha on component load.\r\n    */\r\n    @Output() ready = new EventEmitter<void>();\r\n\r\n    @ViewChild('captchaWrapperElem') captchaWrapperElem: ElementRef;\r\n    @ViewChild('captchaScriptElem') captchaScriptElem: ElementRef;\r\n\r\n    /**\r\n     * Captcha element\r\n     */\r\n    protected captchaElem?: HTMLElement;\r\n\r\n    /**\r\n     * Id of the captcha elem\r\n     */\r\n    protected captchaId?: number;\r\n\r\n    /**\r\n     * Holds last response value\r\n     */\r\n    protected currentResponse?: string;\r\n\r\n    /**\r\n     * If enabled, captcha will reset after receiving success response. This is useful\r\n     * when invisible captcha need to be resolved multiple times on same page\r\n     */\r\n    protected resetCaptchaAfterSuccess = false;\r\n\r\n    /**\r\n     * Indicates if captcha is loaded\r\n     */\r\n    public isLoaded = false;\r\n\r\n    /**\r\n    * Reference to global reCaptcha API\r\n    */\r\n    public reCaptchaApi?: any;\r\n\r\n    /**\r\n     * Id of the DOM element wrapping captcha\r\n     */\r\n    public captchaElemId?: string;\r\n\r\n    /**\r\n     * Captcha type\r\n     */\r\n    protected abstract recaptchaType: ReCaptchaType;\r\n\r\n    constructor(\r\n        protected renderer: Renderer2,\r\n        protected zone: NgZone,\r\n        protected globalConfig?: NgxCaptchaConfig,\r\n    ) {\r\n    }\r\n\r\n    /**\r\n    * Gets reCaptcha properties\r\n    */\r\n    protected abstract getCaptchaProperties(): any;\r\n\r\n    /**\r\n     * Used for captcha specific setup\r\n    */\r\n    protected abstract captchaSpecificSetup(): void;\r\n\r\n    private getGlobalSiteKey(): string {\r\n        if (this.globalConfig) {\r\n            // Invisible captcha\r\n            if (this.recaptchaType === ReCaptchaType.InvisibleReCaptcha) {\r\n                if (!this.globalConfig.invisibleCaptchaSiteKey) {\r\n                    throw Error(`SiteKey for invisible reCaptcha is not set!`);\r\n                }\r\n\r\n                if (this.globalConfig.invisibleCaptchaSiteKey instanceof Function) {\r\n                    return this.globalConfig.invisibleCaptchaSiteKey();\r\n                } else {\r\n                    return this.globalConfig.invisibleCaptchaSiteKey;\r\n                }\r\n\r\n                // recaptcha 2\r\n            } else if (this.recaptchaType === ReCaptchaType.ReCaptcha2) {\r\n                if (!this.globalConfig.reCaptcha2SiteKey) {\r\n                    throw Error(`SiteKey for reCaptcha2 is not set!`);\r\n                }\r\n\r\n                if (this.globalConfig.reCaptcha2SiteKey instanceof Function) {\r\n                    return this.globalConfig.reCaptcha2SiteKey();\r\n                } else {\r\n                    return this.globalConfig.reCaptcha2SiteKey;\r\n                }\r\n\r\n            } else {\r\n                throw Error(`Unsupported captcha type '${this.recaptchaType}'!`);\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if (!this.siteKey) {\r\n            // use global site key if key is not available\r\n            this._siteKey = this.getGlobalSiteKey();\r\n        } else {\r\n            // use comnponent site key\r\n            if (this.siteKey instanceof Function) {\r\n                this._siteKey = this.siteKey();\r\n            } else {\r\n                this._siteKey = this.siteKey;\r\n            }\r\n        }\r\n        this.setupComponent();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        window[this.windowOnLoadCallbackProperty] = {};\r\n        window[this.globalReCaptchaProperty] = {};\r\n    }\r\n\r\n    /**\r\n     * Gets captcha response as per reCaptcha docs\r\n    */\r\n    getResponse(): string {\r\n        return this.reCaptchaApi.getResponse(this.captchaId);\r\n    }\r\n\r\n    /**\r\n     * Gets Id of captcha widget\r\n    */\r\n    getCaptchaId(): number {\r\n        return this.captchaId;\r\n    }\r\n\r\n    /**\r\n    * Resets captcha\r\n    */\r\n    resetCaptcha(): void {\r\n        this.reCaptchaApi.reset(this.captchaId);\r\n    }\r\n\r\n    /**\r\n     * Gets last submitted captcha response\r\n    */\r\n    getCurrentResponse(): string | undefined {\r\n        return this.currentResponse;\r\n    }\r\n\r\n    /**\r\n     * Reload captcha. Useful when properties (i.e. theme) changed and captcha need to reflect them\r\n    */\r\n    reloadCaptcha(): void {\r\n        this.setupComponent();\r\n    }\r\n\r\n    protected ensureCaptchaElem(captchaElemId: string): void {\r\n        const captchaElem = document.getElementById(captchaElemId);\r\n\r\n        if (!captchaElem) {\r\n            throw Error(`Captcha element with id '${captchaElemId}' was not found`);\r\n        }\r\n\r\n        // assign captcha alem\r\n        this.captchaElem = captchaElem;\r\n    }\r\n\r\n    /**\r\n     * Responsible for instantiating captcha element\r\n    */\r\n    protected renderReCaptcha(): void {\r\n        this.captchaId = this.reCaptchaApi.render(this.captchaElemId, this.getCaptchaProperties());\r\n        this.ready.next();\r\n    }\r\n\r\n    /**\r\n     * Called when captcha receives response\r\n     * @param callback Callback\r\n     */\r\n    protected handleCallback(callback: any): void {\r\n        this.currentResponse = callback;\r\n        this.success.next(callback);\r\n\r\n        if (this.resetCaptchaAfterSuccess) {\r\n            this.resetCaptcha();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Registers reCaptcha script if its not available\r\n    */\r\n    protected ensureReCaptchaScript(): void {\r\n        window[this.globalReCaptchaProperty] = {};\r\n        this.reCaptchaApi = {};\r\n\r\n        this.registerReCaptchaScript();\r\n    }\r\n\r\n    /**\r\n     * Add script to page with reference to captcha API. This has to be done manually\r\n     * as we want to avoid adding script to main index.html\r\n    */\r\n    protected registerReCaptchaScript(): void {\r\n        const script = document.createElement('script');\r\n        script.innerHTML = '';\r\n        script.src =\r\n            `https://www.google.com/recaptcha/api.js?onload=${this.windowOnLoadCallbackProperty}&render=explicit${this.getLanguageParam()}`;\r\n        script.async = true;\r\n        script.defer = true;\r\n\r\n        this.captchaScriptElem.nativeElement.appendChild(script);\r\n    }\r\n\r\n    protected getLanguageParam(): string {\r\n        if (!this.hl) {\r\n            return '';\r\n        }\r\n\r\n        return `&hl=${this.hl}`;\r\n    }\r\n\r\n    private getPseudoUniqueNumber(): number {\r\n        return new Date().getUTCMilliseconds() + Math.floor(Math.random() * 9999);\r\n    }\r\n\r\n    /**\r\n     * Checks if reCaptcha Api is defined. It may happen that when navigating from angular component to another\r\n     * via router, the Api was already loaded previously. In such cases, do not render script again.\r\n    */\r\n    private isReCaptchaApiDefined(): boolean {\r\n        if (!window[this.globalReCaptchaProperty]) {\r\n            return false;\r\n        }\r\n        return true;\r\n    }\r\n\r\n    private setupComponent(): void {\r\n        // captcha specific setup\r\n        this.captchaSpecificSetup();\r\n\r\n        // create captcha wrapper\r\n        this.createAndSetCaptchaElem();\r\n\r\n        // we need to patch the callback through global variable, otherwise callback is not accessible\r\n        // note: https://github.com/Enngage/ngx-captcha/issues/2\r\n        window[this.windowOnLoadCallbackProperty] = <any>(() => this.zone.run(\r\n            this.onloadCallback.bind(this)\r\n        ));\r\n\r\n        // create and put reCaptcha script to page\r\n        this.ensureReCaptchaScript();\r\n    }\r\n\r\n    /**\r\n    * Called when google's recaptcha script is ready\r\n    */\r\n    private onloadCallback(): void {\r\n        // assign reference to reCaptcha Api once its loaded\r\n        this.reCaptchaApi = grecaptcha;\r\n\r\n        if (!this.reCaptchaApi) {\r\n            throw Error(`ReCaptcha Api was not initialized correctly`);\r\n        }\r\n\r\n        // loaded flag\r\n        this.isLoaded = true;\r\n\r\n        // fire load event\r\n        this.load.next();\r\n\r\n        // render captcha\r\n        this.renderReCaptcha();\r\n\r\n        // setup component if it was flagges as such\r\n        if (this.setupAfterLoad) {\r\n            this.setupAfterLoad = false;\r\n            this.setupComponent();\r\n        }\r\n    }\r\n\r\n    private generateNewElemId(): string {\r\n        return this.captchaElemPrefix + this.getPseudoUniqueNumber();\r\n    }\r\n\r\n    private createAndSetCaptchaElem(): void {\r\n        // generate new captcha id\r\n        this.captchaElemId = this.generateNewElemId();\r\n\r\n        if (!this.captchaElemId) {\r\n            throw Error(`Captcha elem Id is not set`);\r\n        }\r\n\r\n        // remove old html\r\n        this.captchaWrapperElem.nativeElement.innerHTML = '';\r\n\r\n        // create new wrapper for captcha\r\n        const newElem = this.renderer.createElement('div');\r\n        newElem.id = this.captchaElemId;\r\n\r\n        this.renderer.appendChild(this.captchaWrapperElem.nativeElement, newElem);\r\n\r\n        // update captcha elem\r\n        this.ensureCaptchaElem(this.captchaElemId);\r\n    }\r\n\r\n}\r\n\r\n","export interface INgxCaptchaConfig {\r\n    reCaptcha2SiteKey?: string | (() => string);\r\n    invisibleCaptchaSiteKey?: string | (() => string);\r\n}\r\n\r\nexport class NgxCaptchaConfig implements INgxCaptchaConfig {\r\n\r\n    public reCaptcha2SiteKey?: string | (() => string);\r\n    public invisibleCaptchaSiteKey?: string | (() => string);\r\n}\r\n","import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Optional,\r\n  Output,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  NgZone,\r\n} from '@angular/core';\r\n\r\nimport { BaseReCaptchaComponent } from './base-recaptcha.component';\r\nimport { ReCaptchaType } from './recaptcha-type.enum';\r\nimport { NgxCaptchaConfig } from './recaptcha.config';\r\n\r\n@Component({\r\n  selector: 'ngx-recaptcha2',\r\n  template: `\r\n  <div #captchaScriptElem></div>\r\n  <div #captchaWrapperElem></div>`\r\n})\r\nexport class ReCaptcha2Component extends BaseReCaptchaComponent implements OnChanges, OnDestroy {\r\n\r\n  /**\r\n  * Name of the global expire callback\r\n  */\r\n  protected readonly windowOnErrorCallbackProperty = 'ngx_captcha_error_callback';\r\n\r\n  /**\r\n  * Name of the global error callback\r\n  */\r\n  protected readonly windowOnExpireCallbackProperty = 'ngx_captcha_expire_callback';\r\n\r\n  /**\r\n   * Theme\r\n   */\r\n  @Input() theme: 'dark' | 'light' = 'light';\r\n\r\n  /**\r\n  * Size\r\n  */\r\n  @Input() size: 'compact' | 'normal' = 'normal';\r\n\r\n  /**\r\n   * Language code. Auto-detects the user's language if unspecified.\r\n   */\r\n  @Input() hl: string;\r\n\r\n  /**\r\n  * Expired callback\r\n  */\r\n  @Output() expire = new EventEmitter<void>();\r\n\r\n  /**\r\n  * Error callback\r\n  */\r\n  @Output() error = new EventEmitter<void>();\r\n\r\n  protected recaptchaType: ReCaptchaType = ReCaptchaType.ReCaptcha2;\r\n\r\n  constructor(\r\n    protected renderer: Renderer2,\r\n    protected zone: NgZone,\r\n    @Optional() protected globalConfig: NgxCaptchaConfig,\r\n  ) {\r\n    super(renderer, zone, globalConfig);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    super.ngOnChanges(changes);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    super.ngOnDestroy();\r\n\r\n    window[this.windowOnErrorCallbackProperty] = {};\r\n    window[this.windowOnExpireCallbackProperty] = {};\r\n  }\r\n\r\n  protected captchaSpecificSetup(): void {\r\n    this.registerCallbacks();\r\n  }\r\n\r\n  /**\r\n   * Gets reCaptcha properties\r\n  */\r\n  protected getCaptchaProperties(): any {\r\n    return {\r\n      'sitekey': this._siteKey,\r\n      'callback': (response) => this.zone.run(() => this.handleCallback(response)),\r\n      'expired-callback': () => this.zone.run(() => this.handleExpireCallback()),\r\n      'error-callback': () => this.zone.run(() => this.handleErrorCallback()),\r\n      'theme': this.theme,\r\n      'type': this.type,\r\n      'size': this.size,\r\n      'tabindex': this.tabIndex\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Registers global callbacks\r\n  */\r\n  private registerCallbacks(): void {\r\n    window[this.windowOnErrorCallbackProperty] = this.handleErrorCallback.bind(this);\r\n    window[this.windowOnExpireCallbackProperty] = this.handleExpireCallback.bind(this);\r\n  }\r\n\r\n  /**\r\n   * Handles error callback\r\n  */\r\n  private handleErrorCallback(): void {\r\n    this.error.next();\r\n  }\r\n\r\n  /**\r\n   * Handles expired callback\r\n   */\r\n  private handleExpireCallback(): void {\r\n    this.expire.next();\r\n\r\n    // reset captcha on expire callback\r\n    this.resetCaptcha();\r\n  }\r\n}\r\n\r\n","import { Component, Input, OnChanges, Optional, Renderer2, SimpleChanges, NgZone } from '@angular/core';\r\n\r\nimport { BaseReCaptchaComponent } from './base-recaptcha.component';\r\nimport { ReCaptchaType } from './recaptcha-type.enum';\r\nimport { NgxCaptchaConfig } from './recaptcha.config';\r\n\r\n\r\n@Component({\r\n  selector: 'ngx-invisible-recaptcha',\r\n  template: `\r\n  <div #captchaScriptElem></div>\r\n  <div #captchaWrapperElem></div>`\r\n})\r\nexport class InvisibleReCaptchaComponent extends BaseReCaptchaComponent implements OnChanges {\r\n\r\n  /**\r\n   * This size representing invisible captcha\r\n   */\r\n  protected readonly size = 'invisible';\r\n\r\n  /**\r\n   * Badge\r\n   */\r\n  @Input() badge: 'bottomright' | 'bottomleft' | 'inline' = 'bottomright';\r\n\r\n  /**\r\n   * Language code. Auto-detects the user's language if unspecified.\r\n   */\r\n  @Input() hl: string;\r\n\r\n  protected recaptchaType: ReCaptchaType = ReCaptchaType.InvisibleReCaptcha;\r\n\r\n  constructor(\r\n    protected renderer: Renderer2,\r\n    protected zone: NgZone,\r\n    @Optional() protected globalConfig: NgxCaptchaConfig,\r\n  ) {\r\n    super(renderer, zone, globalConfig);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    super.ngOnChanges(changes);\r\n  }\r\n\r\n  /**\r\n   * Programatically invoke the reCAPTCHA check. Used if the invisible reCAPTCHA is on a div instead of a button.\r\n   */\r\n  execute(): void {\r\n    // execute captcha\r\n    this.reCaptchaApi.execute(this.captchaId);\r\n  }\r\n\r\n  protected captchaSpecificSetup(): void {\r\n  }\r\n\r\n  /**\r\n  * Gets reCaptcha properties\r\n  */\r\n  protected getCaptchaProperties(): any {\r\n    return {\r\n      'sitekey': this._siteKey,\r\n      'callback': (response) => this.zone.run(() => this.handleCallback(response)),\r\n      'badge': this.badge,\r\n      'type': this.type,\r\n      'tabindex': this.tabIndex,\r\n      'size': this.size\r\n    };\r\n  }\r\n}\r\n\r\n","import { CommonModule } from '@angular/common';\nimport { ModuleWithProviders, NgModule } from '@angular/core';\n\nimport { InvisibleReCaptchaComponent } from './invisible-recaptcha.component';\nimport { ReCaptcha2Component } from './recaptcha-2.component';\nimport { NgxCaptchaConfig } from './recaptcha.config';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [\n    ReCaptcha2Component,\n    InvisibleReCaptchaComponent\n  ],\n  exports: [\n    ReCaptcha2Component,\n    InvisibleReCaptchaComponent\n  ]\n})\nexport class NgxCaptchaModule {\n\n  static forRoot(config?: NgxCaptchaConfig): ModuleWithProviders {\n    return {\n      ngModule: NgxCaptchaModule,\n      providers: [\n        {\n          provide: NgxCaptchaConfig,\n          useValue: config,\n        }\n      ]\n    };\n  }\n}\n\n\n"],"names":[],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-captcha.js.map","sources":["ng://ngx-captcha/lib/base-recaptcha.component.ts","ng://ngx-captcha/lib/recaptcha.config.ts","ng://ngx-captcha/lib/recaptcha-2.component.ts","ng://ngx-captcha/lib/invisible-recaptcha.component.ts","ng://ngx-captcha/lib/ngx-captcha.module.ts"],"sourcesContent":["import {\r\n  AfterViewInit,\r\n  ElementRef,\r\n  EventEmitter, Injector,\r\n  Input,\r\n  NgZone,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Output,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { ReCaptchaType } from './recaptcha-type.enum';\r\nimport { NgxCaptchaConfig } from './recaptcha.config';\r\nimport { ControlValueAccessor, FormControl, NgControl } from '@angular/forms';\r\n\r\ndeclare var grecaptcha: any;\r\n\r\nexport abstract class BaseReCaptchaComponent implements OnChanges, OnDestroy, ControlValueAccessor, AfterViewInit {\r\n    /**\r\n     * Form Control to be enable usage in reactive forms\r\n     */\r\n    private control: FormControl;\r\n\r\n    private setupAfterLoad = false;\r\n\r\n    /**\r\n    * Name of the global callback\r\n    */\r\n    protected readonly windowOnLoadCallbackProperty = 'ngx_onload_callback_' + this.getPseudoUniqueNumber();\r\n\r\n    /**\r\n     * Name of the global reCaptcha property\r\n     */\r\n    protected readonly globalReCaptchaProperty = 'grecaptcha';\r\n\r\n    /**\r\n     * Prefix of the captcha element\r\n     */\r\n    protected readonly captchaElemPrefix = 'ngx_captcha_id_';\r\n\r\n    /**\r\n      * Google's site key.\r\n      * You can find this under https://www.google.com/recaptcha\r\n      */\r\n    protected _siteKey?: string;\r\n\r\n    /**\r\n    * Config to use\r\n    */\r\n    @Input() siteKey: string | (() => string);\r\n\r\n    /**\r\n     * Type\r\n     */\r\n    @Input() type: 'audio' | 'image' = 'image';\r\n\r\n    /**\r\n     * Language code. Auto-detects the user's language if unspecified.\r\n     */\r\n    @Input() hl: string;\r\n\r\n    /**\r\n    * Tab index\r\n    */\r\n    @Input() tabIndex = 0;\r\n\r\n    /**\r\n     * Called when captcha receives successful response.\r\n     * Captcha response token is passed to event.\r\n     */\r\n    @Output() success = new EventEmitter<string>();\r\n\r\n    /**\r\n    * Called when captcha is loaded. Event receives id of the captcha\r\n    */\r\n    @Output() load = new EventEmitter<number>();\r\n\r\n    /**\r\n    * Called when captcha is loaded & ready. I.e. when you need to execute captcha on component load.\r\n    */\r\n    @Output() ready = new EventEmitter<void>();\r\n\r\n    @ViewChild('captchaWrapperElem') captchaWrapperElem: ElementRef;\r\n    @ViewChild('captchaScriptElem') captchaScriptElem: ElementRef;\r\n\r\n    /**\r\n     * Captcha element\r\n     */\r\n    protected captchaElem?: HTMLElement;\r\n\r\n    /**\r\n     * Id of the captcha elem\r\n     */\r\n    protected captchaId?: number;\r\n\r\n    /**\r\n     * Holds last response value\r\n     */\r\n    protected currentResponse?: string;\r\n\r\n    /**\r\n     * If enabled, captcha will reset after receiving success response. This is useful\r\n     * when invisible captcha need to be resolved multiple times on same page\r\n     */\r\n    protected resetCaptchaAfterSuccess = false;\r\n\r\n    /**\r\n     * Indicates if captcha is loaded\r\n     */\r\n    public isLoaded = false;\r\n\r\n    /**\r\n    * Reference to global reCaptcha API\r\n    */\r\n    public reCaptchaApi?: any;\r\n\r\n    /**\r\n     * Id of the DOM element wrapping captcha\r\n     */\r\n    public captchaElemId?: string;\r\n\r\n    /**\r\n     * Captcha type\r\n     */\r\n    protected abstract recaptchaType: ReCaptchaType;\r\n\r\n  /**\r\n   * Required by ControlValueAccessor\r\n   */\r\n    protected onChange: (value: string ) => void;\r\n    protected onTouched: (value: string ) => void;\r\n\r\n    protected constructor(\r\n        protected renderer: Renderer2,\r\n        protected zone: NgZone,\r\n        protected injector: Injector,\r\n        protected globalConfig?: NgxCaptchaConfig,\r\n    ) {}\r\n\r\n    ngAfterViewInit() {\r\n      this.control = this.injector.get(NgControl).control;\r\n    }\r\n\r\n    /**\r\n    * Gets reCaptcha properties\r\n    */\r\n    protected abstract getCaptchaProperties(): any;\r\n\r\n    /**\r\n     * Used for captcha specific setup\r\n    */\r\n    protected abstract captchaSpecificSetup(): void;\r\n\r\n    private getGlobalSiteKey(): string {\r\n        if (this.globalConfig) {\r\n            // Invisible captcha\r\n            if (this.recaptchaType === ReCaptchaType.InvisibleReCaptcha) {\r\n                if (!this.globalConfig.invisibleCaptchaSiteKey) {\r\n                    throw Error(`SiteKey for invisible reCaptcha is not set!`);\r\n                }\r\n\r\n                if (this.globalConfig.invisibleCaptchaSiteKey instanceof Function) {\r\n                    return this.globalConfig.invisibleCaptchaSiteKey();\r\n                } else {\r\n                    return this.globalConfig.invisibleCaptchaSiteKey;\r\n                }\r\n\r\n                // recaptcha 2\r\n            } else if (this.recaptchaType === ReCaptchaType.ReCaptcha2) {\r\n                if (!this.globalConfig.reCaptcha2SiteKey) {\r\n                    throw Error(`SiteKey for reCaptcha2 is not set!`);\r\n                }\r\n\r\n                if (this.globalConfig.reCaptcha2SiteKey instanceof Function) {\r\n                    return this.globalConfig.reCaptcha2SiteKey();\r\n                } else {\r\n                    return this.globalConfig.reCaptcha2SiteKey;\r\n                }\r\n\r\n            } else {\r\n                throw Error(`Unsupported captcha type '${this.recaptchaType}'!`);\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if (!this.siteKey) {\r\n            // use global site key if key is not available\r\n            this._siteKey = this.getGlobalSiteKey();\r\n        } else {\r\n            // use comnponent site key\r\n            if (this.siteKey instanceof Function) {\r\n                this._siteKey = this.siteKey();\r\n            } else {\r\n                this._siteKey = this.siteKey;\r\n            }\r\n        }\r\n        this.setupComponent();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        window[this.windowOnLoadCallbackProperty] = {};\r\n        window[this.globalReCaptchaProperty] = {};\r\n    }\r\n\r\n    /**\r\n     * Gets captcha response as per reCaptcha docs\r\n    */\r\n    getResponse(): string {\r\n        return this.reCaptchaApi.getResponse(this.captchaId);\r\n    }\r\n\r\n    /**\r\n     * Gets Id of captcha widget\r\n    */\r\n    getCaptchaId(): number {\r\n        return this.captchaId;\r\n    }\r\n\r\n    /**\r\n    * Resets captcha\r\n    */\r\n    resetCaptcha(): void {\r\n      this.zone.run(() => {\r\n        this.onChange(null);\r\n        this.onTouched(null);\r\n      });\r\n\r\n      this.reCaptchaApi.reset(this.captchaId);\r\n    }\r\n\r\n    /**\r\n     * Gets last submitted captcha response\r\n    */\r\n    getCurrentResponse(): string | undefined {\r\n        return this.currentResponse;\r\n    }\r\n\r\n    /**\r\n     * Reload captcha. Useful when properties (i.e. theme) changed and captcha need to reflect them\r\n    */\r\n    reloadCaptcha(): void {\r\n        this.setupComponent();\r\n    }\r\n\r\n    protected ensureCaptchaElem(captchaElemId: string): void {\r\n        const captchaElem = document.getElementById(captchaElemId);\r\n\r\n        if (!captchaElem) {\r\n            throw Error(`Captcha element with id '${captchaElemId}' was not found`);\r\n        }\r\n\r\n        // assign captcha alem\r\n        this.captchaElem = captchaElem;\r\n    }\r\n\r\n    /**\r\n     * Responsible for instantiating captcha element\r\n    */\r\n    protected renderReCaptcha(): void {\r\n        this.captchaId = this.reCaptchaApi.render(this.captchaElemId, this.getCaptchaProperties());\r\n        this.ready.next();\r\n    }\r\n\r\n    /**\r\n     * Called when captcha receives response\r\n     * @param callback Callback\r\n     */\r\n    protected handleCallback(callback: any): void {\r\n        this.currentResponse = callback;\r\n        this.success.next(callback);\r\n\r\n        this.zone.run(() => {\r\n          this.onChange(callback);\r\n          this.onTouched(callback);\r\n        });\r\n\r\n        if (this.resetCaptchaAfterSuccess) {\r\n            this.resetCaptcha();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Registers reCaptcha script if its not available\r\n    */\r\n    protected ensureReCaptchaScript(): void {\r\n        window[this.globalReCaptchaProperty] = {};\r\n        this.reCaptchaApi = {};\r\n\r\n        this.registerReCaptchaScript();\r\n    }\r\n\r\n    /**\r\n     * Add script to page with reference to captcha API. This has to be done manually\r\n     * as we want to avoid adding script to main index.html\r\n    */\r\n    protected registerReCaptchaScript(): void {\r\n        const script = document.createElement('script');\r\n        script.innerHTML = '';\r\n        script.src =\r\n            `https://www.google.com/recaptcha/api.js?onload=${this.windowOnLoadCallbackProperty}&render=explicit${this.getLanguageParam()}`;\r\n        script.async = true;\r\n        script.defer = true;\r\n\r\n        this.captchaScriptElem.nativeElement.appendChild(script);\r\n    }\r\n\r\n    protected getLanguageParam(): string {\r\n        if (!this.hl) {\r\n            return '';\r\n        }\r\n\r\n        return `&hl=${this.hl}`;\r\n    }\r\n\r\n    private getPseudoUniqueNumber(): number {\r\n        return new Date().getUTCMilliseconds() + Math.floor(Math.random() * 9999);\r\n    }\r\n\r\n    /**\r\n     * Checks if reCaptcha Api is defined. It may happen that when navigating from angular component to another\r\n     * via router, the Api was already loaded previously. In such cases, do not render script again.\r\n    */\r\n    private isReCaptchaApiDefined(): boolean {\r\n        if (!window[this.globalReCaptchaProperty]) {\r\n            return false;\r\n        }\r\n        return true;\r\n    }\r\n\r\n    private setupComponent(): void {\r\n        // captcha specific setup\r\n        this.captchaSpecificSetup();\r\n\r\n        // create captcha wrapper\r\n        this.createAndSetCaptchaElem();\r\n\r\n        // we need to patch the callback through global variable, otherwise callback is not accessible\r\n        // note: https://github.com/Enngage/ngx-captcha/issues/2\r\n        window[this.windowOnLoadCallbackProperty] = <any>(() => this.zone.run(\r\n            this.onloadCallback.bind(this)\r\n        ));\r\n\r\n        // create and put reCaptcha script to page\r\n        this.ensureReCaptchaScript();\r\n    }\r\n\r\n    /**\r\n    * Called when google's recaptcha script is ready\r\n    */\r\n    private onloadCallback(): void {\r\n        // assign reference to reCaptcha Api once its loaded\r\n        this.reCaptchaApi = grecaptcha;\r\n\r\n        if (!this.reCaptchaApi) {\r\n            throw Error(`ReCaptcha Api was not initialized correctly`);\r\n        }\r\n\r\n        // loaded flag\r\n        this.isLoaded = true;\r\n\r\n        // fire load event\r\n        this.load.next();\r\n\r\n        // render captcha\r\n        this.renderReCaptcha();\r\n\r\n        // setup component if it was flagged as such\r\n        if (this.setupAfterLoad) {\r\n            this.setupAfterLoad = false;\r\n            this.setupComponent();\r\n        }\r\n    }\r\n\r\n    private generateNewElemId(): string {\r\n        return this.captchaElemPrefix + this.getPseudoUniqueNumber();\r\n    }\r\n\r\n    private createAndSetCaptchaElem(): void {\r\n        // generate new captcha id\r\n        this.captchaElemId = this.generateNewElemId();\r\n\r\n        if (!this.captchaElemId) {\r\n            throw Error(`Captcha elem Id is not set`);\r\n        }\r\n\r\n        // remove old html\r\n        this.captchaWrapperElem.nativeElement.innerHTML = '';\r\n\r\n        // create new wrapper for captcha\r\n        const newElem = this.renderer.createElement('div');\r\n        newElem.id = this.captchaElemId;\r\n\r\n        this.renderer.appendChild(this.captchaWrapperElem.nativeElement, newElem);\r\n\r\n        // update captcha elem\r\n        this.ensureCaptchaElem(this.captchaElemId);\r\n    }\r\n\r\n    /**\r\n     * To be aligned with the ControlValueAccessor interface we need to implement this method\r\n     * However as we don't want to update the recaptcha, this doesn't need to be implemented\r\n     */\r\n    public writeValue(obj: any): void {}\r\n\r\n    /**\r\n     * This method helps us tie together recaptcha and our formControl values\r\n     */\r\n    public registerOnChange(fn: any): void {\r\n      this.onChange = fn;\r\n    }\r\n\r\n    /**\r\n    * At some point we might be interested whether the user has touched our component\r\n    */\r\n    public registerOnTouched(fn: any): void {\r\n      this.onTouched = fn;\r\n    }\r\n}\r\n\r\n","export interface INgxCaptchaConfig {\r\n    reCaptcha2SiteKey?: string | (() => string);\r\n    invisibleCaptchaSiteKey?: string | (() => string);\r\n}\r\n\r\nexport class NgxCaptchaConfig implements INgxCaptchaConfig {\r\n\r\n    public reCaptcha2SiteKey?: string | (() => string);\r\n    public invisibleCaptchaSiteKey?: string | (() => string);\r\n}\r\n","import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Optional,\r\n  Output,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  NgZone, Injector, forwardRef,\r\n} from '@angular/core';\r\n\r\nimport { BaseReCaptchaComponent } from './base-recaptcha.component';\r\nimport { ReCaptchaType } from './recaptcha-type.enum';\r\nimport { NgxCaptchaConfig } from './recaptcha.config';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'ngx-recaptcha2',\r\n  template: `\r\n  <div #captchaScriptElem></div>\r\n  <div #captchaWrapperElem></div>`,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ReCaptcha2Component),\r\n      multi: true,\r\n    }\r\n  ]\r\n})\r\nexport class ReCaptcha2Component extends BaseReCaptchaComponent implements OnChanges, OnDestroy {\r\n\r\n  /**\r\n  * Name of the global expire callback\r\n  */\r\n  protected readonly windowOnErrorCallbackProperty = 'ngx_captcha_error_callback';\r\n\r\n  /**\r\n  * Name of the global error callback\r\n  */\r\n  protected readonly windowOnExpireCallbackProperty = 'ngx_captcha_expire_callback';\r\n\r\n  /**\r\n   * Theme\r\n   */\r\n  @Input() theme: 'dark' | 'light' = 'light';\r\n\r\n  /**\r\n  * Size\r\n  */\r\n  @Input() size: 'compact' | 'normal' = 'normal';\r\n\r\n  /**\r\n   * Language code. Auto-detects the user's language if unspecified.\r\n   */\r\n  @Input() hl: string;\r\n\r\n  /**\r\n  * Expired callback\r\n  */\r\n  @Output() expire = new EventEmitter<void>();\r\n\r\n  /**\r\n  * Error callback\r\n  */\r\n  @Output() error = new EventEmitter<void>();\r\n\r\n  protected recaptchaType: ReCaptchaType = ReCaptchaType.ReCaptcha2;\r\n\r\n  constructor(\r\n    protected renderer: Renderer2,\r\n    protected zone: NgZone,\r\n    protected injector: Injector,\r\n    @Optional() protected globalConfig: NgxCaptchaConfig,\r\n  ) {\r\n    super(renderer, zone, injector, globalConfig);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    super.ngOnChanges(changes);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    super.ngOnDestroy();\r\n\r\n    window[this.windowOnErrorCallbackProperty] = {};\r\n    window[this.windowOnExpireCallbackProperty] = {};\r\n  }\r\n\r\n  protected captchaSpecificSetup(): void {\r\n    this.registerCallbacks();\r\n  }\r\n\r\n  /**\r\n   * Gets reCaptcha properties\r\n  */\r\n  protected getCaptchaProperties(): any {\r\n    return {\r\n      'sitekey': this._siteKey,\r\n      'callback': (response) => this.zone.run(() => this.handleCallback(response)),\r\n      'expired-callback': () => this.zone.run(() => this.handleExpireCallback()),\r\n      'error-callback': () => this.zone.run(() => this.handleErrorCallback()),\r\n      'theme': this.theme,\r\n      'type': this.type,\r\n      'size': this.size,\r\n      'tabindex': this.tabIndex\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Registers global callbacks\r\n  */\r\n  private registerCallbacks(): void {\r\n    window[this.windowOnErrorCallbackProperty] = this.handleErrorCallback.bind(this);\r\n    window[this.windowOnExpireCallbackProperty] = this.handleExpireCallback.bind(this);\r\n  }\r\n\r\n  /**\r\n   * Handles error callback\r\n  */\r\n  private handleErrorCallback(): void {\r\n    this.zone.run(() => {\r\n      this.onChange(null);\r\n      this.onTouched(null);\r\n    });\r\n\r\n    this.error.next();\r\n  }\r\n\r\n  /**\r\n   * Handles expired callback\r\n   */\r\n  private handleExpireCallback(): void {\r\n    this.expire.next();\r\n\r\n    // reset captcha on expire callback\r\n    this.resetCaptcha();\r\n  }\r\n}\r\n\r\n","import { Component, Input, OnChanges, Optional, Renderer2, SimpleChanges, NgZone, Injector, forwardRef } from '@angular/core';\r\n\r\nimport { BaseReCaptchaComponent } from './base-recaptcha.component';\r\nimport { ReCaptchaType } from './recaptcha-type.enum';\r\nimport { NgxCaptchaConfig } from './recaptcha.config';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\n\r\n@Component({\r\n  selector: 'ngx-invisible-recaptcha',\r\n  template: `\r\n  <div #captchaScriptElem></div>\r\n  <div #captchaWrapperElem></div>`,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InvisibleReCaptchaComponent),\r\n      multi: true,\r\n    }\r\n  ]\r\n})\r\nexport class InvisibleReCaptchaComponent extends BaseReCaptchaComponent implements OnChanges {\r\n\r\n  /**\r\n   * This size representing invisible captcha\r\n   */\r\n  protected readonly size = 'invisible';\r\n\r\n  /**\r\n   * Badge\r\n   */\r\n  @Input() badge: 'bottomright' | 'bottomleft' | 'inline' = 'bottomright';\r\n\r\n  /**\r\n   * Language code. Auto-detects the user's language if unspecified.\r\n   */\r\n  @Input() hl: string;\r\n\r\n  protected recaptchaType: ReCaptchaType = ReCaptchaType.InvisibleReCaptcha;\r\n\r\n  constructor(\r\n    protected renderer: Renderer2,\r\n    protected zone: NgZone,\r\n    protected injector: Injector,\r\n    @Optional() protected globalConfig: NgxCaptchaConfig,\r\n  ) {\r\n    super(renderer, zone, injector, globalConfig);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    super.ngOnChanges(changes);\r\n  }\r\n\r\n  /**\r\n   * Programatically invoke the reCAPTCHA check. Used if the invisible reCAPTCHA is on a div instead of a button.\r\n   */\r\n  execute(): void {\r\n    // execute captcha\r\n    this.reCaptchaApi.execute(this.captchaId);\r\n  }\r\n\r\n  protected captchaSpecificSetup(): void {\r\n  }\r\n\r\n  /**\r\n  * Gets reCaptcha properties\r\n  */\r\n  protected getCaptchaProperties(): any {\r\n    return {\r\n      'sitekey': this._siteKey,\r\n      'callback': (response) => this.zone.run(() => this.handleCallback(response)),\r\n      'badge': this.badge,\r\n      'type': this.type,\r\n      'tabindex': this.tabIndex,\r\n      'size': this.size\r\n    };\r\n  }\r\n}\r\n\r\n","import { CommonModule } from '@angular/common';\nimport { ModuleWithProviders, NgModule } from '@angular/core';\n\nimport { InvisibleReCaptchaComponent } from './invisible-recaptcha.component';\nimport { ReCaptcha2Component } from './recaptcha-2.component';\nimport { NgxCaptchaConfig } from './recaptcha.config';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [\n    ReCaptcha2Component,\n    InvisibleReCaptchaComponent\n  ],\n  exports: [\n    ReCaptcha2Component,\n    InvisibleReCaptchaComponent\n  ]\n})\nexport class NgxCaptchaModule {\n\n  static forRoot(config?: NgxCaptchaConfig): ModuleWithProviders {\n    return {\n      ngModule: NgxCaptchaModule,\n      providers: [\n        {\n          provide: NgxCaptchaConfig,\n          useValue: config,\n        }\n      ]\n    };\n  }\n}\n\n\n"],"names":[],"mappings":"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"} |
@@ -1,8 +0,14 @@ | ||
import { ElementRef, EventEmitter, NgZone, OnChanges, OnDestroy, Renderer2, SimpleChanges } from '@angular/core'; | ||
import { AfterViewInit, ElementRef, EventEmitter, Injector, NgZone, OnChanges, OnDestroy, Renderer2, SimpleChanges } from '@angular/core'; | ||
import { ReCaptchaType } from './recaptcha-type.enum'; | ||
import { NgxCaptchaConfig } from './recaptcha.config'; | ||
export declare abstract class BaseReCaptchaComponent implements OnChanges, OnDestroy { | ||
import { ControlValueAccessor } from '@angular/forms'; | ||
export declare abstract class BaseReCaptchaComponent implements OnChanges, OnDestroy, ControlValueAccessor, AfterViewInit { | ||
protected renderer: Renderer2; | ||
protected zone: NgZone; | ||
protected injector: Injector; | ||
protected globalConfig: NgxCaptchaConfig; | ||
/** | ||
* Form Control to be enable usage in reactive forms | ||
*/ | ||
private control; | ||
private setupAfterLoad; | ||
@@ -90,4 +96,10 @@ /** | ||
protected abstract recaptchaType: ReCaptchaType; | ||
constructor(renderer: Renderer2, zone: NgZone, globalConfig?: NgxCaptchaConfig); | ||
/** | ||
* Required by ControlValueAccessor | ||
*/ | ||
protected onChange: (value: string) => void; | ||
protected onTouched: (value: string) => void; | ||
protected constructor(renderer: Renderer2, zone: NgZone, injector: Injector, globalConfig?: NgxCaptchaConfig); | ||
ngAfterViewInit(): void; | ||
/** | ||
* Gets reCaptcha properties | ||
@@ -156,2 +168,15 @@ */ | ||
private createAndSetCaptchaElem(); | ||
/** | ||
* To be aligned with the ControlValueAccessor interface we need to implement this method | ||
* However as we don't want to update the recaptcha, this doesn't need to be implemented | ||
*/ | ||
writeValue(obj: any): void; | ||
/** | ||
* This method helps us tie together recaptcha and our formControl values | ||
*/ | ||
registerOnChange(fn: any): void; | ||
/** | ||
* At some point we might be interested whether the user has touched our component | ||
*/ | ||
registerOnTouched(fn: any): void; | ||
} |
@@ -1,2 +0,2 @@ | ||
import { OnChanges, Renderer2, SimpleChanges, NgZone } from '@angular/core'; | ||
import { OnChanges, Renderer2, SimpleChanges, NgZone, Injector } from '@angular/core'; | ||
import { BaseReCaptchaComponent } from './base-recaptcha.component'; | ||
@@ -8,2 +8,3 @@ import { ReCaptchaType } from './recaptcha-type.enum'; | ||
protected zone: NgZone; | ||
protected injector: Injector; | ||
protected globalConfig: NgxCaptchaConfig; | ||
@@ -23,3 +24,3 @@ /** | ||
protected recaptchaType: ReCaptchaType; | ||
constructor(renderer: Renderer2, zone: NgZone, globalConfig: NgxCaptchaConfig); | ||
constructor(renderer: Renderer2, zone: NgZone, injector: Injector, globalConfig: NgxCaptchaConfig); | ||
ngOnChanges(changes: SimpleChanges): void; | ||
@@ -26,0 +27,0 @@ /** |
@@ -1,2 +0,2 @@ | ||
import { EventEmitter, OnChanges, OnDestroy, Renderer2, SimpleChanges, NgZone } from '@angular/core'; | ||
import { EventEmitter, OnChanges, OnDestroy, Renderer2, SimpleChanges, NgZone, Injector } from '@angular/core'; | ||
import { BaseReCaptchaComponent } from './base-recaptcha.component'; | ||
@@ -8,2 +8,3 @@ import { ReCaptchaType } from './recaptcha-type.enum'; | ||
protected zone: NgZone; | ||
protected injector: Injector; | ||
protected globalConfig: NgxCaptchaConfig; | ||
@@ -39,3 +40,3 @@ /** | ||
protected recaptchaType: ReCaptchaType; | ||
constructor(renderer: Renderer2, zone: NgZone, globalConfig: NgxCaptchaConfig); | ||
constructor(renderer: Renderer2, zone: NgZone, injector: Injector, globalConfig: NgxCaptchaConfig); | ||
ngOnChanges(changes: SimpleChanges): void; | ||
@@ -42,0 +43,0 @@ ngOnDestroy(): void; |
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":4,"metadata":{"ReCaptcha2Component":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"ɵa"},"decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":17,"character":1},"arguments":[{"selector":"ngx-recaptcha2","template":"\n <div #captchaScriptElem></div>\n <div #captchaWrapperElem></div>"}]}],"members":{"theme":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":38,"character":3}}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":43,"character":3}}]}],"hl":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":48,"character":3}}]}],"expire":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":53,"character":3}}]}],"error":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":58,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":65,"character":5}}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":63,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":64,"character":20},{"__symbolic":"reference","name":"NgxCaptchaConfig"}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"captchaSpecificSetup":[{"__symbolic":"method"}],"getCaptchaProperties":[{"__symbolic":"method"}],"registerCallbacks":[{"__symbolic":"method"}],"handleErrorCallback":[{"__symbolic":"method"}],"handleExpireCallback":[{"__symbolic":"method"}]}},"InvisibleReCaptchaComponent":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"ɵa"},"decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":7,"character":1},"arguments":[{"selector":"ngx-invisible-recaptcha","template":"\n <div #captchaScriptElem></div>\n <div #captchaWrapperElem></div>"}]}],"members":{"badge":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":23,"character":3}}]}],"hl":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":28,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":35,"character":5}}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":33,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":34,"character":20},{"__symbolic":"reference","name":"NgxCaptchaConfig"}]}],"ngOnChanges":[{"__symbolic":"method"}],"execute":[{"__symbolic":"method"}],"captchaSpecificSetup":[{"__symbolic":"method"}],"getCaptchaProperties":[{"__symbolic":"method"}]}},"INgxCaptchaConfig":{"__symbolic":"interface"},"NgxCaptchaConfig":{"__symbolic":"class","members":{}},"NgxCaptchaModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":7,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":9,"character":4}],"declarations":[{"__symbolic":"reference","name":"ReCaptcha2Component"},{"__symbolic":"reference","name":"InvisibleReCaptchaComponent"}],"exports":[{"__symbolic":"reference","name":"ReCaptcha2Component"},{"__symbolic":"reference","name":"InvisibleReCaptchaComponent"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["config"],"value":{"ngModule":{"__symbolic":"reference","name":"NgxCaptchaModule"},"providers":[{"provide":{"__symbolic":"reference","name":"NgxCaptchaConfig"},"useValue":{"__symbolic":"reference","name":"config"}}]}}}},"ɵa":{"__symbolic":"class","members":{"siteKey":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":46,"character":5}}]}],"type":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":51,"character":5}}]}],"hl":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":56,"character":5}}]}],"tabIndex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":61,"character":5}}]}],"success":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":67,"character":5}}]}],"load":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":72,"character":5}}]}],"ready":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":77,"character":5}}]}],"captchaWrapperElem":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":79,"character":5},"arguments":["captchaWrapperElem"]}]}],"captchaScriptElem":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":80,"character":5},"arguments":["captchaScriptElem"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":124,"character":28},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":125,"character":24},{"__symbolic":"reference","name":"NgxCaptchaConfig"}]}],"getCaptchaProperties":[{"__symbolic":"method"}],"captchaSpecificSetup":[{"__symbolic":"method"}],"getGlobalSiteKey":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"getResponse":[{"__symbolic":"method"}],"getCaptchaId":[{"__symbolic":"method"}],"resetCaptcha":[{"__symbolic":"method"}],"getCurrentResponse":[{"__symbolic":"method"}],"reloadCaptcha":[{"__symbolic":"method"}],"ensureCaptchaElem":[{"__symbolic":"method"}],"renderReCaptcha":[{"__symbolic":"method"}],"handleCallback":[{"__symbolic":"method"}],"ensureReCaptchaScript":[{"__symbolic":"method"}],"registerReCaptchaScript":[{"__symbolic":"method"}],"getLanguageParam":[{"__symbolic":"method"}],"getPseudoUniqueNumber":[{"__symbolic":"method"}],"isReCaptchaApiDefined":[{"__symbolic":"method"}],"setupComponent":[{"__symbolic":"method"}],"onloadCallback":[{"__symbolic":"method"}],"generateNewElemId":[{"__symbolic":"method"}],"createAndSetCaptchaElem":[{"__symbolic":"method"}]}}},"origins":{"ReCaptcha2Component":"./lib/recaptcha-2.component","InvisibleReCaptchaComponent":"./lib/invisible-recaptcha.component","INgxCaptchaConfig":"./lib/recaptcha.config","NgxCaptchaConfig":"./lib/recaptcha.config","NgxCaptchaModule":"./lib/ngx-captcha.module","ɵa":"./lib/base-recaptcha.component"},"importAs":"ngx-captcha"} | ||
{"__symbolic":"module","version":4,"metadata":{"ReCaptcha2Component":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"ɵa"},"decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":18,"character":1},"arguments":[{"selector":"ngx-recaptcha2","template":"\n <div #captchaScriptElem></div>\n <div #captchaWrapperElem></div>","providers":[{"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALUE_ACCESSOR","line":25,"character":15},"useExisting":{"__symbolic":"reference","name":"ReCaptcha2Component"},"multi":true}]}]}],"members":{"theme":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":46,"character":3}}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":51,"character":3}}]}],"hl":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":56,"character":3}}]}],"expire":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":61,"character":3}}]}],"error":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":66,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":74,"character":5}}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":71,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":72,"character":20},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":73,"character":24},{"__symbolic":"reference","name":"NgxCaptchaConfig"}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"captchaSpecificSetup":[{"__symbolic":"method"}],"getCaptchaProperties":[{"__symbolic":"method"}],"registerCallbacks":[{"__symbolic":"method"}],"handleErrorCallback":[{"__symbolic":"method"}],"handleExpireCallback":[{"__symbolic":"method"}]}},"InvisibleReCaptchaComponent":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"ɵa"},"decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":8,"character":1},"arguments":[{"selector":"ngx-invisible-recaptcha","template":"\n <div #captchaScriptElem></div>\n <div #captchaWrapperElem></div>","providers":[{"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALUE_ACCESSOR","line":15,"character":15},"useExisting":{"__symbolic":"reference","name":"InvisibleReCaptchaComponent"},"multi":true}]}]}],"members":{"badge":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":31,"character":3}}]}],"hl":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":36,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":44,"character":5}}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":41,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":42,"character":20},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":43,"character":24},{"__symbolic":"reference","name":"NgxCaptchaConfig"}]}],"ngOnChanges":[{"__symbolic":"method"}],"execute":[{"__symbolic":"method"}],"captchaSpecificSetup":[{"__symbolic":"method"}],"getCaptchaProperties":[{"__symbolic":"method"}]}},"INgxCaptchaConfig":{"__symbolic":"interface"},"NgxCaptchaConfig":{"__symbolic":"class","members":{}},"NgxCaptchaModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":7,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":9,"character":4}],"declarations":[{"__symbolic":"reference","name":"ReCaptcha2Component"},{"__symbolic":"reference","name":"InvisibleReCaptchaComponent"}],"exports":[{"__symbolic":"reference","name":"ReCaptcha2Component"},{"__symbolic":"reference","name":"InvisibleReCaptchaComponent"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["config"],"value":{"ngModule":{"__symbolic":"reference","name":"NgxCaptchaModule"},"providers":[{"provide":{"__symbolic":"reference","name":"NgxCaptchaConfig"},"useValue":{"__symbolic":"reference","name":"config"}}]}}}},"ɵa":{"__symbolic":"class","members":{"siteKey":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":52,"character":5}}]}],"type":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":57,"character":5}}]}],"hl":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":62,"character":5}}]}],"tabIndex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":67,"character":5}}]}],"success":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":73,"character":5}}]}],"load":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":78,"character":5}}]}],"ready":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":83,"character":5}}]}],"captchaWrapperElem":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":85,"character":5},"arguments":["captchaWrapperElem"]}]}],"captchaScriptElem":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":86,"character":5},"arguments":["captchaScriptElem"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":136,"character":28},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":137,"character":24},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":138,"character":28},{"__symbolic":"reference","name":"NgxCaptchaConfig"}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"getCaptchaProperties":[{"__symbolic":"method"}],"captchaSpecificSetup":[{"__symbolic":"method"}],"getGlobalSiteKey":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"getResponse":[{"__symbolic":"method"}],"getCaptchaId":[{"__symbolic":"method"}],"resetCaptcha":[{"__symbolic":"method"}],"getCurrentResponse":[{"__symbolic":"method"}],"reloadCaptcha":[{"__symbolic":"method"}],"ensureCaptchaElem":[{"__symbolic":"method"}],"renderReCaptcha":[{"__symbolic":"method"}],"handleCallback":[{"__symbolic":"method"}],"ensureReCaptchaScript":[{"__symbolic":"method"}],"registerReCaptchaScript":[{"__symbolic":"method"}],"getLanguageParam":[{"__symbolic":"method"}],"getPseudoUniqueNumber":[{"__symbolic":"method"}],"isReCaptchaApiDefined":[{"__symbolic":"method"}],"setupComponent":[{"__symbolic":"method"}],"onloadCallback":[{"__symbolic":"method"}],"generateNewElemId":[{"__symbolic":"method"}],"createAndSetCaptchaElem":[{"__symbolic":"method"}],"writeValue":[{"__symbolic":"method"}],"registerOnChange":[{"__symbolic":"method"}],"registerOnTouched":[{"__symbolic":"method"}]}}},"origins":{"ReCaptcha2Component":"./lib/recaptcha-2.component","InvisibleReCaptchaComponent":"./lib/invisible-recaptcha.component","INgxCaptchaConfig":"./lib/recaptcha.config","NgxCaptchaConfig":"./lib/recaptcha.config","NgxCaptchaModule":"./lib/ngx-captcha.module","ɵa":"./lib/base-recaptcha.component"},"importAs":"ngx-captcha"} |
{ | ||
"name": "ngx-captcha", | ||
"version": "3.1.2", | ||
"version": "4.0.0", | ||
"license": "MIT", | ||
@@ -5,0 +5,0 @@ "repository": { |
@@ -19,4 +19,13 @@ [![npm version](https://badge.fury.io/js/ngx-captcha.svg)](https://badge.fury.io/js/ngx-captcha) | ||
### Use with Angular forms | ||
Depending on whether you want to use [reactive forms](https://angular.io/guide/reactive-forms) or [template-driven forms](https://angular.io/guide/forms) you need to include the appropriate modules, too. | ||
Add `ReactiveFormsModule` to your imports in case you want to use reactive forms. If you prefer the the template-driven approach simple add the `FormsModule` to your module. | ||
Both can be imported from `@angular/forms`. In the demo project you can check out the *normal* demo to see how to use reactive forms or the *invisible* demo to see what the template-driven approach looks like. With the template-driven approach you don't necessarily need to use a from element to wrap the component, you can instead use the `[ngModelOptions]="{ standalone: true }"`. | ||
However, using it with the standalone option is not recommended but can be used if needed. | ||
```javascript | ||
import { NgModule } from '@angular/core'; | ||
import { ReactiveFormsModule } from '@angular/forms'; | ||
import { NgxCaptchaModule } from 'ngx-captcha'; | ||
@@ -26,2 +35,3 @@ | ||
imports: [ | ||
ReactiveFormsModule, | ||
NgxCaptchaModule.forRoot({ | ||
@@ -37,17 +47,36 @@ reCaptcha2SiteKey: 'xxxx', // optional, can be overridden with 'siteKey' component property | ||
## Usage | ||
The configuration properties are a copy of the official ones that google provides. For explanation of what these properties do and how to use them, please refer to [https://developers.google.com/recaptcha/docs/display](https://developers.google.com/recaptcha/docs/display) and [https://developers.google.com/recaptcha/docs/invisible](https://developers.google.com/recaptcha/docs/invisible). | ||
The configuration properties are a copy of the official ones that google provides. For explanation of what these properties do and how to use them, please refer to [https://developers.google.com/recaptcha/docs/display](https://developers.google.com/recaptcha/docs/display) and [https://developers.google.com/recaptcha/docs/invisible](https://developers.google.com/recaptcha/docs/invisible) | ||
### reCaptcha2 | ||
your.component.ts | ||
```javascript | ||
export class YourComponent implements OnInit { | ||
protected aFormGroup: FormGroup; | ||
constructor(private formBuilder: FormBuilder) {} | ||
ngOnInit() { | ||
this.aFormGroup = this.formBuilder.group({ | ||
recaptcha: ['', Validators.required] | ||
}); | ||
} | ||
} | ||
``` | ||
your.template.html | ||
```html | ||
<ngx-recaptcha2 | ||
[size]="size" | ||
[hl]="lang" | ||
[theme]="theme" | ||
[type]="type" | ||
(expire)="handleExpire()" | ||
(load)="handleLoad()" | ||
(success)="handleSuccess($event)"> | ||
</ngx-recaptcha2> | ||
<form [formGroup]="aFormGroup"> | ||
<ngx-recaptcha2 | ||
[size]="size" | ||
[hl]="lang" | ||
[theme]="theme" | ||
[type]="type" | ||
(expire)="handleExpire()" | ||
(load)="handleLoad()" | ||
(success)="handleSuccess($event)" | ||
formControlName="recaptcha"> | ||
</ngx-recaptcha2> | ||
</form> | ||
``` | ||
@@ -58,8 +87,11 @@ | ||
```html | ||
<ngx-invisible-recaptcha | ||
[type]="type" | ||
[badge]="badge" | ||
(load)="handleLoad()" | ||
(success)="handleSuccess($event)"> | ||
</ngx-invisible-recaptcha> | ||
<form [formGroup]="aFormGroup"> | ||
<ngx-invisible-recaptcha | ||
[type]="type" | ||
[badge]="badge" | ||
(load)="handleLoad()" | ||
(success)="handleSuccess($event)" | ||
formControlName="recaptcha"> | ||
</ngx-invisible-recaptcha> | ||
</form> | ||
``` |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
525059
4635
94
0