UNPKG

matrix-react-sdk

Version:
101 lines (98 loc) 15.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireDefault(require("react")); var _languageHandler = require("../../../languageHandler"); var _objects = require("../../../utils/objects"); var _StyledCheckbox = _interopRequireDefault(require("../elements/StyledCheckbox")); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); /* Copyright 2024 New Vector Ltd. Copyright 2019 The Matrix.org Foundation C.I.C. SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ class InlineTermsAgreement extends _react.default.Component { constructor(props) { super(props); (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 = []; 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)("terms|inline_intro_text", {}, { 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)("action|accept"))))); } return rendered; } render() { 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.default, { onClick: this.onContinue, disabled: hasUnchecked || this.state.busy, kind: "primary_sm" }, (0, _languageHandler._t)("action|continue"))); } } exports.default = InlineTermsAgreement; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_languageHandler","_objects","_StyledCheckbox","_AccessibleButton","InlineTermsAgreement","React","Component","constructor","props","_defineProperty2","default","index","policies","objectClone","state","checked","setState","hasUnchecked","some","p","busy","onFinished","map","url","componentDidMount","servicePolicies","policiesAndServicePairs","availablePolicies","Object","values","policy","language","pickBestLanguage","keys","filter","renderablePolicy","name","push","renderCheckboxes","rendered","i","length","introText","_t","policyLink","createElement","href","rel","target","className","key","onChange","togglePolicy","render","introElement","onClick","onContinue","disabled","kind","exports"],"sources":["../../../../src/components/views/terms/InlineTermsAgreement.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2019 The Matrix.org Foundation C.I.C.\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport React from \"react\";\n\nimport { _t, pickBestLanguage } from \"../../../languageHandler\";\nimport { objectClone } from \"../../../utils/objects\";\nimport StyledCheckbox from \"../elements/StyledCheckbox\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport { ServicePolicyPair } from \"../../../Terms\";\n\ninterface IProps {\n    policiesAndServicePairs: ServicePolicyPair[];\n    onFinished: (accepted: string[]) => void;\n    agreedUrls: string[]; // array of URLs the user has accepted\n    introElement: React.ReactNode;\n}\n\ninterface IState {\n    policies: Policy[];\n    busy: boolean;\n}\n\ninterface Policy {\n    checked: boolean;\n    url: string;\n    name: string;\n}\n\nexport default class InlineTermsAgreement extends React.Component<IProps, IState> {\n    public constructor(props: IProps) {\n        super(props);\n        this.state = {\n            policies: [],\n            busy: false,\n        };\n    }\n\n    public componentDidMount(): void {\n        // Build all the terms the user needs to accept\n        const policies: Policy[] = [];\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: Policy = {\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    private togglePolicy = (index: number): void => {\n        const policies = objectClone(this.state.policies);\n        policies[index].checked = !policies[index].checked;\n        this.setState({ policies });\n    };\n\n    private onContinue = (): void => {\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    private renderCheckboxes(): React.ReactNode[] {\n        const rendered: JSX.Element[] = [];\n        for (let i = 0; i < this.state.policies.length; i++) {\n            const policy = this.state.policies[i];\n            const introText = _t(\n                \"terms|inline_intro_text\",\n                {},\n                {\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(\"action|accept\")}\n                        </StyledCheckbox>\n                    </div>\n                </div>,\n            );\n        }\n        return rendered;\n    }\n\n    public render(): React.ReactNode {\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(\"action|continue\")}\n                </AccessibleButton>\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}