import React, { useState, useEffect } from 'react'; import PropTypes from 'prop-types'; import initMatrix from '../../../client/initMatrix'; import cons from '../../../client/state/cons'; import navigation from '../../../client/state/navigation'; import { selectSpace, selectRoom } from '../../../client/action/navigation'; import Postie from '../../../util/Postie'; import Text from '../../atoms/text/Text'; import Selector from './Selector'; import { AtoZ } from './common'; const drawerPostie = new Postie(); function Home({ spaceId }) { const [, forceUpdate] = useState({}); const { roomList, notifications } = initMatrix; let spaceIds = []; let roomIds = []; let directIds = []; const spaceChildIds = roomList.getSpaceChildren(spaceId); if (spaceChildIds) { spaceIds = spaceChildIds.filter((roomId) => roomList.spaces.has(roomId)).sort(AtoZ); roomIds = spaceChildIds.filter((roomId) => roomList.rooms.has(roomId)).sort(AtoZ); directIds = spaceChildIds.filter((roomId) => roomList.directs.has(roomId)).sort(AtoZ); } else { spaceIds = [...roomList.spaces] .filter((roomId) => !roomList.roomIdToParents.has(roomId)).sort(AtoZ); roomIds = [...roomList.rooms] .filter((roomId) => !roomList.roomIdToParents.has(roomId)).sort(AtoZ); } function selectorChanged(selectedRoomId, prevSelectedRoomId) { if (!drawerPostie.hasTopic('selector-change')) return; const addresses = []; if (drawerPostie.hasSubscriber('selector-change', selectedRoomId)) addresses.push(selectedRoomId); if (drawerPostie.hasSubscriber('selector-change', prevSelectedRoomId)) addresses.push(prevSelectedRoomId); if (addresses.length === 0) return; drawerPostie.post('selector-change', addresses, selectedRoomId); } function notiChanged(roomId, total, prevTotal) { if (total === prevTotal) return; if (drawerPostie.hasTopicAndSubscriber('unread-change', roomId)) { drawerPostie.post('unread-change', roomId); } } function roomListUpdated() { const { spaces, rooms, directs } = initMatrix.roomList; if (!( spaces.has(navigation.selectedRoomId) || rooms.has(navigation.selectedRoomId) || directs.has(navigation.selectedRoomId)) ) { selectRoom(null); } forceUpdate({}); } useEffect(() => { roomList.on(cons.events.roomList.ROOMLIST_UPDATED, roomListUpdated); navigation.on(cons.events.navigation.ROOM_SELECTED, selectorChanged); notifications.on(cons.events.notifications.NOTI_CHANGED, notiChanged); return () => { roomList.removeListener(cons.events.roomList.ROOMLIST_UPDATED, roomListUpdated); navigation.removeListener(cons.events.navigation.ROOM_SELECTED, selectorChanged); notifications.removeListener(cons.events.notifications.NOTI_CHANGED, notiChanged); }; }, []); return ( <> { spaceIds.length !== 0 && Spaces } { spaceIds.map((id) => ( selectSpace(id)} /> ))} { roomIds.length !== 0 && Rooms } { roomIds.map((id) => ( selectRoom(id)} /> )) } { directIds.length !== 0 && People } { directIds.map((id) => ( selectRoom(id)} /> ))} ); } Home.defaultProps = { spaceId: null, }; Home.propTypes = { spaceId: PropTypes.string, }; export default Home;