UNPKG

matrix-react-sdk

Version:
110 lines (86 loc) 16.2 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 sdk = _interopRequireWildcard(require("../../../index")); var _Modal = _interopRequireDefault(require("../../../Modal")); var _languageHandler = require("../../../languageHandler"); var _MatrixClientPeg = require("../../../MatrixClientPeg"); var _replaceableComponent = require("../../../utils/replaceableComponent"); var _dec, _class, _class2, _temp; let RoomUpgradeWarningBar = (_dec = (0, _replaceableComponent.replaceableComponent)("views.rooms.RoomUpgradeWarningBar"), _dec(_class = (_temp = _class2 = class RoomUpgradeWarningBar extends _react.default.Component { constructor(props) { super(props); (0, _defineProperty2.default)(this, "_onStateEvents", (event, state) => { if (!this.props.room || event.getRoomId() !== this.props.room.roomId) { return; } if (event.getType() !== "m.room.tombstone") return; const tombstone = this.props.room.currentState.getStateEvents("m.room.tombstone", ""); this.setState({ upgraded: tombstone && tombstone.getContent().replacement_room }); }); (0, _defineProperty2.default)(this, "onUpgradeClick", () => { const RoomUpgradeDialog = sdk.getComponent('dialogs.RoomUpgradeDialog'); _Modal.default.createTrackedDialog('Upgrade Room Version', '', RoomUpgradeDialog, { room: this.props.room }); }); this.state = {}; } componentDidMount() { const tombstone = this.props.room.currentState.getStateEvents("m.room.tombstone", ""); this.setState({ upgraded: tombstone && tombstone.getContent().replacement_room }); _MatrixClientPeg.MatrixClientPeg.get().on("RoomState.events", this._onStateEvents); } componentWillUnmount() { const cli = _MatrixClientPeg.MatrixClientPeg.get(); if (cli) { cli.removeListener("RoomState.events", this._onStateEvents); } } render() { const AccessibleButton = sdk.getComponent('elements.AccessibleButton'); let doUpgradeWarnings = /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("div", { className: "mx_RoomUpgradeWarningBar_body" }, /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("Upgrading this room will shut down the current instance of the room and create " + "an upgraded room with the same name.")), /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("<b>Warning</b>: Upgrading a room will <i>not automatically migrate room members " + "to the new version of the room.</i> We'll post a link to the new room in the old " + "version of the room - room members will have to click this link to join the new room.", {}, { "b": sub => /*#__PURE__*/_react.default.createElement("b", null, sub), "i": sub => /*#__PURE__*/_react.default.createElement("i", null, sub) }))), /*#__PURE__*/_react.default.createElement("p", { className: "mx_RoomUpgradeWarningBar_upgradelink" }, /*#__PURE__*/_react.default.createElement(AccessibleButton, { onClick: this.onUpgradeClick }, (0, _languageHandler._t)("Upgrade this room to the recommended room version")))); if (this.state.upgraded) { doUpgradeWarnings = /*#__PURE__*/_react.default.createElement("div", { className: "mx_RoomUpgradeWarningBar_body" }, /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("This room has already been upgraded."))); } return /*#__PURE__*/_react.default.createElement("div", { className: "mx_RoomUpgradeWarningBar" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_RoomUpgradeWarningBar_wrapped" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_RoomUpgradeWarningBar_header" }, (0, _languageHandler._t)("This room is running room version <roomVersion />, which this homeserver has " + "marked as <i>unstable</i>.", {}, { "roomVersion": () => /*#__PURE__*/_react.default.createElement("code", null, this.props.room.getVersion()), "i": sub => /*#__PURE__*/_react.default.createElement("i", null, sub) })), doUpgradeWarnings, /*#__PURE__*/_react.default.createElement("div", { className: "mx_RoomUpgradeWarningBar_small" }, (0, _languageHandler._t)("Only room administrators will see this warning")))); } }, (0, _defineProperty2.default)(_class2, "propTypes", { room: _propTypes.default.object.isRequired, recommendation: _propTypes.default.object.isRequired }), _temp)) || _class); exports.default = RoomUpgradeWarningBar; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/rooms/RoomUpgradeWarningBar.js"],"names":["RoomUpgradeWarningBar","React","Component","constructor","props","event","state","room","getRoomId","roomId","getType","tombstone","currentState","getStateEvents","setState","upgraded","getContent","replacement_room","RoomUpgradeDialog","sdk","getComponent","Modal","createTrackedDialog","componentDidMount","MatrixClientPeg","get","on","_onStateEvents","componentWillUnmount","cli","removeListener","render","AccessibleButton","doUpgradeWarnings","sub","onUpgradeClick","getVersion","PropTypes","object","isRequired","recommendation"],"mappings":"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","sourcesContent":["/*\nCopyright 2018-2020 New Vector 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 from 'react';\nimport PropTypes from 'prop-types';\nimport * as sdk from '../../../index';\nimport Modal from '../../../Modal';\n\nimport { _t } from '../../../languageHandler';\nimport {MatrixClientPeg} from \"../../../MatrixClientPeg\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\n@replaceableComponent(\"views.rooms.RoomUpgradeWarningBar\")\nexport default class RoomUpgradeWarningBar extends React.Component {\n    static propTypes = {\n        room: PropTypes.object.isRequired,\n        recommendation: PropTypes.object.isRequired,\n    };\n\n    constructor(props) {\n        super(props);\n        this.state = {};\n    }\n\n    componentDidMount() {\n        const tombstone = this.props.room.currentState.getStateEvents(\"m.room.tombstone\", \"\");\n        this.setState({upgraded: tombstone && tombstone.getContent().replacement_room});\n\n        MatrixClientPeg.get().on(\"RoomState.events\", this._onStateEvents);\n    }\n\n    componentWillUnmount() {\n        const cli = MatrixClientPeg.get();\n        if (cli) {\n            cli.removeListener(\"RoomState.events\", this._onStateEvents);\n        }\n    }\n\n    _onStateEvents = (event, state) => {\n        if (!this.props.room || event.getRoomId() !== this.props.room.roomId) {\n            return;\n        }\n\n        if (event.getType() !== \"m.room.tombstone\") return;\n\n        const tombstone = this.props.room.currentState.getStateEvents(\"m.room.tombstone\", \"\");\n        this.setState({upgraded: tombstone && tombstone.getContent().replacement_room});\n    };\n\n    onUpgradeClick = () => {\n        const RoomUpgradeDialog = sdk.getComponent('dialogs.RoomUpgradeDialog');\n        Modal.createTrackedDialog('Upgrade Room Version', '', RoomUpgradeDialog, {room: this.props.room});\n    };\n\n    render() {\n        const AccessibleButton = sdk.getComponent('elements.AccessibleButton');\n\n        let doUpgradeWarnings = (\n            <div>\n                <div className=\"mx_RoomUpgradeWarningBar_body\">\n                    <p>\n                        {_t(\n                            \"Upgrading this room will shut down the current instance of the room and create \" +\n                            \"an upgraded room with the same name.\",\n                        )}\n                    </p>\n                    <p>\n                        {_t(\n                            \"<b>Warning</b>: Upgrading a room will <i>not automatically migrate room members \" +\n                            \"to the new version of the room.</i> We'll post a link to the new room in the old \" +\n                            \"version of the room - room members will have to click this link to join the new room.\",\n                            {}, {\n                                \"b\": (sub) => <b>{sub}</b>,\n                                \"i\": (sub) => <i>{sub}</i>,\n                            },\n                        )}\n                    </p>\n                </div>\n                <p className=\"mx_RoomUpgradeWarningBar_upgradelink\">\n                    <AccessibleButton onClick={this.onUpgradeClick}>\n                        {_t(\"Upgrade this room to the recommended room version\")}\n                    </AccessibleButton>\n                </p>\n            </div>\n        );\n\n        if (this.state.upgraded) {\n            doUpgradeWarnings = (\n                <div className=\"mx_RoomUpgradeWarningBar_body\">\n                    <p>\n                        {_t(\"This room has already been upgraded.\")}\n                    </p>\n                </div>\n            );\n        }\n\n        return (\n            <div className=\"mx_RoomUpgradeWarningBar\">\n                <div className=\"mx_RoomUpgradeWarningBar_wrapped\">\n                    <div className=\"mx_RoomUpgradeWarningBar_header\">\n                        {_t(\n                            \"This room is running room version <roomVersion />, which this homeserver has \" +\n                            \"marked as <i>unstable</i>.\",\n                            {},\n                            {\n                                \"roomVersion\": () => <code>{this.props.room.getVersion()}</code>,\n                                \"i\": (sub) => <i>{sub}</i>,\n                            },\n                        )}\n                    </div>\n                    {doUpgradeWarnings}\n                    <div className=\"mx_RoomUpgradeWarningBar_small\">\n                        {_t(\"Only room administrators will see this warning\")}\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\n"]}