import React, { useEffect, useRef } from "react"; import styles from "./LobbyView.module.css"; import { Button, CopyButton, MicButton, VideoButton } from "../button"; import { Header, LeftNav, RightNav, RoomHeaderInfo } from "../Header"; import { GroupCallState } from "matrix-js-sdk/src/webrtc/groupCall"; import { useCallFeed } from "../video-grid/useCallFeed"; import { useMediaStream } from "../video-grid/useMediaStream"; import { getRoomUrl } from "../matrix-utils"; import { OverflowMenu } from "./OverflowMenu"; import { UserMenuContainer } from "../UserMenuContainer"; import { Body, Link } from "../typography/Typography"; import { Avatar } from "../Avatar"; import { useProfile } from "../profile/useProfile"; import useMeasure from "react-use-measure"; import { ResizeObserver } from "@juggle/resize-observer"; import { useLocationNavigation } from "../useLocationNavigation"; import { useMediaHandler } from "../settings/useMediaHandler"; export function LobbyView({ client, roomName, state, onInitLocalCallFeed, onEnter, localCallFeed, microphoneMuted, localVideoMuted, toggleLocalVideoMuted, toggleMicrophoneMuted, setShowInspector, showInspector, roomId, }) { const { stream } = useCallFeed(localCallFeed); const { audioOutput } = useMediaHandler(); const videoRef = useMediaStream(stream, audioOutput, true); const { displayName, avatarUrl } = useProfile(client); const [previewRef, previewBounds] = useMeasure({ polyfill: ResizeObserver }); const avatarSize = (previewBounds.height - 66) / 2; useEffect(() => { onInitLocalCallFeed(); }, [onInitLocalCallFeed]); useLocationNavigation(state === GroupCallState.InitializingLocalCallFeed); const joinCallButtonRef = useRef(); useEffect(() => { if (state === GroupCallState.LocalCallFeedInitialized) { joinCallButtonRef.current.focus(); } }, [state]); return (