2021-08-04 18:52:59 +09:00
|
|
|
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 ChannelViewHeader({ roomId }) {
|
|
|
|
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>
|
|
|
|
<Avatar imageSrc={avatarSrc} text={roomName.slice(0, 1)} bgColor={colorMXID(roomName)} size="small" />
|
|
|
|
<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} />
|
|
|
|
<ContextMenu
|
|
|
|
placement="bottom"
|
|
|
|
content={(toogleMenu) => (
|
|
|
|
<>
|
|
|
|
<MenuHeader>Options</MenuHeader>
|
|
|
|
{/* <MenuBorder /> */}
|
|
|
|
<MenuItem
|
|
|
|
iconSrc={AddUserIC}
|
|
|
|
onClick={() => {
|
|
|
|
openInviteUser(roomId); toogleMenu();
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
Invite
|
|
|
|
</MenuItem>
|
2021-08-09 01:26:34 +09:00
|
|
|
<MenuItem iconSrc={LeaveArrowIC} variant="danger" onClick={() => roomActions.leave(roomId)}>Leave</MenuItem>
|
2021-08-04 18:52:59 +09:00
|
|
|
</>
|
|
|
|
)}
|
|
|
|
render={(toggleMenu) => <IconButton onClick={toggleMenu} tooltip="Options" src={VerticalMenuIC} />}
|
|
|
|
/>
|
|
|
|
</Header>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
ChannelViewHeader.propTypes = {
|
|
|
|
roomId: PropTypes.string.isRequired,
|
|
|
|
};
|
|
|
|
|
|
|
|
export default ChannelViewHeader;
|