Я использую axios для отправки токена в бэкэнд и проверки recaptcha, который все работает нормально, но теперь я понял, что форма отправляется без заполнения обязательных полей.Есть ли способ сохранить браузер, проверяя, что обязательные поля заполнены перед выполнением recaptcha.- в данный момент поведение recpatcha выполняется перед проверкой того, что требуемый вход имеет значение.Также отправка должна использовать ввод, а не div или кнопку.
HTML
<script src="https://www.google.com/recaptcha/api.js?onload=onloadCallback&render=explicit" defer >
<form id="subscribe" class="form" method="POST" accept-charset="utf-8">
{{ getCsrfInput() }}
<input type="hidden" name="action" value="/some/url">
<label>Name</label>
<input type="text" id="fields-name" required name="fields[name]">
<label>Email</label>
<input type="email" id="fields-emailAdress" required name="fields[email]">
<p class="js-form__error-message form__errors"></p>
<div class="submit submit--wrapper submit--disabled text--white js-button__submit">
<input id="g-recaptcha-subscribe" value="" type="submit">
</div>
</form>
JAVASCRIPT
import axios from 'axios';
import qs from 'qs';
const subscribe = document.querySelector('#subscribe');
const gRecaptchaSubscribeCallback = (token) => {
grecaptcha.execute();
const formResponse = subscribe.querySelector('.js-form__error-message');
const submitButtonSubscribe = subscribe.querySelector('.js-button__submit');
submitButtonSubscribe.classList.add('submit--disabled');
axios({
method: 'POST',
url: '/actions/newsletter/verifyRecaptcha',
data: qs.stringify({
recaptcha: token,
[window.csrfTokenName]: window.csrfTokenValue,
}),
config: {
headers: {
'Content-Type': 'application/x-www-form-urlencoded',
},
},
}).then((data) => {
if (data && data.data.success) {
formResponse.innerHTML = '';
subscribe.submit();
} else {
formResponse.innerHTML = 'Form submission failed, please try again';
submitButtonSubscribe.classList.remove('submit--disabled');
}
});
grecaptcha.reset();
};
const onloadCallback = () => {
if (subscribe) {
grecaptcha.render('g-recaptcha-subscribe', {
'sitekey': '[sitekeyhere]',
'callback': 'gRecaptchaSubscribeCallback',
'data-size': 'invisble',
});
}
};
window.onloadCallback = onloadCallback;
window.gRecaptchaSubscribeCallback = gRecaptchaSubscribeCallback;