🌃🎑 Checkpoint

./views/audience.handlebars:530995/1047
./room.js:530995/667
./server.js:530995/158
This commit is contained in:
Glitch (hello-express) 2020-04-13 11:44:31 +00:00
parent beecb36236
commit 7f5ec3e395
3 changed files with 35 additions and 14 deletions

23
room.js
View File

@ -32,7 +32,8 @@ function addParticipant(roomId, participantId, participantName) {
room.participants.push({ room.participants.push({
participantId, participantId,
participantName, participantName,
character: room.characters[room.participants.length] character: room.characters[room.participants.length],
active: true
}); });
rooms[roomId] = room; rooms[roomId] = room;
@ -40,19 +41,33 @@ function addParticipant(roomId, participantId, participantName) {
function removeParticipant(roomId, participantId) { function removeParticipant(roomId, participantId) {
let room = getOrCreateRoom(roomId); let room = getOrCreateRoom(roomId);
room.participants = room.participants.filter(p => p.participantId !== participantId); room.participants.find(p => p.participantId === participantId).active = false;
room.audience.forEach(ws => ws.send(JSON.stringify({type: "new_participant"}))); room.audience.forEach(ws => {
ws.send(JSON.stringify({
type: "participants",
participants: room.participants
}));
});
} }
function addParticipantWS(roomId, participantId, ws) { function addParticipantWS(roomId, participantId, ws) {
let room = getOrCreateRoom(roomId); let room = getOrCreateRoom(roomId);
room.participants.find(p => p.participantId === participantId).ws = ws; room.participants.find(p => p.participantId === participantId).ws = ws;
room.audience.forEach(ws => ws.send(JSON.stringify({type: "new_participant"}))); room.audience.forEach(ws => {
ws.send(JSON.stringify({
type: "participants",
participants: room.participants
}));
});
} }
function addAudienceWS(roomId, ws) { function addAudienceWS(roomId, ws) {
let room = getOrCreateRoom(roomId); let room = getOrCreateRoom(roomId);
room.audience.push(ws); room.audience.push(ws);
ws.send(JSON.stringify({
type: "participants",
participants: room.participants
}));
} }
function buzz(roomId, participant) { function buzz(roomId, participant) {

View File

@ -34,6 +34,9 @@ app.get("/:roomId/join", (request, response) => {
let room = rooms.getOrCreateRoom(request.params.roomId.toLowerCase()); let room = rooms.getOrCreateRoom(request.params.roomId.toLowerCase());
let participant = room.participants.find(p => p.participantId === request.fingerprint.hash); let participant = room.participants.find(p => p.participantId === request.fingerprint.hash);
console.log(request.fingerprint.hash);
console.log(participant);
if (participant) { if (participant) {
response.render('room', { response.render('room', {
layout: false, layout: false,

View File

@ -16,14 +16,7 @@
<main> <main>
<h2>Participants</h2> <h2>Participants</h2>
<div> <div id="participants"></div>
{{#each participants}}
<figure class="participant" id="p-{{this.participantId}}">
<img src="{{this.character}}" />
<figcaption>{{this.participantName}}</figcaption>
</figure>
{{/each}}
</div>
</main> </main>
@ -37,8 +30,18 @@
let buzzed = document.getElementById(`p-${msg.participant.participantId}`); let buzzed = document.getElementById(`p-${msg.participant.participantId}`);
buzzed.classList.add('buzzed'); buzzed.classList.add('buzzed');
setTimeout(() => buzzed.classList.remove('buzzed'), 5000) setTimeout(() => buzzed.classList.remove('buzzed'), 5000)
} else if (msg.type === "new_participant") { } else if (msg.type === "participants") {
window.location = window.location; let participantContainer = document.getElementById('participants');
let contents = '';
msg.participants.forEach(p => {
contents += `
<figure class="participant ${!p.active ? 'hide': ''}" id="p-${p.participantId}">
<img src="${p.character}" />
<figcaption>${p.participantName}</figcaption>
</figure>
`;
});
participantContainer.innerHTML = contents;
} }
}; };