matrix-react-sdk
Version:
SDK for matrix.org using React
155 lines (124 loc) • 19.7 kB
JavaScript
"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 _propTypes = _interopRequireDefault(require("prop-types"));
var _languageHandler = require("../../../languageHandler");
var _Pill = _interopRequireDefault(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 _replaceableComponent = require("../../../utils/replaceableComponent");
var _Media = require("../../../customisations/Media");
var _dec, _class, _class2, _temp;
let BridgeTile = (_dec = (0, _replaceableComponent.replaceableComponent)("views.settings.BridgeTile"), _dec(_class = (_temp = _class2 = class BridgeTile extends _react.default.PureComponent
/*:: <IProps>*/
{
render() {
const content
/*: IBridgeStateEvent*/
= this.props.ev.getContent(); // Validate
if (!content.channel?.id || !content.protocol?.id) {
console.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.
console.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 = null;
if (content.creator) {
creator = /*#__PURE__*/_react.default.createElement("li", null, (0, _languageHandler._t)("This bridge was provisioned by <user />.", {}, {
user: () => /*#__PURE__*/_react.default.createElement(_Pill.default, {
type: _Pill.default.TYPE_USER_MENTION,
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)("This bridge is managed by <user />.", {}, {
user: () => /*#__PURE__*/_react.default.createElement(_Pill.default, {
type: _Pill.default.TYPE_USER_MENTION,
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);
networkIcon = /*#__PURE__*/_react.default.createElement(_BaseAvatar.default, {
className: "protocol-icon",
width: 48,
height: 48,
resizeMethod: "crop",
name: protocolName,
idName: protocolName,
url: avatarUrl
});
} else {
networkIcon = /*#__PURE__*/_react.default.createElement("div", {
className: "noProtocolIcon"
});
}
let networkItem = null;
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)("Workspace: <networkLink/>", {}, {
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
}, /*#__PURE__*/_react.default.createElement("div", {
className: "column-icon"
}, networkIcon), /*#__PURE__*/_react.default.createElement("div", {
className: "column-data"
}, /*#__PURE__*/_react.default.createElement("h3", null, protocolName), /*#__PURE__*/_react.default.createElement("p", {
className: "workspace-channel-details"
}, networkItem, /*#__PURE__*/_react.default.createElement("span", {
className: "channel"
}, (0, _languageHandler._t)("Channel: <channelLink/>", {}, {
channelLink: () => channelLink
}))), /*#__PURE__*/_react.default.createElement("ul", {
className: "metadata"
}, creator, " ", bot)));
}
}, (0, _defineProperty2.default)(_class2, "propTypes", {
ev: _propTypes.default.object.isRequired,
room: _propTypes.default.object.isRequired
}), _temp)) || _class);
exports.default = BridgeTile;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/settings/BridgeTile.tsx"],"names":["BridgeTile","React","PureComponent","render","content","props","ev","getContent","channel","id","protocol","console","warn","getId","bridgebot","getSender","network","protocolName","displayname","channelName","creator","user","Pill","TYPE_USER_MENTION","room","SettingsStore","getValue","bot","networkIcon","avatar_url","avatarUrl","getSquareThumbnailHttp","networkItem","networkName","networkLink","external_url","channelLink","PropTypes","object","isRequired"],"mappings":"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","sourcesContent":["/*\nCopyright 2020 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 PropTypes from 'prop-types';\nimport {_t} from \"../../../languageHandler\";\nimport Pill from \"../elements/Pill\";\nimport {makeUserPermalink} from \"../../../utils/permalinks/Permalinks\";\nimport BaseAvatar from \"../avatars/BaseAvatar\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport {MatrixEvent} from \"matrix-js-sdk/src/models/event\";\nimport { Room } from \"matrix-js-sdk/src/models/room\";\nimport { isUrlPermitted } from '../../../HtmlUtils';\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\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\n@replaceableComponent(\"views.settings.BridgeTile\")\nexport default class BridgeTile extends React.PureComponent<IProps> {\n    static propTypes = {\n        ev: PropTypes.object.isRequired,\n        room: PropTypes.object.isRequired,\n    }\n\n    render() {\n        const content: IBridgeStateEvent = this.props.ev.getContent();\n        // Validate\n        if (!content.channel?.id || !content.protocol?.id) {\n            console.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            console.warn(`Bridge info event ${this.props.ev.getId()} does not provide a 'bridgebot' key which`\n             + \"is deprecated behaviour. Using sender for now.\");\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 = null;\n        if (content.creator) {\n            creator = <li>{_t(\"This bridge was provisioned by <user />.\", {}, {\n                user: () => <Pill\n                    type={Pill.TYPE_USER_MENTION}\n                    room={this.props.room}\n                    url={makeUserPermalink(content.creator)}\n                    shouldShowPillAvatar={SettingsStore.getValue(\"Pill.shouldShowPillAvatar\")}\n                />,\n            })}</li>;\n        }\n\n        const bot = <li>{_t(\"This bridge is managed by <user />.\", {}, {\n            user: () => <Pill\n                type={Pill.TYPE_USER_MENTION}\n                room={this.props.room}\n                url={makeUserPermalink(content.bridgebot)}\n                shouldShowPillAvatar={SettingsStore.getValue(\"Pill.shouldShowPillAvatar\")}\n            />,\n        })}</li>;\n\n        let networkIcon;\n\n        if (protocol.avatar_url) {\n            const avatarUrl = mediaFromMxc(protocol.avatar_url).getSquareThumbnailHttp(64);\n\n            networkIcon = <BaseAvatar className=\"protocol-icon\"\n                width={48}\n                height={48}\n                resizeMethod='crop'\n                name={ protocolName }\n                idName={ protocolName }\n                url={ avatarUrl }\n            />;\n        } else {\n            networkIcon = <div className=\"noProtocolIcon\"></div>;\n        }\n        let networkItem = null;\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 = <a href={network.external_url} target=\"_blank\" rel=\"noreferrer noopener\">{networkName}</a>\n            }\n            networkItem = _t(\"Workspace: <networkLink/>\", {}, {\n                networkLink: () => networkLink,\n            });\n        }\n\n        let channelLink = <span>{channelName}</span>;\n        if (typeof channel.external_url === \"string\" && isUrlPermitted(channel.external_url)) {\n            channelLink = <a href={channel.external_url} target=\"_blank\" rel=\"noreferrer noopener\">{channelName}</a>\n        }\n\n        const id = this.props.ev.getId();\n        return (<li key={id}>\n            <div className=\"column-icon\">\n                {networkIcon}\n            </div>\n            <div className=\"column-data\">\n                <h3>{protocolName}</h3>\n                <p className=\"workspace-channel-details\">\n                    {networkItem}\n                    <span className=\"channel\">{_t(\"Channel: <channelLink/>\", {}, {\n                        channelLink: () => channelLink,\n                    })}</span>\n                </p>\n                <ul className=\"metadata\">\n                    {creator} {bot}\n                </ul>\n            </div>\n        </li>);\n    }\n}\n"]}