matrix-react-sdk
Version:
SDK for matrix.org using React
165 lines (134 loc) • 21.2 kB
JavaScript
"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 _MatrixClientPeg = require("../../../MatrixClientPeg");
var _languageHandler = require("../../../languageHandler");
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var sdk = _interopRequireWildcard(require("../../../index"));
var _Modal = _interopRequireDefault(require("../../../Modal"));
var _RoomInvite = require("../../../RoomInvite");
var _RoomAvatar = _interopRequireDefault(require("../avatars/RoomAvatar"));
var _RoomName = _interopRequireDefault(require("../elements/RoomName"));
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore"));
var _dec, _class, _temp;
let ThirdPartyMemberInfo = (_dec = (0, _replaceableComponent.replaceableComponent)("views.rooms.ThirdPartyMemberInfo"), _dec(_class = (_temp = class ThirdPartyMemberInfo extends _react.default.Component
/*:: <IProps, IState>*/
{
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "room", void 0);
(0, _defineProperty2.default)(this, "onRoomStateEvents", ev => {
if (ev.getType() === "m.room.third_party_invite" && ev.getStateKey() === this.state.stateKey) {
const newDisplayName = ev.getContent().display_name;
const isInvited = (0, _RoomInvite.isValid3pidInvite)(ev);
const newState = {
invited: isInvited
};
if (newDisplayName) newState['displayName'] = newDisplayName;
this.setState(newState);
}
});
(0, _defineProperty2.default)(this, "onCancel", () => {
_dispatcher.default.dispatch({
action: "view_3pid_invite",
event: null
});
});
(0, _defineProperty2.default)(this, "onKickClick", () => {
_MatrixClientPeg.MatrixClientPeg.get().sendStateEvent(this.state.roomId, "m.room.third_party_invite", {}, this.state.stateKey).catch(err => {
console.error(err); // Revert echo because of error
this.setState({
invited: true
});
const ErrorDialog = sdk.getComponent("dialogs.ErrorDialog");
_Modal.default.createTrackedDialog('Revoke 3pid invite failed', '', ErrorDialog, {
title: (0, _languageHandler._t)("Failed to revoke invite"),
description: (0, _languageHandler._t)("Could not revoke the invite. The server may be experiencing a temporary problem or " + "you do not have sufficient permissions to revoke the invite.")
});
}); // Local echo
this.setState({
invited: false
});
});
this.room = _MatrixClientPeg.MatrixClientPeg.get().getRoom(this.props.event.getRoomId());
const me = this.room.getMember(_MatrixClientPeg.MatrixClientPeg.get().getUserId());
const powerLevels = this.room.currentState.getStateEvents("m.room.power_levels", "");
let kickLevel = powerLevels ? powerLevels.getContent().kick : 50;
if (typeof kickLevel !== 'number') kickLevel = 50;
const sender = this.room.getMember(this.props.event.getSender());
this.state = {
stateKey: this.props.event.getStateKey(),
roomId: this.props.event.getRoomId(),
displayName: this.props.event.getContent().display_name,
invited: true,
canKick: me ? me.powerLevel > kickLevel : false,
senderName: sender ? sender.name : this.props.event.getSender()
};
}
componentDidMount()
/*: void*/
{
_MatrixClientPeg.MatrixClientPeg.get().on("RoomState.events", this.onRoomStateEvents);
}
componentWillUnmount()
/*: void*/
{
const client = _MatrixClientPeg.MatrixClientPeg.get();
if (client) {
client.removeListener("RoomState.events", this.onRoomStateEvents);
}
}
render() {
const AccessibleButton = sdk.getComponent("elements.AccessibleButton");
let adminTools = null;
if (this.state.canKick && this.state.invited) {
adminTools = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo_container"
}, /*#__PURE__*/_react.default.createElement("h3", null, (0, _languageHandler._t)("Admin Tools")), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo_buttons"
}, /*#__PURE__*/_react.default.createElement(AccessibleButton, {
className: "mx_MemberInfo_field",
onClick: this.onKickClick
}, (0, _languageHandler._t)("Revoke invite"))));
}
let scopeHeader;
if (_SettingsStore.default.getValue("feature_spaces") && this.room.isSpaceRoom()) {
scopeHeader = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RightPanel_scopeHeader"
}, /*#__PURE__*/_react.default.createElement(_RoomAvatar.default, {
room: this.room,
height: 32,
width: 32
}), /*#__PURE__*/_react.default.createElement(_RoomName.default, {
room: this.room
}));
} // We shamelessly rip off the MemberInfo styles here.
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo",
role: "tabpanel"
}, scopeHeader, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo_name"
}, /*#__PURE__*/_react.default.createElement(AccessibleButton, {
className: "mx_MemberInfo_cancel",
onClick: this.onCancel,
title: (0, _languageHandler._t)('Close')
}), /*#__PURE__*/_react.default.createElement("h2", null, this.state.displayName)), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo_container"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo_profile"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MemberInfo_profileField"
}, (0, _languageHandler._t)("Invited by %(sender)s", {
sender: this.state.senderName
})))), adminTools);
}
}, _temp)) || _class);
exports.default = ThirdPartyMemberInfo;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/rooms/ThirdPartyMemberInfo.tsx"],"names":["ThirdPartyMemberInfo","React","Component","constructor","props","ev","getType","getStateKey","state","stateKey","newDisplayName","getContent","display_name","isInvited","newState","invited","setState","dis","dispatch","action","event","MatrixClientPeg","get","sendStateEvent","roomId","catch","err","console","error","ErrorDialog","sdk","getComponent","Modal","createTrackedDialog","title","description","room","getRoom","getRoomId","me","getMember","getUserId","powerLevels","currentState","getStateEvents","kickLevel","kick","sender","getSender","displayName","canKick","powerLevel","senderName","name","componentDidMount","on","onRoomStateEvents","componentWillUnmount","client","removeListener","render","AccessibleButton","adminTools","onKickClick","scopeHeader","SettingsStore","getValue","isSpaceRoom","onCancel"],"mappings":"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","sourcesContent":["/*\nCopyright 2019-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 {MatrixClientPeg} from \"../../../MatrixClientPeg\";\nimport {MatrixEvent} from \"matrix-js-sdk/src/models/event\";\nimport {Room} from \"matrix-js-sdk/src/models/room\";\nimport {_t} from \"../../../languageHandler\";\nimport dis from \"../../../dispatcher/dispatcher\";\nimport * as sdk from \"../../../index\";\nimport Modal from \"../../../Modal\";\nimport {isValid3pidInvite} from \"../../../RoomInvite\";\nimport RoomAvatar from \"../avatars/RoomAvatar\";\nimport RoomName from \"../elements/RoomName\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\n\ninterface IProps {\n    event: MatrixEvent;\n}\n\ninterface IState {\n    stateKey: string;\n    roomId: string;\n    displayName: string;\n    invited: boolean;\n    canKick: boolean;\n    senderName: string;\n}\n\n@replaceableComponent(\"views.rooms.ThirdPartyMemberInfo\")\nexport default class ThirdPartyMemberInfo extends React.Component<IProps, IState> {\n    private room: Room;\n\n    constructor(props) {\n        super(props);\n\n        this.room = MatrixClientPeg.get().getRoom(this.props.event.getRoomId());\n        const me = this.room.getMember(MatrixClientPeg.get().getUserId());\n        const powerLevels = this.room.currentState.getStateEvents(\"m.room.power_levels\", \"\");\n\n        let kickLevel = powerLevels ? powerLevels.getContent().kick : 50;\n        if (typeof(kickLevel) !== 'number') kickLevel = 50;\n\n        const sender = this.room.getMember(this.props.event.getSender());\n\n        this.state = {\n            stateKey: this.props.event.getStateKey(),\n            roomId: this.props.event.getRoomId(),\n            displayName: this.props.event.getContent().display_name,\n            invited: true,\n            canKick: me ? me.powerLevel > kickLevel : false,\n            senderName: sender ? sender.name : this.props.event.getSender(),\n        };\n    }\n\n    componentDidMount(): void {\n        MatrixClientPeg.get().on(\"RoomState.events\", this.onRoomStateEvents);\n    }\n\n    componentWillUnmount(): void {\n        const client = MatrixClientPeg.get();\n        if (client) {\n            client.removeListener(\"RoomState.events\", this.onRoomStateEvents);\n        }\n    }\n\n    onRoomStateEvents = (ev) => {\n        if (ev.getType() === \"m.room.third_party_invite\" && ev.getStateKey() === this.state.stateKey) {\n            const newDisplayName = ev.getContent().display_name;\n            const isInvited = isValid3pidInvite(ev);\n\n            const newState = {invited: isInvited};\n            if (newDisplayName) newState['displayName'] = newDisplayName;\n            this.setState(newState);\n        }\n    };\n\n    onCancel = () => {\n        dis.dispatch({\n            action: \"view_3pid_invite\",\n            event: null,\n        });\n    };\n\n    onKickClick = () => {\n        MatrixClientPeg.get().sendStateEvent(this.state.roomId, \"m.room.third_party_invite\", {}, this.state.stateKey)\n            .catch((err) => {\n                console.error(err);\n\n                // Revert echo because of error\n                this.setState({invited: true});\n\n                const ErrorDialog = sdk.getComponent(\"dialogs.ErrorDialog\");\n                Modal.createTrackedDialog('Revoke 3pid invite failed', '', ErrorDialog, {\n                    title: _t(\"Failed to revoke invite\"),\n                    description: _t(\n                        \"Could not revoke the invite. The server may be experiencing a temporary problem or \" +\n                        \"you do not have sufficient permissions to revoke the invite.\",\n                    ),\n                });\n            });\n\n        // Local echo\n        this.setState({invited: false});\n    };\n\n    render() {\n        const AccessibleButton = sdk.getComponent(\"elements.AccessibleButton\");\n\n        let adminTools = null;\n        if (this.state.canKick && this.state.invited) {\n            adminTools = (\n                <div className=\"mx_MemberInfo_container\">\n                    <h3>{_t(\"Admin Tools\")}</h3>\n                    <div className=\"mx_MemberInfo_buttons\">\n                        <AccessibleButton className=\"mx_MemberInfo_field\" onClick={this.onKickClick}>\n                            {_t(\"Revoke invite\")}\n                        </AccessibleButton>\n                    </div>\n                </div>\n            );\n        }\n\n        let scopeHeader;\n        if (SettingsStore.getValue(\"feature_spaces\") && this.room.isSpaceRoom()) {\n            scopeHeader = <div className=\"mx_RightPanel_scopeHeader\">\n                <RoomAvatar room={this.room} height={32} width={32} />\n                <RoomName room={this.room} />\n            </div>;\n        }\n\n        // We shamelessly rip off the MemberInfo styles here.\n        return (\n            <div className=\"mx_MemberInfo\" role=\"tabpanel\">\n                { scopeHeader }\n                <div className=\"mx_MemberInfo_name\">\n                    <AccessibleButton className=\"mx_MemberInfo_cancel\"\n                        onClick={this.onCancel}\n                        title={_t('Close')}\n                    />\n                    <h2>{this.state.displayName}</h2>\n                </div>\n                <div className=\"mx_MemberInfo_container\">\n                    <div className=\"mx_MemberInfo_profile\">\n                        <div className=\"mx_MemberInfo_profileField\">\n                            {_t(\"Invited by %(sender)s\", {sender: this.state.senderName})}\n                        </div>\n                    </div>\n                </div>\n                {adminTools}\n            </div>\n        );\n    }\n}\n"]}