From 44446b8d4758572a50db355e031302e1e9116708 Mon Sep 17 00:00:00 2001 From: Robert Long Date: Fri, 1 Oct 2021 16:17:47 -0700 Subject: [PATCH] List group rooms and public group rooms properly --- .env | 8 ++++++++ README.md | 4 ++++ src/ConferenceCallManagerHooks.js | 31 ++++++++++++++++++++++++----- src/Home.jsx | 33 +++++++++++++++++++++++++++++-- 4 files changed, 69 insertions(+), 7 deletions(-) create mode 100644 .env diff --git a/.env b/.env new file mode 100644 index 0000000..55ce932 --- /dev/null +++ b/.env @@ -0,0 +1,8 @@ +#### +# App Config +# Environment files are documented here: +# https://vitejs.dev/guide/env-and-mode.html#env-files +#### + +# The room id for the space to use for listing public group call rooms +# VITE_PUBLIC_SPACE_ROOM_ID=!hjdfshkdskjdsk:myhomeserver.com \ No newline at end of file diff --git a/README.md b/README.md index de51102..a9eb707 100644 --- a/README.md +++ b/README.md @@ -39,3 +39,7 @@ yarn link matrix-js-sdk yarn link matrix-react-sdk yarn dev ``` + +## Config + +Configuration options are documented in the `.env` file. diff --git a/src/ConferenceCallManagerHooks.js b/src/ConferenceCallManagerHooks.js index 103ed47..f2e4f28 100644 --- a/src/ConferenceCallManagerHooks.js +++ b/src/ConferenceCallManagerHooks.js @@ -277,24 +277,45 @@ function sortRooms(client, rooms) { }); } -export function useRooms(client) { +export function useGroupCallRooms(client) { const [rooms, setRooms] = useState([]); useEffect(() => { function updateRooms() { - const visibleRooms = client.getVisibleRooms(); - const sortedRooms = sortRooms(client, visibleRooms); + const groupCalls = client.groupCallEventHandler.groupCalls.values(); + const rooms = Array.from(groupCalls).map((groupCall) => groupCall.room); + const sortedRooms = sortRooms(client, rooms); setRooms(sortedRooms); } updateRooms(); - client.on("Room", updateRooms); + client.on("GroupCall.incoming", updateRooms); return () => { - client.removeListener("Room", updateRooms); + client.removeListener("GroupCall.incoming", updateRooms); }; }, []); return rooms; } + +export function usePublicRooms(client, publicSpaceRoomId, maxRooms = 50) { + const [rooms, setRooms] = useState([]); + + useEffect(() => { + if (publicSpaceRoomId) { + client.getRoomHierarchy(publicSpaceRoomId, maxRooms).then(({ rooms }) => { + const filteredRooms = rooms.filter( + (room) => room.room_type !== "m.space" + ); + + setRooms(filteredRooms); + }); + } else { + setRooms([]); + } + }, [publicSpaceRoomId]); + + return rooms; +} diff --git a/src/Home.jsx b/src/Home.jsx index 42faaa6..be506c0 100644 --- a/src/Home.jsx +++ b/src/Home.jsx @@ -16,7 +16,10 @@ limitations under the License. import React, { useCallback, useRef, useState } from "react"; import { useHistory, Link } from "react-router-dom"; -import { useRooms } from "./ConferenceCallManagerHooks"; +import { + useGroupCallRooms, + usePublicRooms, +} from "./ConferenceCallManagerHooks"; import { Header, LeftNav, UserNav } from "./Header"; import ColorHash from "color-hash"; import styles from "./Home.module.css"; @@ -34,7 +37,11 @@ export function Home({ client, onLogout }) { const roomNameRef = useRef(); const guestAccessRef = useRef(); const [createRoomError, setCreateRoomError] = useState(); - const rooms = useRooms(client); + const rooms = useGroupCallRooms(client); + const publicRooms = usePublicRooms( + client, + import.meta.env.VITE_PUBLIC_SPACE_ROOM_ID + ); const onCreateRoom = useCallback( (e) => { @@ -139,6 +146,28 @@ export function Home({ client, onLogout }) { + {publicRooms.length > 0 && ( +
+

Public Rooms

+
+ {publicRooms.map((room) => ( + +
+ {room.name.slice(0, 1)} +
+
{room.name}
+ + ))} +
+
+ )}

Recent Rooms