diff --git a/index.js b/index.js index 520425f..8fad2b6 100644 --- a/index.js +++ b/index.js @@ -370,6 +370,11 @@ wss.on('connection', ws => { tentarNovamente = true; break; } + case "PALAVRA_JÁ_ESCOLHIDA":{ + alertarClientesEvento("EVENTO_TERMO_ESCOLHIDO", cliente.sala, { tipo: letra ? "LETRA" : "TERMO", termo: resposta.extra.termo, resultado: r }); + tentarNovamente = true; + break; + } case "LETRAS_PREENCHIDAS":{ alertarClientesEvento("EVENTO_TERMO_ESCOLHIDO", cliente.sala, { tipo: letra ? "LETRA" : "TERMO", termo: resposta.extra.termo, resultado: r, ldc: salaObj.ldc }); diff --git a/sala.js b/sala.js index 41474cf..6e316a4 100644 --- a/sala.js +++ b/sala.js @@ -86,6 +86,7 @@ class Sala { novaRodada(){ this.lei = []; // Letras escolhidas inexistentes this.lee = []; // Letras escolhidas existentes + this.pei = []; // Palavras escolhidas inexistentes this.ldc = []; // Letras descobertas this.jpa = null; // Jogador que escolheu a palavra atual (Jogador Palavra Atual) this.palavra = null; @@ -185,6 +186,12 @@ class Sala { } return resultadoTermo; } else { + // Esta palavra já foi enviada? + if (this.pei.indexOf(termo) !== -1){ + resultadoTermo.resultado = "PALAVRA_JÁ_ESCOLHIDA"; + return resultadoTermo; + } + this.pei.push(termo); let palavraCorreta = this.palavra === termo; resultadoTermo.resultado = palavraCorreta ? "PALAVRA_CORRETA" : "PALAVRA_INCORRETA"; if (palavraCorreta){