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