UNPKG

matrix-react-sdk

Version:
127 lines (105 loc) 15.6 kB
"use strict"; 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 = _interopRequireDefault(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _languageHandler = require("../../../languageHandler"); var sdk = _interopRequireWildcard(require("../../..")); var _objects = require("../../../utils/objects"); var _StyledCheckbox = _interopRequireDefault(require("../elements/StyledCheckbox")); var _replaceableComponent = require("../../../utils/replaceableComponent"); var _dec, _class, _class2, _temp; let InlineTermsAgreement = (_dec = (0, _replaceableComponent.replaceableComponent)("views.terms.InlineTermsAgreement"), _dec(_class = (_temp = _class2 = class InlineTermsAgreement extends _react.default.Component { constructor() { super(); (0, _defineProperty2.default)(this, "_togglePolicy", index => { const policies = (0, _objects.objectClone)(this.state.policies); policies[index].checked = !policies[index].checked; this.setState({ policies }); }); (0, _defineProperty2.default)(this, "_onContinue", () => { const hasUnchecked = !!this.state.policies.some(p => !p.checked); if (hasUnchecked) return; this.setState({ busy: true }); this.props.onFinished(this.state.policies.map(p => p.url)); }); this.state = { policies: [], busy: false }; } componentDidMount() { // Build all the terms the user needs to accept const policies = []; // { checked, url, name } for (const servicePolicies of this.props.policiesAndServicePairs) { const availablePolicies = Object.values(servicePolicies.policies); for (const policy of availablePolicies) { const language = (0, _languageHandler.pickBestLanguage)(Object.keys(policy).filter(p => p !== 'version')); const renderablePolicy = { checked: false, url: policy[language].url, name: policy[language].name }; policies.push(renderablePolicy); } } this.setState({ policies }); } _renderCheckboxes() { const rendered = []; for (let i = 0; i < this.state.policies.length; i++) { const policy = this.state.policies[i]; const introText = (0, _languageHandler._t)("Accept <policyLink /> to continue:", {}, { policyLink: () => { return /*#__PURE__*/_react.default.createElement("a", { href: policy.url, rel: "noreferrer noopener", target: "_blank" }, policy.name, /*#__PURE__*/_react.default.createElement("span", { className: "mx_InlineTermsAgreement_link" })); } }); rendered.push( /*#__PURE__*/_react.default.createElement("div", { key: i, className: "mx_InlineTermsAgreement_cbContainer" }, /*#__PURE__*/_react.default.createElement("div", null, introText), /*#__PURE__*/_react.default.createElement("div", { className: "mx_InlineTermsAgreement_checkbox" }, /*#__PURE__*/_react.default.createElement(_StyledCheckbox.default, { onChange: () => this._togglePolicy(i), checked: policy.checked }, (0, _languageHandler._t)("Accept"))))); } return rendered; } render() { const AccessibleButton = sdk.getComponent("views.elements.AccessibleButton"); const hasUnchecked = !!this.state.policies.some(p => !p.checked); return /*#__PURE__*/_react.default.createElement("div", null, this.props.introElement, this._renderCheckboxes(), /*#__PURE__*/_react.default.createElement(AccessibleButton, { onClick: this._onContinue, disabled: hasUnchecked || this.state.busy, kind: "primary_sm" }, (0, _languageHandler._t)("Continue"))); } }, (0, _defineProperty2.default)(_class2, "propTypes", { policiesAndServicePairs: _propTypes.default.array.isRequired, // array of service/policy pairs agreedUrls: _propTypes.default.array.isRequired, // array of URLs the user has accepted onFinished: _propTypes.default.func.isRequired, // takes an argument of accepted URLs introElement: _propTypes.default.node }), _temp)) || _class); exports.default = InlineTermsAgreement; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/terms/InlineTermsAgreement.js"],"names":["InlineTermsAgreement","React","Component","constructor","index","policies","state","checked","setState","hasUnchecked","some","p","busy","props","onFinished","map","url","componentDidMount","servicePolicies","policiesAndServicePairs","availablePolicies","Object","values","policy","language","keys","filter","renderablePolicy","name","push","_renderCheckboxes","rendered","i","length","introText","policyLink","_togglePolicy","render","AccessibleButton","sdk","getComponent","introElement","_onContinue","PropTypes","array","isRequired","agreedUrls","func","node"],"mappings":"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","sourcesContent":["/*\nCopyright 2019 The Matrix.org Foundation C.I.C.\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 from \"react\";\nimport PropTypes from \"prop-types\";\nimport {_t, pickBestLanguage} from \"../../../languageHandler\";\nimport * as sdk from \"../../..\";\nimport {objectClone} from \"../../../utils/objects\";\nimport StyledCheckbox from \"../elements/StyledCheckbox\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\n@replaceableComponent(\"views.terms.InlineTermsAgreement\")\nexport default class InlineTermsAgreement extends React.Component {\n    static propTypes = {\n        policiesAndServicePairs: PropTypes.array.isRequired, // array of service/policy pairs\n        agreedUrls: PropTypes.array.isRequired, // array of URLs the user has accepted\n        onFinished: PropTypes.func.isRequired, // takes an argument of accepted URLs\n        introElement: PropTypes.node,\n    };\n\n    constructor() {\n        super();\n\n        this.state = {\n            policies: [],\n            busy: false,\n        };\n    }\n\n    componentDidMount() {\n        // Build all the terms the user needs to accept\n        const policies = []; // { checked, url, name }\n        for (const servicePolicies of this.props.policiesAndServicePairs) {\n            const availablePolicies = Object.values(servicePolicies.policies);\n            for (const policy of availablePolicies) {\n                const language = pickBestLanguage(Object.keys(policy).filter(p => p !== 'version'));\n                const renderablePolicy = {\n                    checked: false,\n                    url: policy[language].url,\n                    name: policy[language].name,\n                };\n                policies.push(renderablePolicy);\n            }\n        }\n\n        this.setState({policies});\n    }\n\n    _togglePolicy = (index) => {\n        const policies = objectClone(this.state.policies);\n        policies[index].checked = !policies[index].checked;\n        this.setState({policies});\n    };\n\n    _onContinue = () => {\n        const hasUnchecked = !!this.state.policies.some(p => !p.checked);\n        if (hasUnchecked) return;\n\n        this.setState({busy: true});\n        this.props.onFinished(this.state.policies.map(p => p.url));\n    };\n\n    _renderCheckboxes() {\n        const rendered = [];\n        for (let i = 0; i < this.state.policies.length; i++) {\n            const policy = this.state.policies[i];\n            const introText = _t(\n                \"Accept <policyLink /> to continue:\", {}, {\n                    policyLink: () => {\n                        return (\n                            <a href={policy.url} rel='noreferrer noopener' target='_blank'>\n                                {policy.name}\n                                <span className='mx_InlineTermsAgreement_link' />\n                            </a>\n                        );\n                    },\n                },\n            );\n            rendered.push(\n                <div key={i} className='mx_InlineTermsAgreement_cbContainer'>\n                    <div>{introText}</div>\n                    <div className='mx_InlineTermsAgreement_checkbox'>\n                        <StyledCheckbox onChange={() => this._togglePolicy(i)} checked={policy.checked}>\n                            {_t(\"Accept\")}\n                        </StyledCheckbox>\n                    </div>\n                </div>,\n            );\n        }\n        return rendered;\n    }\n\n    render() {\n        const AccessibleButton = sdk.getComponent(\"views.elements.AccessibleButton\");\n        const hasUnchecked = !!this.state.policies.some(p => !p.checked);\n\n        return (\n            <div>\n                {this.props.introElement}\n                {this._renderCheckboxes()}\n                <AccessibleButton\n                    onClick={this._onContinue}\n                    disabled={hasUnchecked || this.state.busy}\n                    kind=\"primary_sm\"\n                >\n                    {_t(\"Continue\")}\n                </AccessibleButton>\n            </div>\n        );\n    }\n}\n"]}