0

My code as below:

import { useEffect, useState } from "react";
import Meeting from "./util/Meeting";
export default function TestMeeting(){
    const [peerList, setPeerList] = useState();
    const [meeting, setMeeting] = useState();
    let peerName;
    let sUsrAg = navigator.userAgent;
    if (sUsrAg.indexOf("Edg") > -1) {
        peerName = "Edge";
    } else {
        if (sUsrAg.indexOf("Chrome") > -1) {
            peerName = "Chrome";
        } else {
            if (sUsrAg.indexOf("Firefox") > -1) {
                peerName = "Firefox";
            } else {
                if (sUsrAg.indexOf("Safari") > -1) {
                    peerName = "Safari";
                }
            }
        }
    }
    useEffect(() => {
        let temp = new Meeting();
        temp.setDebug(true);
        temp.on("data", param => {
            console.log("Data Event Recevied:" + JSON.stringify(param));
        })
        temp.on("initialPeerList", (newPeerList) => {
            console.log("initialPeerList event recevied");
            console.log(newPeerList);
            setPeerList(newPeerList);
        });
        temp.on("newPeer", (newPeer) => {
            console.log("newPeer event recevied");
            console.log(peerList);
        });
        temp.on("removePeer", socketId => {
            console.log("removePeer event recevied");
            
        });
        temp.on("stream", param => {
            console.log("A stream event received:" + JSON.stringify(param));
            
        })
        temp.join(peerName);
        setMeeting(temp);
    }, [peerName]);   
    return (
        <>
        </>
    )
}

The "initialPeerList" event is received first and the peerList state variable should be updated. After that, when the "newPeer"event is received, suppose the content of peerList state variable should not undefined, however, it does.

I have followed the page: useState set method not reflecting change immediately

However, it does not solve the problem.

Why is this like that and how would I be able to fix it?

The KNVB
  • 3,588
  • 3
  • 29
  • 54

0 Answers0