matrix-react-sdk
Version:
SDK for matrix.org using React
260 lines (223 loc) • 35 kB
JavaScript
"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 _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _Modal = _interopRequireDefault(require("../../../Modal"));
var _PersistedElement = _interopRequireDefault(require("../elements/PersistedElement"));
var _QuestionDialog = _interopRequireDefault(require("./QuestionDialog"));
var _SdkConfig = _interopRequireDefault(require("../../../SdkConfig"));
var _classnames = _interopRequireDefault(require("classnames"));
var _languageHandler = require("../../../languageHandler");
var _MatrixClientPeg = require("../../../MatrixClientPeg");
var _HostSignupStore = require("../../../stores/HostSignupStore");
var _OwnProfileStore = require("../../../stores/OwnProfileStore");
var _HostSignupDialogTypes = require("./HostSignupDialogTypes");
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _dec, _class, _temp;
const HOST_SIGNUP_KEY = "host_signup";
let HostSignupDialog = (_dec = (0, _replaceableComponent.replaceableComponent)("views.dialogs.HostSignupDialog"), _dec(_class = (_temp = class HostSignupDialog extends _react.default.PureComponent
/*:: <IProps, IState>*/
{
constructor(props
/*: IProps*/
) {
super(props);
(0, _defineProperty2.default)(this, "iframeRef", /*#__PURE__*/_react.default.createRef());
(0, _defineProperty2.default)(this, "config", void 0);
(0, _defineProperty2.default)(this, "messageHandler", async (message
/*: IPostmessage*/
) => {
if (!this.config.url.startsWith(message.origin)) {
return;
}
switch (message.data.action) {
case _HostSignupDialogTypes.PostmessageAction.HostSignupAccountDetailsRequest:
this.onAccountDetailsRequest();
break;
case _HostSignupDialogTypes.PostmessageAction.Maximize:
this.setState({
minimized: false
});
break;
case _HostSignupDialogTypes.PostmessageAction.Minimize:
this.setState({
minimized: true
});
break;
case _HostSignupDialogTypes.PostmessageAction.SetupComplete:
this.setState({
completed: true
});
break;
case _HostSignupDialogTypes.PostmessageAction.CloseDialog:
return this.closeDialog();
}
});
(0, _defineProperty2.default)(this, "maximizeDialog", () => {
this.setState({
minimized: false
}); // Send this action to the iframe so it can act accordingly
this.sendMessage({
action: _HostSignupDialogTypes.PostmessageAction.Maximize
});
});
(0, _defineProperty2.default)(this, "minimizeDialog", () => {
this.setState({
minimized: true
}); // Send this action to the iframe so it can act accordingly
this.sendMessage({
action: _HostSignupDialogTypes.PostmessageAction.Minimize
});
});
(0, _defineProperty2.default)(this, "closeDialog", async () => {
window.removeEventListener("message", this.messageHandler); // Ensure we destroy the host signup persisted element
_PersistedElement.default.destroyElement("host_signup"); // Finally clear the flag in
return _HostSignupStore.HostSignupStore.instance.setHostSignupActive(false);
});
(0, _defineProperty2.default)(this, "onCloseClick", async () => {
if (this.state.completed) {
// We're done, close
return this.closeDialog();
} else {
_Modal.default.createDialog(_QuestionDialog.default, {
title: (0, _languageHandler._t)("Confirm abort of host creation"),
description: (0, _languageHandler._t)("Are you sure you wish to abort creation of the host? The process cannot be continued."),
button: (0, _languageHandler._t)("Abort"),
onFinished: result => {
if (result) {
return this.closeDialog();
}
}
});
}
});
(0, _defineProperty2.default)(this, "sendMessage", (message
/*: IPostmessageResponseData*/
) => {
this.iframeRef.current.contentWindow.postMessage(message, this.config.url);
});
(0, _defineProperty2.default)(this, "onAccountDetailsDialogFinished", async result => {
if (result) {
return this.sendAccountDetails();
}
return this.closeDialog();
});
(0, _defineProperty2.default)(this, "onAccountDetailsRequest", () => {
const textComponent = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("Continuing temporarily allows the %(hostSignupBrand)s setup process to access your " + "account to fetch verified email addresses. This data is not stored.", {
hostSignupBrand: this.config.brand
})), /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("Learn more in our <privacyPolicyLink />, <termsOfServiceLink /> and <cookiePolicyLink />.", {}, {
cookiePolicyLink: () => /*#__PURE__*/_react.default.createElement("a", {
href: this.config.cookiePolicyUrl,
target: "_blank",
rel: "noreferrer noopener"
}, (0, _languageHandler._t)("Cookie Policy")),
privacyPolicyLink: () => /*#__PURE__*/_react.default.createElement("a", {
href: this.config.privacyPolicyUrl,
target: "_blank",
rel: "noreferrer noopener"
}, (0, _languageHandler._t)("Privacy Policy")),
termsOfServiceLink: () => /*#__PURE__*/_react.default.createElement("a", {
href: this.config.termsOfServiceUrl,
target: "_blank",
rel: "noreferrer noopener"
}, (0, _languageHandler._t)("Terms of Service"))
})));
_Modal.default.createDialog(_QuestionDialog.default, {
title: (0, _languageHandler._t)("You should know"),
description: textComponent,
button: (0, _languageHandler._t)("Continue"),
onFinished: this.onAccountDetailsDialogFinished
});
});
this.state = {
completed: false,
error: null,
minimized: false
};
this.config = _SdkConfig.default.get().hostSignup;
}
async sendAccountDetails() {
const openIdToken = await _MatrixClientPeg.MatrixClientPeg.get().getOpenIdToken();
if (!openIdToken || !openIdToken.access_token) {
console.warn("Failed to connect to homeserver for OpenID token.");
this.setState({
completed: true,
error: (0, _languageHandler._t)("Failed to connect to your homeserver. Please close this dialog and try again.")
});
return;
}
this.sendMessage({
action: _HostSignupDialogTypes.PostmessageAction.HostSignupAccountDetails,
account: {
accessToken: await _MatrixClientPeg.MatrixClientPeg.get().getAccessToken(),
name: _OwnProfileStore.OwnProfileStore.instance.displayName,
openIdToken: openIdToken.access_token,
serverName: await _MatrixClientPeg.MatrixClientPeg.get().getDomain(),
userLocalpart: await _MatrixClientPeg.MatrixClientPeg.get().getUserIdLocalpart(),
termsAccepted: true
}
});
}
componentDidMount() {
window.addEventListener("message", this.messageHandler);
}
componentWillUnmount() {
if (_HostSignupStore.HostSignupStore.instance.isHostSignupActive) {
// Run the close dialog actions if we're still active, otherwise good to go
return this.closeDialog();
}
}
render()
/*: React.ReactNode*/
{
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_HostSignup_persisted"
}, /*#__PURE__*/_react.default.createElement(_PersistedElement.default, {
key: HOST_SIGNUP_KEY,
persistKey: HOST_SIGNUP_KEY
}, /*#__PURE__*/_react.default.createElement("div", {
className: (0, _classnames.default)({
"mx_Dialog_wrapper": !this.state.minimized
})
}, /*#__PURE__*/_react.default.createElement("div", {
className: (0, _classnames.default)("mx_Dialog", {
"mx_HostSignupDialog_minimized": this.state.minimized,
"mx_HostSignupDialog": !this.state.minimized
})
}, this.state.minimized && /*#__PURE__*/_react.default.createElement("div", {
className: "mx_Dialog_header mx_Dialog_headerWithButton"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_Dialog_title"
}, (0, _languageHandler._t)("%(hostSignupBrand)s Setup", {
hostSignupBrand: this.config.brand
})), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_HostSignup_maximize_button",
onClick: this.maximizeDialog,
"aria-label": (0, _languageHandler._t)("Maximize dialog"),
title: (0, _languageHandler._t)("Maximize dialog")
})), !this.state.minimized && /*#__PURE__*/_react.default.createElement("div", {
className: "mx_Dialog_header mx_Dialog_headerWithCancel"
}, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: this.minimizeDialog,
className: "mx_HostSignup_minimize_button",
"aria-label": (0, _languageHandler._t)("Minimize dialog"),
title: (0, _languageHandler._t)("Minimize dialog")
}), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: this.onCloseClick,
className: "mx_Dialog_cancelButton",
"aria-label": (0, _languageHandler._t)("Close dialog"),
title: (0, _languageHandler._t)("Close dialog")
})), this.state.error && /*#__PURE__*/_react.default.createElement("div", null, this.state.error), !this.state.error && /*#__PURE__*/_react.default.createElement("iframe", {
src: this.config.url,
ref: this.iframeRef,
sandbox: "allow-forms allow-scripts allow-same-origin allow-popups"
})))));
}
}, _temp)) || _class);
exports.default = HostSignupDialog;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/dialogs/HostSignupDialog.tsx"],"names":["HOST_SIGNUP_KEY","HostSignupDialog","React","PureComponent","constructor","props","createRef","message","config","url","startsWith","origin","data","action","PostmessageAction","HostSignupAccountDetailsRequest","onAccountDetailsRequest","Maximize","setState","minimized","Minimize","SetupComplete","completed","CloseDialog","closeDialog","sendMessage","window","removeEventListener","messageHandler","PersistedElement","destroyElement","HostSignupStore","instance","setHostSignupActive","state","Modal","createDialog","QuestionDialog","title","description","button","onFinished","result","iframeRef","current","contentWindow","postMessage","sendAccountDetails","textComponent","hostSignupBrand","brand","cookiePolicyLink","cookiePolicyUrl","privacyPolicyLink","privacyPolicyUrl","termsOfServiceLink","termsOfServiceUrl","onAccountDetailsDialogFinished","error","SdkConfig","get","hostSignup","openIdToken","MatrixClientPeg","getOpenIdToken","access_token","console","warn","HostSignupAccountDetails","account","accessToken","getAccessToken","name","OwnProfileStore","displayName","serverName","getDomain","userLocalpart","getUserIdLocalpart","termsAccepted","componentDidMount","addEventListener","componentWillUnmount","isHostSignupActive","render","maximizeDialog","minimizeDialog","onCloseClick"],"mappings":"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","sourcesContent":["/*\nCopyright 2021 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 AccessibleButton from \"../elements/AccessibleButton\";\nimport Modal from \"../../../Modal\";\nimport PersistedElement from \"../elements/PersistedElement\";\nimport QuestionDialog from './QuestionDialog';\nimport SdkConfig from \"../../../SdkConfig\";\nimport classNames from \"classnames\";\nimport { _t } from \"../../../languageHandler\";\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport { HostSignupStore } from \"../../../stores/HostSignupStore\";\nimport { OwnProfileStore } from \"../../../stores/OwnProfileStore\";\nimport {\n    IHostSignupConfig,\n    IPostmessage,\n    IPostmessageResponseData,\n    PostmessageAction,\n} from \"./HostSignupDialogTypes\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\nconst HOST_SIGNUP_KEY = \"host_signup\";\n\ninterface IProps {}\n\ninterface IState {\n    completed: boolean;\n    error: string;\n    minimized: boolean;\n}\n\n@replaceableComponent(\"views.dialogs.HostSignupDialog\")\nexport default class HostSignupDialog extends React.PureComponent<IProps, IState> {\n    private iframeRef: React.RefObject<HTMLIFrameElement> = React.createRef();\n    private readonly config: IHostSignupConfig;\n\n    constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            completed: false,\n            error: null,\n            minimized: false,\n        };\n\n        this.config = SdkConfig.get().hostSignup;\n    }\n\n    private messageHandler = async (message: IPostmessage) => {\n        if (!this.config.url.startsWith(message.origin)) {\n            return;\n        }\n        switch (message.data.action) {\n            case PostmessageAction.HostSignupAccountDetailsRequest:\n                this.onAccountDetailsRequest();\n                break;\n            case PostmessageAction.Maximize:\n                this.setState({\n                    minimized: false,\n                });\n                break;\n            case PostmessageAction.Minimize:\n                this.setState({\n                    minimized: true,\n                });\n                break;\n            case PostmessageAction.SetupComplete:\n                this.setState({\n                    completed: true,\n                });\n                break;\n            case PostmessageAction.CloseDialog:\n                return this.closeDialog();\n        }\n    }\n\n    private maximizeDialog = () => {\n        this.setState({\n            minimized: false,\n        });\n        // Send this action to the iframe so it can act accordingly\n        this.sendMessage({\n            action: PostmessageAction.Maximize,\n        });\n    }\n\n    private minimizeDialog = () => {\n        this.setState({\n            minimized: true,\n        });\n        // Send this action to the iframe so it can act accordingly\n        this.sendMessage({\n            action: PostmessageAction.Minimize,\n        });\n    }\n\n    private closeDialog = async () => {\n        window.removeEventListener(\"message\", this.messageHandler);\n        // Ensure we destroy the host signup persisted element\n        PersistedElement.destroyElement(\"host_signup\");\n        // Finally clear the flag in\n        return HostSignupStore.instance.setHostSignupActive(false);\n    }\n\n    private onCloseClick = async () => {\n        if (this.state.completed) {\n            // We're done, close\n            return this.closeDialog();\n        } else {\n            Modal.createDialog(\n                QuestionDialog,\n                {\n                    title: _t(\"Confirm abort of host creation\"),\n                    description: _t(\n                        \"Are you sure you wish to abort creation of the host? The process cannot be continued.\",\n                    ),\n                    button: _t(\"Abort\"),\n                    onFinished: result => {\n                        if (result) {\n                            return this.closeDialog();\n                        }\n                    },\n                },\n            );\n        }\n    }\n\n    private sendMessage = (message: IPostmessageResponseData) => {\n        this.iframeRef.current.contentWindow.postMessage(message, this.config.url);\n    }\n\n    private async sendAccountDetails() {\n        const openIdToken = await MatrixClientPeg.get().getOpenIdToken();\n        if (!openIdToken || !openIdToken.access_token) {\n            console.warn(\"Failed to connect to homeserver for OpenID token.\")\n            this.setState({\n                completed: true,\n                error: _t(\"Failed to connect to your homeserver. Please close this dialog and try again.\"),\n            });\n            return;\n        }\n        this.sendMessage({\n            action: PostmessageAction.HostSignupAccountDetails,\n            account: {\n                accessToken: await MatrixClientPeg.get().getAccessToken(),\n                name: OwnProfileStore.instance.displayName,\n                openIdToken: openIdToken.access_token,\n                serverName: await MatrixClientPeg.get().getDomain(),\n                userLocalpart: await MatrixClientPeg.get().getUserIdLocalpart(),\n                termsAccepted: true,\n            },\n        });\n    }\n\n    private onAccountDetailsDialogFinished = async (result) => {\n        if (result) {\n            return this.sendAccountDetails();\n        }\n        return this.closeDialog();\n    }\n\n    private onAccountDetailsRequest = () => {\n        const textComponent = (\n            <>\n                <p>\n                    {_t(\"Continuing temporarily allows the %(hostSignupBrand)s setup process to access your \" +\n                        \"account to fetch verified email addresses. This data is not stored.\", {\n                        hostSignupBrand: this.config.brand,\n                    })}\n                </p>\n                <p>\n                    {_t(\"Learn more in our <privacyPolicyLink />, <termsOfServiceLink /> and <cookiePolicyLink />.\",\n                        {},\n                        {\n                            cookiePolicyLink: () => (\n                                <a href={this.config.cookiePolicyUrl} target=\"_blank\" rel=\"noreferrer noopener\">\n                                    {_t(\"Cookie Policy\")}\n                                </a>\n                            ),\n                            privacyPolicyLink: () => (\n                                <a href={this.config.privacyPolicyUrl} target=\"_blank\" rel=\"noreferrer noopener\">\n                                    {_t(\"Privacy Policy\")}\n                                </a>\n                            ),\n                            termsOfServiceLink: () => (\n                                <a href={this.config.termsOfServiceUrl} target=\"_blank\" rel=\"noreferrer noopener\">\n                                    {_t(\"Terms of Service\")}\n                                </a>\n                            ),\n                        },\n                    )}\n                </p>\n            </>\n        );\n        Modal.createDialog(\n            QuestionDialog,\n            {\n                title: _t(\"You should know\"),\n                description: textComponent,\n                button: _t(\"Continue\"),\n                onFinished: this.onAccountDetailsDialogFinished,\n            },\n        );\n    }\n\n    public componentDidMount() {\n        window.addEventListener(\"message\", this.messageHandler);\n    }\n\n    public componentWillUnmount() {\n        if (HostSignupStore.instance.isHostSignupActive) {\n            // Run the close dialog actions if we're still active, otherwise good to go\n            return this.closeDialog();\n        }\n    }\n\n    public render(): React.ReactNode {\n        return (\n            <div className=\"mx_HostSignup_persisted\">\n                <PersistedElement key={HOST_SIGNUP_KEY} persistKey={HOST_SIGNUP_KEY}>\n                    <div className={classNames({ \"mx_Dialog_wrapper\": !this.state.minimized })}>\n                        <div\n                            className={classNames(\"mx_Dialog\",\n                                {\n                                    \"mx_HostSignupDialog_minimized\": this.state.minimized,\n                                    \"mx_HostSignupDialog\": !this.state.minimized,\n                                },\n                            )}\n                        >\n                            {this.state.minimized &&\n                                <div className=\"mx_Dialog_header mx_Dialog_headerWithButton\">\n                                    <div className=\"mx_Dialog_title\">\n                                        {_t(\"%(hostSignupBrand)s Setup\", {\n                                            hostSignupBrand: this.config.brand,\n                                        })}\n                                    </div>\n                                    <AccessibleButton\n                                        className=\"mx_HostSignup_maximize_button\"\n                                        onClick={this.maximizeDialog}\n                                        aria-label={_t(\"Maximize dialog\")}\n                                        title={_t(\"Maximize dialog\")}\n                                    />\n                                </div>\n                            }\n                            {!this.state.minimized &&\n                                <div className=\"mx_Dialog_header mx_Dialog_headerWithCancel\">\n                                    <AccessibleButton\n                                        onClick={this.minimizeDialog}\n                                        className=\"mx_HostSignup_minimize_button\"\n                                        aria-label={_t(\"Minimize dialog\")}\n                                        title={_t(\"Minimize dialog\")}\n                                    />\n                                    <AccessibleButton\n                                        onClick={this.onCloseClick}\n                                        className=\"mx_Dialog_cancelButton\"\n                                        aria-label={_t(\"Close dialog\")}\n                                        title={_t(\"Close dialog\")}\n                                    />\n                                </div>\n                            }\n                            {this.state.error &&\n                                <div>\n                                    {this.state.error}\n                                </div>\n                            }\n                            {!this.state.error &&\n                                <iframe\n                                    src={this.config.url}\n                                    ref={this.iframeRef}\n                                    sandbox=\"allow-forms allow-scripts allow-same-origin allow-popups\"\n                                />\n                            }\n                        </div>\n                    </div>\n                </PersistedElement>\n            </div>\n        );\n    }\n}\n"]}