|
@ -60,6 +60,7 @@ if (window.WebSocket) { |
|
|
.setEventType(EventEnum.IAMHERE) |
|
|
.setEventType(EventEnum.IAMHERE) |
|
|
.setMessage(player.getName()) |
|
|
.setMessage(player.getName()) |
|
|
.setMatrix(series.getGameMatrix()) |
|
|
.setMatrix(series.getGameMatrix()) |
|
|
|
|
|
.setMatrixHistory(series.getGameMatrixHistory()) |
|
|
.serialize() |
|
|
.serialize() |
|
|
conn.send(payload) |
|
|
conn.send(payload) |
|
|
} else { |
|
|
} else { |
|
@ -80,6 +81,7 @@ if (window.WebSocket) { |
|
|
series.setTurn(player.getId()) |
|
|
series.setTurn(player.getId()) |
|
|
status.innerText = "Your Turn" |
|
|
status.innerText = "Your Turn" |
|
|
series.setGameMatrix(data.Matrix) |
|
|
series.setGameMatrix(data.Matrix) |
|
|
|
|
|
series.setGameMatrixHistory(data.MatrixHistory) |
|
|
_renderGame() |
|
|
_renderGame() |
|
|
break; |
|
|
break; |
|
|
case EventEnum.CHAT: |
|
|
case EventEnum.CHAT: |
|
@ -93,6 +95,7 @@ if (window.WebSocket) { |
|
|
break; |
|
|
break; |
|
|
case EventEnum.NEW: |
|
|
case EventEnum.NEW: |
|
|
series.logGame() |
|
|
series.logGame() |
|
|
|
|
|
_appendGameHistory() |
|
|
series.emptyGameMatrix() |
|
|
series.emptyGameMatrix() |
|
|
series.setTurn(player.getId()) |
|
|
series.setTurn(player.getId()) |
|
|
status.innerText = "Your Turn" |
|
|
status.innerText = "Your Turn" |
|
@ -185,13 +188,16 @@ function _renderGame () { |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
let [me, positions] = _analyzeBoard() |
|
|
let [me, positions] = _analyzeBoard() |
|
|
if (positions) |
|
|
|
|
|
|
|
|
if (positions) { |
|
|
_highlightBoard(positions) |
|
|
_highlightBoard(positions) |
|
|
|
|
|
} |
|
|
if (me) { |
|
|
if (me) { |
|
|
|
|
|
status.innerText = "YOU WIN!!!" |
|
|
setTimeout(() => { |
|
|
setTimeout(() => { |
|
|
let playagain = confirm("Play another round?") |
|
|
let playagain = confirm("Play another round?") |
|
|
if (playagain) { |
|
|
if (playagain) { |
|
|
series.logGame() |
|
|
series.logGame() |
|
|
|
|
|
_appendGameHistory() |
|
|
series.emptyGameMatrix() |
|
|
series.emptyGameMatrix() |
|
|
_renderGame() |
|
|
_renderGame() |
|
|
payload = new Payload(series.getId(), player.getId()) |
|
|
payload = new Payload(series.getId(), player.getId()) |
|
@ -200,8 +206,40 @@ function _renderGame () { |
|
|
conn.send(payload) |
|
|
conn.send(payload) |
|
|
} |
|
|
} |
|
|
}, 1000) |
|
|
}, 1000) |
|
|
|
|
|
} else if (positions) { |
|
|
|
|
|
status.innerText = "LOSER" |
|
|
|
|
|
} |
|
|
|
|
|
if (_draw()) { |
|
|
|
|
|
if (series.getTurn() == player.getId()) { |
|
|
|
|
|
setTimeout(() => { |
|
|
|
|
|
let playagain = confirm("Play another round?") |
|
|
|
|
|
if (playagain) { |
|
|
|
|
|
series.logGame() |
|
|
|
|
|
_appendGameHistory() |
|
|
|
|
|
series.emptyGameMatrix() |
|
|
|
|
|
_renderGame() |
|
|
|
|
|
payload = new Payload(series.getId(), player.getId()) |
|
|
|
|
|
.setEventType(EventEnum.NEW) |
|
|
|
|
|
.serialize() |
|
|
|
|
|
conn.send(payload) |
|
|
|
|
|
} |
|
|
|
|
|
}, 1000) |
|
|
|
|
|
} |
|
|
|
|
|
document.querySelectorAll('#gameTable td').forEach(el => el.classList.add("dim")) |
|
|
|
|
|
status.innerText = "Its a draw!" |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
function _appendGameHistory() { |
|
|
|
|
|
let gameTableClone = gameTable.cloneNode(true) |
|
|
|
|
|
gameTableClone.id = lib.generateRandom(6) |
|
|
|
|
|
gameTableClone.querySelectorAll("td").forEach(el => { |
|
|
|
|
|
el.id = "" |
|
|
|
|
|
}) |
|
|
|
|
|
// if (tally.childNodes.length >= 7) {
|
|
|
|
|
|
// tally.firstChild.remove()
|
|
|
|
|
|
// }
|
|
|
|
|
|
tally.appendChild(gameTableClone) |
|
|
|
|
|
} |
|
|
function _analyzeBoard() { |
|
|
function _analyzeBoard() { |
|
|
let matrix = series.getGameMatrix() |
|
|
let matrix = series.getGameMatrix() |
|
|
for (let i = 0; i <= 8; i) { |
|
|
for (let i = 0; i <= 8; i) { |
|
@ -223,6 +261,15 @@ function _analyzeBoard() { |
|
|
} |
|
|
} |
|
|
return [false, null] |
|
|
return [false, null] |
|
|
} |
|
|
} |
|
|
|
|
|
function _draw() { |
|
|
|
|
|
let matrix = series.getGameMatrix() |
|
|
|
|
|
for (let i = 0; i < matrix.length; i++) { |
|
|
|
|
|
if (!matrix[i]) { |
|
|
|
|
|
return false |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
return true |
|
|
|
|
|
} |
|
|
function _highlightBoard(positions) { |
|
|
function _highlightBoard(positions) { |
|
|
document.querySelectorAll('#gameTable td').forEach(el => el.classList.add("dim")) |
|
|
document.querySelectorAll('#gameTable td').forEach(el => el.classList.add("dim")) |
|
|
for (let pos of positions) { |
|
|
for (let pos of positions) { |
|
@ -347,14 +394,6 @@ function _threeInARow() { |
|
|
} |
|
|
} |
|
|
return [false, null, null] |
|
|
return [false, null, null] |
|
|
} |
|
|
} |
|
|
function _draw() { |
|
|
|
|
|
for (let i = 0; i < game.matrix.length; i++) { |
|
|
|
|
|
if (!game.matrix[i]) { |
|
|
|
|
|
return false |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
return true |
|
|
|
|
|
} |
|
|
|
|
|
function _dimBoard(reverse) { |
|
|
function _dimBoard(reverse) { |
|
|
if (reverse) { |
|
|
if (reverse) { |
|
|
document.querySelectorAll('td').forEach(el => el.classList.remove("dim")) |
|
|
document.querySelectorAll('td').forEach(el => el.classList.remove("dim")) |
|
|