import React from 'react'; import PropTypes from 'prop-types'; import initMatrix from '../../../client/initMatrix'; import { togglePeopleDrawer, openInviteUser } from '../../../client/action/navigation'; import * as roomActions from '../../../client/action/room'; import colorMXID from '../../../util/colorMXID'; import Text from '../../atoms/text/Text'; import IconButton from '../../atoms/button/IconButton'; import Header, { TitleWrapper } from '../../atoms/header/Header'; import Avatar from '../../atoms/avatar/Avatar'; import ContextMenu, { MenuItem, MenuHeader } from '../../atoms/context-menu/ContextMenu'; import UserIC from '../../../../public/res/ic/outlined/user.svg'; import VerticalMenuIC from '../../../../public/res/ic/outlined/vertical-menu.svg'; import LeaveArrowIC from '../../../../public/res/ic/outlined/leave-arrow.svg'; import AddUserIC from '../../../../public/res/ic/outlined/add-user.svg'; function RoomViewHeader({ roomId }) { const mx = initMatrix.matrixClient; const isDM = initMatrix.roomList.directs.has(roomId); let avatarSrc = mx.getRoom(roomId).getAvatarUrl(mx.baseUrl, 36, 36, 'crop'); avatarSrc = isDM ? mx.getRoom(roomId).getAvatarFallbackMember()?.getAvatarUrl(mx.baseUrl, 36, 36, 'crop') : avatarSrc; const roomName = mx.getRoom(roomId).name; const roomTopic = mx.getRoom(roomId).currentState.getStateEvents('m.room.topic')[0]?.getContent().topic; return (
{roomName} { typeof roomTopic !== 'undefined' &&

{roomTopic}

}
( <> Options {/* */} { openInviteUser(roomId); toogleMenu(); }} > Invite roomActions.leave(roomId)}>Leave )} render={(toggleMenu) => } />
); } RoomViewHeader.propTypes = { roomId: PropTypes.string.isRequired, }; export default RoomViewHeader;