mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-15 03:29:15 +00:00
b96845ae01
To keep blame info accurate and to avoid [changes like this](https://github.com/go-gitea/gitea/pull/29977/files#diff-c3422631a14edbe1e508c4b22f0c718db318be08a6e889427802f9b6165d88d6R359), it's good to always have a trailing comma, so let's enforce it in JS. This rule is completely automatically fixable with `make lint-js-fix` and that's what I did here. (cherry picked from commit 3d751b6ec18e57698ce86b79866031d2c80c2071) Conflicts: web_src/js/components/DashboardRepoList.vue trivial context conflict because of '3b7b899afa fix commit_status'
52 lines
1.3 KiB
JavaScript
52 lines
1.3 KiB
JavaScript
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,
|
|
theme: isDark ? 'dark' : 'light',
|
|
};
|
|
|
|
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,
|
|
},
|
|
});
|
|
break;
|
|
}
|
|
default:
|
|
}
|
|
}
|