reCAPTCHA неправильно загружается в документе XHTML - PullRequest
0 голосов
/ 22 октября 2019

Я записываю документ SHTML CSS & JS в документ XML, в котором используется синтаксический анализатор XHTML.

Когда я пытаюсь загрузить в него капчу, она на короткое время отображается в виде белого поля, а затем исчезает, никогдачтобы снова увидеть внутри рендерера.

Я понимаю, что это может быть вызвано тем, что скрипты загружаются в неправильном порядке, но я не могу позволить себе роскошь использовать ключевые слова async defer, которые рекомендуются Google просто потому, что парсер их не примет.

<script src="https://www.google.com/recaptcha/api.js" type="text/javascript"></script>
<script type="text/javascript"><![CDATA[
class Token {

    constructor(tokenInstance) {
        this.props = tokenInstance;
        this.getStatus();
        this.setOnConfirm();
        this.setAdditionalProps();
    }

    setAdditionalProps() {
        this.props.claimed = false;
        this.props.claimTokensMessage = "Claim free DAI, DeFi & ETH tokens";
        this.props.claimedMessage = "You have already claimed DAI, DeFi & ETH tokens, stay posted for new freebies!";
        this.props.serverError = "Server Error, please try again later";
        this.props.success = "ETH, DeFi & DAI tokens will be sent to your address shortly!";
        this.props.fillCaptchaMessage = "Please click the captcha below to receive the tokens";
    }

    getBaseURL() {
        return "http://192.168.26.189:8080/api/" 
    }

    getStatus() {
        let suffix = "claimed?userAddress=" + this.props.ownerAddress;
        fetch(this.getBaseURL() + suffix).then((res) => {
            if(parseInt(res.status) === 200) {
                document.getElementById("message").innerHTML = this.props.claimTokensMessage;
            } else if(parseInt(res.status) === 412) {
                this.props.claimed = true;
                document.getElementById("message").innerHTML = this.props.claimedMessage;
            } else {
                document.getElementById("message").innerHTML = this.props.serverError;
            }
        }).catch((err) => {
            document.getElementById("message").innerHTML = err;
            window.onConfirm = function() { window.close() };
        });
    }

    setOnConfirm() {
        window.onConfirm = () => {
            if(this.props.claimed) {
                window.close();
            } else {
                web3.personal.sign({ data: "To receive free tokens, you must reveal your public address to a smart contract. Is that ok?" }, (err, val) => {
                    if(err) { throw err; }
                    //user completes the request by filling the captcha
                    document.getElementById("message").innerHTML = this.props.success;
                    document.getElementById("captcha").submit();
                    window.onConfirm = function () { window.close(); };
                });
            }
        };
    }

    render() {
        let suffix = "discover?userAddress=" + this.props.ownerAddress;
        return`
        <div class="ui container">
          <div class="ui segment">
            <img src="">
            <h3 id="message"></h3>
            <form action=${this.getBaseURL() + suffix} id="captcha" method="post">
                <button class="g-recaptcha" data-sitekey="6LeK070UAAAAAHuzSEGgoqbuLGuJq-GRDd-LA4kH" data-callback="onSubmit" hidden>fill captcha</button>
            </form>
          </div>
        </div>
`;
    }
}

web3.tokens.dataChanged = (oldTokens, updatedTokens) => {
    const currentTokenInstance = web3.tokens.data.currentInstance;
    document.getElementById('root').innerHTML = new Token(currentTokenInstance).render();
};
]]></script>
<div id="root"></div>
...