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

133 lines
4.5 KiB
React
Raw Normal View History

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';
2023-06-22 09:14:50 +10:00
import {
toggleRoomSettings,
openReusableContextMenu,
openNavigation,
} from '../../../client/action/navigation';
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';
2022-04-24 11:23:10 +01:00
import BackArrowIC from '../../../../public/res/ic/outlined/chevron-left.svg';
2021-08-04 15:22:59 +05:30
2021-12-23 10:03:20 +05:30
import { useForceUpdate } from '../../hooks/useForceUpdate';
2023-06-22 09:14:50 +10:00
import { useSetSetting } from '../../state/hooks/settings';
import { settingsAtom } from '../../state/settings';
2021-12-23 10:03:20 +05:30
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);
2022-09-05 08:30:45 +05:30
const room = mx.getRoom(roomId);
2023-06-22 09:14:50 +10:00
const setPeopleDrawer = useSetSetting(settingsAtom, 'isPeopleDrawer');
2022-09-05 08:30:45 +05:30
let avatarSrc = room.getAvatarUrl(mx.baseUrl, 36, 36, 'crop');
2023-06-22 09:14:50 +10:00
avatarSrc = isDM
? room.getAvatarFallbackMember()?.getAvatarUrl(mx.baseUrl, 36, 36, 'crop')
: avatarSrc;
2022-09-05 08:30:45 +05:30
const roomName = room.name;
2021-08-04 15:22:59 +05:30
2021-12-22 20:18:32 +05:30
const roomHeaderBtnRef = useRef(null);
useEffect(() => {
const settingsToggle = (isVisibile) => {
const rawIcon = roomHeaderBtnRef.current.lastElementChild;
2023-06-22 09:14:50 +10:00
rawIcon.style.transform = isVisibile ? 'rotateX(180deg)' : 'rotateX(0deg)';
2021-12-22 20:18:32 +05:30
};
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) => {
2023-06-22 09:14:50 +10:00
openReusableContextMenu('bottom', getEventCords(e, '.ic-btn'), (closeMenu) => (
<RoomOptions roomId={roomId} afterOptionSelect={closeMenu} />
));
2022-01-13 18:30:43 +05:30
};
2021-08-04 15:22:59 +05:30
return (
<Header>
2022-04-24 11:23:10 +01:00
<IconButton
src={BackArrowIC}
className="room-header__back-btn"
tooltip="Return to navigation"
onClick={() => openNavigation()}
2022-04-24 11:23:10 +01:00
/>
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>
2023-06-22 09:14:50 +10:00
<Text variant="h2" weight="medium" primary>
{twemojify(roomName)}
</Text>
2021-12-22 20:18:32 +05:30
</TitleWrapper>
<RawIcon src={ChevronBottomIC} />
</button>
2023-06-22 09:14:50 +10:00
{mx.isRoomEncrypted(roomId) === false && (
<IconButton
onClick={() => toggleRoomSettings(tabText.SEARCH)}
tooltip="Search"
src={SearchIC}
/>
)}
<IconButton
2023-06-22 09:14:50 +10:00
className="room-header__drawer-btn"
onClick={() => {
setPeopleDrawer((t) => !t);
}}
tooltip="People"
src={UserIC}
2021-08-04 15:22:59 +05:30
/>
2023-06-22 09:14:50 +10:00
<IconButton
className="room-header__members-btn"
onClick={() => toggleRoomSettings(tabText.MEMBERS)}
tooltip="Members"
src={UserIC}
/>
<IconButton 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;