Enha: avoid replacing div that connects to sse
This commit is contained in:
@ -13,8 +13,10 @@
|
|||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="ancestor" hx-ext="sse" sse-connect="/sub/sse">
|
<div id="ancestor" hx-ext="sse" sse-connect="/sub/sse">
|
||||||
|
<div id="main-content">
|
||||||
{{template "main" .}}
|
{{template "main" .}}
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
{{end}}
|
{{end}}
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
Create a room <br/>
|
Create a room <br/>
|
||||||
or<br/>
|
or<br/>
|
||||||
<button button class="justify-center rounded-md bg-indigo-600 px-3 py-1.5 text-sm font-semibold leading-6 text-white shadow-sm hover:bg-indigo-500 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-indigo-600" hx-get="/room/hideform" hx-target=".create-room-div" >Hide Form</button>
|
<button button class="justify-center rounded-md bg-indigo-600 px-3 py-1.5 text-sm font-semibold leading-6 text-white shadow-sm hover:bg-indigo-500 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-indigo-600" hx-get="/room/hideform" hx-target=".create-room-div" >Hide Form</button>
|
||||||
<form hx-post="/room-create" hx-target="#ancestor">
|
<form hx-post="/room-create" hx-target="#main-content">
|
||||||
<label For="game_time">Turn Seconds:</label><br/>
|
<label For="game_time">Turn Seconds:</label><br/>
|
||||||
<input type="number" id="game_time" name="game_time" class="text-center text-white" value="300"/><br/>
|
<input type="number" id="game_time" name="game_time" class="text-center text-white" value="300"/><br/>
|
||||||
<label For="language">Language:</label><br/>
|
<label For="language">Language:</label><br/>
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{{define "linklogin"}}
|
{{define "linklogin"}}
|
||||||
<div id="logindiv">
|
<div id="logindiv">
|
||||||
You're about to join room#{{.}}; but first!
|
You're about to join room#{{.}}; but first!
|
||||||
<form class="space-y-6" hx-post="/login" hx-target="#ancestor">
|
<form class="space-y-6" hx-post="/login" hx-target="#main-content">
|
||||||
<label For="username" class="block text-sm font-medium leading-6 text-white-900">tell us your username</label>
|
<label For="username" class="block text-sm font-medium leading-6 text-white-900">tell us your username</label>
|
||||||
<div class="mt-2">
|
<div class="mt-2">
|
||||||
<input id="username" name="username" hx-target="#login_notice" hx-swap="outerHTML" hx-post="/check/name" hx-trigger="input changed delay:400ms" autocomplete="username" required class="block w-full rounded-md border-0 bg-white py-1.5 text-gray-900 shadow-sm ring-1 ring-inset ring-gray-300 placeholder:text-gray-300 focus:ring-2 focus:ring-inset focus:ring-indigo-600 sm:text-sm sm:leading-6 text-center"/>
|
<input id="username" name="username" hx-target="#login_notice" hx-swap="outerHTML" hx-post="/check/name" hx-trigger="input changed delay:400ms" autocomplete="username" required class="block w-full rounded-md border-0 bg-white py-1.5 text-gray-900 shadow-sm ring-1 ring-inset ring-gray-300 placeholder:text-gray-300 focus:ring-2 focus:ring-inset focus:ring-indigo-600 sm:text-sm sm:leading-6 text-center"/>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{{define "login"}}
|
{{define "login"}}
|
||||||
<div id="logindiv">
|
<div id="logindiv">
|
||||||
<form class="space-y-6" hx-post="/login" hx-target="#ancestor">
|
<form class="space-y-6" hx-post="/login" hx-target="#main-content">
|
||||||
<div>
|
<div>
|
||||||
<label For="username" class="block text-sm font-medium leading-6 text-white-900">tell us your username (signup|login)</label>
|
<label For="username" class="block text-sm font-medium leading-6 text-white-900">tell us your username (signup|login)</label>
|
||||||
<div class="mt-2">
|
<div class="mt-2">
|
||||||
|
@ -80,7 +80,7 @@
|
|||||||
</div>
|
</div>
|
||||||
{{if not .Room.IsRunning}}
|
{{if not .Room.IsRunning}}
|
||||||
<div id="exitbtn">
|
<div id="exitbtn">
|
||||||
<button button id="exit-room-btn" type="submit" class="justify-center rounded-md bg-indigo-600 px-3 py-1.5 text-sm font-semibold leading-6 text-white shadow-sm hover:bg-indigo-500 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-indigo-600" hx-get="/room/exit" hx-target="#ancestor">Exit Room</button>
|
<button button id="exit-room-btn" type="submit" class="justify-center rounded-md bg-indigo-600 px-3 py-1.5 text-sm font-semibold leading-6 text-white shadow-sm hover:bg-indigo-500 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-indigo-600" hx-get="/room/exit" hx-target="#main-content">Exit Room</button>
|
||||||
</div>
|
</div>
|
||||||
{{end}}
|
{{end}}
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{{define "roomlist"}}
|
{{define "roomlist"}}
|
||||||
<div id="roomlist" hx-get="/" hx-trigger="sse:roomlistupdate" hx-target="#ancestor">
|
<div id="roomlist" hx-get="/" hx-trigger="sse:roomlistupdate" hx-target="#main-content">
|
||||||
{{range .}}
|
{{range .}}
|
||||||
<div hx-get="/room-join?id={{.ID}}" hx-target="#ancestor" class="room-item mb-3 p-4 border rounded-lg hover:bg-gray-50 transition-colors">
|
<div hx-get="/room-join?id={{.ID}}" hx-target="#main-content" class="room-item mb-3 p-4 border rounded-lg hover:bg-gray-50 transition-colors">
|
||||||
<div class="flex justify-between items-center">
|
<div class="flex justify-between items-center">
|
||||||
<div class="room-info">
|
<div class="room-info">
|
||||||
<div class="text-sm text-gray-500">
|
<div class="text-sm text-gray-500">
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
<link rel="icon" sizes="64x64" href="/assets/favicon/wolfhead_negated.ico"/>
|
<link rel="icon" sizes="64x64" href="/assets/favicon/wolfhead_negated.ico"/>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="ancestor">
|
<div id="main-content">
|
||||||
<div class="container mx-auto p-4">
|
<div class="container mx-auto p-4">
|
||||||
<h1 class="text-2xl font-bold mb-4">Player Leaderboard</h1>
|
<h1 class="text-2xl font-bold mb-4">Player Leaderboard</h1>
|
||||||
<div class="mb-4">
|
<div class="mb-4">
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
<div class="space-y-4">
|
<div class="space-y-4">
|
||||||
<div>
|
<div>
|
||||||
<h2 class="text-xl mb-4">Join Blue Team</h2>
|
<h2 class="text-xl mb-4">Join Blue Team</h2>
|
||||||
<form hx-post="/join-team" hx-target="#ancestor">
|
<form hx-post="/join-team" hx-target="#main-content">
|
||||||
<input type="hidden" name="team" value="blue">
|
<input type="hidden" name="team" value="blue">
|
||||||
<div class="mb-1">
|
<div class="mb-1">
|
||||||
{{if and (eq .State.Role "guesser") (eq .State.Team "blue")}}
|
{{if and (eq .State.Role "guesser") (eq .State.Team "blue")}}
|
||||||
@ -23,7 +23,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
<h2 class="text-xl mb-4">Join Red Team</h2>
|
<h2 class="text-xl mb-4">Join Red Team</h2>
|
||||||
<form hx-post="/join-team" hx-target="#ancestor">
|
<form hx-post="/join-team" hx-target="#main-content">
|
||||||
<input type="hidden" name="team" value="red">
|
<input type="hidden" name="team" value="red">
|
||||||
<div class="mb-1">
|
<div class="mb-1">
|
||||||
{{if and (eq .State.Role "guesser") (eq .State.Team "red")}}
|
{{if and (eq .State.Role "guesser") (eq .State.Team "red")}}
|
||||||
|
2
todos.md
2
todos.md
@ -90,4 +90,4 @@
|
|||||||
- there is a problem of two timers, they both could switch turn, but it is not easy to stop them from llmapi or handlers. +
|
- there is a problem of two timers, they both could switch turn, but it is not easy to stop them from llmapi or handlers. +
|
||||||
- journal still does not work; +
|
- journal still does not work; +
|
||||||
- lose/win game; then exit room (while being the creator), then press to stats -> cannot find session in db, although cookie in place and session in db;
|
- lose/win game; then exit room (while being the creator), then press to stats -> cannot find session in db, although cookie in place and session in db;
|
||||||
- player got deleted from db;
|
- exit endpoints delets player from db;
|
||||||
|
Reference in New Issue
Block a user