UNPKG

matrix-react-sdk

Version:
129 lines (125 loc) 22.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireDefault(require("react")); var _logger = require("matrix-js-sdk/src/logger"); var _languageHandler = require("../../../languageHandler"); var _Pill = require("../elements/Pill"); var _Permalinks = require("../../../utils/permalinks/Permalinks"); var _BaseAvatar = _interopRequireDefault(require("../avatars/BaseAvatar")); var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore")); var _HtmlUtils = require("../../../HtmlUtils"); var _Media = require("../../../customisations/Media"); /* Copyright 2024 New Vector Ltd. Copyright 2020-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. */ /** * This should match https://github.com/matrix-org/matrix-doc/blob/hs/msc-bridge-inf/proposals/2346-bridge-info-state-event.md#mbridge */ class BridgeTile extends _react.default.PureComponent { render() { const content = this.props.ev.getContent(); // Validate if (!content.channel?.id || !content.protocol?.id) { _logger.logger.warn(`Bridge info event ${this.props.ev.getId()} has missing content. Tile will not render`); return null; } if (!content.bridgebot) { // Bridgebot was not required previously, so in order to not break rooms we are allowing // the sender to be used in place. When the proposal is merged, this should be removed. _logger.logger.warn(`Bridge info event ${this.props.ev.getId()} does not provide a 'bridgebot' key which` + "is deprecated behaviour. Using sender for now."); content.bridgebot = this.props.ev.getSender(); } const { channel, network, protocol } = content; const protocolName = protocol.displayname || protocol.id; const channelName = channel.displayname || channel.id; let creator; if (content.creator) { creator = /*#__PURE__*/_react.default.createElement("li", null, (0, _languageHandler._t)("labs|bridge_state_creator", {}, { user: () => /*#__PURE__*/_react.default.createElement(_Pill.Pill, { type: _Pill.PillType.UserMention, room: this.props.room, url: (0, _Permalinks.makeUserPermalink)(content.creator), shouldShowPillAvatar: _SettingsStore.default.getValue("Pill.shouldShowPillAvatar") }) })); } const bot = /*#__PURE__*/_react.default.createElement("li", null, (0, _languageHandler._t)("labs|bridge_state_manager", {}, { user: () => /*#__PURE__*/_react.default.createElement(_Pill.Pill, { type: _Pill.PillType.UserMention, room: this.props.room, url: (0, _Permalinks.makeUserPermalink)(content.bridgebot), shouldShowPillAvatar: _SettingsStore.default.getValue("Pill.shouldShowPillAvatar") }) })); let networkIcon; if (protocol.avatar_url) { const avatarUrl = (0, _Media.mediaFromMxc)(protocol.avatar_url).getSquareThumbnailHttp(64) ?? undefined; networkIcon = /*#__PURE__*/_react.default.createElement(_BaseAvatar.default, { className: "mx_RoomSettingsDialog_protocolIcon", size: "48px", name: protocolName, idName: protocolName, url: avatarUrl }); } else { networkIcon = /*#__PURE__*/_react.default.createElement("div", { className: "mx_RoomSettingsDialog_noProtocolIcon" }); } let networkItem; if (network) { const networkName = network.displayname || network.id; let networkLink = /*#__PURE__*/_react.default.createElement("span", null, networkName); if (typeof network.external_url === "string" && (0, _HtmlUtils.isUrlPermitted)(network.external_url)) { networkLink = /*#__PURE__*/_react.default.createElement("a", { href: network.external_url, target: "_blank", rel: "noreferrer noopener" }, networkName); } networkItem = (0, _languageHandler._t)("labs|bridge_state_workspace", {}, { networkLink: () => networkLink }); } let channelLink = /*#__PURE__*/_react.default.createElement("span", null, channelName); if (typeof channel.external_url === "string" && (0, _HtmlUtils.isUrlPermitted)(channel.external_url)) { channelLink = /*#__PURE__*/_react.default.createElement("a", { href: channel.external_url, target: "_blank", rel: "noreferrer noopener" }, channelName); } const id = this.props.ev.getId(); return /*#__PURE__*/_react.default.createElement("li", { key: id, className: "mx_RoomSettingsDialog_BridgeList_listItem" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_RoomSettingsDialog_column_icon" }, networkIcon), /*#__PURE__*/_react.default.createElement("div", { className: "mx_RoomSettingsDialog_column_data" }, /*#__PURE__*/_react.default.createElement("h3", { className: "mx_RoomSettingsDialog_column_data_protocolName" }, protocolName), /*#__PURE__*/_react.default.createElement("p", { className: "mx_RoomSettingsDialog_column_data_details mx_RoomSettingsDialog_workspace_channel_details" }, networkItem, /*#__PURE__*/_react.default.createElement("span", { className: "mx_RoomSettingsDialog_channel" }, (0, _languageHandler._t)("labs|bridge_state_channel", {}, { channelLink: () => channelLink }))), /*#__PURE__*/_react.default.createElement("ul", { className: "mx_RoomSettingsDialog_column_data_metadata mx_RoomSettingsDialog_metadata" }, creator, " ", bot))); } } exports.default = BridgeTile; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_logger","_languageHandler","_Pill","_Permalinks","_BaseAvatar","_SettingsStore","_HtmlUtils","_Media","BridgeTile","React","PureComponent","render","content","props","ev","getContent","channel","id","protocol","logger","warn","getId","bridgebot","getSender","network","protocolName","displayname","channelName","creator","default","createElement","_t","user","Pill","type","PillType","UserMention","room","url","makeUserPermalink","shouldShowPillAvatar","SettingsStore","getValue","bot","networkIcon","avatar_url","avatarUrl","mediaFromMxc","getSquareThumbnailHttp","undefined","className","size","name","idName","networkItem","networkName","networkLink","external_url","isUrlPermitted","href","target","rel","channelLink","key","exports"],"sources":["../../../../src/components/views/settings/BridgeTile.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020-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, { ReactNode } from \"react\";\nimport { MatrixEvent, Room } from \"matrix-js-sdk/src/matrix\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\n\nimport { _t } from \"../../../languageHandler\";\nimport { Pill, PillType } from \"../elements/Pill\";\nimport { makeUserPermalink } from \"../../../utils/permalinks/Permalinks\";\nimport BaseAvatar from \"../avatars/BaseAvatar\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport { isUrlPermitted } from \"../../../HtmlUtils\";\nimport { mediaFromMxc } from \"../../../customisations/Media\";\n\ninterface IProps {\n    ev: MatrixEvent;\n    room: Room;\n}\n\n/**\n * This should match https://github.com/matrix-org/matrix-doc/blob/hs/msc-bridge-inf/proposals/2346-bridge-info-state-event.md#mbridge\n */\ninterface IBridgeStateEvent {\n    bridgebot: string;\n    creator?: string;\n    protocol: {\n        id: string;\n        displayname?: string;\n        // eslint-disable-next-line camelcase\n        avatar_url?: string;\n        // eslint-disable-next-line camelcase\n        external_url?: string;\n    };\n    network?: {\n        id: string;\n        displayname?: string;\n        // eslint-disable-next-line camelcase\n        avatar_url?: string;\n        // eslint-disable-next-line camelcase\n        external_url?: string;\n    };\n    channel: {\n        id: string;\n        displayname?: string;\n        // eslint-disable-next-line camelcase\n        avatar_url?: string;\n        // eslint-disable-next-line camelcase\n        external_url?: string;\n    };\n}\n\nexport default class BridgeTile extends React.PureComponent<IProps> {\n    public render(): React.ReactNode {\n        const content: IBridgeStateEvent = this.props.ev.getContent();\n        // Validate\n        if (!content.channel?.id || !content.protocol?.id) {\n            logger.warn(`Bridge info event ${this.props.ev.getId()} has missing content. Tile will not render`);\n            return null;\n        }\n        if (!content.bridgebot) {\n            // Bridgebot was not required previously, so in order to not break rooms we are allowing\n            // the sender to be used in place. When the proposal is merged, this should be removed.\n            logger.warn(\n                `Bridge info event ${this.props.ev.getId()} does not provide a 'bridgebot' key which` +\n                    \"is deprecated behaviour. Using sender for now.\",\n            );\n            content.bridgebot = this.props.ev.getSender()!;\n        }\n        const { channel, network, protocol } = content;\n        const protocolName = protocol.displayname || protocol.id;\n        const channelName = channel.displayname || channel.id;\n\n        let creator: JSX.Element | undefined;\n        if (content.creator) {\n            creator = (\n                <li>\n                    {_t(\n                        \"labs|bridge_state_creator\",\n                        {},\n                        {\n                            user: () => (\n                                <Pill\n                                    type={PillType.UserMention}\n                                    room={this.props.room}\n                                    url={makeUserPermalink(content.creator!)}\n                                    shouldShowPillAvatar={SettingsStore.getValue(\"Pill.shouldShowPillAvatar\")}\n                                />\n                            ),\n                        },\n                    )}\n                </li>\n            );\n        }\n\n        const bot = (\n            <li>\n                {_t(\n                    \"labs|bridge_state_manager\",\n                    {},\n                    {\n                        user: () => (\n                            <Pill\n                                type={PillType.UserMention}\n                                room={this.props.room}\n                                url={makeUserPermalink(content.bridgebot)}\n                                shouldShowPillAvatar={SettingsStore.getValue(\"Pill.shouldShowPillAvatar\")}\n                            />\n                        ),\n                    },\n                )}\n            </li>\n        );\n\n        let networkIcon;\n\n        if (protocol.avatar_url) {\n            const avatarUrl = mediaFromMxc(protocol.avatar_url).getSquareThumbnailHttp(64) ?? undefined;\n\n            networkIcon = (\n                <BaseAvatar\n                    className=\"mx_RoomSettingsDialog_protocolIcon\"\n                    size=\"48px\"\n                    name={protocolName}\n                    idName={protocolName}\n                    url={avatarUrl}\n                />\n            );\n        } else {\n            networkIcon = <div className=\"mx_RoomSettingsDialog_noProtocolIcon\" />;\n        }\n        let networkItem: ReactNode | undefined;\n        if (network) {\n            const networkName = network.displayname || network.id;\n            let networkLink = <span>{networkName}</span>;\n            if (typeof network.external_url === \"string\" && isUrlPermitted(network.external_url)) {\n                networkLink = (\n                    <a href={network.external_url} target=\"_blank\" rel=\"noreferrer noopener\">\n                        {networkName}\n                    </a>\n                );\n            }\n            networkItem = _t(\n                \"labs|bridge_state_workspace\",\n                {},\n                {\n                    networkLink: () => networkLink,\n                },\n            );\n        }\n\n        let channelLink = <span>{channelName}</span>;\n        if (typeof channel.external_url === \"string\" && isUrlPermitted(channel.external_url)) {\n            channelLink = (\n                <a href={channel.external_url} target=\"_blank\" rel=\"noreferrer noopener\">\n                    {channelName}\n                </a>\n            );\n        }\n\n        const id = this.props.ev.getId();\n        return (\n            <li key={id} className=\"mx_RoomSettingsDialog_BridgeList_listItem\">\n                <div className=\"mx_RoomSettingsDialog_column_icon\">{networkIcon}</div>\n                <div className=\"mx_RoomSettingsDialog_column_data\">\n                    <h3 className=\"mx_RoomSettingsDialog_column_data_protocolName\">{protocolName}</h3>\n                    <p className=\"mx_RoomSettingsDialog_column_data_details mx_RoomSettingsDialog_workspace_channel_details\">\n                        {networkItem}\n                        <span className=\"mx_RoomSettingsDialog_channel\">\n                            {_t(\n                                \"labs|bridge_state_channel\",\n                                {},\n                                {\n                                    channelLink: () => channelLink,\n                                },\n                            )}\n                        </span>\n                    </p>\n                    <ul className=\"mx_RoomSettingsDialog_column_data_metadata mx_RoomSettingsDialog_metadata\">\n                        {creator} {bot}\n                    </ul>\n                </div>\n            </li>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}