UNPKG

matrix-react-sdk

Version:
81 lines (78 loc) 12.5 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 _matrix = require("matrix-js-sdk/src/matrix"); var _types = require("matrix-js-sdk/src/types"); var _languageHandler = require("../../../languageHandler"); var _RightPanelStore = _interopRequireDefault(require("../../../stores/right-panel/RightPanelStore")); var _RightPanelStorePhases = require("../../../stores/right-panel/RightPanelStorePhases"); var _useAsyncMemo = require("../../../hooks/useAsyncMemo"); var _useRoomState = require("../../../hooks/useRoomState"); var _useRoomMembers = require("../../../hooks/useRoomMembers"); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _videoRooms = require("../../../utils/video-rooms"); /* Copyright 2024 New Vector Ltd. Copyright 2022 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. */ const RoomInfoLine = ({ room }) => { // summary will begin as undefined whilst loading and go null if it fails to load or we are not invited. const summary = (0, _useAsyncMemo.useAsyncMemo)(async () => { if (room.getMyMembership() !== _types.KnownMembership.Invite) return null; try { return await room.client.getRoomSummary(room.roomId); } catch (e) { return null; } }, [room]); const joinRule = (0, _useRoomState.useRoomState)(room, state => state.getJoinRule()); const membership = (0, _useRoomMembers.useMyRoomMembership)(room); const memberCount = (0, _useRoomMembers.useRoomMemberCount)(room); const isVideoRoom = (0, _videoRooms.isVideoRoom)(room); let iconClass; let roomType; if (isVideoRoom) { iconClass = "mx_RoomInfoLine_video"; roomType = (0, _languageHandler._t)("common|video_room"); } else if (joinRule === _matrix.JoinRule.Public) { iconClass = "mx_RoomInfoLine_public"; roomType = room.isSpaceRoom() ? (0, _languageHandler._t)("common|public_space") : (0, _languageHandler._t)("common|public_room"); } else { iconClass = "mx_RoomInfoLine_private"; roomType = room.isSpaceRoom() ? (0, _languageHandler._t)("common|private_space") : (0, _languageHandler._t)("common|private_room"); } let members; if (membership === _types.KnownMembership.Invite && summary) { // Don't trust local state and instead use the summary API members = /*#__PURE__*/_react.default.createElement("span", { className: "mx_RoomInfoLine_members" }, (0, _languageHandler._t)("common|n_members", { count: summary.num_joined_members })); } else if (memberCount && summary !== undefined) { // summary is not still loading const viewMembers = () => _RightPanelStore.default.instance.setCard({ phase: room.isSpaceRoom() ? _RightPanelStorePhases.RightPanelPhases.SpaceMemberList : _RightPanelStorePhases.RightPanelPhases.RoomMemberList }); members = /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { kind: "link", className: "mx_RoomInfoLine_members", onClick: viewMembers }, (0, _languageHandler._t)("common|n_members", { count: memberCount })); } return /*#__PURE__*/_react.default.createElement("div", { className: `mx_RoomInfoLine ${iconClass}` }, roomType, members); }; var _default = exports.default = RoomInfoLine; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_matrix","_types","_languageHandler","_RightPanelStore","_RightPanelStorePhases","_useAsyncMemo","_useRoomState","_useRoomMembers","_AccessibleButton","_videoRooms","RoomInfoLine","room","summary","useAsyncMemo","getMyMembership","KnownMembership","Invite","client","getRoomSummary","roomId","e","joinRule","useRoomState","state","getJoinRule","membership","useMyRoomMembership","memberCount","useRoomMemberCount","isVideoRoom","calcIsVideoRoom","iconClass","roomType","_t","JoinRule","Public","isSpaceRoom","members","default","createElement","className","count","num_joined_members","undefined","viewMembers","RightPanelStore","instance","setCard","phase","RightPanelPhases","SpaceMemberList","RoomMemberList","kind","onClick","_default","exports"],"sources":["../../../../src/components/views/rooms/RoomInfoLine.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2022 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, { FC } from \"react\";\nimport { Room, JoinRule, MatrixClient } from \"matrix-js-sdk/src/matrix\";\nimport { KnownMembership } from \"matrix-js-sdk/src/types\";\n\nimport { _t } from \"../../../languageHandler\";\nimport RightPanelStore from \"../../../stores/right-panel/RightPanelStore\";\nimport { RightPanelPhases } from \"../../../stores/right-panel/RightPanelStorePhases\";\nimport { useAsyncMemo } from \"../../../hooks/useAsyncMemo\";\nimport { useRoomState } from \"../../../hooks/useRoomState\";\nimport { useRoomMemberCount, useMyRoomMembership } from \"../../../hooks/useRoomMembers\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport { isVideoRoom as calcIsVideoRoom } from \"../../../utils/video-rooms\";\n\ninterface IProps {\n    room: Room;\n}\n\nconst RoomInfoLine: FC<IProps> = ({ room }) => {\n    // summary will begin as undefined whilst loading and go null if it fails to load or we are not invited.\n    const summary = useAsyncMemo(async (): Promise<Awaited<ReturnType<MatrixClient[\"getRoomSummary\"]>> | null> => {\n        if (room.getMyMembership() !== KnownMembership.Invite) return null;\n        try {\n            return await room.client.getRoomSummary(room.roomId);\n        } catch (e) {\n            return null;\n        }\n    }, [room]);\n    const joinRule = useRoomState(room, (state) => state.getJoinRule());\n    const membership = useMyRoomMembership(room);\n    const memberCount = useRoomMemberCount(room);\n\n    const isVideoRoom = calcIsVideoRoom(room);\n\n    let iconClass: string;\n    let roomType: string;\n    if (isVideoRoom) {\n        iconClass = \"mx_RoomInfoLine_video\";\n        roomType = _t(\"common|video_room\");\n    } else if (joinRule === JoinRule.Public) {\n        iconClass = \"mx_RoomInfoLine_public\";\n        roomType = room.isSpaceRoom() ? _t(\"common|public_space\") : _t(\"common|public_room\");\n    } else {\n        iconClass = \"mx_RoomInfoLine_private\";\n        roomType = room.isSpaceRoom() ? _t(\"common|private_space\") : _t(\"common|private_room\");\n    }\n\n    let members: JSX.Element | undefined;\n    if (membership === KnownMembership.Invite && summary) {\n        // Don't trust local state and instead use the summary API\n        members = (\n            <span className=\"mx_RoomInfoLine_members\">\n                {_t(\"common|n_members\", { count: summary.num_joined_members })}\n            </span>\n        );\n    } else if (memberCount && summary !== undefined) {\n        // summary is not still loading\n        const viewMembers = (): void =>\n            RightPanelStore.instance.setCard({\n                phase: room.isSpaceRoom() ? RightPanelPhases.SpaceMemberList : RightPanelPhases.RoomMemberList,\n            });\n\n        members = (\n            <AccessibleButton kind=\"link\" className=\"mx_RoomInfoLine_members\" onClick={viewMembers}>\n                {_t(\"common|n_members\", { count: memberCount })}\n            </AccessibleButton>\n        );\n    }\n\n    return (\n        <div className={`mx_RoomInfoLine ${iconClass}`}>\n            {roomType}\n            {members}\n        </div>\n    );\n};\n\nexport default RoomInfoLine;\n"],"mappings":"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","ignoreList":[]}