Added multi user support and split session logic to new file
This commit is contained in:
parent
a06a26f931
commit
65e102292b
44
src/App.js
44
src/App.js
@ -1,5 +1,4 @@
|
||||
import React, { useEffect, useState, useRef } from "react";
|
||||
import Peer from "peerjs";
|
||||
|
||||
import {
|
||||
ThemeProvider,
|
||||
@ -12,41 +11,12 @@ import {
|
||||
} from "theme-ui";
|
||||
import theme from "./theme.js";
|
||||
|
||||
import useSession from "./useSession";
|
||||
|
||||
function App() {
|
||||
const [id, setId] = useState("");
|
||||
const peer = useRef(null);
|
||||
|
||||
useEffect(() => {
|
||||
peer.current = new Peer();
|
||||
}, []);
|
||||
|
||||
const connectionRef = useRef(null);
|
||||
useEffect(() => {
|
||||
function handleOpen(id) {
|
||||
console.log("My peer ID is: " + id);
|
||||
setId(id);
|
||||
}
|
||||
|
||||
function handleConnection(connection) {
|
||||
connectionRef.current = connection;
|
||||
connection.on("open", () => {
|
||||
if (imgRef.current) {
|
||||
connection.send(imgRef.current);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
peer.current.on("open", handleOpen);
|
||||
peer.current.on("connection", handleConnection);
|
||||
return () => {
|
||||
peer.current.removeListener("open", handleOpen);
|
||||
peer.current.removeListener("connection", handleConnection);
|
||||
};
|
||||
}, [id]);
|
||||
|
||||
const [connectId, setConnectId] = useState("");
|
||||
const connectToId = () => {
|
||||
const connection = peer.current.connect(connectId);
|
||||
const connection = peer.connect(connectId);
|
||||
connection.on("open", () => {
|
||||
connection.on("data", data => {
|
||||
const blob = new Blob([data]);
|
||||
@ -61,16 +31,18 @@ function App() {
|
||||
const loadImage = e => {
|
||||
imgRef.current = e.target.files[0];
|
||||
setImgSrc(URL.createObjectURL(imgRef.current));
|
||||
if(connectionRef.current) {
|
||||
connectionRef.current.send(imgRef.current);
|
||||
for (let connection of Object.values(connections)) {
|
||||
connection.send(imgRef.current);
|
||||
}
|
||||
};
|
||||
|
||||
const [peer, peerId, connections] = useSession(imgRef);
|
||||
|
||||
return (
|
||||
<ThemeProvider theme={theme}>
|
||||
<Box width={256}>
|
||||
<Heading as="h3">Your ID</Heading>
|
||||
<Text>{id}</Text>
|
||||
<Text>{peerId}</Text>
|
||||
|
||||
<Box>
|
||||
<img src={imgSrc} />
|
||||
|
45
src/useSession.js
Normal file
45
src/useSession.js
Normal file
@ -0,0 +1,45 @@
|
||||
import { useEffect, useState } from "react";
|
||||
import Peer from "peerjs";
|
||||
|
||||
function useSession(imgRef) {
|
||||
const [peerId, setPeerId] = useState(null);
|
||||
const [peer, setPeer] = useState(null);
|
||||
const [connections, setConnections] = useState({});
|
||||
|
||||
useEffect(() => {
|
||||
setPeer(new Peer());
|
||||
}, []);
|
||||
|
||||
useEffect(() => {
|
||||
function handleOpen(id) {
|
||||
setPeerId(id);
|
||||
}
|
||||
|
||||
function handleConnection(connection) {
|
||||
setConnections(prevConnnections => ({
|
||||
...prevConnnections,
|
||||
[connection.peer]: connection
|
||||
}));
|
||||
connection.on("open", () => {
|
||||
if (imgRef.current) {
|
||||
connection.send(imgRef.current);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
if (!peer) {
|
||||
return;
|
||||
}
|
||||
|
||||
peer.on("open", handleOpen);
|
||||
peer.on("connection", handleConnection);
|
||||
return () => {
|
||||
peer.removeListener("open", handleOpen);
|
||||
peer.removeListener("connection", handleConnection);
|
||||
};
|
||||
}, [peer, peerId, connections]);
|
||||
|
||||
return [peer, peerId, connections];
|
||||
}
|
||||
|
||||
export default useSession;
|
Loading…
Reference in New Issue
Block a user