forked from Shiloh/remnantchat
feat: show number of peers in the room
This commit is contained in:
parent
c0b6d4c543
commit
caaa59d014
@ -6,6 +6,8 @@ import AppBar from '@mui/material/AppBar'
|
|||||||
import Toolbar from '@mui/material/Toolbar'
|
import Toolbar from '@mui/material/Toolbar'
|
||||||
import Box from '@mui/material/Box'
|
import Box from '@mui/material/Box'
|
||||||
import Typography from '@mui/material/Typography'
|
import Typography from '@mui/material/Typography'
|
||||||
|
import StepIcon from '@mui/material/StepIcon'
|
||||||
|
import Tooltip from '@mui/material/Tooltip'
|
||||||
|
|
||||||
import { ShellContext } from 'ShellContext'
|
import { ShellContext } from 'ShellContext'
|
||||||
import { Home } from 'pages/Home/'
|
import { Home } from 'pages/Home/'
|
||||||
@ -29,8 +31,12 @@ function Bootstrap({
|
|||||||
const [settings, setSettings] = useState({ userId: getUuid() })
|
const [settings, setSettings] = useState({ userId: getUuid() })
|
||||||
const { userId } = settings
|
const { userId } = settings
|
||||||
const [title, setTitle] = useState('')
|
const [title, setTitle] = useState('')
|
||||||
|
const [numberOfPeers, setNumberOfPeers] = useState(1)
|
||||||
|
|
||||||
const shellContextValue = useMemo(() => ({ setTitle }), [setTitle])
|
const shellContextValue = useMemo(
|
||||||
|
() => ({ numberOfPeers, setNumberOfPeers, setTitle }),
|
||||||
|
[numberOfPeers, setNumberOfPeers, setTitle]
|
||||||
|
)
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
;(async () => {
|
;(async () => {
|
||||||
@ -61,8 +67,18 @@ function Bootstrap({
|
|||||||
sx={{ height: '100vh', display: 'flex', flexDirection: 'column' }}
|
sx={{ height: '100vh', display: 'flex', flexDirection: 'column' }}
|
||||||
>
|
>
|
||||||
<AppBar position="relative">
|
<AppBar position="relative">
|
||||||
<Toolbar variant="regular">
|
<Toolbar
|
||||||
|
variant="regular"
|
||||||
|
sx={{
|
||||||
|
display: 'flex',
|
||||||
|
flexDirection: 'row',
|
||||||
|
justifyContent: 'space-between',
|
||||||
|
}}
|
||||||
|
>
|
||||||
<Typography sx={{ fontWeight: 'bold' }}>{title}</Typography>
|
<Typography sx={{ fontWeight: 'bold' }}>{title}</Typography>
|
||||||
|
<Tooltip title="Number of peers in the room">
|
||||||
|
<StepIcon icon={numberOfPeers} sx={{ marginLeft: 'auto' }} />
|
||||||
|
</Tooltip>
|
||||||
</Toolbar>
|
</Toolbar>
|
||||||
</AppBar>
|
</AppBar>
|
||||||
{hasLoadedSettings ? (
|
{hasLoadedSettings ? (
|
||||||
|
@ -2,8 +2,12 @@ import { createContext, Dispatch, SetStateAction } from 'react'
|
|||||||
|
|
||||||
interface ShellContextProps {
|
interface ShellContextProps {
|
||||||
setTitle: Dispatch<SetStateAction<string>>
|
setTitle: Dispatch<SetStateAction<string>>
|
||||||
|
setNumberOfPeers: Dispatch<SetStateAction<number>>
|
||||||
|
numberOfPeers: number
|
||||||
}
|
}
|
||||||
|
|
||||||
export const ShellContext = createContext<ShellContextProps>({
|
export const ShellContext = createContext<ShellContextProps>({
|
||||||
setTitle: () => {},
|
setTitle: () => {},
|
||||||
|
setNumberOfPeers: () => {},
|
||||||
|
numberOfPeers: 1,
|
||||||
})
|
})
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import React, { useState } from 'react'
|
import React, { useContext, useEffect, useState } from 'react'
|
||||||
import { v4 as uuid } from 'uuid'
|
import { v4 as uuid } from 'uuid'
|
||||||
import Box from '@mui/material/Box'
|
import Box from '@mui/material/Box'
|
||||||
import FormControl from '@mui/material/FormControl'
|
import FormControl from '@mui/material/FormControl'
|
||||||
@ -7,6 +7,7 @@ import TextField from '@mui/material/TextField'
|
|||||||
import Fab from '@mui/material/Fab'
|
import Fab from '@mui/material/Fab'
|
||||||
import ArrowUpward from '@mui/icons-material/ArrowUpward'
|
import ArrowUpward from '@mui/icons-material/ArrowUpward'
|
||||||
|
|
||||||
|
import { ShellContext } from 'ShellContext'
|
||||||
import { usePeerRoom, usePeerRoomAction } from 'hooks/usePeerRoom'
|
import { usePeerRoom, usePeerRoomAction } from 'hooks/usePeerRoom'
|
||||||
import { PeerActions } from 'models/network'
|
import { PeerActions } from 'models/network'
|
||||||
import { UnsentMessage, ReceivedMessage } from 'models/chat'
|
import { UnsentMessage, ReceivedMessage } from 'models/chat'
|
||||||
@ -25,6 +26,7 @@ export function Room({
|
|||||||
roomId,
|
roomId,
|
||||||
userId,
|
userId,
|
||||||
}: RoomProps) {
|
}: RoomProps) {
|
||||||
|
const shellContext = useContext(ShellContext)
|
||||||
const [isMessageSending, setIsMessageSending] = useState(false)
|
const [isMessageSending, setIsMessageSending] = useState(false)
|
||||||
const [textMessage, setTextMessage] = useState('')
|
const [textMessage, setTextMessage] = useState('')
|
||||||
const [messageLog, setMessageLog] = useState<
|
const [messageLog, setMessageLog] = useState<
|
||||||
@ -41,6 +43,12 @@ export function Room({
|
|||||||
roomId
|
roomId
|
||||||
)
|
)
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
peerRoom.onPeersChange((numberOfPeers: number) => {
|
||||||
|
shellContext.setNumberOfPeers(numberOfPeers)
|
||||||
|
})
|
||||||
|
}, [peerRoom, shellContext])
|
||||||
|
|
||||||
const [sendMessage, receiveMessage] = usePeerRoomAction<UnsentMessage>(
|
const [sendMessage, receiveMessage] = usePeerRoomAction<UnsentMessage>(
|
||||||
peerRoom,
|
peerRoom,
|
||||||
PeerActions.MESSAGE
|
PeerActions.MESSAGE
|
||||||
|
@ -5,16 +5,32 @@ export class PeerRoom {
|
|||||||
|
|
||||||
private roomConfig: RoomConfig
|
private roomConfig: RoomConfig
|
||||||
|
|
||||||
|
private numberOfPeers: number
|
||||||
|
|
||||||
constructor(config: RoomConfig, roomId: string) {
|
constructor(config: RoomConfig, roomId: string) {
|
||||||
this.roomConfig = config
|
this.roomConfig = config
|
||||||
this.room = joinRoom(this.roomConfig, roomId)
|
this.room = joinRoom(this.roomConfig, roomId)
|
||||||
|
this.numberOfPeers = 1 // Includes this peer
|
||||||
|
}
|
||||||
|
|
||||||
|
onPeersChange = (handlePeersChange: (numberOfPeers: number) => void) => {
|
||||||
|
if (!this.room) return
|
||||||
|
|
||||||
|
this.room.onPeerJoin(() => {
|
||||||
|
this.numberOfPeers++
|
||||||
|
handlePeersChange(this.numberOfPeers)
|
||||||
|
})
|
||||||
|
|
||||||
|
this.room.onPeerLeave(() => {
|
||||||
|
this.numberOfPeers--
|
||||||
|
handlePeersChange(this.numberOfPeers)
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
leaveRoom = () => {
|
leaveRoom = () => {
|
||||||
if (this.room) {
|
if (!this.room) return
|
||||||
this.room.leave()
|
this.room.leave()
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
makeAction = <T>(namespace: string) => {
|
makeAction = <T>(namespace: string) => {
|
||||||
return this.room.makeAction<T>(namespace)
|
return this.room.makeAction<T>(namespace)
|
||||||
|
Loading…
Reference in New Issue
Block a user