matrix-react-sdk
Version:
SDK for matrix.org using React
85 lines (82 loc) • 15.1 kB
JavaScript
;
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 _matrix = require("matrix-js-sdk/src/matrix");
var _Modal = _interopRequireDefault(require("../../../Modal"));
var _languageHandler = require("../../../languageHandler");
var _RoomUpgradeDialog = _interopRequireDefault(require("../dialogs/RoomUpgradeDialog"));
var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext"));
/*
Copyright 2024 New Vector Ltd.
Copyright 2018-2021 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 RoomUpgradeWarningBar extends _react.default.PureComponent {
constructor(props, context) {
super(props, context);
(0, _defineProperty2.default)(this, "onStateEvents", event => {
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", () => {
_Modal.default.createDialog(_RoomUpgradeDialog.default, {
room: this.props.room
});
});
const _tombstone = this.props.room.currentState.getStateEvents("m.room.tombstone", "");
this.state = {
upgraded: _tombstone?.getContent().replacement_room
};
}
componentDidMount() {
this.context.on(_matrix.RoomStateEvent.Events, this.onStateEvents);
}
componentWillUnmount() {
this.context.removeListener(_matrix.RoomStateEvent.Events, this.onStateEvents);
}
render() {
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)("room|upgrade_warning_bar")), /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("room_settings|advanced|room_upgrade_warning", {}, {
b: sub => /*#__PURE__*/_react.default.createElement("strong", 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.default, {
onClick: this.onUpgradeClick
}, (0, _languageHandler._t)("room_settings|advanced|room_upgrade_button"))));
if (this.state.upgraded) {
doUpgradeWarnings = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RoomUpgradeWarningBar_body"
}, /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("room|upgrade_warning_bar_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)("room|upgrade_warning_bar_unstable", {}, {
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)("room|upgrade_warning_bar_admins"))));
}
}
exports.default = RoomUpgradeWarningBar;
(0, _defineProperty2.default)(RoomUpgradeWarningBar, "contextType", _MatrixClientContext.default);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_matrix","_Modal","_languageHandler","_RoomUpgradeDialog","_AccessibleButton","_MatrixClientContext","RoomUpgradeWarningBar","React","PureComponent","constructor","props","context","_defineProperty2","default","event","room","getRoomId","roomId","getType","tombstone","currentState","getStateEvents","setState","upgraded","getContent","replacement_room","Modal","createDialog","RoomUpgradeDialog","state","componentDidMount","on","RoomStateEvent","Events","onStateEvents","componentWillUnmount","removeListener","render","doUpgradeWarnings","createElement","className","_t","b","sub","i","onClick","onUpgradeClick","roomVersion","getVersion","exports","MatrixClientContext"],"sources":["../../../../src/components/views/rooms/RoomUpgradeWarningBar.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2018-2021 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\";\nimport { MatrixEvent, Room, RoomStateEvent } from \"matrix-js-sdk/src/matrix\";\n\nimport Modal from \"../../../Modal\";\nimport { _t } from \"../../../languageHandler\";\nimport RoomUpgradeDialog from \"../dialogs/RoomUpgradeDialog\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\n\ninterface IProps {\n    room: Room;\n}\n\ninterface IState {\n    upgraded?: boolean;\n}\n\nexport default class RoomUpgradeWarningBar extends React.PureComponent<IProps, IState> {\n    public static contextType = MatrixClientContext;\n    public declare context: React.ContextType<typeof MatrixClientContext>;\n\n    public constructor(props: IProps, context: React.ContextType<typeof MatrixClientContext>) {\n        super(props, context);\n\n        const tombstone = this.props.room.currentState.getStateEvents(\"m.room.tombstone\", \"\");\n        this.state = {\n            upgraded: tombstone?.getContent().replacement_room,\n        };\n    }\n\n    public componentDidMount(): void {\n        this.context.on(RoomStateEvent.Events, this.onStateEvents);\n    }\n\n    public componentWillUnmount(): void {\n        this.context.removeListener(RoomStateEvent.Events, this.onStateEvents);\n    }\n\n    private onStateEvents = (event: MatrixEvent): void => {\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    private onUpgradeClick = (): void => {\n        Modal.createDialog(RoomUpgradeDialog, { room: this.props.room });\n    };\n\n    public render(): React.ReactNode {\n        let doUpgradeWarnings = (\n            <div>\n                <div className=\"mx_RoomUpgradeWarningBar_body\">\n                    <p>{_t(\"room|upgrade_warning_bar\")}</p>\n                    <p>\n                        {_t(\n                            \"room_settings|advanced|room_upgrade_warning\",\n                            {},\n                            {\n                                b: (sub) => <strong>{sub}</strong>,\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(\"room_settings|advanced|room_upgrade_button\")}\n                    </AccessibleButton>\n                </p>\n            </div>\n        );\n\n        if (this.state.upgraded) {\n            doUpgradeWarnings = (\n                <div className=\"mx_RoomUpgradeWarningBar_body\">\n                    <p>{_t(\"room|upgrade_warning_bar_upgraded\")}</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                            \"room|upgrade_warning_bar_unstable\",\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\">{_t(\"room|upgrade_warning_bar_admins\")}</div>\n                </div>\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}