mirror of
https://github.com/randyjc/Rahoot.git
synced 2026-03-13 20:15:35 +01:00
adding more persistence for the client to be able to rejoin the session on clientId
This commit is contained in:
@@ -5,11 +5,13 @@ import Username from "@rahoot/web/components/game/join/Username"
|
|||||||
import { useEvent, useSocket } from "@rahoot/web/contexts/socketProvider"
|
import { useEvent, useSocket } from "@rahoot/web/contexts/socketProvider"
|
||||||
import { usePlayerStore } from "@rahoot/web/stores/player"
|
import { usePlayerStore } from "@rahoot/web/stores/player"
|
||||||
import { useEffect } from "react"
|
import { useEffect } from "react"
|
||||||
|
import { useRouter } from "next/navigation"
|
||||||
import toast from "react-hot-toast"
|
import toast from "react-hot-toast"
|
||||||
|
|
||||||
const Home = () => {
|
const Home = () => {
|
||||||
const { isConnected, connect } = useSocket()
|
const { isConnected, connect, socket } = useSocket()
|
||||||
const { player } = usePlayerStore()
|
const { player } = usePlayerStore()
|
||||||
|
const router = useRouter()
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!isConnected) {
|
if (!isConnected) {
|
||||||
@@ -17,6 +19,19 @@ const Home = () => {
|
|||||||
}
|
}
|
||||||
}, [connect, isConnected])
|
}, [connect, isConnected])
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (!isConnected) return
|
||||||
|
try {
|
||||||
|
const storedGameId = localStorage.getItem("last_game_id")
|
||||||
|
if (storedGameId) {
|
||||||
|
socket?.emit("player:reconnect", { gameId: storedGameId })
|
||||||
|
router.replace(`/game/${storedGameId}`)
|
||||||
|
}
|
||||||
|
} catch {
|
||||||
|
// ignore
|
||||||
|
}
|
||||||
|
}, [isConnected, socket, router])
|
||||||
|
|
||||||
useEvent("game:errorMessage", (message) => {
|
useEvent("game:errorMessage", (message) => {
|
||||||
toast.error(message)
|
toast.error(message)
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -35,6 +35,12 @@ const Game = () => {
|
|||||||
setStatus(status.name, status.data)
|
setStatus(status.name, status.data)
|
||||||
setPlayer(player)
|
setPlayer(player)
|
||||||
setQuestionStates(currentQuestion)
|
setQuestionStates(currentQuestion)
|
||||||
|
try {
|
||||||
|
localStorage.setItem("last_game_id", gameId)
|
||||||
|
if (player?.username) {
|
||||||
|
localStorage.setItem("last_username", player.username)
|
||||||
|
}
|
||||||
|
} catch {}
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -48,6 +54,10 @@ const Game = () => {
|
|||||||
router.replace("/")
|
router.replace("/")
|
||||||
reset()
|
reset()
|
||||||
setQuestionStates(null)
|
setQuestionStates(null)
|
||||||
|
try {
|
||||||
|
localStorage.removeItem("last_game_id")
|
||||||
|
localStorage.removeItem("last_username")
|
||||||
|
} catch {}
|
||||||
toast.error(message)
|
toast.error(message)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
@@ -33,6 +33,10 @@ const Username = () => {
|
|||||||
useEvent("game:successJoin", (gameId) => {
|
useEvent("game:successJoin", (gameId) => {
|
||||||
setStatus(STATUS.WAIT, { text: "Waiting for the players" })
|
setStatus(STATUS.WAIT, { text: "Waiting for the players" })
|
||||||
login(username)
|
login(username)
|
||||||
|
try {
|
||||||
|
localStorage.setItem("last_game_id", gameId)
|
||||||
|
localStorage.setItem("last_username", username)
|
||||||
|
} catch {}
|
||||||
|
|
||||||
router.replace(`/game/${gameId}`)
|
router.replace(`/game/${gameId}`)
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user