2019-12-07 21:02:00 +02:00
|
|
|
import { loadScript } from 'app/functions';
|
|
|
|
import options from 'app/services/api/options';
|
2016-07-31 16:53:16 +03:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
let readyPromise: Promise<void>;
|
2016-07-31 16:53:16 +03:00
|
|
|
let lang = 'en';
|
2020-01-17 12:44:22 +03:00
|
|
|
let sitekey: string;
|
2016-07-31 16:53:16 +03:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
export type CaptchaID = string;
|
2018-04-18 22:49:10 +03:00
|
|
|
|
2019-12-27 22:00:13 +02:00
|
|
|
class Captcha {
|
2020-05-24 02:08:24 +03:00
|
|
|
/**
|
|
|
|
* @param {DOMNode|string} el - dom node or id of element where to render captcha
|
|
|
|
* @param {object} options
|
|
|
|
* @param {string} options.skin - skin color (dark|light)
|
|
|
|
* @param {Function} options.onSetCode - the callback, that will be called with
|
|
|
|
* captcha verification code, after user successfully solves captcha
|
|
|
|
*
|
|
|
|
* @returns {Promise} - resolves to captchaId
|
|
|
|
*/
|
|
|
|
render(
|
|
|
|
el: HTMLElement,
|
|
|
|
{
|
|
|
|
skin: theme,
|
|
|
|
onSetCode: callback,
|
|
|
|
}: {
|
|
|
|
skin: 'dark' | 'light';
|
|
|
|
onSetCode: (code: string) => void;
|
|
|
|
},
|
|
|
|
): Promise<CaptchaID> {
|
|
|
|
// for testing purposes only
|
|
|
|
(window as any).e2eCaptchaSetCode = callback;
|
2019-12-27 22:00:13 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
return this.loadApi().then(() =>
|
|
|
|
(window as any).grecaptcha.render(el, {
|
|
|
|
sitekey,
|
|
|
|
theme,
|
|
|
|
callback,
|
|
|
|
}),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {string} captchaId - captcha id, returned from render promise
|
|
|
|
*/
|
|
|
|
reset(captchaId: CaptchaID) {
|
|
|
|
delete (window as any).e2eCaptchaSetCode;
|
2016-07-31 16:53:16 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
this.loadApi().then(() => (window as any).grecaptcha.reset(captchaId));
|
|
|
|
}
|
2019-12-27 22:00:13 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
/**
|
|
|
|
* @param {stirng} newLang
|
|
|
|
*
|
|
|
|
* @see https://developers.google.com/recaptcha/docs/language
|
|
|
|
*/
|
|
|
|
setLang(newLang: string) {
|
|
|
|
lang = newLang;
|
|
|
|
}
|
2016-08-14 13:10:59 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
/**
|
|
|
|
* @param {string} apiKey
|
|
|
|
*
|
|
|
|
* @see http://www.google.com/recaptcha/admin
|
|
|
|
*/
|
|
|
|
setApiKey(apiKey: string) {
|
|
|
|
sitekey = apiKey;
|
|
|
|
}
|
2016-07-31 16:53:16 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
/**
|
|
|
|
* @returns {Promise}
|
|
|
|
*/
|
|
|
|
private loadApi(): Promise<void> {
|
|
|
|
if (!readyPromise) {
|
|
|
|
readyPromise = Promise.all([
|
|
|
|
new Promise((resolve) => {
|
|
|
|
(window as any).onReCaptchaReady = resolve;
|
|
|
|
}),
|
|
|
|
options.get().then((resp) => this.setApiKey(resp.reCaptchaPublicKey)),
|
|
|
|
]).then(() => {});
|
2016-08-05 08:41:33 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
loadScript(`https://recaptcha.net/recaptcha/api.js?onload=onReCaptchaReady&render=explicit&hl=${lang}`);
|
|
|
|
}
|
2016-07-31 16:53:16 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
return readyPromise;
|
2016-07-31 16:53:16 +03:00
|
|
|
}
|
2019-12-27 22:00:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export default new Captcha();
|