UNPKG

matrix-react-sdk

Version:
140 lines (135 loc) 21 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 _matrix = require("matrix-js-sdk/src/matrix"); var _logger = require("matrix-js-sdk/src/logger"); var _compoundWeb = require("@vector-im/compound-web"); var _MatrixClientPeg = require("../../../MatrixClientPeg"); var _languageHandler = require("../../../languageHandler"); var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher")); var _Modal = _interopRequireDefault(require("../../../Modal")); var _RoomInvite = require("../../../RoomInvite"); var _actions = require("../../../dispatcher/actions"); var _ErrorDialog = _interopRequireDefault(require("../dialogs/ErrorDialog")); var _BaseCard = _interopRequireDefault(require("../right_panel/BaseCard")); var _Flex = require("../../utils/Flex"); /* Copyright 2024 New Vector Ltd. Copyright 2019-2023 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 ThirdPartyMemberInfo extends _react.default.Component { constructor(props) { super(props); (0, _defineProperty2.default)(this, "room", void 0); (0, _defineProperty2.default)(this, "onRoomStateEvents", ev => { if (ev.getType() === _matrix.EventType.RoomThirdPartyInvite && 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: _actions.Action.View3pidInvite, event: null }); }); (0, _defineProperty2.default)(this, "onKickClick", () => { _MatrixClientPeg.MatrixClientPeg.safeGet().sendStateEvent(this.state.roomId, _matrix.EventType.RoomThirdPartyInvite, {}, this.state.stateKey).catch(err => { _logger.logger.error(err); // Revert echo because of error this.setState({ invited: true }); _Modal.default.createDialog(_ErrorDialog.default, { title: (0, _languageHandler._t)("user_info|error_revoke_3pid_invite_title"), description: (0, _languageHandler._t)("user_info|error_revoke_3pid_invite_description") }); }); // Local echo this.setState({ invited: false }); }); this.room = _MatrixClientPeg.MatrixClientPeg.safeGet().getRoom(this.props.event.getRoomId()); const me = this.room?.getMember(_MatrixClientPeg.MatrixClientPeg.safeGet().getSafeUserId()); const powerLevels = this.room?.currentState.getStateEvents("m.room.power_levels", ""); const senderId = this.props.event.getSender(); let kickLevel = powerLevels ? powerLevels.getContent().kick : 50; if (typeof kickLevel !== "number") kickLevel = 50; const sender = this.room?.getMember(senderId); 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?.name ?? senderId }; } componentDidMount() { _MatrixClientPeg.MatrixClientPeg.safeGet().on(_matrix.RoomStateEvent.Events, this.onRoomStateEvents); } componentWillUnmount() { const client = _MatrixClientPeg.MatrixClientPeg.get(); if (client) { client.removeListener(_matrix.RoomStateEvent.Events, this.onRoomStateEvents); } } render() { let adminTools; if (this.state.canKick && this.state.invited) { adminTools = /*#__PURE__*/_react.default.createElement(_Flex.Flex, { direction: "column", as: "section", justify: "start", gap: "var(--cpd-space-2x)" }, /*#__PURE__*/_react.default.createElement(_compoundWeb.Text, { as: "span", role: "heading", size: "lg", weight: "semibold" }, (0, _languageHandler._t)("user_info|admin_tools_section")), /*#__PURE__*/_react.default.createElement(_compoundWeb.Button, { size: "sm", kind: "destructive", className: "mx_MemberInfo_field", onClick: this.onKickClick }, (0, _languageHandler._t)("user_info|revoke_invite"))); } return /*#__PURE__*/_react.default.createElement(_BaseCard.default, { onClose: this.props.onClose, header: (0, _languageHandler._t)("common|profile") }, /*#__PURE__*/_react.default.createElement(_Flex.Flex, { className: "mx_ThirdPartyMemberInfo", direction: "column", gap: "var(--cpd-space-4x)" }, /*#__PURE__*/_react.default.createElement(_Flex.Flex, { direction: "column", as: "section", justify: "start", gap: "var(--cpd-space-2x)" }, /*#__PURE__*/_react.default.createElement(_compoundWeb.Text, { as: "span", role: "heading", size: "lg", weight: "semibold" }, this.state.displayName), /*#__PURE__*/_react.default.createElement(_compoundWeb.Text, { as: "span" }, (0, _languageHandler._t)("user_info|invited_by", { sender: this.state.senderName }))), adminTools)); } } exports.default = ThirdPartyMemberInfo; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_matrix","_logger","_compoundWeb","_MatrixClientPeg","_languageHandler","_dispatcher","_Modal","_RoomInvite","_actions","_ErrorDialog","_BaseCard","_Flex","ThirdPartyMemberInfo","React","Component","constructor","props","_defineProperty2","default","ev","getType","EventType","RoomThirdPartyInvite","getStateKey","state","stateKey","newDisplayName","getContent","display_name","isInvited","isValid3pidInvite","newState","invited","setState","dis","dispatch","action","Action","View3pidInvite","event","MatrixClientPeg","safeGet","sendStateEvent","roomId","catch","err","logger","error","Modal","createDialog","ErrorDialog","title","_t","description","room","getRoom","getRoomId","me","getMember","getSafeUserId","powerLevels","currentState","getStateEvents","senderId","getSender","kickLevel","kick","sender","displayName","canKick","powerLevel","senderName","name","componentDidMount","on","RoomStateEvent","Events","onRoomStateEvents","componentWillUnmount","client","get","removeListener","render","adminTools","createElement","Flex","direction","as","justify","gap","Text","role","size","weight","Button","kind","className","onClick","onKickClick","onClose","header","exports"],"sources":["../../../../src/components/views/rooms/ThirdPartyMemberInfo.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2019-2023 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 { EventType, MatrixEvent, Room, RoomStateEvent } from \"matrix-js-sdk/src/matrix\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\nimport { Button, Text } from \"@vector-im/compound-web\";\n\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport { _t } from \"../../../languageHandler\";\nimport dis from \"../../../dispatcher/dispatcher\";\nimport Modal from \"../../../Modal\";\nimport { isValid3pidInvite } from \"../../../RoomInvite\";\nimport { Action } from \"../../../dispatcher/actions\";\nimport ErrorDialog from \"../dialogs/ErrorDialog\";\nimport BaseCard from \"../right_panel/BaseCard\";\nimport { Flex } from \"../../utils/Flex\";\n\ninterface IProps {\n    event: MatrixEvent;\n    onClose?: () => void;\n}\n\ninterface IState {\n    stateKey: string;\n    roomId: string;\n    displayName: string;\n    invited: boolean;\n    canKick: boolean;\n    senderName: string;\n}\n\nexport default class ThirdPartyMemberInfo extends React.Component<IProps, IState> {\n    private readonly room: Room | null;\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.room = MatrixClientPeg.safeGet().getRoom(this.props.event.getRoomId());\n        const me = this.room?.getMember(MatrixClientPeg.safeGet().getSafeUserId());\n        const powerLevels = this.room?.currentState.getStateEvents(\"m.room.power_levels\", \"\");\n        const senderId = this.props.event.getSender()!;\n\n        let kickLevel = powerLevels ? powerLevels.getContent().kick : 50;\n        if (typeof kickLevel !== \"number\") kickLevel = 50;\n\n        const sender = this.room?.getMember(senderId);\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?.name ?? senderId,\n        };\n    }\n\n    public componentDidMount(): void {\n        MatrixClientPeg.safeGet().on(RoomStateEvent.Events, this.onRoomStateEvents);\n    }\n\n    public componentWillUnmount(): void {\n        const client = MatrixClientPeg.get();\n        if (client) {\n            client.removeListener(RoomStateEvent.Events, this.onRoomStateEvents);\n        }\n    }\n\n    public onRoomStateEvents = (ev: MatrixEvent): void => {\n        if (ev.getType() === EventType.RoomThirdPartyInvite && ev.getStateKey() === this.state.stateKey) {\n            const newDisplayName = ev.getContent().display_name;\n            const isInvited = isValid3pidInvite(ev);\n\n            const newState = { invited: isInvited } as IState;\n            if (newDisplayName) newState[\"displayName\"] = newDisplayName;\n            this.setState(newState);\n        }\n    };\n\n    public onCancel = (): void => {\n        dis.dispatch({\n            action: Action.View3pidInvite,\n            event: null,\n        });\n    };\n\n    public onKickClick = (): void => {\n        MatrixClientPeg.safeGet()\n            .sendStateEvent(this.state.roomId, EventType.RoomThirdPartyInvite, {}, this.state.stateKey)\n            .catch((err) => {\n                logger.error(err);\n\n                // Revert echo because of error\n                this.setState({ invited: true });\n\n                Modal.createDialog(ErrorDialog, {\n                    title: _t(\"user_info|error_revoke_3pid_invite_title\"),\n                    description: _t(\"user_info|error_revoke_3pid_invite_description\"),\n                });\n            });\n\n        // Local echo\n        this.setState({ invited: false });\n    };\n\n    public render(): React.ReactNode {\n        let adminTools: JSX.Element | undefined;\n        if (this.state.canKick && this.state.invited) {\n            adminTools = (\n                <Flex direction=\"column\" as=\"section\" justify=\"start\" gap=\"var(--cpd-space-2x)\">\n                    <Text as=\"span\" role=\"heading\" size=\"lg\" weight=\"semibold\">\n                        {_t(\"user_info|admin_tools_section\")}\n                    </Text>\n                    <Button size=\"sm\" kind=\"destructive\" className=\"mx_MemberInfo_field\" onClick={this.onKickClick}>\n                        {_t(\"user_info|revoke_invite\")}\n                    </Button>\n                </Flex>\n            );\n        }\n\n        return (\n            <BaseCard onClose={this.props.onClose} header={_t(\"common|profile\")}>\n                <Flex className=\"mx_ThirdPartyMemberInfo\" direction=\"column\" gap=\"var(--cpd-space-4x)\">\n                    <Flex direction=\"column\" as=\"section\" justify=\"start\" gap=\"var(--cpd-space-2x)\">\n                        {/* same as userinfo name style */}\n                        <Text as=\"span\" role=\"heading\" size=\"lg\" weight=\"semibold\">\n                            {this.state.displayName}\n                        </Text>\n                        <Text as=\"span\">{_t(\"user_info|invited_by\", { sender: this.state.senderName })}</Text>\n                    </Flex>\n                    {adminTools}\n                </Flex>\n            </BaseCard>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}