UNPKG

matrix-react-sdk

Version:
332 lines (270 loc) 38.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.useWidgets = void 0; var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext")); var _useIsEncrypted = require("../../../hooks/useIsEncrypted"); var _BaseCard = _interopRequireWildcard(require("./BaseCard")); var _languageHandler = require("../../../languageHandler"); var _RoomAvatar = _interopRequireDefault(require("../avatars/RoomAvatar")); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher")); var _actions = require("../../../dispatcher/actions"); var _RightPanelStorePhases = require("../../../stores/RightPanelStorePhases"); var _Modal = _interopRequireDefault(require("../../../Modal")); var _ShareDialog = _interopRequireDefault(require("../dialogs/ShareDialog")); var _useEventEmitter = require("../../../hooks/useEventEmitter"); var _WidgetUtils = _interopRequireDefault(require("../../../utils/WidgetUtils")); var _IntegrationManagers = require("../../../integrations/IntegrationManagers"); var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore")); var _TextWithTooltip = _interopRequireDefault(require("../elements/TextWithTooltip")); var _WidgetAvatar = _interopRequireDefault(require("../avatars/WidgetAvatar")); var _AccessibleTooltipButton = _interopRequireDefault(require("../elements/AccessibleTooltipButton")); var _WidgetStore = _interopRequireDefault(require("../../../stores/WidgetStore")); var _ShieldUtils = require("../../../utils/ShieldUtils"); var _RoomContext = _interopRequireDefault(require("../../../contexts/RoomContext")); var _UIFeature = require("../../../settings/UIFeature"); var _ContextMenu = require("../../structures/ContextMenu"); var _WidgetContextMenu = _interopRequireDefault(require("../context_menus/WidgetContextMenu")); var _useRoomMembers = require("../../../hooks/useRoomMembers"); var _WidgetLayoutStore = require("../../../stores/widgets/WidgetLayoutStore"); /* Copyright 2020 The Matrix.org Foundation C.I.C. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ const Button /*: React.FC<IButtonProps>*/ = ({ children, className, onClick }) => { return /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: (0, _classnames.default)("mx_BaseCard_Button mx_RoomSummaryCard_Button", className), onClick: onClick }, children); }; const useWidgets = (room /*: Room*/ ) => { const [apps, setApps] = (0, _react.useState)(_WidgetStore.default.instance.getApps(room.roomId)); const updateApps = (0, _react.useCallback)(() => { // Copy the array so that we always trigger a re-render, as some updates mutate the array of apps/settings setApps([..._WidgetStore.default.instance.getApps(room.roomId)]); }, [room]); (0, _react.useEffect)(updateApps, [room, updateApps]); (0, _useEventEmitter.useEventEmitter)(_WidgetStore.default.instance, room.roomId, updateApps); (0, _useEventEmitter.useEventEmitter)(_WidgetLayoutStore.WidgetLayoutStore.instance, _WidgetLayoutStore.WidgetLayoutStore.emissionForRoom(room), updateApps); return apps; }; exports.useWidgets = useWidgets; const AppRow /*: React.FC<IAppRowProps>*/ = ({ app, room }) => { const name = _WidgetUtils.default.getWidgetName(app); const dataTitle = _WidgetUtils.default.getWidgetDataTitle(app); const subtitle = dataTitle && " - " + dataTitle; const onOpenWidgetClick = () => { _dispatcher.default.dispatch({ action: _actions.Action.SetRightPanelPhase, phase: _RightPanelStorePhases.RightPanelPhases.Widget, refireParams: { widgetId: app.id } }); }; const isPinned = _WidgetLayoutStore.WidgetLayoutStore.instance.isInContainer(room, app, _WidgetLayoutStore.Container.Top); const togglePin = isPinned ? () => { _WidgetLayoutStore.WidgetLayoutStore.instance.moveToContainer(room, app, _WidgetLayoutStore.Container.Right); } : () => { _WidgetLayoutStore.WidgetLayoutStore.instance.moveToContainer(room, app, _WidgetLayoutStore.Container.Top); }; const [menuDisplayed, handle, openMenu, closeMenu] = (0, _ContextMenu.useContextMenu)(); let contextMenu; if (menuDisplayed) { const rect = handle.current.getBoundingClientRect(); contextMenu = /*#__PURE__*/_react.default.createElement(_WidgetContextMenu.default, { chevronFace: _ContextMenu.ChevronFace.None, right: window.innerWidth - rect.right, bottom: window.innerHeight - rect.top, onFinished: closeMenu, app: app }); } const cannotPin = !isPinned && !_WidgetLayoutStore.WidgetLayoutStore.instance.canAddToContainer(room, _WidgetLayoutStore.Container.Top); let pinTitle /*: string*/ ; if (cannotPin) { pinTitle = (0, _languageHandler._t)("You can only pin up to %(count)s widgets", { count: _WidgetLayoutStore.MAX_PINNED }); } else { pinTitle = isPinned ? (0, _languageHandler._t)("Unpin") : (0, _languageHandler._t)("Pin"); } const classes = (0, _classnames.default)("mx_BaseCard_Button mx_RoomSummaryCard_Button", { mx_RoomSummaryCard_Button_pinned: isPinned }); return /*#__PURE__*/_react.default.createElement("div", { className: classes, ref: handle }, /*#__PURE__*/_react.default.createElement(_AccessibleTooltipButton.default, { className: "mx_RoomSummaryCard_icon_app", onClick: onOpenWidgetClick // only show a tooltip if the widget is pinned , title: isPinned ? (0, _languageHandler._t)("Unpin a widget to view it in this panel") : "", forceHide: !isPinned, disabled: isPinned, yOffset: -48 }, /*#__PURE__*/_react.default.createElement(_WidgetAvatar.default, { app: app }), /*#__PURE__*/_react.default.createElement("span", null, name), subtitle), /*#__PURE__*/_react.default.createElement(_ContextMenu.ContextMenuTooltipButton, { className: "mx_RoomSummaryCard_app_options", isExpanded: menuDisplayed, onClick: openMenu, title: (0, _languageHandler._t)("Options"), yOffset: -24 }), /*#__PURE__*/_react.default.createElement(_AccessibleTooltipButton.default, { className: "mx_RoomSummaryCard_app_pinToggle", onClick: togglePin, title: pinTitle, disabled: cannotPin, yOffset: -24 }), contextMenu); }; const AppsSection /*: React.FC<IAppsSectionProps>*/ = ({ room }) => { const apps = useWidgets(room); const onManageIntegrations = () => { const managers = _IntegrationManagers.IntegrationManagers.sharedInstance(); if (!managers.hasManager()) { managers.openNoManagerDialog(); } else { if (_SettingsStore.default.getValue("feature_many_integration_managers")) { managers.openAll(room); } else { managers.getPrimaryManager().open(room); } } }; let copyLayoutBtn = null; if (apps.length > 0 && _WidgetLayoutStore.WidgetLayoutStore.instance.canCopyLayoutToRoom(room)) { copyLayoutBtn = /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { kind: "link", onClick: () => _WidgetLayoutStore.WidgetLayoutStore.instance.copyLayoutToRoom(room) }, (0, _languageHandler._t)("Set my room layout for everyone")); } return /*#__PURE__*/_react.default.createElement(_BaseCard.Group, { className: "mx_RoomSummaryCard_appsGroup", title: (0, _languageHandler._t)("Widgets") }, apps.map(app => /*#__PURE__*/_react.default.createElement(AppRow, { key: app.id, app: app, room: room })), copyLayoutBtn, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { kind: "link", onClick: onManageIntegrations }, apps.length > 0 ? (0, _languageHandler._t)("Edit widgets, bridges & bots") : (0, _languageHandler._t)("Add widgets, bridges & bots"))); }; const onRoomMembersClick = () => { _dispatcher.default.dispatch({ action: _actions.Action.SetRightPanelPhase, phase: _RightPanelStorePhases.RightPanelPhases.RoomMemberList }); }; const onRoomFilesClick = () => { _dispatcher.default.dispatch({ action: _actions.Action.SetRightPanelPhase, phase: _RightPanelStorePhases.RightPanelPhases.FilePanel }); }; const onRoomSettingsClick = () => { _dispatcher.default.dispatch({ action: "open_room_settings" }); }; const RoomSummaryCard /*: React.FC<IProps>*/ = ({ room, onClose }) => { const cli = (0, _react.useContext)(_MatrixClientContext.default); const onShareRoomClick = () => { _Modal.default.createTrackedDialog('share room dialog', '', _ShareDialog.default, { target: room }); }; const isRoomEncrypted = (0, _useIsEncrypted.useIsEncrypted)(cli, room); const roomContext = (0, _react.useContext)(_RoomContext.default); const e2eStatus = roomContext.e2eStatus; const alias = room.getCanonicalAlias() || room.getAltAliases()[0] || ""; const header = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", { className: "mx_RoomSummaryCard_avatar", role: "presentation" }, /*#__PURE__*/_react.default.createElement(_RoomAvatar.default, { room: room, height: 54, width: 54, viewAvatarOnClick: true }), /*#__PURE__*/_react.default.createElement(_TextWithTooltip.default, { tooltip: isRoomEncrypted ? (0, _languageHandler._t)("Encrypted") : (0, _languageHandler._t)("Not encrypted"), class: (0, _classnames.default)("mx_RoomSummaryCard_e2ee", { mx_RoomSummaryCard_e2ee_normal: isRoomEncrypted, mx_RoomSummaryCard_e2ee_warning: isRoomEncrypted && e2eStatus === _ShieldUtils.E2EStatus.Warning, mx_RoomSummaryCard_e2ee_verified: isRoomEncrypted && e2eStatus === _ShieldUtils.E2EStatus.Verified }) })), /*#__PURE__*/_react.default.createElement("h2", { title: room.name }, room.name), /*#__PURE__*/_react.default.createElement("div", { className: "mx_RoomSummaryCard_alias", title: alias }, alias)); const memberCount = (0, _useRoomMembers.useRoomMemberCount)(room); return /*#__PURE__*/_react.default.createElement(_BaseCard.default, { header: header, className: "mx_RoomSummaryCard", onClose: onClose }, /*#__PURE__*/_react.default.createElement(_BaseCard.Group, { title: (0, _languageHandler._t)("About"), className: "mx_RoomSummaryCard_aboutGroup" }, /*#__PURE__*/_react.default.createElement(Button, { className: "mx_RoomSummaryCard_icon_people", onClick: onRoomMembersClick }, (0, _languageHandler._t)("%(count)s people", { count: memberCount })), /*#__PURE__*/_react.default.createElement(Button, { className: "mx_RoomSummaryCard_icon_files", onClick: onRoomFilesClick }, (0, _languageHandler._t)("Show files")), /*#__PURE__*/_react.default.createElement(Button, { className: "mx_RoomSummaryCard_icon_share", onClick: onShareRoomClick }, (0, _languageHandler._t)("Share room")), /*#__PURE__*/_react.default.createElement(Button, { className: "mx_RoomSummaryCard_icon_settings", onClick: onRoomSettingsClick }, (0, _languageHandler._t)("Room settings"))), _SettingsStore.default.getValue(_UIFeature.UIFeature.Widgets) && /*#__PURE__*/_react.default.createElement(AppsSection, { room: room })); }; var _default = RoomSummaryCard; exports.default = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/right_panel/RoomSummaryCard.tsx"],"names":["Button","children","className","onClick","useWidgets","room","apps","setApps","WidgetStore","instance","getApps","roomId","updateApps","WidgetLayoutStore","emissionForRoom","AppRow","app","name","WidgetUtils","getWidgetName","dataTitle","getWidgetDataTitle","subtitle","onOpenWidgetClick","defaultDispatcher","dispatch","action","Action","SetRightPanelPhase","phase","RightPanelPhases","Widget","refireParams","widgetId","id","isPinned","isInContainer","Container","Top","togglePin","moveToContainer","Right","menuDisplayed","handle","openMenu","closeMenu","contextMenu","rect","current","getBoundingClientRect","ChevronFace","None","window","innerWidth","right","innerHeight","top","cannotPin","canAddToContainer","pinTitle","count","MAX_PINNED","classes","mx_RoomSummaryCard_Button_pinned","AppsSection","onManageIntegrations","managers","IntegrationManagers","sharedInstance","hasManager","openNoManagerDialog","SettingsStore","getValue","openAll","getPrimaryManager","open","copyLayoutBtn","length","canCopyLayoutToRoom","copyLayoutToRoom","map","onRoomMembersClick","RoomMemberList","onRoomFilesClick","FilePanel","onRoomSettingsClick","RoomSummaryCard","onClose","cli","MatrixClientContext","onShareRoomClick","Modal","createTrackedDialog","ShareDialog","target","isRoomEncrypted","roomContext","RoomContext","e2eStatus","alias","getCanonicalAlias","getAltAliases","header","mx_RoomSummaryCard_e2ee_normal","mx_RoomSummaryCard_e2ee_warning","E2EStatus","Warning","mx_RoomSummaryCard_e2ee_verified","Verified","memberCount","UIFeature","Widgets"],"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, {useCallback, useState, useEffect, useContext} from \"react\";\nimport classNames from \"classnames\";\nimport {Room} from \"matrix-js-sdk/src/models/room\";\n\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport { useIsEncrypted } from '../../../hooks/useIsEncrypted';\nimport BaseCard, { Group } from \"./BaseCard\";\nimport { _t } from '../../../languageHandler';\nimport RoomAvatar from \"../avatars/RoomAvatar\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport defaultDispatcher from \"../../../dispatcher/dispatcher\";\nimport {Action} from \"../../../dispatcher/actions\";\nimport {RightPanelPhases} from \"../../../stores/RightPanelStorePhases\";\nimport {SetRightPanelPhasePayload} from \"../../../dispatcher/payloads/SetRightPanelPhasePayload\";\nimport Modal from \"../../../Modal\";\nimport ShareDialog from '../dialogs/ShareDialog';\nimport {useEventEmitter} from \"../../../hooks/useEventEmitter\";\nimport WidgetUtils from \"../../../utils/WidgetUtils\";\nimport {IntegrationManagers} from \"../../../integrations/IntegrationManagers\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport TextWithTooltip from \"../elements/TextWithTooltip\";\nimport WidgetAvatar from \"../avatars/WidgetAvatar\";\nimport AccessibleTooltipButton from \"../elements/AccessibleTooltipButton\";\nimport WidgetStore, {IApp} from \"../../../stores/WidgetStore\";\nimport { E2EStatus } from \"../../../utils/ShieldUtils\";\nimport RoomContext from \"../../../contexts/RoomContext\";\nimport {UIFeature} from \"../../../settings/UIFeature\";\nimport {ChevronFace, ContextMenuTooltipButton, useContextMenu} from \"../../structures/ContextMenu\";\nimport WidgetContextMenu from \"../context_menus/WidgetContextMenu\";\nimport {useRoomMemberCount} from \"../../../hooks/useRoomMembers\";\nimport { Container, MAX_PINNED, WidgetLayoutStore } from \"../../../stores/widgets/WidgetLayoutStore\";\n\ninterface IProps {\n    room: Room;\n    onClose(): void;\n}\n\ninterface IAppsSectionProps {\n    room: Room;\n}\n\ninterface IButtonProps {\n    className: string;\n    onClick(): void;\n}\n\nconst Button: React.FC<IButtonProps> = ({ children, className, onClick }) => {\n    return <AccessibleButton\n        className={classNames(\"mx_BaseCard_Button mx_RoomSummaryCard_Button\", className)}\n        onClick={onClick}\n    >\n        { children }\n    </AccessibleButton>;\n};\n\nexport const useWidgets = (room: Room) => {\n    const [apps, setApps] = useState<IApp[]>(WidgetStore.instance.getApps(room.roomId));\n\n    const updateApps = useCallback(() => {\n        // Copy the array so that we always trigger a re-render, as some updates mutate the array of apps/settings\n        setApps([...WidgetStore.instance.getApps(room.roomId)]);\n    }, [room]);\n\n    useEffect(updateApps, [room, updateApps]);\n    useEventEmitter(WidgetStore.instance, room.roomId, updateApps);\n    useEventEmitter(WidgetLayoutStore.instance, WidgetLayoutStore.emissionForRoom(room), updateApps);\n\n    return apps;\n};\n\ninterface IAppRowProps {\n    app: IApp;\n    room: Room;\n}\n\nconst AppRow: React.FC<IAppRowProps> = ({ app, room }) => {\n    const name = WidgetUtils.getWidgetName(app);\n    const dataTitle = WidgetUtils.getWidgetDataTitle(app);\n    const subtitle = dataTitle && \" - \" + dataTitle;\n\n    const onOpenWidgetClick = () => {\n        defaultDispatcher.dispatch<SetRightPanelPhasePayload>({\n            action: Action.SetRightPanelPhase,\n            phase: RightPanelPhases.Widget,\n            refireParams: {\n                widgetId: app.id,\n            },\n        });\n    };\n\n    const isPinned = WidgetLayoutStore.instance.isInContainer(room, app, Container.Top);\n    const togglePin = isPinned\n        ? () => { WidgetLayoutStore.instance.moveToContainer(room, app, Container.Right); }\n        : () => { WidgetLayoutStore.instance.moveToContainer(room, app, Container.Top); };\n\n    const [menuDisplayed, handle, openMenu, closeMenu] = useContextMenu<HTMLDivElement>();\n    let contextMenu;\n    if (menuDisplayed) {\n        const rect = handle.current.getBoundingClientRect();\n        contextMenu = <WidgetContextMenu\n            chevronFace={ChevronFace.None}\n            right={window.innerWidth - rect.right}\n            bottom={window.innerHeight - rect.top}\n            onFinished={closeMenu}\n            app={app}\n        />;\n    }\n\n    const cannotPin = !isPinned && !WidgetLayoutStore.instance.canAddToContainer(room, Container.Top);\n\n    let pinTitle: string;\n    if (cannotPin) {\n        pinTitle = _t(\"You can only pin up to %(count)s widgets\", { count: MAX_PINNED });\n    } else {\n        pinTitle = isPinned ? _t(\"Unpin\") : _t(\"Pin\");\n    }\n\n    const classes = classNames(\"mx_BaseCard_Button mx_RoomSummaryCard_Button\", {\n        mx_RoomSummaryCard_Button_pinned: isPinned,\n    });\n\n    return <div className={classes} ref={handle}>\n        <AccessibleTooltipButton\n            className=\"mx_RoomSummaryCard_icon_app\"\n            onClick={onOpenWidgetClick}\n            // only show a tooltip if the widget is pinned\n            title={isPinned ? _t(\"Unpin a widget to view it in this panel\") : \"\"}\n            forceHide={!isPinned}\n            disabled={isPinned}\n            yOffset={-48}\n        >\n            <WidgetAvatar app={app} />\n            <span>{name}</span>\n            { subtitle }\n        </AccessibleTooltipButton>\n\n        <ContextMenuTooltipButton\n            className=\"mx_RoomSummaryCard_app_options\"\n            isExpanded={menuDisplayed}\n            onClick={openMenu}\n            title={_t(\"Options\")}\n            yOffset={-24}\n        />\n\n        <AccessibleTooltipButton\n            className=\"mx_RoomSummaryCard_app_pinToggle\"\n            onClick={togglePin}\n            title={pinTitle}\n            disabled={cannotPin}\n            yOffset={-24}\n        />\n\n        { contextMenu }\n    </div>;\n};\n\nconst AppsSection: React.FC<IAppsSectionProps> = ({ room }) => {\n    const apps = useWidgets(room);\n\n    const onManageIntegrations = () => {\n        const managers = IntegrationManagers.sharedInstance();\n        if (!managers.hasManager()) {\n            managers.openNoManagerDialog();\n        } else {\n            if (SettingsStore.getValue(\"feature_many_integration_managers\")) {\n                managers.openAll(room);\n            } else {\n                managers.getPrimaryManager().open(room);\n            }\n        }\n    };\n\n    let copyLayoutBtn = null;\n    if (apps.length > 0 && WidgetLayoutStore.instance.canCopyLayoutToRoom(room)) {\n        copyLayoutBtn = (\n            <AccessibleButton kind=\"link\" onClick={() => WidgetLayoutStore.instance.copyLayoutToRoom(room)}>\n                { _t(\"Set my room layout for everyone\") }\n            </AccessibleButton>\n        );\n    }\n\n    return <Group className=\"mx_RoomSummaryCard_appsGroup\" title={_t(\"Widgets\")}>\n        { apps.map(app => <AppRow key={app.id} app={app} room={room} />) }\n        { copyLayoutBtn }\n        <AccessibleButton kind=\"link\" onClick={onManageIntegrations}>\n            { apps.length > 0 ? _t(\"Edit widgets, bridges & bots\") : _t(\"Add widgets, bridges & bots\") }\n        </AccessibleButton>\n    </Group>;\n};\n\nconst onRoomMembersClick = () => {\n    defaultDispatcher.dispatch<SetRightPanelPhasePayload>({\n        action: Action.SetRightPanelPhase,\n        phase: RightPanelPhases.RoomMemberList,\n    });\n};\n\nconst onRoomFilesClick = () => {\n    defaultDispatcher.dispatch<SetRightPanelPhasePayload>({\n        action: Action.SetRightPanelPhase,\n        phase: RightPanelPhases.FilePanel,\n    });\n};\n\nconst onRoomSettingsClick = () => {\n    defaultDispatcher.dispatch({ action: \"open_room_settings\" });\n};\n\nconst RoomSummaryCard: React.FC<IProps> = ({ room, onClose }) => {\n    const cli = useContext(MatrixClientContext);\n\n    const onShareRoomClick = () => {\n        Modal.createTrackedDialog('share room dialog', '', ShareDialog, {\n            target: room,\n        });\n    };\n\n    const isRoomEncrypted = useIsEncrypted(cli, room);\n    const roomContext = useContext(RoomContext);\n    const e2eStatus = roomContext.e2eStatus;\n\n    const alias = room.getCanonicalAlias() || room.getAltAliases()[0] || \"\";\n    const header = <React.Fragment>\n        <div className=\"mx_RoomSummaryCard_avatar\" role=\"presentation\">\n            <RoomAvatar room={room} height={54} width={54} viewAvatarOnClick />\n            <TextWithTooltip\n                tooltip={isRoomEncrypted ? _t(\"Encrypted\") : _t(\"Not encrypted\")}\n                class={classNames(\"mx_RoomSummaryCard_e2ee\", {\n                    mx_RoomSummaryCard_e2ee_normal: isRoomEncrypted,\n                    mx_RoomSummaryCard_e2ee_warning: isRoomEncrypted && e2eStatus === E2EStatus.Warning,\n                    mx_RoomSummaryCard_e2ee_verified: isRoomEncrypted && e2eStatus === E2EStatus.Verified,\n                })}\n            />\n        </div>\n\n        <h2 title={room.name}>{ room.name }</h2>\n        <div className=\"mx_RoomSummaryCard_alias\" title={alias}>\n            { alias }\n        </div>\n    </React.Fragment>;\n\n    const memberCount = useRoomMemberCount(room);\n\n    return <BaseCard header={header} className=\"mx_RoomSummaryCard\" onClose={onClose}>\n        <Group title={_t(\"About\")} className=\"mx_RoomSummaryCard_aboutGroup\">\n            <Button className=\"mx_RoomSummaryCard_icon_people\" onClick={onRoomMembersClick}>\n                {_t(\"%(count)s people\", { count: memberCount })}\n            </Button>\n            <Button className=\"mx_RoomSummaryCard_icon_files\" onClick={onRoomFilesClick}>\n                {_t(\"Show files\")}\n            </Button>\n            <Button className=\"mx_RoomSummaryCard_icon_share\" onClick={onShareRoomClick}>\n                {_t(\"Share room\")}\n            </Button>\n            <Button className=\"mx_RoomSummaryCard_icon_settings\" onClick={onRoomSettingsClick}>\n                {_t(\"Room settings\")}\n            </Button>\n        </Group>\n\n        { SettingsStore.getValue(UIFeature.Widgets) && <AppsSection room={room} /> }\n    </BaseCard>;\n};\n\nexport default RoomSummaryCard;\n"]}