matrix-react-sdk
Version:
SDK for matrix.org using React
140 lines (107 loc) • 14.2 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _languageHandler = require("../../../languageHandler");
var _CountlyAnalytics = _interopRequireDefault(require("../../../CountlyAnalytics"));
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _dec, _class, _class2, _temp;
const DIV_ID = 'mx_recaptcha';
/**
* A pure UI component which displays a captcha form.
*/
let CaptchaForm = (_dec = (0, _replaceableComponent.replaceableComponent)("views.auth.CaptchaForm"), _dec(_class = (_temp = _class2 = class CaptchaForm extends _react.default.Component {
constructor(props) {
super(props);
this.state = {
errorText: null
};
this._captchaWidgetId = null;
this._recaptchaContainer = /*#__PURE__*/(0, _react.createRef)();
_CountlyAnalytics.default.instance.track("onboarding_grecaptcha_begin");
}
componentDidMount() {
// Just putting a script tag into the returned jsx doesn't work, annoyingly,
// so we do this instead.
if (global.grecaptcha) {
// already loaded
this._onCaptchaLoaded();
} else {
console.log("Loading recaptcha script...");
window.mx_on_recaptcha_loaded = () => {
this._onCaptchaLoaded();
};
const scriptTag = document.createElement('script');
scriptTag.setAttribute('src', `https://www.recaptcha.net/recaptcha/api.js?onload=mx_on_recaptcha_loaded&render=explicit`);
this._recaptchaContainer.current.appendChild(scriptTag);
}
}
componentWillUnmount() {
this._resetRecaptcha();
}
_renderRecaptcha(divId) {
if (!global.grecaptcha) {
console.error("grecaptcha not loaded!");
throw new Error("Recaptcha did not load successfully");
}
const publicKey = this.props.sitePublicKey;
if (!publicKey) {
console.error("No public key for recaptcha!");
throw new Error("This server has not supplied enough information for Recaptcha " + "authentication");
}
console.info("Rendering to %s", divId);
this._captchaWidgetId = global.grecaptcha.render(divId, {
sitekey: publicKey,
callback: this.props.onCaptchaResponse
});
}
_resetRecaptcha() {
if (this._captchaWidgetId !== null) {
global.grecaptcha.reset(this._captchaWidgetId);
}
}
_onCaptchaLoaded() {
console.log("Loaded recaptcha script.");
try {
this._renderRecaptcha(DIV_ID); // clear error if re-rendered
this.setState({
errorText: null
});
_CountlyAnalytics.default.instance.track("onboarding_grecaptcha_loaded");
} catch (e) {
this.setState({
errorText: e.toString()
});
_CountlyAnalytics.default.instance.track("onboarding_grecaptcha_error", {
error: e.toString()
});
}
}
render() {
let error = null;
if (this.state.errorText) {
error = /*#__PURE__*/_react.default.createElement("div", {
className: "error"
}, this.state.errorText);
}
return /*#__PURE__*/_react.default.createElement("div", {
ref: this._recaptchaContainer
}, /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("This homeserver would like to make sure you are not a robot.")), /*#__PURE__*/_react.default.createElement("div", {
id: DIV_ID
}), error);
}
}, (0, _defineProperty2.default)(_class2, "propTypes", {
sitePublicKey: _propTypes.default.string,
// called with the captcha response
onCaptchaResponse: _propTypes.default.func
}), (0, _defineProperty2.default)(_class2, "defaultProps", {
onCaptchaResponse: () => {}
}), _temp)) || _class);
exports.default = CaptchaForm;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/auth/CaptchaForm.js"],"names":["DIV_ID","CaptchaForm","React","Component","constructor","props","state","errorText","_captchaWidgetId","_recaptchaContainer","CountlyAnalytics","instance","track","componentDidMount","global","grecaptcha","_onCaptchaLoaded","console","log","window","mx_on_recaptcha_loaded","scriptTag","document","createElement","setAttribute","current","appendChild","componentWillUnmount","_resetRecaptcha","_renderRecaptcha","divId","error","Error","publicKey","sitePublicKey","info","render","sitekey","callback","onCaptchaResponse","reset","setState","e","toString","PropTypes","string","func"],"mappings":"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","sourcesContent":["/*\nCopyright 2015, 2016 OpenMarket Ltd\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport React, {createRef} from 'react';\nimport PropTypes from 'prop-types';\nimport { _t } from '../../../languageHandler';\nimport CountlyAnalytics from \"../../../CountlyAnalytics\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\nconst DIV_ID = 'mx_recaptcha';\n\n/**\n * A pure UI component which displays a captcha form.\n */\n@replaceableComponent(\"views.auth.CaptchaForm\")\nexport default class CaptchaForm extends React.Component {\n    static propTypes = {\n        sitePublicKey: PropTypes.string,\n\n        // called with the captcha response\n        onCaptchaResponse: PropTypes.func,\n    };\n\n    static defaultProps = {\n        onCaptchaResponse: () => {},\n    };\n\n    constructor(props) {\n        super(props);\n\n        this.state = {\n            errorText: null,\n        };\n\n        this._captchaWidgetId = null;\n\n        this._recaptchaContainer = createRef();\n\n        CountlyAnalytics.instance.track(\"onboarding_grecaptcha_begin\");\n    }\n\n    componentDidMount() {\n        // Just putting a script tag into the returned jsx doesn't work, annoyingly,\n        // so we do this instead.\n        if (global.grecaptcha) {\n            // already loaded\n            this._onCaptchaLoaded();\n        } else {\n            console.log(\"Loading recaptcha script...\");\n            window.mx_on_recaptcha_loaded = () => {this._onCaptchaLoaded();};\n            const scriptTag = document.createElement('script');\n            scriptTag.setAttribute(\n                'src', `https://www.recaptcha.net/recaptcha/api.js?onload=mx_on_recaptcha_loaded&render=explicit`,\n            );\n            this._recaptchaContainer.current.appendChild(scriptTag);\n        }\n    }\n\n    componentWillUnmount() {\n        this._resetRecaptcha();\n    }\n\n    _renderRecaptcha(divId) {\n        if (!global.grecaptcha) {\n            console.error(\"grecaptcha not loaded!\");\n            throw new Error(\"Recaptcha did not load successfully\");\n        }\n\n        const publicKey = this.props.sitePublicKey;\n        if (!publicKey) {\n            console.error(\"No public key for recaptcha!\");\n            throw new Error(\n                \"This server has not supplied enough information for Recaptcha \"\n                    + \"authentication\");\n        }\n\n        console.info(\"Rendering to %s\", divId);\n        this._captchaWidgetId = global.grecaptcha.render(divId, {\n            sitekey: publicKey,\n            callback: this.props.onCaptchaResponse,\n        });\n    }\n\n    _resetRecaptcha() {\n        if (this._captchaWidgetId !== null) {\n            global.grecaptcha.reset(this._captchaWidgetId);\n        }\n    }\n\n    _onCaptchaLoaded() {\n        console.log(\"Loaded recaptcha script.\");\n        try {\n            this._renderRecaptcha(DIV_ID);\n            // clear error if re-rendered\n            this.setState({\n                errorText: null,\n            });\n            CountlyAnalytics.instance.track(\"onboarding_grecaptcha_loaded\");\n        } catch (e) {\n            this.setState({\n                errorText: e.toString(),\n            });\n            CountlyAnalytics.instance.track(\"onboarding_grecaptcha_error\", { error: e.toString() });\n        }\n    }\n\n    render() {\n        let error = null;\n        if (this.state.errorText) {\n            error = (\n                <div className=\"error\">\n                    { this.state.errorText }\n                </div>\n            );\n        }\n\n        return (\n            <div ref={this._recaptchaContainer}>\n                <p>{_t(\n                    \"This homeserver would like to make sure you are not a robot.\",\n                )}</p>\n                <div id={DIV_ID} />\n                { error }\n            </div>\n        );\n    }\n}\n"]}