matrix-react-sdk
Version:
SDK for matrix.org using React
224 lines (221 loc) • 42.6 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _matrix = require("matrix-js-sdk/src/matrix");
var _types = require("matrix-js-sdk/src/types");
var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext"));
var _RoomContext = _interopRequireDefault(require("../../../contexts/RoomContext"));
var _DMRoomMap = _interopRequireDefault(require("../../../utils/DMRoomMap"));
var _languageHandler = require("../../../languageHandler");
var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _MiniAvatarUploader = _interopRequireWildcard(require("../elements/MiniAvatarUploader"));
var _RoomAvatar = _interopRequireDefault(require("../avatars/RoomAvatar"));
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _actions = require("../../../dispatcher/actions");
var _SpaceStore = _interopRequireDefault(require("../../../stores/spaces/SpaceStore"));
var _space = require("../../../utils/space");
var _EventTileBubble = _interopRequireDefault(require("../messages/EventTileBubble"));
var _RoomSettingsDialog = require("../dialogs/RoomSettingsDialog");
var _MatrixClientPeg = require("../../../MatrixClientPeg");
var _UIComponents = require("../../../customisations/helpers/UIComponents");
var _UIFeature = require("../../../settings/UIFeature");
var _rooms = require("../../../utils/rooms");
var _LocalRoom = require("../../../models/LocalRoom");
var _shouldEncryptRoomWithSingle3rdPartyInvite = require("../../../utils/room/shouldEncryptRoomWithSingle3rdPartyInvite");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
/*
Copyright 2024 New Vector Ltd.
Copyright 2020, 2021 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.
*/
function hasExpectedEncryptionSettings(matrixClient, room) {
const isEncrypted = matrixClient.isRoomEncrypted(room.roomId);
const isPublic = room.getJoinRule() === "public";
return isPublic || !(0, _rooms.privateShouldBeEncrypted)(matrixClient) || isEncrypted;
}
const determineIntroMessage = (room, encryptedSingle3rdPartyInvite) => {
if (room instanceof _LocalRoom.LocalRoom) {
return (0, _languageHandler._td)("room|intro|send_message_start_dm");
}
if (encryptedSingle3rdPartyInvite) {
return (0, _languageHandler._td)("room|intro|encrypted_3pid_dm_pending_join");
}
return (0, _languageHandler._td)("room|intro|start_of_dm_history");
};
const NewRoomIntro = () => {
const cli = (0, _react.useContext)(_MatrixClientContext.default);
const {
room,
roomId
} = (0, _react.useContext)(_RoomContext.default);
if (!room || !roomId) {
throw new Error("Unable to create a NewRoomIntro without room and roomId");
}
const isLocalRoom = room instanceof _LocalRoom.LocalRoom;
const dmPartner = isLocalRoom ? room.targets[0]?.userId : _DMRoomMap.default.shared().getUserIdForRoomId(roomId);
let body;
if (dmPartner) {
const {
shouldEncrypt: encryptedSingle3rdPartyInvite
} = (0, _shouldEncryptRoomWithSingle3rdPartyInvite.shouldEncryptRoomWithSingle3rdPartyInvite)(room);
const introMessage = determineIntroMessage(room, encryptedSingle3rdPartyInvite);
let caption;
if (!(room instanceof _LocalRoom.LocalRoom) && !encryptedSingle3rdPartyInvite && room.getJoinedMemberCount() + room.getInvitedMemberCount() === 2) {
caption = (0, _languageHandler._t)("room|intro|dm_caption");
}
const member = room?.getMember(dmPartner);
const displayName = room?.name || member?.rawDisplayName || dmPartner;
body = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_RoomAvatar.default, {
room: room,
size: _MiniAvatarUploader.AVATAR_SIZE,
onClick: () => {
_dispatcher.default.dispatch({
action: _actions.Action.ViewUser,
// XXX: We should be using a real member object and not assuming what the receiver wants.
member: member || {
userId: dmPartner
}
});
}
}), /*#__PURE__*/_react.default.createElement("h2", null, room.name), /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)(introMessage, {}, {
displayName: () => /*#__PURE__*/_react.default.createElement("strong", null, displayName)
})), caption && /*#__PURE__*/_react.default.createElement("p", null, caption));
} else {
const inRoom = room && room.getMyMembership() === _types.KnownMembership.Join;
const topic = room.currentState.getStateEvents(_matrix.EventType.RoomTopic, "")?.getContent()?.topic;
const canAddTopic = inRoom && room.currentState.maySendStateEvent(_matrix.EventType.RoomTopic, cli.getSafeUserId());
const onTopicClick = () => {
_dispatcher.default.dispatch({
action: "open_room_settings",
room_id: roomId
}, true);
// focus the topic field to help the user find it as it'll gain an outline
setTimeout(() => {
window.document.getElementById("profileTopic")?.focus();
});
};
let topicText;
if (canAddTopic && topic) {
topicText = (0, _languageHandler._t)("room|intro|topic_edit", {
topic
}, {
a: sub => /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
element: "a",
kind: "link_inline",
onClick: onTopicClick
}, sub)
});
} else if (topic) {
topicText = (0, _languageHandler._t)("room|intro|topic", {
topic
});
} else if (canAddTopic) {
topicText = (0, _languageHandler._t)("room|intro|no_topic", {}, {
a: sub => /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
element: "a",
kind: "link_inline",
onClick: onTopicClick
}, sub)
});
}
const creator = room.currentState.getStateEvents(_matrix.EventType.RoomCreate, "")?.getSender();
const creatorName = creator && room?.getMember(creator)?.rawDisplayName || creator;
let createdText;
if (creator === cli.getUserId()) {
createdText = (0, _languageHandler._t)("room|intro|you_created");
} else {
createdText = (0, _languageHandler._t)("room|intro|user_created", {
displayName: creatorName
});
}
let parentSpace;
if (_SpaceStore.default.instance.activeSpaceRoom?.canInvite(cli.getSafeUserId()) && _SpaceStore.default.instance.isRoomInSpace(_SpaceStore.default.instance.activeSpace, room.roomId)) {
parentSpace = _SpaceStore.default.instance.activeSpaceRoom;
}
let buttons;
if (parentSpace && (0, _UIComponents.shouldShowComponent)(_UIFeature.UIComponent.InviteUsers)) {
buttons = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_NewRoomIntro_buttons"
}, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_NewRoomIntro_inviteButton",
kind: "primary",
onClick: () => {
(0, _space.showSpaceInvite)(parentSpace);
}
}, (0, _languageHandler._t)("invite|to_space", {
spaceName: parentSpace.name
})), room.canInvite(cli.getSafeUserId()) && /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_NewRoomIntro_inviteButton",
kind: "primary_outline",
onClick: () => {
_dispatcher.default.dispatch({
action: "view_invite",
roomId
});
}
}, (0, _languageHandler._t)("room|intro|room_invite")));
} else if (room.canInvite(cli.getSafeUserId()) && (0, _UIComponents.shouldShowComponent)(_UIFeature.UIComponent.InviteUsers)) {
buttons = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_NewRoomIntro_buttons"
}, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_NewRoomIntro_inviteButton",
kind: "primary",
onClick: () => {
_dispatcher.default.dispatch({
action: "view_invite",
roomId
});
}
}, (0, _languageHandler._t)("room|invite_this_room")));
}
const avatarUrl = room.currentState.getStateEvents(_matrix.EventType.RoomAvatar, "")?.getContent()?.url;
let avatar = /*#__PURE__*/_react.default.createElement(_RoomAvatar.default, {
room: room,
size: _MiniAvatarUploader.AVATAR_SIZE,
viewAvatarOnClick: !!avatarUrl
});
if (!avatarUrl) {
avatar = /*#__PURE__*/_react.default.createElement(_MiniAvatarUploader.default, {
hasAvatar: false,
noAvatarLabel: (0, _languageHandler._t)("room|intro|no_avatar_label"),
setAvatarUrl: url => cli.sendStateEvent(roomId, _matrix.EventType.RoomAvatar, {
url
}, "")
}, avatar);
}
body = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, avatar, /*#__PURE__*/_react.default.createElement("h2", null, room.name), /*#__PURE__*/_react.default.createElement("p", null, createdText, " ", (0, _languageHandler._t)("room|intro|start_of_room", {}, {
roomName: () => /*#__PURE__*/_react.default.createElement("strong", null, room.name)
})), /*#__PURE__*/_react.default.createElement("p", null, topicText), buttons);
}
function openRoomSettings(event) {
event.preventDefault();
_dispatcher.default.dispatch({
action: "open_room_settings",
initial_tab_id: _RoomSettingsDialog.RoomSettingsTab.Security
});
}
const subText = (0, _languageHandler._t)("room|intro|private_unencrypted_warning");
let subButton;
if (room.currentState.mayClientSendStateEvent(_matrix.EventType.RoomEncryption, _MatrixClientPeg.MatrixClientPeg.safeGet()) && !isLocalRoom) {
subButton = /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
kind: "link_inline",
onClick: openRoomSettings
}, (0, _languageHandler._t)("room|intro|enable_encryption_prompt"));
}
const subtitle = /*#__PURE__*/_react.default.createElement("span", null, " ", subText, " ", subButton, " ");
return /*#__PURE__*/_react.default.createElement("li", {
className: "mx_NewRoomIntro"
}, !hasExpectedEncryptionSettings(cli, room) && /*#__PURE__*/_react.default.createElement(_EventTileBubble.default, {
className: "mx_cryptoEvent mx_cryptoEvent_icon_warning",
title: (0, _languageHandler._t)("room|intro|unencrypted_warning"),
subtitle: subtitle
}), body);
};
var _default = exports.default = NewRoomIntro;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_matrix","_types","_MatrixClientContext","_interopRequireDefault","_RoomContext","_DMRoomMap","_languageHandler","_AccessibleButton","_MiniAvatarUploader","_RoomAvatar","_dispatcher","_actions","_SpaceStore","_space","_EventTileBubble","_RoomSettingsDialog","_MatrixClientPeg","_UIComponents","_UIFeature","_rooms","_LocalRoom","_shouldEncryptRoomWithSingle3rdPartyInvite","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","hasExpectedEncryptionSettings","matrixClient","room","isEncrypted","isRoomEncrypted","roomId","isPublic","getJoinRule","privateShouldBeEncrypted","determineIntroMessage","encryptedSingle3rdPartyInvite","LocalRoom","_td","NewRoomIntro","cli","useContext","MatrixClientContext","RoomContext","Error","isLocalRoom","dmPartner","targets","userId","DMRoomMap","shared","getUserIdForRoomId","body","shouldEncrypt","shouldEncryptRoomWithSingle3rdPartyInvite","introMessage","caption","getJoinedMemberCount","getInvitedMemberCount","_t","member","getMember","displayName","name","rawDisplayName","createElement","Fragment","size","AVATAR_SIZE","onClick","defaultDispatcher","dispatch","action","Action","ViewUser","inRoom","getMyMembership","KnownMembership","Join","topic","currentState","getStateEvents","EventType","RoomTopic","getContent","canAddTopic","maySendStateEvent","getSafeUserId","onTopicClick","room_id","setTimeout","window","document","getElementById","focus","topicText","sub","element","kind","creator","RoomCreate","getSender","creatorName","createdText","getUserId","parentSpace","SpaceStore","instance","activeSpaceRoom","canInvite","isRoomInSpace","activeSpace","buttons","shouldShowComponent","UIComponent","InviteUsers","className","showSpaceInvite","spaceName","avatarUrl","RoomAvatar","url","avatar","viewAvatarOnClick","hasAvatar","noAvatarLabel","setAvatarUrl","sendStateEvent","roomName","openRoomSettings","event","preventDefault","initial_tab_id","RoomSettingsTab","Security","subText","subButton","mayClientSendStateEvent","RoomEncryption","MatrixClientPeg","safeGet","subtitle","title","_default","exports"],"sources":["../../../../src/components/views/rooms/NewRoomIntro.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020, 2021 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, { useContext } from \"react\";\nimport { EventType, Room, User, MatrixClient } from \"matrix-js-sdk/src/matrix\";\nimport { KnownMembership } from \"matrix-js-sdk/src/types\";\n\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport RoomContext from \"../../../contexts/RoomContext\";\nimport DMRoomMap from \"../../../utils/DMRoomMap\";\nimport { _t, _td, TranslationKey } from \"../../../languageHandler\";\nimport AccessibleButton, { ButtonEvent } from \"../elements/AccessibleButton\";\nimport MiniAvatarUploader, { AVATAR_SIZE } from \"../elements/MiniAvatarUploader\";\nimport RoomAvatar from \"../avatars/RoomAvatar\";\nimport defaultDispatcher from \"../../../dispatcher/dispatcher\";\nimport { ViewUserPayload } from \"../../../dispatcher/payloads/ViewUserPayload\";\nimport { Action } from \"../../../dispatcher/actions\";\nimport SpaceStore from \"../../../stores/spaces/SpaceStore\";\nimport { showSpaceInvite } from \"../../../utils/space\";\nimport EventTileBubble from \"../messages/EventTileBubble\";\nimport { RoomSettingsTab } from \"../dialogs/RoomSettingsDialog\";\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport { shouldShowComponent } from \"../../../customisations/helpers/UIComponents\";\nimport { UIComponent } from \"../../../settings/UIFeature\";\nimport { privateShouldBeEncrypted } from \"../../../utils/rooms\";\nimport { LocalRoom } from \"../../../models/LocalRoom\";\nimport { shouldEncryptRoomWithSingle3rdPartyInvite } from \"../../../utils/room/shouldEncryptRoomWithSingle3rdPartyInvite\";\n\nfunction hasExpectedEncryptionSettings(matrixClient: MatrixClient, room: Room): boolean {\n    const isEncrypted: boolean = matrixClient.isRoomEncrypted(room.roomId);\n    const isPublic: boolean = room.getJoinRule() === \"public\";\n    return isPublic || !privateShouldBeEncrypted(matrixClient) || isEncrypted;\n}\n\nconst determineIntroMessage = (room: Room, encryptedSingle3rdPartyInvite: boolean): TranslationKey => {\n    if (room instanceof LocalRoom) {\n        return _td(\"room|intro|send_message_start_dm\");\n    }\n\n    if (encryptedSingle3rdPartyInvite) {\n        return _td(\"room|intro|encrypted_3pid_dm_pending_join\");\n    }\n\n    return _td(\"room|intro|start_of_dm_history\");\n};\n\nconst NewRoomIntro: React.FC = () => {\n    const cli = useContext(MatrixClientContext);\n    const { room, roomId } = useContext(RoomContext);\n\n    if (!room || !roomId) {\n        throw new Error(\"Unable to create a NewRoomIntro without room and roomId\");\n    }\n\n    const isLocalRoom = room instanceof LocalRoom;\n    const dmPartner = isLocalRoom ? room.targets[0]?.userId : DMRoomMap.shared().getUserIdForRoomId(roomId);\n\n    let body: JSX.Element;\n    if (dmPartner) {\n        const { shouldEncrypt: encryptedSingle3rdPartyInvite } = shouldEncryptRoomWithSingle3rdPartyInvite(room);\n        const introMessage = determineIntroMessage(room, encryptedSingle3rdPartyInvite);\n        let caption: string | undefined;\n\n        if (\n            !(room instanceof LocalRoom) &&\n            !encryptedSingle3rdPartyInvite &&\n            room.getJoinedMemberCount() + room.getInvitedMemberCount() === 2\n        ) {\n            caption = _t(\"room|intro|dm_caption\");\n        }\n\n        const member = room?.getMember(dmPartner);\n        const displayName = room?.name || member?.rawDisplayName || dmPartner;\n        body = (\n            <React.Fragment>\n                <RoomAvatar\n                    room={room}\n                    size={AVATAR_SIZE}\n                    onClick={() => {\n                        defaultDispatcher.dispatch<ViewUserPayload>({\n                            action: Action.ViewUser,\n                            // XXX: We should be using a real member object and not assuming what the receiver wants.\n                            member: member || ({ userId: dmPartner } as User),\n                        });\n                    }}\n                />\n\n                <h2>{room.name}</h2>\n\n                <p>\n                    {_t(\n                        introMessage,\n                        {},\n                        {\n                            displayName: () => <strong>{displayName}</strong>,\n                        },\n                    )}\n                </p>\n                {caption && <p>{caption}</p>}\n            </React.Fragment>\n        );\n    } else {\n        const inRoom = room && room.getMyMembership() === KnownMembership.Join;\n        const topic = room.currentState.getStateEvents(EventType.RoomTopic, \"\")?.getContent()?.topic;\n        const canAddTopic = inRoom && room.currentState.maySendStateEvent(EventType.RoomTopic, cli.getSafeUserId());\n\n        const onTopicClick = (): void => {\n            defaultDispatcher.dispatch(\n                {\n                    action: \"open_room_settings\",\n                    room_id: roomId,\n                },\n                true,\n            );\n            // focus the topic field to help the user find it as it'll gain an outline\n            setTimeout(() => {\n                window.document.getElementById(\"profileTopic\")?.focus();\n            });\n        };\n\n        let topicText;\n        if (canAddTopic && topic) {\n            topicText = _t(\n                \"room|intro|topic_edit\",\n                { topic },\n                {\n                    a: (sub) => (\n                        <AccessibleButton element=\"a\" kind=\"link_inline\" onClick={onTopicClick}>\n                            {sub}\n                        </AccessibleButton>\n                    ),\n                },\n            );\n        } else if (topic) {\n            topicText = _t(\"room|intro|topic\", { topic });\n        } else if (canAddTopic) {\n            topicText = _t(\n                \"room|intro|no_topic\",\n                {},\n                {\n                    a: (sub) => (\n                        <AccessibleButton element=\"a\" kind=\"link_inline\" onClick={onTopicClick}>\n                            {sub}\n                        </AccessibleButton>\n                    ),\n                },\n            );\n        }\n\n        const creator = room.currentState.getStateEvents(EventType.RoomCreate, \"\")?.getSender();\n        const creatorName = (creator && room?.getMember(creator)?.rawDisplayName) || creator;\n\n        let createdText: string;\n        if (creator === cli.getUserId()) {\n            createdText = _t(\"room|intro|you_created\");\n        } else {\n            createdText = _t(\"room|intro|user_created\", {\n                displayName: creatorName,\n            });\n        }\n\n        let parentSpace: Room | undefined;\n        if (\n            SpaceStore.instance.activeSpaceRoom?.canInvite(cli.getSafeUserId()) &&\n            SpaceStore.instance.isRoomInSpace(SpaceStore.instance.activeSpace!, room.roomId)\n        ) {\n            parentSpace = SpaceStore.instance.activeSpaceRoom;\n        }\n\n        let buttons: JSX.Element | undefined;\n        if (parentSpace && shouldShowComponent(UIComponent.InviteUsers)) {\n            buttons = (\n                <div className=\"mx_NewRoomIntro_buttons\">\n                    <AccessibleButton\n                        className=\"mx_NewRoomIntro_inviteButton\"\n                        kind=\"primary\"\n                        onClick={() => {\n                            showSpaceInvite(parentSpace!);\n                        }}\n                    >\n                        {_t(\"invite|to_space\", { spaceName: parentSpace.name })}\n                    </AccessibleButton>\n                    {room.canInvite(cli.getSafeUserId()) && (\n                        <AccessibleButton\n                            className=\"mx_NewRoomIntro_inviteButton\"\n                            kind=\"primary_outline\"\n                            onClick={() => {\n                                defaultDispatcher.dispatch({ action: \"view_invite\", roomId });\n                            }}\n                        >\n                            {_t(\"room|intro|room_invite\")}\n                        </AccessibleButton>\n                    )}\n                </div>\n            );\n        } else if (room.canInvite(cli.getSafeUserId()) && shouldShowComponent(UIComponent.InviteUsers)) {\n            buttons = (\n                <div className=\"mx_NewRoomIntro_buttons\">\n                    <AccessibleButton\n                        className=\"mx_NewRoomIntro_inviteButton\"\n                        kind=\"primary\"\n                        onClick={() => {\n                            defaultDispatcher.dispatch({ action: \"view_invite\", roomId });\n                        }}\n                    >\n                        {_t(\"room|invite_this_room\")}\n                    </AccessibleButton>\n                </div>\n            );\n        }\n\n        const avatarUrl = room.currentState.getStateEvents(EventType.RoomAvatar, \"\")?.getContent()?.url;\n        let avatar = <RoomAvatar room={room} size={AVATAR_SIZE} viewAvatarOnClick={!!avatarUrl} />;\n\n        if (!avatarUrl) {\n            avatar = (\n                <MiniAvatarUploader\n                    hasAvatar={false}\n                    noAvatarLabel={_t(\"room|intro|no_avatar_label\")}\n                    setAvatarUrl={(url) => cli.sendStateEvent(roomId, EventType.RoomAvatar, { url }, \"\")}\n                >\n                    {avatar}\n                </MiniAvatarUploader>\n            );\n        }\n\n        body = (\n            <React.Fragment>\n                {avatar}\n\n                <h2>{room.name}</h2>\n\n                <p>\n                    {createdText}{\" \"}\n                    {_t(\n                        \"room|intro|start_of_room\",\n                        {},\n                        {\n                            roomName: () => <strong>{room.name}</strong>,\n                        },\n                    )}\n                </p>\n                <p>{topicText}</p>\n                {buttons}\n            </React.Fragment>\n        );\n    }\n\n    function openRoomSettings(event: ButtonEvent): void {\n        event.preventDefault();\n        defaultDispatcher.dispatch({\n            action: \"open_room_settings\",\n            initial_tab_id: RoomSettingsTab.Security,\n        });\n    }\n\n    const subText = _t(\"room|intro|private_unencrypted_warning\");\n\n    let subButton: JSX.Element | undefined;\n    if (\n        room.currentState.mayClientSendStateEvent(EventType.RoomEncryption, MatrixClientPeg.safeGet()) &&\n        !isLocalRoom\n    ) {\n        subButton = (\n            <AccessibleButton kind=\"link_inline\" onClick={openRoomSettings}>\n                {_t(\"room|intro|enable_encryption_prompt\")}\n            </AccessibleButton>\n        );\n    }\n\n    const subtitle = (\n        <span>\n            {\" \"}\n            {subText} {subButton}{\" \"}\n        </span>\n    );\n\n    return (\n        <li className=\"mx_NewRoomIntro\">\n            {!hasExpectedEncryptionSettings(cli, room) && (\n                <EventTileBubble\n                    className=\"mx_cryptoEvent mx_cryptoEvent_icon_warning\"\n                    title={_t(\"room|intro|unencrypted_warning\")}\n                    subtitle={subtitle}\n                />\n            )}\n\n            {body}\n        </li>\n    );\n};\n\nexport default NewRoomIntro;\n"],"mappings":"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","ignoreList":[]}