X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=empathy.js;h=3a3f80de007e6eab8a0b855a8a4f908d6b834d45;hb=99fe599c5e4efab0fd285bc58f39ea09e2655dad;hp=60e1ecfd825b53de2db2132c0dd9987c15076229;hpb=2b198e296f7a247156d554631896cb04e1ca1251;p=lmno-server diff --git a/empathy.js b/empathy.js index 60e1ecf..3a3f80d 100644 --- a/empathy.js +++ b/empathy.js @@ -8,6 +8,8 @@ class Empathy extends Game { prompts: [], active_prompt: null, players_answered: 0, + ambiguities: null, + players_judged: 0, scores: null }; this.answers = []; @@ -15,6 +17,20 @@ class Empathy extends Game { } reset() { + + /* Before closing out the current round, we accumulate that score + * for each player into their runnning total. */ + for (let score of this.state.scores.scores) { + const player = this.players.find(p => p.name === score.player); + if (player.score) + player.score += score.score; + else + player.score = score.score; + + /* And broadcast that new score out. */ + this.broadcast_event('player-update', player.info_json()); + } + /* Now that we're done with the active prompt, we remove it from * the list of prompts and also remove any prompts that received * no votes. This keeps the list of prompts clean. @@ -27,6 +43,8 @@ class Empathy extends Game { this.state.active_prompt = null; this.state.players_answered = 0; + this.state.ambiguities = 0; + this.state.players_judged = 0; this.state.scores = null; this.answers = []; @@ -103,6 +121,33 @@ class Empathy extends Game { return { valid: true }; } + perform_judging() { + const word_map = {}; + + for (let a of this.answers) { + for (let word of a.answers) { + const key = this.canonize(word); + word_map[key] = word; + } + } + + this.state.ambiguities = Object.values(word_map); + + this.broadcast_event_object('ambiguities', this.state.ambiguities); + } + + receive_judging() { + /* And notify players how many players have completed judging. */ + this.state.players_judged++; + this.broadcast_event_object('judged', this.state.players_judged); + + return { valid: true }; + } + + canonize(word) { + return word.replace(/[^a-zA-Z0-9]/g, '').toLowerCase(); + } + compute_scores() { const word_submitters = {}; const scores = []; @@ -139,11 +184,14 @@ class Empathy extends Game { return b.players.length - a.players.length; }); + /* Put this round's scores into the game state object so it will + * be sent to any new clients that join. */ this.state.scores = { scores: scores, words: word_submitters_arr }; + /* And broadcast the scores to all connected clients. */ this.broadcast_event_object('scores', this.state.scores); } } @@ -170,7 +218,9 @@ class Prompt { router.post('/prompts', (request, response) => { const game = request.game; - game.add_prompt(request.body.items, request.body.prompt); + prompt = game.add_prompt(request.body.items, request.body.prompt); + + response.json({ id: prompt.id}); }); router.post('/vote/:prompt_id([0-9]+)', (request, response) => { @@ -178,7 +228,7 @@ router.post('/vote/:prompt_id([0-9]+)', (request, response) => { const prompt_id = parseInt(request.params.prompt_id, 10); if (game.toggle_vote(prompt_id, request.session.id)) - response.sendStatus(200); + response.send(''); else response.sendStatus(404); }); @@ -188,7 +238,7 @@ router.post('/start/:prompt_id([0-9]+)', (request, response) => { const prompt_id = parseInt(request.params.prompt_id, 10); if (game.start(prompt_id)) - response.sendStatus(200); + response.send(''); else response.sendStatus(404); }); @@ -202,7 +252,20 @@ router.post('/answer/:prompt_id([0-9]+)', (request, response) => { request.body.answers); response.json(result); - if (game.answers.length >= game.players.length) + if (game.state.players_answered >= game.players.length) + game.perform_judging(); +}); + +router.post('/judging/:prompt_id([0-9]+)', (request, response) => { + const game = request.game; + const prompt_id = parseInt(request.params.prompt_id, 10); + + const result = game.receive_judging(prompt_id, + request.session.id, + request.body); + response.json(result); + + if (game.state.players_judged >= game.players.length) game.compute_scores(); });