matrix-react-sdk
Version:
SDK for matrix.org using React
105 lines (86 loc) • 12.6 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireDefault(require("react"));
var _languageHandler = require("../../../../../languageHandler");
var _MatrixClientPeg = require("../../../../../MatrixClientPeg");
var _BridgeTile = _interopRequireDefault(require("../../BridgeTile"));
var _replaceableComponent = require("../../../../../utils/replaceableComponent");
var _dec, _class;
const BRIDGE_EVENT_TYPES = ["uk.half-shot.bridge" // m.bridge
];
const BRIDGES_LINK = "https://matrix.org/bridges/";
let BridgeSettingsTab = (_dec = (0, _replaceableComponent.replaceableComponent)("views.settings.tabs.room.BridgeSettingsTab"), _dec(_class = class BridgeSettingsTab extends _react.default.Component
/*:: <IProps>*/
{
renderBridgeCard(event
/*: MatrixEvent*/
, room
/*: Room*/
) {
const content = event.getContent();
if (!content || !content.channel || !content.protocol) {
return null;
}
return /*#__PURE__*/_react.default.createElement(_BridgeTile.default, {
key: event.getId(),
room: room,
ev: event
});
}
static getBridgeStateEvents(roomId
/*: string*/
) {
const client = _MatrixClientPeg.MatrixClientPeg.get();
const roomState = client.getRoom(roomId).currentState;
return BRIDGE_EVENT_TYPES.map(typeName => {
const events = roomState.events.get(typeName);
return events ? Array.from(events.values()) : [];
}).flat(1);
}
render() {
// This settings tab will only be invoked if the following function returns more
// than 0 events, so no validation is needed at this stage.
const bridgeEvents = BridgeSettingsTab.getBridgeStateEvents(this.props.roomId);
const client = _MatrixClientPeg.MatrixClientPeg.get();
const room = client.getRoom(this.props.roomId);
let content
/*: JSX.Element*/
;
if (bridgeEvents.length > 0) {
content = /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("This room is bridging messages to the following platforms. " + "<a>Learn more.</a>", {}, {
// TODO: We don't have this link yet: this will prevent the translators
// having to re-translate the string when we do.
a: sub => /*#__PURE__*/_react.default.createElement("a", {
href: BRIDGES_LINK,
target: "_blank",
rel: "noreferrer noopener"
}, sub)
})), /*#__PURE__*/_react.default.createElement("ul", {
className: "mx_RoomSettingsDialog_BridgeList"
}, bridgeEvents.map(event => this.renderBridgeCard(event, room))));
} else {
content = /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("This room isn’t bridging messages to any platforms. " + "<a>Learn more.</a>", {}, {
// TODO: We don't have this link yet: this will prevent the translators
// having to re-translate the string when we do.
a: sub => /*#__PURE__*/_react.default.createElement("a", {
href: BRIDGES_LINK,
target: "_blank",
rel: "noreferrer noopener"
}, sub)
}));
}
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_SettingsTab"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_SettingsTab_heading"
}, (0, _languageHandler._t)("Bridges")), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_SettingsTab_section mx_SettingsTab_subsectionText"
}, content));
}
}) || _class);
exports.default = BridgeSettingsTab;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../../src/components/views/settings/tabs/room/BridgeSettingsTab.tsx"],"names":["BRIDGE_EVENT_TYPES","BRIDGES_LINK","BridgeSettingsTab","React","Component","renderBridgeCard","event","room","content","getContent","channel","protocol","getId","getBridgeStateEvents","roomId","client","MatrixClientPeg","get","roomState","getRoom","currentState","map","typeName","events","Array","from","values","flat","render","bridgeEvents","props","length","a","sub"],"mappings":";;;;;;;;;AAgBA;;AAIA;;AACA;;AACA;;AACA;;;;AAEA,MAAMA,kBAAkB,GAAG,CACvB,qBADuB,CAEvB;AAFuB,CAA3B;AAKA,MAAMC,YAAY,GAAG,6BAArB;IAOqBC,iB,WADpB,gDAAqB,4CAArB,C,gBAAD,MACqBA,iBADrB,SAC+CC,eAAMC;AADrD;AACuE;AAC3DC,EAAAA,gBAAR,CAAyBC;AAAzB;AAAA,IAA6CC;AAA7C;AAAA,IAAyD;AACrD,UAAMC,OAAO,GAAGF,KAAK,CAACG,UAAN,EAAhB;;AACA,QAAI,CAACD,OAAD,IAAY,CAACA,OAAO,CAACE,OAArB,IAAgC,CAACF,OAAO,CAACG,QAA7C,EAAuD;AACnD,aAAO,IAAP;AACH;;AACD,wBAAO,6BAAC,mBAAD;AAAY,MAAA,GAAG,EAAEL,KAAK,CAACM,KAAN,EAAjB;AAAgC,MAAA,IAAI,EAAEL,IAAtC;AAA4C,MAAA,EAAE,EAAED;AAAhD,MAAP;AACH;;AAED,SAAOO,oBAAP,CAA4BC;AAA5B;AAAA,IAA4C;AACxC,UAAMC,MAAM,GAAGC,iCAAgBC,GAAhB,EAAf;;AACA,UAAMC,SAAS,GAAGH,MAAM,CAACI,OAAP,CAAeL,MAAf,EAAuBM,YAAzC;AAEA,WAAOpB,kBAAkB,CAACqB,GAAnB,CAAuBC,QAAQ,IAAI;AACtC,YAAMC,MAAM,GAAGL,SAAS,CAACK,MAAV,CAAiBN,GAAjB,CAAqBK,QAArB,CAAf;AACA,aAAOC,MAAM,GAAGC,KAAK,CAACC,IAAN,CAAWF,MAAM,CAACG,MAAP,EAAX,CAAH,GAAiC,EAA9C;AACH,KAHM,EAGJC,IAHI,CAGC,CAHD,CAAP;AAIH;;AAEDC,EAAAA,MAAM,GAAG;AACL;AACA;AACA,UAAMC,YAAY,GAAG3B,iBAAiB,CAACW,oBAAlB,CAAuC,KAAKiB,KAAL,CAAWhB,MAAlD,CAArB;;AACA,UAAMC,MAAM,GAAGC,iCAAgBC,GAAhB,EAAf;;AACA,UAAMV,IAAI,GAAGQ,MAAM,CAACI,OAAP,CAAe,KAAKW,KAAL,CAAWhB,MAA1B,CAAb;AAEA,QAAIN;AAAoB;AAAxB;;AACA,QAAIqB,YAAY,CAACE,MAAb,GAAsB,CAA1B,EAA6B;AACzBvB,MAAAA,OAAO,gBAAG,uDACN,wCAAI,yBACA,gEACA,oBAFA,EAEsB,EAFtB,EAGA;AACI;AACA;AACAwB,QAAAA,CAAC,EAAEC,GAAG,iBAAI;AAAG,UAAA,IAAI,EAAEhC,YAAT;AAAuB,UAAA,MAAM,EAAC,QAA9B;AAAuC,UAAA,GAAG,EAAC;AAA3C,WAAkEgC,GAAlE;AAHd,OAHA,CAAJ,CADM,eAUN;AAAI,QAAA,SAAS,EAAC;AAAd,SACMJ,YAAY,CAACR,GAAb,CAAkBf,KAAD,IAAW,KAAKD,gBAAL,CAAsBC,KAAtB,EAA6BC,IAA7B,CAA5B,CADN,CAVM,CAAV;AAcH,KAfD,MAeO;AACHC,MAAAA,OAAO,gBAAG,wCAAI,yBACV,yDACA,oBAFU,EAEY,EAFZ,EAGV;AACI;AACA;AACAwB,QAAAA,CAAC,EAAEC,GAAG,iBAAI;AAAG,UAAA,IAAI,EAAEhC,YAAT;AAAuB,UAAA,MAAM,EAAC,QAA9B;AAAuC,UAAA,GAAG,EAAC;AAA3C,WAAkEgC,GAAlE;AAHd,OAHU,CAAJ,CAAV;AASH;;AAED,wBACI;AAAK,MAAA,SAAS,EAAC;AAAf,oBACI;AAAK,MAAA,SAAS,EAAC;AAAf,OAAyC,yBAAG,SAAH,CAAzC,CADJ,eAEI;AAAK,MAAA,SAAS,EAAC;AAAf,OACKzB,OADL,CAFJ,CADJ;AAQH;;AA9DkE,C","sourcesContent":["/*\nCopyright 2019, 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 {Room} from \"matrix-js-sdk/src/models/room\";\nimport {MatrixEvent} from \"matrix-js-sdk/src/models/event\";\n\nimport {_t} from \"../../../../../languageHandler\";\nimport {MatrixClientPeg} from \"../../../../../MatrixClientPeg\";\nimport BridgeTile from \"../../BridgeTile\";\nimport {replaceableComponent} from \"../../../../../utils/replaceableComponent\";\n\nconst BRIDGE_EVENT_TYPES = [\n    \"uk.half-shot.bridge\",\n    // m.bridge\n];\n\nconst BRIDGES_LINK = \"https://matrix.org/bridges/\";\n\ninterface IProps {\n    roomId: string;\n}\n\n@replaceableComponent(\"views.settings.tabs.room.BridgeSettingsTab\")\nexport default class BridgeSettingsTab extends React.Component<IProps> {\n    private renderBridgeCard(event: MatrixEvent, room: Room) {\n        const content = event.getContent();\n        if (!content || !content.channel || !content.protocol) {\n            return null;\n        }\n        return <BridgeTile key={event.getId()} room={room} ev={event} />;\n    }\n\n    static getBridgeStateEvents(roomId: string) {\n        const client = MatrixClientPeg.get();\n        const roomState = client.getRoom(roomId).currentState;\n\n        return BRIDGE_EVENT_TYPES.map(typeName => {\n            const events = roomState.events.get(typeName);\n            return events ? Array.from(events.values()) : [];\n        }).flat(1);\n    }\n\n    render() {\n        // This settings tab will only be invoked if the following function returns more\n        // than 0 events, so no validation is needed at this stage.\n        const bridgeEvents = BridgeSettingsTab.getBridgeStateEvents(this.props.roomId);\n        const client = MatrixClientPeg.get();\n        const room = client.getRoom(this.props.roomId);\n\n        let content: JSX.Element;\n        if (bridgeEvents.length > 0) {\n            content = <div>\n                <p>{_t(\n                    \"This room is bridging messages to the following platforms. \" +\n                    \"<a>Learn more.</a>\", {},\n                    {\n                        // TODO: We don't have this link yet: this will prevent the translators\n                        // having to re-translate the string when we do.\n                        a: sub => <a href={BRIDGES_LINK} target=\"_blank\" rel=\"noreferrer noopener\">{sub}</a>,\n                    },\n                )}</p>\n                <ul className=\"mx_RoomSettingsDialog_BridgeList\">\n                    { bridgeEvents.map((event) => this.renderBridgeCard(event, room)) }\n                </ul>\n            </div>;\n        } else {\n            content = <p>{_t(\n                \"This room isn’t bridging messages to any platforms. \" +\n                \"<a>Learn more.</a>\", {},\n                {\n                    // TODO: We don't have this link yet: this will prevent the translators\n                    // having to re-translate the string when we do.\n                    a: sub => <a href={BRIDGES_LINK} target=\"_blank\" rel=\"noreferrer noopener\">{sub}</a>,\n                },\n            )}</p>;\n        }\n\n        return (\n            <div className=\"mx_SettingsTab\">\n                <div className=\"mx_SettingsTab_heading\">{_t(\"Bridges\")}</div>\n                <div className='mx_SettingsTab_section mx_SettingsTab_subsectionText'>\n                    {content}\n                </div>\n            </div>\n        );\n    }\n}\n"]}