Recaptcha не проверяет обязательные поля заполнены перед выполнением? - PullRequest
0 голосов
/ 12 мая 2019

Я использую 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;
...