2023-02-05 15:29:03 +08:00
|
|
|
import {isDarkTheme} from '../utils.js';
|
|
|
|
|
|
|
|
export async function initCaptcha() {
|
|
|
|
const captchaEl = document.querySelector('#captcha');
|
|
|
|
if (!captchaEl) return;
|
|
|
|
|
|
|
|
const siteKey = captchaEl.getAttribute('data-sitekey');
|
|
|
|
const isDark = isDarkTheme();
|
|
|
|
|
|
|
|
const params = {
|
|
|
|
sitekey: siteKey,
|
2024-03-22 22:06:53 +08:00
|
|
|
theme: isDark ? 'dark' : 'light',
|
2023-02-05 15:29:03 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
switch (captchaEl.getAttribute('data-captcha-type')) {
|
|
|
|
case 'g-recaptcha': {
|
|
|
|
if (window.grecaptcha) {
|
|
|
|
window.grecaptcha.ready(() => {
|
|
|
|
window.grecaptcha.render(captchaEl, params);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case 'cf-turnstile': {
|
|
|
|
if (window.turnstile) {
|
|
|
|
window.turnstile.render(captchaEl, params);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case 'h-captcha': {
|
|
|
|
if (window.hcaptcha) {
|
|
|
|
window.hcaptcha.render(captchaEl, params);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case 'm-captcha': {
|
|
|
|
const {default: mCaptcha} = await import(/* webpackChunkName: "mcaptcha-vanilla-glue" */'@mcaptcha/vanilla-glue');
|
|
|
|
mCaptcha.INPUT_NAME = 'm-captcha-response';
|
|
|
|
const instanceURL = captchaEl.getAttribute('data-instance-url');
|
|
|
|
|
|
|
|
mCaptcha.default({
|
|
|
|
siteKey: {
|
|
|
|
instanceUrl: new URL(instanceURL),
|
|
|
|
key: siteKey,
|
2024-03-22 22:06:53 +08:00
|
|
|
},
|
2023-02-05 15:29:03 +08:00
|
|
|
});
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
}
|
|
|
|
}
|