cinny/src/app/organisms/room/RoomViewHeader.jsx

46 lines
1.8 KiB
React
Raw Normal View History

2021-08-04 09:52:59 +00:00
import React from 'react';
import PropTypes from 'prop-types';
import initMatrix from '../../../client/initMatrix';
import { togglePeopleDrawer, openRoomOptions } from '../../../client/action/navigation';
2021-08-04 09:52:59 +00:00
import colorMXID from '../../../util/colorMXID';
import { getEventCords } from '../../../util/common';
2021-08-04 09:52:59 +00:00
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 UserIC from '../../../../public/res/ic/outlined/user.svg';
import VerticalMenuIC from '../../../../public/res/ic/outlined/vertical-menu.svg';
2021-08-31 13:13:31 +00:00
function RoomViewHeader({ roomId }) {
2021-08-04 09:52:59 +00:00
const mx = initMatrix.matrixClient;
2021-08-17 11:07:31 +00:00
const isDM = initMatrix.roomList.directs.has(roomId);
let avatarSrc = mx.getRoom(roomId).getAvatarUrl(mx.baseUrl, 36, 36, 'crop');
2021-08-17 11:21:22 +00:00
avatarSrc = isDM ? mx.getRoom(roomId).getAvatarFallbackMember()?.getAvatarUrl(mx.baseUrl, 36, 36, 'crop') : avatarSrc;
2021-08-04 09:52:59 +00:00
const roomName = mx.getRoom(roomId).name;
const roomTopic = mx.getRoom(roomId).currentState.getStateEvents('m.room.topic')[0]?.getContent().topic;
return (
<Header>
<Avatar imageSrc={avatarSrc} text={roomName} bgColor={colorMXID(roomId)} size="small" />
2021-08-04 09:52:59 +00:00
<TitleWrapper>
<Text variant="h2">{roomName}</Text>
{ typeof roomTopic !== 'undefined' && <p title={roomTopic} className="text text-b3">{roomTopic}</p>}
</TitleWrapper>
<IconButton onClick={togglePeopleDrawer} tooltip="People" src={UserIC} />
<IconButton
onClick={(e) => openRoomOptions(getEventCords(e), roomId)}
tooltip="Options"
src={VerticalMenuIC}
2021-08-04 09:52:59 +00:00
/>
</Header>
);
}
2021-08-31 13:13:31 +00:00
RoomViewHeader.propTypes = {
2021-08-04 09:52:59 +00:00
roomId: PropTypes.string.isRequired,
};
2021-08-31 13:13:31 +00:00
export default RoomViewHeader;