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

104 lines
3.8 KiB
React
Raw Normal View History

2021-12-22 20:18:32 +05:30
import React, { useEffect, useRef } from 'react';
2021-08-04 15:22:59 +05:30
import PropTypes from 'prop-types';
2021-12-22 20:18:32 +05:30
import './RoomViewHeader.scss';
2021-08-04 15:22:59 +05:30
2021-11-23 11:56:02 +05:30
import { twemojify } from '../../../util/twemojify';
2021-12-22 20:18:32 +05:30
import { blurOnBubbling } from '../../atoms/button/script';
2021-11-23 11:56:02 +05:30
2021-08-04 15:22:59 +05:30
import initMatrix from '../../../client/initMatrix';
2021-12-22 20:18:32 +05:30
import cons from '../../../client/state/cons';
import navigation from '../../../client/state/navigation';
2022-01-13 18:30:43 +05:30
import { toggleRoomSettings, openReusableContextMenu } from '../../../client/action/navigation';
import { togglePeopleDrawer } from '../../../client/action/settings';
2021-08-04 15:22:59 +05:30
import colorMXID from '../../../util/colorMXID';
import { getEventCords } from '../../../util/common';
2021-08-04 15:22:59 +05:30
2022-01-16 18:18:33 +05:30
import { tabText } from './RoomSettings';
2021-08-04 15:22:59 +05:30
import Text from '../../atoms/text/Text';
2021-12-22 20:18:32 +05:30
import RawIcon from '../../atoms/system-icons/RawIcon';
2021-08-04 15:22:59 +05:30
import IconButton from '../../atoms/button/IconButton';
import Header, { TitleWrapper } from '../../atoms/header/Header';
import Avatar from '../../atoms/avatar/Avatar';
2022-01-14 09:43:35 +05:30
import RoomOptions from '../../molecules/room-options/RoomOptions';
2021-08-04 15:22:59 +05:30
2021-12-22 20:18:32 +05:30
import ChevronBottomIC from '../../../../public/res/ic/outlined/chevron-bottom.svg';
2022-01-16 18:18:33 +05:30
import SearchIC from '../../../../public/res/ic/outlined/search.svg';
import UserIC from '../../../../public/res/ic/outlined/user.svg';
2021-08-04 15:22:59 +05:30
import VerticalMenuIC from '../../../../public/res/ic/outlined/vertical-menu.svg';
2021-12-23 10:03:20 +05:30
import { useForceUpdate } from '../../hooks/useForceUpdate';
2021-08-31 18:43:31 +05:30
function RoomViewHeader({ roomId }) {
2021-12-23 10:03:20 +05:30
const [, forceUpdate] = useForceUpdate();
2021-08-04 15:22:59 +05:30
const mx = initMatrix.matrixClient;
2021-08-17 16:37:31 +05:30
const isDM = initMatrix.roomList.directs.has(roomId);
let avatarSrc = mx.getRoom(roomId).getAvatarUrl(mx.baseUrl, 36, 36, 'crop');
2021-08-17 16:51:22 +05:30
avatarSrc = isDM ? mx.getRoom(roomId).getAvatarFallbackMember()?.getAvatarUrl(mx.baseUrl, 36, 36, 'crop') : avatarSrc;
2021-08-04 15:22:59 +05:30
const roomName = mx.getRoom(roomId).name;
2021-12-22 20:18:32 +05:30
const roomHeaderBtnRef = useRef(null);
useEffect(() => {
const settingsToggle = (isVisibile) => {
const rawIcon = roomHeaderBtnRef.current.lastElementChild;
rawIcon.style.transform = isVisibile
? 'rotateX(180deg)'
: 'rotateX(0deg)';
};
navigation.on(cons.events.navigation.ROOM_SETTINGS_TOGGLED, settingsToggle);
return () => {
navigation.removeListener(cons.events.navigation.ROOM_SETTINGS_TOGGLED, settingsToggle);
};
}, []);
2021-12-23 10:03:20 +05:30
useEffect(() => {
const { roomList } = initMatrix;
const handleProfileUpdate = (rId) => {
if (roomId !== rId) return;
forceUpdate();
};
roomList.on(cons.events.roomList.ROOM_PROFILE_UPDATED, handleProfileUpdate);
return () => {
2022-01-05 17:48:37 +05:30
roomList.removeListener(cons.events.roomList.ROOM_PROFILE_UPDATED, handleProfileUpdate);
2021-12-23 10:03:20 +05:30
};
}, [roomId]);
2022-01-13 18:30:43 +05:30
const openRoomOptions = (e) => {
openReusableContextMenu(
'bottom',
getEventCords(e, '.ic-btn'),
(closeMenu) => <RoomOptions roomId={roomId} afterOptionSelect={closeMenu} />,
);
};
2021-08-04 15:22:59 +05:30
return (
<Header>
2021-12-22 20:18:32 +05:30
<button
ref={roomHeaderBtnRef}
className="room-header__btn"
2022-01-16 18:18:33 +05:30
onClick={() => toggleRoomSettings()}
2021-12-22 20:18:32 +05:30
type="button"
onMouseUp={(e) => blurOnBubbling(e, '.room-header__btn')}
>
<Avatar imageSrc={avatarSrc} text={roomName} bgColor={colorMXID(roomId)} size="small" />
<TitleWrapper>
<Text variant="h2" weight="medium" primary>{twemojify(roomName)}</Text>
</TitleWrapper>
<RawIcon src={ChevronBottomIC} />
</button>
2022-01-17 10:00:19 +05:30
<IconButton onClick={() => toggleRoomSettings(tabText.SEARCH)} tooltip="Search" src={SearchIC} />
2021-08-04 15:22:59 +05:30
<IconButton onClick={togglePeopleDrawer} tooltip="People" src={UserIC} />
<IconButton
2022-01-13 18:30:43 +05:30
onClick={openRoomOptions}
tooltip="Options"
src={VerticalMenuIC}
2021-08-04 15:22:59 +05:30
/>
</Header>
);
}
2021-08-31 18:43:31 +05:30
RoomViewHeader.propTypes = {
2021-08-04 15:22:59 +05:30
roomId: PropTypes.string.isRequired,
};
2021-08-31 18:43:31 +05:30
export default RoomViewHeader;