import React, { useState, useEffect } from 'react'; import PropTypes from 'prop-types'; import './SideBar.scss'; import initMatrix from '../../../client/initMatrix'; import cons from '../../../client/state/cons'; import colorMXID from '../../../util/colorMXID'; import logout from '../../../client/action/logout'; import { openInviteList, openPublicChannels, openSettings } from '../../../client/action/navigation'; import ScrollView from '../../atoms/scroll/ScrollView'; import SidebarAvatar from '../../molecules/sidebar-avatar/SidebarAvatar'; import ContextMenu, { MenuItem, MenuHeader, MenuBorder } from '../../atoms/context-menu/ContextMenu'; import HomeIC from '../../../../public/res/ic/outlined/home.svg'; import UserIC from '../../../../public/res/ic/outlined/user.svg'; import HashSearchIC from '../../../../public/res/ic/outlined/hash-search.svg'; import InviteIC from '../../../../public/res/ic/outlined/invite.svg'; import SettingsIC from '../../../../public/res/ic/outlined/settings.svg'; import PowerIC from '../../../../public/res/ic/outlined/power.svg'; function ProfileAvatarMenu() { const mx = initMatrix.matrixClient; return ( ( <> {mx.getUserId()} {/* ''}>Profile */} {/* ''}>Notification settings */} { hideMenu(); openSettings(); }} > Settings Logout )} render={(toggleMenu) => ( )} /> ); } function SideBar({ tabId, changeTab }) { const totalInviteCount = () => initMatrix.roomList.inviteRooms.size + initMatrix.roomList.inviteSpaces.size + initMatrix.roomList.inviteDirects.size; const [totalInvites, updateTotalInvites] = useState(totalInviteCount()); function onInviteListChange() { updateTotalInvites(totalInviteCount()); } useEffect(() => { initMatrix.roomList.on( cons.events.roomList.INVITELIST_UPDATED, onInviteListChange, ); return () => { initMatrix.roomList.removeListener( cons.events.roomList.INVITELIST_UPDATED, onInviteListChange, ); }; }, []); return (
changeTab('channels')} tooltip="Home" iconSrc={HomeIC} /> changeTab('dm')} tooltip="People" iconSrc={UserIC} /> openPublicChannels()} tooltip="Public channels" iconSrc={HashSearchIC} />
{ totalInvites !== 0 && ( openInviteList()} tooltip="Invites" iconSrc={InviteIC} /> )}
); } SideBar.propTypes = { tabId: PropTypes.string.isRequired, changeTab: PropTypes.func.isRequired, }; export default SideBar;