diff --git a/app/[id]/page.tsx b/app/[id]/page.tsx index dca3fa4..7c88966 100644 --- a/app/[id]/page.tsx +++ b/app/[id]/page.tsx @@ -4,6 +4,7 @@ import { io } from "socket.io-client" import { getRandomQuestion } from "./questions" import { useForceUpdate } from "./forceUpdate" import { IconCrown } from "@tabler/icons-react" +import { defaultAvatarImage } from '../avatarImage' interface roomProps { params: { @@ -17,6 +18,7 @@ export default function Home({ params }: roomProps) { const [role, setRole] = useState("") const [name, setName] = useState("") + const [avatar, setAvatar] = useState(defaultAvatarImage) const [gameStarted, setGameStarted] = useState(false) const [gameEnded, setGameEnded] = useState(false) @@ -37,14 +39,16 @@ export default function Home({ params }: roomProps) { const roomNameDisplay = id.substring(0,3) + " " + id.substring(3,6) useEffect(() => { - const username = localStorage.getItem('name') - setName(username) + const localName = localStorage.getItem('name') + setName(localName) + const localAvatar = localStorage.getItem('avatar') + setAvatar(localAvatar) // Listen for incoming setMessages socketRef.current = io("ws://localhost:3000"); socketRef.current.on("connect", () => { setIsConnected(true) - socketRef.current.emit('room_connect', {"id": id, "name": username}) + socketRef.current.emit('room_connect', {id: id, name: localName, avatar: localAvatar}) }); socketRef.current.on("new_player", (params) => { @@ -195,19 +199,21 @@ export default function Home({ params }: roomProps) { } { (isConnected && players.length > 0) &&
-
+
{ players.map((player) => { - console.log(player) - if(player.role == "player") { - return ( -

{player.name}

- ) - } - if(player.role == "owner") { - return ( -

{player.name}

- ) - } + return ( + <> +
+
+ {player.role == "owner" && } +
+ +
+
+

{player.name}

+
+ + ) })}
{ role == "owner" && diff --git a/app/avatarImage.ts b/app/avatarImage.ts new file mode 100644 index 0000000..9a72002 --- /dev/null +++ b/app/avatarImage.ts @@ -0,0 +1 @@ +export const defaultAvatarImage = "" diff --git a/app/page.tsx b/app/page.tsx index 5672327..b3634c3 100644 --- a/app/page.tsx +++ b/app/page.tsx @@ -2,10 +2,16 @@ import { navigate } from './action' import { useState, useEffect, useRef } from 'react' -import { IconPencilMinus } from "@tabler/icons-react" +import { IconPencilMinus, IconCamera, IconDice6 } from "@tabler/icons-react" +import { defaultAvatarImage } from './avatarImage' +import { getUsername } from './usernameGenerate' +import Webcam from 'react-webcam' export default function Home() { const [name, setName] = useState("") + const [avatar, setAvatar] = useState(defaultAvatarImage) + const [showWebcam, setShowWebcam] = useState(false) + const webcamRef = useRef() const modal = useRef() const inputName = useRef() @@ -14,35 +20,113 @@ export default function Home() { localStorage.setItem("name", inputName.current.value) } + function setAndStoreAvatar(data){ + resizeBase64Image(data).then((data) => { + localStorage.setItem("avatar", data) + setAvatar(data) + }) + } + + function takePictureAvatar() { + const imageSrc = webcamRef.current.getScreenshot() + setAndStoreAvatar(imageSrc) + setShowWebcam(false) + } + + function getBase64OfImage(file, cb) { + let reader = new FileReader(); + reader.readAsDataURL(file); + reader.onload = function () { + cb(reader.result) + }; + reader.onerror = function (error) { + console.log('Error: ', error); + }; + } + + function resizeBase64Image(base64Image) { + return new Promise((resolve, reject) => { + const maxSizeInKB = 500; + const maxSizeInBytes = maxSizeInKB * 1024; + const img = new Image(); + img.src = base64Image; + img.onload = function () { + const canvas = document.createElement("canvas"); + const ctx = canvas.getContext('2d'); + const width = img.width; + const height = img.height; + const aspectRatio = width / height; + const newWidth = Math.sqrt(maxSizeInBytes * aspectRatio); + const newHeight = Math.sqrt(maxSizeInBytes / aspectRatio); + canvas.width = newWidth; + canvas.height = newHeight; + ctx.drawImage(img, 0, 0, newWidth, newHeight); + let quality = 0.8; + let dataURL = canvas.toDataURL('image/jpeg', quality); + resolve(dataURL); + }; + }); + } + useEffect(() => { let localName = localStorage.getItem("name") + let localAvatar = localStorage.getItem("avatar") if(localName != null){ setName(localName) } else { modal.current.showModal() } + + if(localAvatar != null) { + setAvatar(localAvatar) + } }, []) return (
-
-

Bazaar

+
+
+ +
+
{name}